현재 enumitem을 사용하고 있으며 문서의 목록에 대한 환경을 만들었습니다. 그것은 다음과 같습니다:
\newenvironment{alternativas}[1][0]
{
\begin{enumerate}[label={\Alph*)}, itemsep=#1cm, topsep = 0.5cm, wide=0pt,labelwidth=.5cm,leftmargin=!]
}
{
\end{enumerate}
}
(물론 질문에는 그다지 중요하지 않다고 생각합니다)
그리고 저는 모든 항목 사이에 동일한 공간을 갖도록 itemsep을 자동 조정하는 방법을 찾고 있었습니다. 이것이 내가~하지 않다일어나길 원해:
더 많은 높이를 사용하는 분수 때문에 ABC 사이의 간격이 CDE 사이의 간격과 다르고 이상하게 보입니다. 현재 수정 사항은 환경에서 선택적 매개 변수를 사용하여 itemsep 매개 변수를 수동으로 조정하고 다음과 같이 표시되도록 하는 것입니다.
하지만 수동으로 조정하는 속도가 느리고 이 환경을 사용하려면 경험이 부족한 사람이 필요합니다. itemsep을 자동으로 항목 간의 가장 큰 간격으로 설정하는 방법이 있습니까? 많이 검색했지만 찾을 수 없었습니다(어쩌면 내 서투른 영어가 도움이 되지 않았을 수도 있습니다). 감사해요!
답변1
제가 제안한 솔루션은 각 항목의 높이와 깊이를 측정하여 최대 높이와 깊이를 얻는 것입니다. 필요한 경우 기준선 건너뛰기는 최대 높이에 최대 깊이에 2pt를 더한 값으로 설정됩니다.
\documentclass{article}
\usepackage{xparse,enumitem,amsmath}
\ExplSyntaxOn
\NewDocumentCommand{\alternatives}{m}
{
\blaz_alternativas:n { #1 }
}
\seq_new:N \l__blaz_alternativas_seq
\box_new:N \l__blaz_alternativas_item_box
\dim_new:N \l__blaz_alternativas_height_dim
\dim_new:N \l__blaz_alternativas_depth_dim
\cs_new_protected:Nn \blaz_alternativas:n
{
% first populate the sequence of items
\seq_set_split:Nnn \l__blaz_alternativas_seq { \\ } { #1 }
% now measure the heights and depths
\dim_zero:N \l__blaz_alternativas_height_dim
\dim_zero:N \l__blaz_alternativas_depth_dim
\seq_indexed_map_inline:Nn \l__blaz_alternativas_seq
{
% set the box to the current item
\hbox_set:Nn \l__blaz_alternativas_item_box { ##2 }
% measure the height if not the first item
\int_compare:nT { ##1 > 1 }
{
\dim_set:Nn \l__blaz_alternativas_height_dim
{
\dim_max:nn { \l__blaz_alternativas_height_dim }
{ \box_ht:N \l__blaz_alternativas_item_box }
}
}
% measure the depth if not the last item
\int_compare:nT { ##1 < \seq_count:N \l__blaz_alternativas_seq }
{
\dim_set:Nn \l__blaz_alternativas_depth_dim
{
\dim_max:nn { \l__blaz_alternativas_depth_dim }
{ \box_dp:N \l__blaz_alternativas_item_box }
}
}
}
\begin{enumerate}[label={\Alph*)},wide=0pt,labelwidth=.5cm,leftmargin=!,itemsep=0pt]
% set the baselineskip
\skip_set:Nn \baselineskip
{
\dim_max:nn { \baselineskip }
{ \l__blaz_alternativas_height_dim + \l__blaz_alternativas_depth_dim }
+ 2pt
}
% deliver the items
\seq_map_inline:Nn \l__blaz_alternativas_seq { \item ##1 }
\end{enumerate}
}
\ExplSyntaxOff
\begin{document}
\alternatives{ $1$ \\ $2$ \\ $3$ \\ $4$ \\ $5$ }
\alternatives{
$1$ \\
$\dfrac{3}{2}$ \\
$\dfrac{3}{4}$ \\
$4$ \\
$5$
}
\end{document}
\hphantom{$-$}
로 시작하지 않는 각 항목 앞에 추가하는 버전은 다음과 같습니다 $-
(적어도 하나 이상인 경우).
\documentclass{article}
\usepackage{xparse,enumitem,amsmath}
\ExplSyntaxOn
\NewDocumentCommand{\alternatives}{m}
{
\blaz_alternativas:n { #1 }
}
\seq_new:N \l__blaz_alternativas_seq
\box_new:N \l__blaz_alternativas_item_box
\dim_new:N \l__blaz_alternativas_height_dim
\dim_new:N \l__blaz_alternativas_depth_dim
\cs_new_protected:Nn \blaz_alternativas:n
{
% first populate the sequence of items
\seq_set_split:Nnn \l__blaz_alternativas_seq { \\ } { #1 }
% now measure the heights and depths
\dim_zero:N \l__blaz_alternativas_height_dim
\dim_zero:N \l__blaz_alternativas_depth_dim
\seq_indexed_map_inline:Nn \l__blaz_alternativas_seq
{
% set the box to the current item
\hbox_set:Nn \l__blaz_alternativas_item_box { ##2 }
% measure the height if not the first item
\int_compare:nT { ##1 > 1 }
{
\dim_set:Nn \l__blaz_alternativas_height_dim
{
\dim_max:nn { \l__blaz_alternativas_height_dim }
{ \box_ht:N \l__blaz_alternativas_item_box }
}
}
% measure the depth if not the last item
\int_compare:nT { ##1 < \seq_count:N \l__blaz_alternativas_seq }
{
\dim_set:Nn \l__blaz_alternativas_depth_dim
{
\dim_max:nn { \l__blaz_alternativas_depth_dim }
{ \box_dp:N \l__blaz_alternativas_item_box }
}
}
}
\begin{enumerate}[label={\Alph*)},wide=0pt,labelwidth=.5cm,leftmargin=!,itemsep=0pt]
% set the baselineskip
\skip_set:Nn \baselineskip
{
\dim_max:nn { \baselineskip }
{ \l__blaz_alternativas_height_dim + \l__blaz_alternativas_depth_dim }
+ 2pt
}
% check whether some items start with $-
\cs_set_protected:Nn \__blaz_alternativas_minus:n {##1} % do nothing by default
\seq_map_inline:Nn \l__blaz_alternativas_seq
{
\regex_match:nnT { \A \$\- } { ##1 }
{
\seq_map_break:n
{
\cs_set_eq:NN \__blaz_alternativas_minus:n \__blaz_alternativas_addminus:n
}
}
}
% deliver the items
\seq_map_inline:Nn \l__blaz_alternativas_seq { \item \__blaz_alternativas_minus:n {##1} }
\end{enumerate}
}
\cs_new_protected:Nn \__blaz_alternativas_addminus:n
{
\regex_match:nnF { \A \$\- } { #1 } { \hphantom{$-$} } #1
}
\ExplSyntaxOff
\begin{document}
\alternatives{ $1$ \\ $2$ \\ $3$ \\ $4$ \\ $5$ }
\alternatives{
$-1$ \\
$-\dfrac{3}{2}$ \\
$\dfrac{3}{4}$ \\
$4$ \\
$5$
}
\end{document}
답변2
다음은 표 형식을 기반으로 한 완전히 다른 접근 방식입니다. 나는 약간 개조된 버전을 사용했습니다.자동 테이블 행 번호 매기기 와 결합하여cellspace
항목 주위의 간격을 위해 패키지 . 열을 오른쪽으로 정렬했기 때문에 이것도 해결되는 것 같습니다.후속 질문:
\documentclass{article}
\usepackage[column=0]{cellspace}
\setlength\cellspacetoplimit{6pt}
\setlength\cellspacebottomlimit{\cellspacetoplimit}
\usepackage{array,etoolbox}
\preto\tabular{\setcounter{magicrownumbers}{0}}
\newcounter{magicrownumbers}
\newcommand\rownumber{\stepcounter{magicrownumbers}\Alph{magicrownumbers}}
\usepackage{amsmath}
\newenvironment{myalternatives}[1][0]
{\begin{tabular}{@{\makebox[3em][r]{\rownumber)~}} >{$}0r<{$}}}
{\end{tabular}}
\begin{document}
\begin{myalternatives}
1 \\
\dfrac{3}{2} \\
\dfrac{3}{4} \\
4 \\
5 \\
-6\\
\end{myalternatives}
\end{document}