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 heightminimum 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}

在此輸入影像描述

仔細觀察紅線和藍線的起點和終點。

相關內容