data:image/s3,"s3://crabby-images/5f5b2/5f5b2b42849b6896c76fd118c0395251ed96eb31" alt="Рисование между двумя узлами в Tikz"
Я пытаюсь понять, почему я не могу нарисовать сплошную синюю горизонтальную линию по центру между узлами???
\documentclass{article}
\usepackage{tikz,amsmath}
\usetikzlibrary{positioning}
\begin{document}
\begin{center}
\begin{tikzpicture}
\node(X)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-6cm]
{\large Input \textcolor{red}{$2$}};%
\node(Y)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-.5cm]
{\large $\begin{aligned}[t] g(\textcolor{red}
{2})&=\textcolor{red}{2}^{2}+1\\ &=5\end{aligned}$\\
\large The output of $g$, \textcolor{blue}{$5$},is\\
\large the input to $f$};%
\node (Z)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=6cm]
{\large $\begin{aligned}[t] f(\textcolor{blue}
{5})&=4(\textcolor{blue}{5})-3\\ &=17\end{aligned}$};%
\end{tikzpicture}
\end{center}
\begin{tikzpicture}
\draw[blue,thick,-latex] (X.east) to ( Y.west);
\end{tikzpicture}
\end{document}
решение1
Предположим, что вы хотите иметь два отдельных tikzpicture
s, вам нужно добавить remember picture
и overlay,remember picture
, соответственно.
\documentclass{article}
\usepackage{tikz,amsmath}
\usetikzlibrary{positioning}
\begin{document}
\begin{center}
\begin{tikzpicture}[remember picture]
\node(X)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-6cm]
{\large Input \textcolor{red}{$2$}};%
\node(Y)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-.5cm]
{\large $\begin{aligned}[t] g(\textcolor{red}
{2})&=\textcolor{red}{2}^{2}+1\\ &=5\end{aligned}$\\
\large The output of $g$, \textcolor{blue}{$5$},is\\
\large the input to $f$};%
\node (Z)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=6cm]
{\large $\begin{aligned}[t] f(\textcolor{blue}
{5})&=4(\textcolor{blue}{5})-3\\ &=17\end{aligned}$};%
\end{tikzpicture}
\end{center}
\begin{tikzpicture}[overlay,remember picture]
\draw[blue,thick,-latex] (X.east) to ( Y.west);
\end{tikzpicture}
\end{document}
Конечно, вы можете использовать только один tikzpicture
.
\documentclass{article}
\usepackage{tikz,amsmath}
\usetikzlibrary{positioning}
\begin{document}
\begin{center}
\begin{tikzpicture}
\node(X)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-6cm]
{\large Input \textcolor{red}{$2$}};%
\node(Y)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=-.5cm]
{\large $\begin{aligned}[t] g(\textcolor{red}
{2})&=\textcolor{red}{2}^{2}+1\\ &=5\end{aligned}$\\
\large The output of $g$, \textcolor{blue}{$5$},is\\
\large the input to $f$};%
\node (Z)[draw,rectangle, rounded corners,draw=black,
fill=white,align=center,xshift=6cm]
{\large $\begin{aligned}[t] f(\textcolor{blue}
{5})&=4(\textcolor{blue}{5})-3\\ &=17\end{aligned}$};%
\draw[blue,thick,-latex] (X.east) to ( Y.west);
\end{tikzpicture}
\end{center}
\end{document}
Результат обоих кодов:
решение2
Вдохновлено вторым примером из ответа кота Шредингера. С использованием библиотек chains
и его макроса join
, позиционированием и определением общего стиля для всех узлов:
\documentclass{article}
\usepackage{tikz,amsmath}
\usetikzlibrary{chains,
positioning}
\begin{document}
\begin{center}
\begin{tikzpicture}[
node distance = 22mm,
start chain = going right,
box/.style = {draw, rounded corners, font=\large,
align=center, on chain},
every join/.style = {blue,thick,-latex}
]
\node (X) [box] {Input \textcolor{red}{$2$}};%
\node (Y) [box, join]
{$\begin{aligned}[t]
g(\textcolor{red}{2}) & = \textcolor{red}{2}^{2}+1\\
& = 5
\end{aligned}$\\
The output of $g$, \textcolor{blue}{$5$}, \\
is the input to $f$};
\node (Z) [box] {$\begin{aligned}[t]
f(\textcolor{blue}{5}) & = 4(\textcolor{blue}{5})-3\\
& = 17
\end{aligned}$};%
\end{tikzpicture}
\end{center}
\end{document}