Неправильно подключены узлы в TikZ

Неправильно подключены узлы в TikZ

Я хочу добиться следующего:

введите описание изображения здесь

Но соединение узлов не работает должным образом. Я получаю следующий вывод:

введите описание изображения здесь

Как это исправить и где я ошибаюсь?

МВЭ:

\documentclass[tikz]{article}
\usepackage{tikz}
\tikzset{square/.style = {
    shape  = rectangle,
    fill   = gray!50,
    draw   = black,
    thick
}}

\tikzset{circle/.style = {
    shape  = circle,
    fill   = blue!20,
    draw   = blue,
    thick
}}

\begin{document}
\begin{tikzpicture}
  \draw[square] (-4,4)rectangle node (r1) {r1} (-3,5);
  \draw[circle] (-1,4.5) circle [radius=0.5cm] node (s1) {s1};
  \draw[->] (r1.west) -- (s1.east);

\end{tikzpicture}
\end{document} 

Обратите внимание, что я хотел бы придерживаться подхода\draw[->] (r1.west) -- (s1.east);

решение1

Правильная картинка

\documentclass[tikz,margin=3mm]{standalone}
\tikzset{squarenode/.style = {
    shape  = rectangle,
    fill   = gray!50,
    draw   = black,
    thick,
    minimum size=1cm %%%% Take note of this!
},
    circlenode/.style = {
    shape  = circle,
    fill   = blue!20,
    draw   = blue,
    thick,
    minimum size=1cm %%%% and this!
}}

\begin{document}
\begin{tikzpicture}
  \draw (-4,4.5) node[squarenode] (r1) {r1}; % Or \node[squarenode] (r1) at (-4,4.5) {r1};
  \draw (-1,4.5) node[circlenode] (s1) {s1}; % Or \node[circlenode] (s1) at (-1,4.5) {s1};
  \draw[->] (r1) -- (s1); % or (r1.east)--(s1.west);

\end{tikzpicture}
\end{document} 

введите описание изображения здесь

Некоторые примечания (важные!)

  1. circleэто определенная опция, поэтому вы не должны определять новый circle. Я изменил его на circlenode.
  2. Вам не нужно рисовать круг и квадрат вручную. Вы можете использовать форму в узле и minimum size. Для большего контроля у нас есть minimum heightи minimum width.
  3. Я не рекомендую использовать много \tikzset{}s.
  4. tikzне является опцией article. Это опция standalone. Когда вы уже загружаете tikzопцию , вам не нужно \usepackage{tikz}.

Разница при использовании (r1)--(s1)и(r1.east)--(s1.west)

\documentclass[tikz,margin=3mm]{standalone}
\begin{document}
\begin{tikzpicture}
\node[draw] (a) at (0,0) {Some text};
\node[draw] (b) at (5,3) {Hello world};
\draw[thick] (0,0)--(5,3);
\draw[red] (a)--(b);
\draw[blue] (a.east)--(b.west);
\end{tikzpicture}
\end{document}

введите описание изображения здесь

Внимательно посмотрите на начальную и конечную точку красной и синей линий.

Связанный контент