LaTeX で文字を積み重ねた後のスペースを正規化する: タイプセット o͘

LaTeX で文字を積み重ねた後のスペースを正規化する: タイプセット o͘

私はタイプセットしようとしていますキャラクターLaTeX では、文字 の上に盛り上がったピリオドを重ねることで、 を実現していますo。以下のスクリーンショットでわかるように、私が達成した結果の間隔は一貫していません。

カーニングが不十分なo͘

文字の後のスペースは通常の文字の後のスペースよりも大きいことに注意してくださいo

間隔を手動で調整することもできますが、特殊文字を含むフォントに依存しない、より一般的なソリューションが必要です

MWE は次のとおりです。

\documentclass{article}

\newlength{\templen}
\newlength{\templentwo}

\newcommand{\oo}{%
  \settowidth{\templen}{o}%
  \settowidth{\templentwo}{.}%
  o\hspace{\dimexpr-\templen/2\relax}%
  \raisebox{1ex}{.}%
  \hspace{\dimexpr-\templentwo\relax}
}

\begin{document}

o\oo o \oo oo \oo\oo o ooo

\end{document}

アップデート

提供された回答の助けを借りて、私は次の解決策にたどり着きました。今後の参考のために、他の発音区別記号を使用した文字の組版を示すコード全体を記載します。

\documentclass{article}

\usepackage{stackengine}
\usepackage{upquote}

\renewcommand{\.}[1]{\stackinset{c}{}{t}{-0.75ex}{\textquotesingle}{#1}}

\newcommand{\OX}{o\DOTABOVERIGHT{o}{0.6}\leavevmode\phantom{o}}
\DeclareRobustCommand{\DOTABOVERIGHT}[2]{%
  \kern-\fontcharwd\font`#1% back up
  \makebox[0pt][l]{%
    \sbox0{\leavevmode\phantom{#1}}%
    \raisebox{\ht0}[0pt][0pt]{\kern#2\wd0 .}%
  }%
}

\newcommand{\OO}[1]{\stackinset{r}{}{t}{-1.5pt}{.}{#1}}



\begin{document}

So-i goan u siat pat-mih e hoat-to, eng peh-oe-ji lai in-chheh, ho lin cheng-lang khoa\textsuperscript{n} khah khoai bat.

S\OO{\'{o}}-\'{i} g\'{o}an \={u} siat p\.{a}t-mih \^{e} hoat-t\OO{\={o}}, \={e}ng p\.{e}h-\={o}e-j\={i} l\^{a}i \`{i}n-chheh, h\OO{\={o}} l\'{i}n ch\`{e}ng-l\^{a}ng kh\`{o}a\textsuperscript{n} khah kh\`{o}ai bat.

S\'{\OX}-\'{i} g\'{o}an \={u} siat p\.{a}t-mih \^{e} hoat-t\={\OX}, \={e}ng p\.{e}h-\={o}e-j\={i} l\^{a}i \`{i}n-chheh, h\={\OX} l\'{i}n ch\`{e}ng-l\^{a}ng kh\`{o}a\textsuperscript{n} khah kh\`{o}ai bat.

Thai-khong peng-iu, lin-ho. Lin chiah-pa--be? U-eng, toh lai gun chia che--o!

Th\`{a}i-khong p\^{e}ng-i\'{u}, l\'{i}n-h\'{o}. L\'{i}n chi\.{a}h-p\'{a}--b\={e}? \={U}-\^{e}ng, t\.{o}h l\^{a}i g\'{u}n chia ch\={e}--\OO{\^{o}}!

Th\`{a}i-khong p\^{e}ng-i\'{u}, l\'{i}n-h\'{o}. L\'{i}n chi\.{a}h-p\'{a}--b\={e}? \={U}-\^{e}ng, t\.{o}h l\^{a}i g\'{u}n chia ch\={e}--\^{\OX}!


\end{document}

以下はタイプセットされたテキストの画像です。

適切にカーニングされたo͘

\OX私の個人的な好みは、発音区別符号が の上に適切に表示されるバージョンです

答え1

文字間の自動カーニングを維持したい場合は、「o」を 2 回印刷して重ね合わせ、中央に隆起したドットを追加する必要があります。

\documentclass{article}

\newcommand{\oo}{o\DOTABOVERIGHT{o}{0.6}o}
\DeclareRobustCommand{\DOTABOVERIGHT}[2]{%
  \kern-\fontcharwd\font`#1% back up
  \makebox[0pt][l]{%
    \sbox0{#1}%
    \raisebox{\ht0}[0pt][0pt]{\kern#2\wd0 .}%
  }%
}

\begin{document}

o\oo o \oo oo \oo\oo o ooo

ooo  ooo ooo ooo

\end{document}

この\DOTABOVERIGHTコマンドは、ドットを適用する文字とオフセット量 (文字幅の割合) の 2 つの引数を取ります。

ここに画像の説明を入力してください

答え2

あなたが何を望んでいるかよく理解しているなら、\stackinset コマンドを使用した解決策は次のとおりですstackengine

\documentclass{article}

\usepackage{stackengine}

\newcommand{\Oo}{\stackinset{r}{}{t}{-1.5pt}{.}{o}}

\begin{document}

o\Oo o \Oo oo \Oo\Oo o ooo

\end{document}

ここに画像の説明を入力してください

関連情報