.png)
Estou desenhando pedras em um tabuleiro Go (jogo) comSGFcoordenadas (o que só consegui fazer com a ajuda que as pessoas me deram noessa questão) assim \drawStoneFromSgfCoords{ab}
.
Porém, pode haver muitas pedras por diagrama, então seria prático ter também outra macro como esta: \drawStonesFromSgfCoords{{black, ab}, {white, cd}}
(as cores normalmente se alternam, mas às vezes é mais prático ter uma lista de coordenadas pretas e depois brancas).
Aqui está o que estou tentando agora, embora não funcione (quero dizer, funciona, mas não com a nova macro):
\documentclass{article}
\usepackage{tikz}
% From [this answer by @DavidCarlisle](https://tex.stackexchange.com/a/708876/64441).
\newcommand\notwhite{black}
\newcommand\notblack{white}
% From [this answer by @DavidCarlisle](https://tex.stackexchange.com/a/708893/64441).
\ExplSyntaxOn
\cs_generate_variant:Nn \int_from_alph:n {e}
\newcommand\stringToCoordX[1]{
\int_from_alph:e{\use_i:nn#1}
}
\newcommand\stringToCoordY[1]{
~\int_from_alph:e{\use_ii:nn#1}
}
\ExplSyntaxOff
\newcommand{\drawStoneFromSgfCoords}[2]{
\pgfmathsetmacro{\x}{\stringToCoordX{#2} - 1}
\pgfmathsetmacro{\y}{\stringToCoordY{#2} - 1}
\draw[draw = \UseName{not#1}, fill = #1, line width = 0.1mm]
(\x * 10cm / 18, \y * 10cm / 18)
circle [radius = 0.2575cm];
node[color = white] {1};
}
% Example usage: `drawStonesFromSgfCoords{{black, ab}, {white, cd}}`
\newcommand{\drawStonesFromSgfCoords}[1]{
\foreach \coords in {#1}{
\drawStoneFromSgfCoords{{\coords}[0]}{{\coords}[1]}
}
}
\begin{document}
\begin{tikzpicture}
\pgfmathsetmacro{\step}{10 / 18}
\draw[step=\step] (0, 0) grid (10, 10);
\drawStoneFromSgfCoords{black}{ab}
\drawStoneFromSgfCoords{white}{cd}
% \drawStonesFromSgfCoords{{black, ab}, {white, cd}}
\end{tikzpicture}
\end{document}
Qual é a maneira correta de acessar ou passar arrays (dentro de um loop)?
(Estou usando PGF \foreach
porque é isso que eu sei.)
Responder1
Eu acho que é uma ideia melhor processar o aninhado clist
(uma lista separada por vírgula) por meio de ferramentas expl aqui, uma vez que já existem ferramentas para lidar com essas listas:
\documentclass{article}
\usepackage{tikz}
% From [this answer by @DavidCarlisle](https://tex.stackexchange.com/a/708876/64441).
\newcommand\notwhite{black}
\newcommand\notblack{white}
% From [this answer by @DavidCarlisle](https://tex.stackexchange.com/a/708893/64441).
\ExplSyntaxOn
\cs_generate_variant:Nn \int_from_alph:n {e}
\NewExpandableDocumentCommand{\stringToCoordX}{ m }{
\int_from_alph:e { \use_i:nn #1 }
}
\NewExpandableDocumentCommand{\stringToCoordY}{ m }{
\int_from_alph:e { \use_ii:nn #1 }
}
\ExplSyntaxOff
\newcommand{\drawStoneFromSgfCoords}[2]{
\pgfmathsetmacro{\x}{\stringToCoordX{#2} - 1}
\pgfmathsetmacro{\y}{\stringToCoordY{#2} - 1}
\draw[draw = \UseName{not#1}, fill = #1, line width = 0.1mm]
(\x * 10cm / 18, \y * 10cm / 18)
circle [radius = 0.2575cm];
}
\ExplSyntaxOn
% Example usage: `drawStonesFromSgfCoords{{black, ab}, {white, cd}}`
\NewExpandableDocumentCommand{\drawStonesFromSgfCoords}{ m }{
\clist_set:Nn \l_tmpa_clist { #1 }
\clist_map_inline:Nn \l_tmpa_clist {
\clist_set:Nn \l_tmpb_clist { ##1 }
\clist_pop:NN \l_tmpb_clist \l_tmpa_tl
\clist_pop:NN \l_tmpb_clist \l_tmpb_tl
\exp_args:Noo \drawStoneFromSgfCoords { \l_tmpa_tl } { \l_tmpb_tl }
}
}
\ExplSyntaxOff
\begin{document}
\begin{tikzpicture}
\pgfmathsetmacro{\step}{10 / 18}
\draw[step=\step] (0, 0) grid (10, 10);
%\drawStoneFromSgfCoords{black}{ab}
%\drawStoneFromSgfCoords{white}{cd}
\drawStonesFromSgfCoords{{black, ab}, {white, cd}}
\end{tikzpicture}
\end{document}
Algumas notas sobre os comandos usados (uma boa visão geral e uma documentação completa podem ser encontradas noInterfaces L3 PDF):
\clist_set:Nn \l_tmpa_clist { #1 }
armazena aclist
(uma lista separada por vírgula) em uma variável de token para torná-la acessível. No caso do exemplo,{{black, ab}, {white, cd}}
é armazenado comoclist
na variável token\l_tmpa_clist
.\clist_map_inline:Nn \l_tmpa_clist { ... }
faz um loop sobre cada item noclist
(armazenado na variável token) e executa o código entre chaves. O item atual é acessado via#1
(##1
no exemplo de código, porque está aninhado um nível mais profundo).\clist_pop:NN \l_tmpb_clist \l_tmpa_tl
pega o primeiro item declist
e o armazena em uma variável de token (l_tmpa_tl
). Em seguida, ele remove esse item do arquivoclist
.\exp_args:Noo \drawStoneFromSgfCoords { \l_tmpa_tl } { \l_tmpb_tl }
primeiro expande as duas variáveis de token e insere o resultado como argumentos para\drawStoneFromSgfCoords
.
Então, vamos ver o que acontece passo a passo se dissermos \drawStonesFromSgfCoords{{black, ab}, {white, cd}}
:
\NewExpandableDocumentCommand{\drawStonesFromSgfCoords}{ m }{
% store {{black, ab}, {white, cd}} in \l_tmpa_clist
\clist_set:Nn \l_tmpa_clist { #1 }
% loop over items in \l_tmpa_clist
\clist_map_inline:Nn \l_tmpa_clist {
% store {black, ab} in \l_tmpb_clist
\clist_set:Nn \l_tmpb_clist { ##1 }
% store black in \l_tmpa_tl and remove item from clist
\clist_pop:NN \l_tmpb_clist \l_tmpa_tl
% store ab in \l_tmpb_tl and remove item from clist
\clist_pop:NN \l_tmpb_clist \l_tmpb_tl
% expand \l_tmpa_tl and \l_tmpb_tl so that we get
% \drawStoneFromSgfCoords{black}{ab}
\exp_args:Noo \drawStoneFromSgfCoords { \l_tmpa_tl } { \l_tmpb_tl }
% repeat this loop for the next item in the clist in \l_tmpa_clist
}
}