答案1
更新:我添加了第二种方法来做到这一点。
- 第一种方式使用
double
line 和clip
s。 - 第二种方法是使用
arc
s。这种方法比较简单,但不适用于任何类型的曲线。
\documentclass[tikz,border=2mm]{standalone}
\newcommand{\myline}{(0,0) -- (5,0) to[out=0,in=180] (6,0.25) to[out=0,in=180] (7,0) -- (8,0)}
\definecolor{mygreen} {HTML}{9DC634}
\definecolor{myorange}{HTML}{F39614}
\definecolor{mypink} {HTML}{FF00FF} % changed
\definecolor{mypurple}{HTML}{AB7CB5}
\begin{document}
\begin{tikzpicture}
\useasboundingbox (-0.5,-1.5) rectangle (8.5,1);
% first way
\begin{scope}
\clip (0,-1) rectangle (8,1);
\begin{scope}
\clip\myline |- (0,1) --cycle;
\draw[mypurple,double distance=1.5mm-\pgflinewidth] \myline;
\draw[mypink ,double distance=0.5mm-\pgflinewidth] \myline;
\end{scope}
\begin{scope}
\clip\myline |- (0,-1) --cycle;
\draw[mygreen ,double distance=1.5mm-\pgflinewidth] \myline;
\draw[myorange,double distance=0.5mm-\pgflinewidth] \myline;
\end{scope}
\end{scope}
% second way
\begin{scope}[shift={(0,-1)}]
\foreach[count=\ii]\i in {mygreen,myorange,mypink,mypurple}
\draw[draw=\i] (0,0.05*\ii) --++ (1,0) arc (270:290:1.5-0.05*\ii) arc (110:70:2+0.05*\ii)
arc (250:270:1.5-0.05*\ii) -- (8,0.05*\ii);
\end{scope}
\end{tikzpicture}
\end{document}
答案2
让贝塞尔曲线平行并非易事。以下是第三种巧妙的方法。
代码
\documentclass[tikz]{standalone}
\begin{document}
\tikz[
very thick,
loo/.style args={#1:#2}{#1 looseness=1.05^\i,#2 looseness=.95^\i}
] \foreach[count=\i]\c in {9DC634, F39614, FFC0CB, AB7CB5}
\color[HTML]{\c}
\draw[yshift=\i mm, out=0, in=180] (0,0) --++(right:3)
to[loo=in:out] ++(2,.5) to[loo=out:in] ++(2,-.5) -- ++(right:1);
\end{document}
输出
答案3
答案4
这是另一种解决方案tikz-nfold,致谢这个答案颜色。
此解决方案的优点在于它几乎适用于所有路径,并且曲线部分彼此之间的距离都是恒定的。缺点在于您必须加载另一个库,并且编译时间可能会更长一些。
更新
tikz-nfold 版本 0.1.0 的界面变得更加简单:
\usepackage{tikz}
\usetikzlibrary{nfold}
[...]
\begin{tikzpicture}
\path[save path=\mypath]
(0,0) -- (5,0) to[out=0, in=180] (7,.75) to[out=0, in=180] (9,0) -- (10,0);
\pgfsetlinewidth{1pt}
\foreach \mycolor [count=\i] in {9DC634,F39614,FF00FF,AB7CB5}
\definecolor{tempcolor}{HTML}{\mycolor}
\color{tempcolor}
\pgfoffsetpathindex{\mypath}{8pt}{\i}{4}
\pgfusepathqstroke;
\end{tikzpicture}