
我用米亞馬用於模擬短(幾行)手寫文字的字體。由於字體相當輕,我使用了史蒂文·B·塞格萊斯解決方案來自 如何將自訂書法文字加粗
- 問題是,
\BODY
作為\calbf
參數給出,它會吞掉所有換行符。 (但它可以很好地處理帶有德語變音符號等的 UTF-8 字元)。這與 miama 字體無關。如果沒有它,斷線也會受到影響。 我還想知道
\calbf
最後一行(註解掉的)中所示的呼叫會引發此錯誤:!包 inputenc 錯誤:無效的 UTF-8 位元組序列。
請參閱 inputenc 套件文件以取得解釋。輸入 H 以獲得立即幫助。 …
l.61 ...á é ó í ú \ldots \"e \"i \"a \"o \"u} 在此輸入代碼
有人可以告訴我如何處理(特別是)問題 1 嗎?
\documentclass[12pt]{article}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}
\usepackage{environ}
\usepackage[scale=1]{miama}
\usepackage{stackengine}
\def\useanchorwidth{T}
\def\stacktype{L}
\def\stackalignment{l}
\def\calup{.2pt}
\def\calover{.15pt}
\def\calbf#1{\calbfhelpA#1 \relax\relax}
\def\calbfhelpA#1 #2\relax{%
\calbfhelpB#1\relax\relax%
\ifx\relax#2\else\ \calbfhelpA#2\relax\fi
}
\def\calbfhelpB#1#2\relax{%
\stackon[\calup]{#1}{\kern\calover#1}%
\ifx\relax#2\else
\calbfhelpB#2\relax%
\fi
}
\NewEnviron{MyCal}%
{%
\fmmfamily%
\noindent%
\calbf{Test0}\\ \BODY \\\\ \calbf{\BODY}%
}
\begin{document}
\def\calup{.3pt}
\def\calover{.3pt}
\begin{MyCal}
MyCal:\\
Test1: ä.ö.ü.Ä.Ö.Ü.ß.\ss.
\par
á é ó í ú
\"e \"i \"a \"o \"u
\end{MyCal}
\par\vspace{1em}
%\calbf{ä.ö.ü.Ä.Ö.Ü.ß.\ss \ldots á é ó í ú \ldots \"e \"i \"a \"o \"u}
\end{document}
答案1
嘗試解決問題 1。
主要問題是原始版本\calbf
根本沒有處理擴充功能。所以發生的事情是,\calbf
看到一個令牌\BODY
,然後將其傳遞出去並說\stackon[\calup]{\BODY}{\kern\calover\BODY}
。\calbf
嘗試一次傳遞一個令牌的原因\calup
大概是因為傳遞一整塊文字會破壞換行。
因此,改變\calbf
以擴大其論點是有幫助的。我使用這個\romannumeral
技巧來遞歸地擴展 的第一個標記\calbfhelpA
。在這種情況下,第一個令牌是\BODY
,它會擴展並轉儲其餘所有內容。
然後出現了另一個問題,那就是它之前所說的唯一原因\"a
是因為\calbf
沒有成功地分離出輸入的各個字符,因為它全部都在\BODY
.此修復需要在內部測試\calbfhelpB
第一個參數是否為巨集。如果第一個參數是宏,則儲存它並取得下一個標記。如果我們看到\par
or標記,我們也會遇到麻煩\\
,因此我們單獨測試它們。
\documentclass[12pt]{article}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}
\usepackage{environ}
\usepackage[scale=1]{miama}
\usepackage{stackengine}
\def\useanchorwidth{T}
\def\stacktype{L}
\def\stackalignment{l}
\def\calup{.2pt}
\def\calover{.15pt}
\makeatletter
% Terminal token to signal end of input.
% We give it a unique definition so that `\ifx\endtoken\anythingelse` always tests false.
% Since we're using fexpansion, we need an extra `\noexpand` to prevent it from getting
% turned into something else.
\def\calbf@endtoken{\noexpand\calbf@endtoken}
% Use \romannumeral trick to "f expand" argument
% We are going to parse by spaces, so we need to add a terminal space and \relax
% so we can tell when we are done.
\def\calbf#1{\expandafter\calbf@\romannumeral-`0#1 \calbf@endtoken}
% Needs to be \long in case argument is a \par token.
% #1 - a single word
\long\def\calbf@#1 {%
\calbf@handleword{}#1\calbf@endtoken
% Check if we are done. If not, fexpand rest of input and recurse.
\@ifnextchar\calbf@endtoken{}{\ \expandafter\calbf@\romannumeral-`0}%
}
% Helper macro to test for equality.
\long\def\calbf@ifx#1#2{%
\ifx#1#2\expandafter\@firstoftwo\else\expandafter\@secondoftwo\fi
}
% Test if argument is a macro (checks if \string#1 contains multiple characters).
\long\def\calbf@ifmacro#1{%
\expandafter\ifx\expandafter$\romannumeral-`0\expandafter\@gobble\string#1$%
\expandafter\@secondoftwo
\else
\expandafter\@firstoftwo
\fi
}
\long\def\calbf@handleword#1#2{%
\calbf@ifx{#2}{\calbf@endtoken}{}{% we're done with this word
\calbf@ifx{#2}{\par}{%
#2\calbf@handleword{}% just pass \par tokens through
}{%
\calbf@ifx{#2}{\\}{%
#2\calbf@handleword{}% just pass \\ tokens through
}{%
\calbf@ifmacro#2{% If it's an accent, save it and grab the argument too.
\calbf@handleword{#1#2}%
}{%
\stackon[\calup]{#1{#2}}{\kern\calover#1{#2}}% Otherwise print it.
\calbf@handleword{}%
}%
}}}%
}
\NewEnviron{MyCal}{%
%\fmmfamily
\noindent
\calbf{Test0}\\ \BODY \\\\
\calbf{\BODY}%
}
\makeatother
\begin{document}
\def\calup{.3pt}
\def\calover{.3pt}
\"{ab}
\begin{MyCal}
MyCal:\\
Test1: %ä.ö.ü.Ä.Ö.Ü.ß.\ss.
\par
abcd
\"e \"i \"a \"o \"u \"e\"i\"a\"o\"u \"{abcd} {1234}
\end{MyCal}
\par\vspace{1em}
%\calbf{ä.ö.ü.Ä.Ö.Ü.ß.\ss \ldots á é ó í ú \ldots \"e \"i \"a \"o \"u}
\end{document}