
Eu flow diagram
fiz um usando smartdiagram
. Ele produz o diagrama conforme mostrado abaixo:
Quero adicionar alguns rótulos de texto às setas, para que apareça algo assim:
Como isso pode ser alcançado dentro smartdiagram
ou de outra forma?
MWE está anexado abaixo:
\documentclass{article}
\usepackage{smartdiagram}
\usetikzlibrary{arrows}
\usesmartdiagramlibrary{additions}
\begin{document}
\smartdiagram[flow diagram]{D, IP, V}
\end{document}
Responder1
Acho que smartdiagram
só faz sentido se você seguir os designs implementados; smartdiagram
não parece suportar rótulos de seta.
Eu sugiro usar o tikz "simples" (que não é tão simples), pois é mais flexível.
\documentclass[border=2mm]{standalone}
\usepackage{tikz}
\usetikzlibrary{shadows,positioning}
\colorlet{colD}{red!40}
\colorlet{colIP}{cyan!40}
\colorlet{colV}{blue!40}
\colorlet{colBorder}{gray!70}
\tikzset
{mybox/.style=
{rectangle,rounded corners,drop shadow,minimum height=1cm,
minimum width=2cm,align=center,fill=#1,draw=colBorder,line width=1pt
},
myarrow/.style=
{draw=#1,line width=3pt,-stealth,rounded corners
},
mylabel/.style={text=#1}
}
\begin{document}
\begin{tikzpicture}
\node[mybox=colD] (D) {D};
\node[mybox=colIP,below=of D] (IP) {IP};
\node[mybox=colV,below=of IP] (V) {V};
\draw[myarrow=colIP] (D) -- (IP);
\draw[myarrow=colV] (IP) -- (V);
\draw[myarrow=colD] (V.east) -- +(0.7,0) coordinate (VD1)
-- (VD1|-D) coordinate (VD2) -- (D);
\path (D) -- node[mylabel=colIP,left]{Process 1} (IP);
\path (IP) -- node[mylabel=colV,left]{Process 2} (V);
\path (VD1) -- node[mylabel=colD,right]{Process 3} (VD2);
\end{tikzpicture}
\end{document}
Responder2
Embora o TiKz seja flexível de manusear, a codificação do TiKz pode ser um pouco simplificada com a ajuda do design inteligente:
\documentclass[border=1.8cm]{standalone}
\usepackage{tikz, smartdiagram}
\usetikzlibrary{shapes.multipart}
\tikzset{
state/.style={rectangle split, draw=black, text width=3cm}
}
\tikzset{every picture/.append style={remember picture}}
\begin{document}
\smartdiagramset{module y sep=2.2}
\smartdiagram[flow diagram:vertical]{D,IP,V}
\begin{tikzpicture}[overlay]
\path (module1) -- (module2) node[midway,below=0.05cm, left=0.5cm,draw=none]{\textcolor{cyan!40}{Process 1}};
\path (module2) -- (module3) node[midway,below=0.1cm, left=0.5cm,draw=none]{\textcolor{blue!40}{Process 2}};
\path (module3) -- (module1) node[midway,below=0.05cm, right=1.7cm,draw=none]{\textcolor{red!40}{Process 3}};
\end{tikzpicture}
\end{document}
Responder3
Inspirado na interessante {resposta de Ahmed Aafaq (+1). Com uso de quotes
TikBiblioteca Z:
\documentclass[border={17mm 3mm}]{standalone}
\usepackage{tikz, smartdiagram}
\usetikzlibrary{quotes}
\tikzset{every picture/.append style={remember picture},
lbl/.style = {auto=right, inner xsep=4mm, text=#1}
}
\begin{document}
\smartdiagramset{module y sep=2.2}
\smartdiagram[flow diagram:vertical]{D,IP,V}
\begin{tikzpicture}[overlay]
\path (module1) to [lbl=cyan, "Process 1"] (module2)
(module2) to [lbl=blue, "Process 1"] (module3)
(module3) to [lbl=red, "Process 3" xshift=15mm] (module1)
;
\end{tikzpicture}
\end{document}