![Tikz はレイヤー スタックを上から下に描画します (逆順)](https://rvso.com/image/420763/Tikz%20%E3%81%AF%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%20%E3%82%B9%E3%82%BF%E3%83%83%E3%82%AF%E3%82%92%E4%B8%8A%E3%81%8B%E3%82%89%E4%B8%8B%E3%81%AB%E6%8F%8F%E7%94%BB%E3%81%97%E3%81%BE%E3%81%99%20(%E9%80%86%E9%A0%86).png)
Tikzでは、コマンドを使いたいのですが
\StartDrawOnBottomOfLayerStack
以下のすべての要素を描画する最下層の底つまり、次のノードとパスが画像の背後に表示されます。標準の動作に戻すコマンドが必要です
\StartDrawOnTopOfLayerStack
現時点では、描画する背景ノードと同じ数のレイヤーを定義する必要があります。もっと簡単に実現できるでしょうか?
\documentclass[tikz]{standalone}
\usepackage{tikz}
\usetikzlibrary{fit}
\begin{document}
\pgfdeclarelayer{background3}
\pgfdeclarelayer{background2}
\pgfdeclarelayer{background1}
\pgfsetlayers{background3,background2,background1,main}
\begin{tikzpicture}
%% block diagram
\node[rectangle,draw,fill=yellow] (A) at (-4,0) {A};
\node[rectangle,draw,fill=yellow] (B) at (-3,0) {B};
\node[rectangle,draw,fill=yellow] (C) at (-2,0) {C};
\node[rectangle,draw,fill=yellow] (D) at (-1,0) {D};
% \StartDrawOnBottomOfLayerStack
%% group 1
\begin{pgfonlayer}{background1}
\node[rectangle,fill=green,fit={(B) (C)}](G1) {};
\end{pgfonlayer}
%% group 2
\begin{pgfonlayer}{background2}
\node[fill=blue,fit={(B) (C) (D)(G1)}](G2) {};
\end{pgfonlayer}
%% group 3
\begin{pgfonlayer}{background3}
\node[fill=red,fit={(A)(B) (C) (D) (G1) (G2)}](G3) {};
\end{pgfonlayer}
\end{tikzpicture}
\end{document}
答え1
下から上への短い紹介:
- 環境と同様に
pgfonlayer
、新しい環境pgfonlayerreversed
が定義されます。その内容は指定されたレイヤーに逆順でタイプセットされます。つまり、最新の内容がタイプセットされます。下に蓄積されたコンテンツ。 on background layer
ライブラリ のオプション と同様に、新しい環境(レイヤー 上)を利用するbackgrounds
新しい オプションが定義されます。on background layer reversed
pgfonlayerreversed
background
- 最後に、
\StartDrawOnBottomOfLayerStack
と は\EndDrawOnBottomOfLayerStack
特殊なscope
環境を構成し、 のすべての使用は\node
と同等になります\scoped[on lowest layer] \node
。
完全実装:
% from https://tex.stackexchange.com/q/562577
\documentclass{article}
\usepackage{tikz}
\usetikzlibrary{backgrounds, fit}
\usepackage{xpatch}
\makeatletter
% similar to env "pgfonlayer", but the latest contents are typeset on
% lowest bottom (on reversed order)
\let\pgfonlayerreversed\pgfonlayer
\let\endpgfonlayerreversed\endpgfonlayer
\xpatchcmd\pgfonlayerreversed
{\expandafter\box\csname pgf@layerbox@#1\endcsname\begingroup}
{\begingroup}
{}{\fail}
\xpatchcmd\endpgfonlayerreversed
{\endgroup}
{\endgroup\expandafter\box\csname pgf@layerbox@\pgfonlayer@name\endcsname}
{}{\fail}
\tikzset{
on background layer reversed/.style={%
execute at begin scope={%
\pgfonlayerreversed{background}%
\let\tikz@options=\pgfutil@empty
\tikzset{every on background layer/.try,#1}%
\tikz@options
},
execute at end scope={\endpgfonlayerreversed}
}
}
\def\StartDrawOnBottomOfLayerStack{%
\scope\relax
% patch \path variants to auto insert "\scoped[on lowest layer]"
% currently \node, \pic, \coordinate, and \matrix are patched
\let\tikz@path@overlay\tikz@path@overlay@autoscoped
\let\tikz@path@overlayed\tikz@path@overlayed@autoscoped
}
\def\EndDrawOnTopOfLayerStack{%
\endscope
}
\def\tikz@path@overlay@autoscoped#1{%
\let\tikz@signal@path=\tikz@signal@path% for detection at begin of matrix cell
\pgfutil@ifnextchar<%
{\tikz@path@overlayed{#1}}
{\scoped[on background layer reversed] \path #1}}%
\def\tikz@path@overlayed@autoscoped#1<#2>{%
\scoped[on background layer reversed] \path<#2> #1}%
\makeatother
\begin{document}
\begin{tikzpicture}
% text nodes
\node[rectangle,draw,fill=yellow] (A) at (-4,0) {A};
\node[rectangle,draw,fill=yellow] (B) at (-3,0) {B};
\node[rectangle,draw,fill=yellow] (C) at (-2,0) {C};
\node[rectangle,draw,fill=yellow] (D) at (-1,0) {D};
% background rectangles
\StartDrawOnBottomOfLayerStack
\node[rectangle,fill=green,fit={(B) (C)}](G1) {};
\node[fill=blue,fit={(B) (C) (D)(G1)}](G2) {};
\node[fill=red,fit={(A)(B) (C) (D) (G1) (G2)}](G3) {};
\EndDrawOnTopOfLayerStack
\end{tikzpicture}
\end{document}