OSDN Git Service

Merge branch 'zh-maqiyuan' into kitagawa_test
[luatex-ja/luatexja.git] / doc / luatexja-zh.tex
1 \documentclass{ltjarticle}
2 \usepackage[twoside,left=23mm,width=170mm,right=17mm,top=25mm,height=231mm,bottom=32mm]{geometry}
3 \usepackage{amsmath,amssymb,xcolor,pict2e,multienum,amsthm,float,makecell,multicol,hyperref,showexpl}
4
5 \lstset{
6   basicstyle=\ttfamily\small, pos=o, breaklines=true,
7   numbers=none, rframe={}, basewidth=0.5em
8 }
9 \DeclareYokoKanjiEncoding{ZH}{}{}
10 \DeclareKanjiEncodingDefaults{}{}
11 \DeclareErrorKanjiFont{ZH}{song}{m}{n}{10}
12 \DeclareKanjiSubstitution{ZH}{song}{m}{n}
13 \newcommand\songdefault{song}
14 \newcommand\heidefault{hei}
15 \renewcommand\kanjiencodingdefault{ZH}
16 \renewcommand\kanjifamilydefault{\songdefault}
17 \renewcommand\kanjiseriesdefault{\mddefault}
18 \renewcommand\kanjishapedefault{\updefault}
19 \DeclareKanjiFamily{ZH}{song}{}
20 \DeclareFontShape{ZH}{song}{m}{n}{<->name:AdobeSongStd-Light:jfm=jis}{}
21 \DeclareFontShape{ZH}{song}{bx}{n}{<->ssub*hei/m/n}{}
22 \DeclareKanjiFamily{ZH}{hei}{}
23 \DeclareFontShape{ZH}{hei}{m}{n}{<->name:AdobeHeitiStd-Regular:jfm=jis}{}
24 \fontencoding{ZH}\selectfont
25 \DeclareTextFontCommand{\textsong}{\songfamily}
26 \DeclareTextFontCommand{\texthei}{\heifamily}
27 \DeclareOldFontCommand{\song}{\normalfont\songfamily}{}
28 \DeclareOldFontCommand{\hei}{\normalfont\heifamily}{}
29 \DeclareSymbolFont{songti}{ZH}{song}{m}{n}
30 \jfam\symsongti
31 \SetSymbolFont{songti}{bold}{ZH}{hei}{m}{n}
32 \DeclareSymbolFontAlphabet{\mathsong}{songti}
33 \DeclareMathAlphabet{\mathhei}{ZH}{hei}{m}{n}
34 \makeatletter
35 \DeclareRobustCommand\songfamily{\not@math@alphabet\songfamily\mathsong\kanjifamily\songdefault\selectfont}
36 \DeclareRobustCommand\heifamily{\not@math@alphabet\heifamily\mathhei\kanjifamily\heidefault\selectfont}
37 \DeclareRobustCommand\rmfamily{\not@math@alphabet\rmfamily\mathrm\romanfamily\rmdefault\kanjifamily\songdefault\selectfont}
38 \DeclareRobustCommand\sffamily{\not@math@alphabet\sffamily\mathsf\romanfamily\sfdefault\kanjifamily\heidefault\selectfont}
39 \makeatother
40 \def\LuaTeX{Lua\TeX}
41 \def\pTeX{p\TeX}
42 \def\pLaTeX{p\LaTeX}
43 \title{\LuaTeX-ja宏包}
44 \author{\LuaTeX-ja项目团队}
45 \date{}
46 \begin{document}
47 \maketitle
48 \tableofcontents
49 \section{引言}
50 \subsection{开发背景}
51 \LuaTeX-ja是日本开发者北川弘典首倡的一个\LuaTeX的日文支持项目,该项目将\pTeX移植到了\LuaTeX,并做了一定的扩展,删除了一些不正常的特性。
52
53 %\LuaTeX-ja的项目开发者如下:北川弘典,前田一贵,八登崇之,黑木裕介,阿部纪行,山本宗宏,本田知亮,斋藤修三郎和马起园等。
54
55 \LuaTeX-ja现在只能用于plain \TeX格式和\LaTeXe格式,尚不支持\TeX info和Con\TeX t格式。
56
57 \LuaTeX-ja现在的代码实现依赖于\verb!luatexbase!以及\verb!luaotfload!等宏包,并且现在仅仅实现了横排,直排组版尚未实现。
58 \subsection{一些约定}
59 在本文档中,有下面一些约定:
60 \begin{itemize}
61 \item 所有的日文字符为\textbf{JAchar},所有的其他字符为\textbf{ALchar}
62 \item primitive,该词在本文档中不仅表示\LuaTeX的基本控制命令,也包括\LuaTeX-ja的相关的基本控制命令
63 \item 所有的自然数从0开始
64 \item 本文档中文文档是根据日文文档翻译并添加部分材料组织而成的,所以在大部分篇幅上还是主要依赖于日文原文档
65 \end{itemize}
66 \subsection{关于本项目}
67 \paragraph{项目wiki} 本项目wiki正在不断编写中。
68 \begin{itemize}
69 \item \url{http://sourceforge.jp/projects/luatex-ja/wiki/FrontPage%28en%29}(英文)
70 \item \url{http://sourceforge.jp/projects/luatex-ja/wiki/FrontPage}(日文)
71 \item \url{http://sourceforge.jp/projects/luatex-ja/wiki/FrontPage%28zh%29}(中文)
72 \end{itemize}
73 \paragraph{开发者}
74 \begin{multienumerate}
75 \def\labelenumi{$\bullet$}
76 \mitemxxx{北川弘典}{前田一贵}{八登崇之}
77 \mitemxxx{黒木裕介}{阿部纪行}{山本宗宏}
78 \mitemxxx{本田知亮}{斋藤修三郎}{马起园}
79 \end{multienumerate}
80 \section{初次使用}
81 \subsection{安装}
82 在安装\LuaTeX-ja之前,请确认:
83 \begin{itemize}
84 \item \LuaTeX(版本号为大于0.65)和相关支持宏包。\\
85 如果用户使用的是\TeX Live2011以及最新版本的W32\TeX,都可以不考虑此项。
86 \item \LuaTeX-ja的源码:)
87 \item \underline{\texttt{xunicode}}宏包,当前版本必须为\textit{v0.981(2011/09/09)}。\\
88 如果你使用\underline{\texttt{fontspec}}宏包,\underline{\texttt{xunicode}}必须存在。但是请注意该包版本,其他版本可能不会正常工作。
89 \end{itemize}
90 安装方法如下:
91 \begin{enumerate}
92 \item \LuaTeX-ja宏包的获取:
93         \begin{itemize}
94         \item 如果用户使用git,那么可以使用如下命令获取:\\
95                 \verb!$ git clone git://git.sourceforge.jp/gitroot/luatex-ja/luatexja.git!
96         \item 另外用户还可以直接下载master版本:\\
97                 \verb!$ wget http://git.sourceforge.jp/view?p=luatex-ja/luatexja.git;a=snapshot;h=HEAD;sf=tgz!
98         \end{itemize}
99 \item 用户需要将获取的\LuaTeX-ja宏包的\verb!src/!放置到你所用的发行版中的\verb!TEXMFLOACL!树下\verb!tex/!文件夹(如果不存在,请建立)下即可,查询该环境变量需要使用:\\
100         \verb!$ kpeswhich -expand-var "$TEXMFLOCAL"!
101 \item 刷新数据库:\\
102         \verb!$ texhash!\\
103         \verb!$ mkluatexfontdb!
104 \end{enumerate}
105 \section{\LuaTeX-ja在plain \TeX格式下的使用}
106 对于日本用户,日文的排版可以直接使用:
107 \begin{verbatim}
108 \input luatexja.sty
109 \end{verbatim}
110
111 这一行会默认调用\verb!luatexja.sty!文件,该文件作用相当于\pTeX中的\verb!ptex.tex!。该文件中设定了两款非嵌入字体:Ryumin-Light(明朝体)和GothicBBB-Medium(哥特体)。
112 这些字体分别有三种大小:\verb!\tenmin!和\verb!\tengt!(10pt);\verb!\sevenmin!和\verb!\sevengt!(7pt);\verb!\fivemin!和\verb!\fivegt!(5pt)。
113
114 有几点请用户注意:
115 \begin{itemize}
116 \item 上述的两款字体需要你的pdf阅读器带有良好的非嵌入字体的支持,这里建议使用Adobe Reader,该阅读器使用了Kozuka Mincho字体。
117 \item 在定义字体的时候,可以使用“级”(Q)单位,$1 \mathrm{Q} = 0.25\mathrm{mm}$,在\LuaTeX-ja中可以使用\verb!\jQ!命令调用该长度单位
118 \item 一般情况下,相同大小日文字体比西文字体要大一下(中文字体也是如此),所以定义日文字体的时候需要一个缩放率:0.962216
119 \item 在\textbf{JAchar}和\textbf{ALchar}之间插入的胶大小为:$(0.25\times0.962216\times\mathrm{10pt})^{\mathrm{+1pt}}_{\mathrm{-1pt}} = 2.40554\mathrm{pt}^{\mathrm{+1pt}}_{\mathrm{-1pt}}$
120 \end{itemize}
121 \section{\LuaTeX-ja在\LaTeXe格式的使用}
122 \subsection{日文排版设置}
123 在\LaTeXe下使用\LuaTeX-ja比较便利:
124 \begin{verbatim}
125 \usepackage{luatexja}
126 \end{verbatim}
127
128 该宏包的作用相当于\pLaTeX中的\verb!plfonts.dtx!和\verb!pldefs.ltx!。
129 \begin{itemize}
130 \item 在该宏包中设定了\verb!JY3!编码,这个编码用来调用日文字体
131 \item 该宏包定义了两个字体族:\verb!mc!和\verb!gt!。\\
132 \begin{center}
133         \begin{tabular}{ccccc}
134         \hline
135         字体&字体族&\verb!\mdseries!&\verb!\bfseries!&缩放率\\
136         \hline
137         \textit{mincho}&\verb!mc!&Ryumin-Light&GothicBBB-Medium&0.962216\\
138         \textit{gothic}&\verb!gt!&GothicBBB-Medium&GothicBBB-Medium&0.962216\\
139         \hline
140         \end{tabular}
141 \end{center}
142 \item 在数学模式下,所有的字符使用\verb!mc!字体族来排印
143 \end{itemize}
144
145 上述使用的宏包,只满足了最小的日文环境设定需求,并为满足所有的日文排版需求。
146 \LuaTeX-ja宏包提供了两个文档类:\verb!jclasses!(\pLaTeX标准文档类)和\verb!jsclasses!(奥村晴彦)。用户可自行选择两种文档类。
147
148 \subsection{中文排版设定}
149 请先下载\verb!zh-classes!:
150 \begin{verbatim}
151 $ wget http://fandol-doc.googlecode.com/files/zh-classes.tar.xz
152 \end{verbatim}
153
154 该文档类是基于\verb!jclasses!文档的中文设定版。
155 这个文档类需要你安装Adobe Reader并使用两款字体。
156 值得注意的是,本文档类提供的两款字体并不嵌入,这首先是为了减轻文档大小,其次为了加快编译速度。
157 这两款字体在你安装的中文版Adobe Reader的文件夹下。这两款字体设定如下:
158 \begin{center}
159         \begin{tabular}{cccc}
160         \hline
161         字体&字体族&\verb!\mdseries!&\verb!\bfseries!\\
162         \hline
163         \textit{song}&\verb!song!&AdobeSongStd-Light&AdobeHeitiStd-Regular\\
164         \textit{hei}&\verb!hei!&AdobeHeitiStd-Regular&AdobeHeitiStd-Regular\\
165         \hline
166         \end{tabular}
167 \end{center}
168
169 例如:
170 \begin{verbatim}
171 \documentclass{zh-article}
172 \title{Lua\TeX测试}
173 \author{某人甲}
174 \begin{document}
175 \maketitle
176 Lua\TeX-ja中文测试。{\hei 测试}
177 \end{document}
178 \end{verbatim}
179
180 我们在这里建议用户更改\textsf{zh-classes.dtx}文件中的相关代码来定制符合自己的文档类。
181 但请注意,请将你更改后的文档类更名为你自己的自定义名称。
182 这里给出一些常见的中文字体组合:
183 \begin{center}
184         \begin{tabular}{ccc}
185         \hline
186         组合&宋体&黑体\\
187         \hline
188         Windows$^{(1)}$&SimSun&SimHei\\
189         Windows$^{(2)}$&方正书宋&方正粗宋简体\\
190         Mac OS X&STSong&STHeiti\\
191         \hline
192         \end{tabular}
193 \end{center}
194 %名称 SIL-Kai-Reg-Jian        全名  Kai Regular 
195 %名称 SimSun-ExtB             全名  SimSun-ExtB 
196 %名称 FangSong                全名  仿宋
197 %名称 SimHei                  全名  黑体
198 %名称 STHeitiSC-Medium        全名  黑体-简 中等
199 %名称 STFangsong              全名  华文仿宋
200 %名称 STHeiti                 全名  华文黑体
201 %名称 STHupo                  全名  华文琥珀
202 %名称 STKaiti                 全名  华文楷体
203 %名称 STLiti                  全名  华文隶书
204 %名称 STSong                  全名  华文宋体
205 %名称 STXinwei                全名  华文新魏
206 %名称 STXingkai               全名  华文行楷
207 %名称 STZhongsong             全名  华文中宋
208 \subsection{fontspec}
209 在\LuaTeX-ja中,和\texttt{fontspec}共存的一个包为\texttt{luatexja-fontspec}。
210 这个包自动加载\texttt{fontspec}和\texttt{luatexja}宏包。
211
212 在\texttt{luatexja-fontspec},定义了如下七条命令,这些命令和\texttt{fontspec}的相关命令对比如下:
213 \begin{center}
214         \begin{tabular}{ccccc}
215         \hline
216         日文字体&\verb+\jfontspec+&\verb+\setmainjfont+&\verb+\setsansjfont+&\verb+\newjfontfamily+\\
217         西文字体&\verb+\fontspec+&\verb+\setmainfont+&\verb+\setsansfont+&\verb+\newfontfamily+\\
218         \hline
219         日文字体&\verb+\newjfontface+&\verb+\defaultjfontfeatures+&\verb+\addjfontfeatures+&\\
220         西文字体&\verb+\newfontface+&\verb+\defaultfontfeatures+&\verb+\addfontfeatures+&\\
221         \hline
222         \end{tabular}
223 \end{center}
224 \section{\LuaTeX-ja参数设定}
225 \LuaTeX-ja包含大量的参数,以控制排版细节。
226 设定这些参数需要使用命令:\verb!\ltjsetparameter!和\verb!\ltjgetparameter!命令。
227 \subsection{JAchar范围的设定}
228 在设定\textbf{JAchar}之前,需要分配一个小于217的自然数。如:
229 \begin{verbatim}
230 \ltjdefcharrange{100}{"10000-"1FFFF,`漢}
231 \end{verbatim}
232
233 请注意这个设定是全局性的,不建议在文档正文中进行设定。
234
235 在范围设定好了之后,需要进行\verb!jacharrange!的设定:
236 \begin{verbatim}
237 \ltjsetparameter{jacharrange={-1, +2, +3, -4, -5, +6, +7, +8}}
238 \end{verbatim}
239
240 这里定义了8个范围,在每个范围之前使用“+”或“-”进行设定,其中如果为$-$,则代表该范围为\textbf{ALchar},如果为$+$,则该范围视作\textbf{JAchar}。
241
242 \LuaTeX-ja默认设定了8个范围,这些范围来源于下列数据:
243 \begin{itemize}
244 \item Unicode 6.0
245 \item Adobe-Japan1-6与Unicode之间的映射\verb!Adobe-Japan1-UCS2!
246 \item 八登崇之的up\TeX宏包:\verb!PXbase!
247 \end{itemize}
248
249 \begin{description}
250 \item[范围 $\mathbf{8^J}$] ISO 8859-1(Latin-1补充)的上半部和JIS X 0208(日文基本字符集)的重叠部分,包含下列字符:
251 \begin{multicols}{2}
252         \begin{itemize}
253         \def\ch#1#2{\item \char"#1\ (\texttt{U+00#1}, #2)}
254         \ch{A7}{Section Sign}
255         \ch{A8}{Diaeresis}
256         \ch{B0}{Degree sign}
257         \ch{B1}{Plus-minus sign}
258         \ch{B4}{Spacing acute}
259         \ch{B6}{Paragraph sign}
260         \ch{D7}{Multiplication sign}
261         \ch{F7}{Division Sign}
262         \end{itemize}
263 \end{multicols}
264
265 \item[范围 $\mathbf{1^A}$] 包含于Adobe-Japan1-6中的拉丁字符,此范围包含下列Unicode区域,但不包括上述提到过的范围8:
266 \begin{multicols}{2}
267         \begin{itemize}
268         \item \texttt{U+0080}--\texttt{U+00FF}: 拉丁字母补充-1
269         \item \texttt{U+0100}--\texttt{U+017F}: 拉丁字母扩充-A
270         \item \texttt{U+0180}--\texttt{U+024F}: 拉丁字母扩充-B
271         \item \texttt{U+0250}--\texttt{U+02AF}: 国际音标扩充
272         \item \texttt{U+02B0}--\texttt{U+02FF}: 进格修饰符元
273         \item \texttt{U+0300}--\texttt{U+036F}: 组合音标附加符号
274         \item \texttt{U+1E00}--\texttt{U+1EFF}: 拉丁字母扩充附加
275         \end{itemize}
276 \end{multicols}
277
278 \item[范围 $\mathbf{2^J}$] 希腊文和西里尔字母,使用JIS X 0208的大部分日文字体包含这些字符:
279 \begin{multicols}{2}
280         \begin{itemize}
281         \item \texttt{U+0370}--\texttt{U+03FF}: 希腊字母
282         \item \texttt{U+0400}--\texttt{U+04FF}: 西里尔字母 
283         \item \texttt{U+1F00}--\texttt{U+1FFF}: 希腊文扩充
284         \end{itemize}
285 \end{multicols}
286
287 \item[范围 $\mathbf{3^J}$] 标点以及杂项符号:
288 \begin{multicols}{2}
289         \begin{itemize}
290         \item \texttt{U+2000}--\texttt{U+206F}: 一般标点符号
291         \item \texttt{U+2070}--\texttt{U+209F}: 上标及下标
292         \item \texttt{U+20A0}--\texttt{U+20CF}: 货币符号
293         \item \texttt{U+20D0}--\texttt{U+20FF}: 符号用组合附加符号
294         \item \texttt{U+2100}--\texttt{U+214F}: 类字母符号
295         \item \texttt{U+2150}--\texttt{U+218F}: 数字形式
296         \item \texttt{U+2190}--\texttt{U+21FF}: 箭头符号
297         \item \texttt{U+2200}--\texttt{U+22FF}: 数学运算符号
298         \item \texttt{U+2300}--\texttt{U+23FF}: 杂项技术符号
299         \item \texttt{U+2400}--\texttt{U+243F}: 控制图像
300         \item \texttt{U+2500}--\texttt{U+257F}: 制表符
301         \item \texttt{U+2580}--\texttt{U+259F}: 区块元素
302         \item \texttt{U+25A0}--\texttt{U+25FF}: 几何形状
303         \item \texttt{U+2600}--\texttt{U+26FF}: 杂项符号
304         \item \texttt{U+2700}--\texttt{U+27BF}: 什锦符号
305         \item \texttt{U+2900}--\texttt{U+297F}: 补充性箭头-B
306         \item \texttt{U+2980}--\texttt{U+29FF}: 混合数学符号-B
307         \item \texttt{U+2B00}--\texttt{U+2BFF}: 杂项符号和箭头符号
308         \item \texttt{U+E000}--\texttt{U+F8FF}: 私用区域
309         \end{itemize}
310 \end{multicols}
311
312 \item[范围 $\mathbf{4^A}$] 通常情况下不包含于日文字体的部分。本范围包含有其他范围尚未涵盖部分。故,我们直接给出定义:
313 \begin{verbatim}
314 \ltjdefcharrange{4}{%
315    "500-"10FF, "1200-"1DFF, "2440-"245F, "27C0-"28FF, "2A00-"2AFF, 
316   "2C00-"2E7F, "4DC0-"4DFF, "A4D0-"A82F, "A840-"ABFF, "FB50-"FE0F, 
317   "FE20-"FE2F, "FE70-"FEFF, "FB00-"FB4F, "10000-"1FFFF} % non-Japanese
318 \end{verbatim}
319
320 \item[范围 $\mathbf{5^A}$] 代替以及补充私有使用区域。
321 \item[范围 $\mathbf{6^J}$] 日文字符。
322 \begin{multicols}{2}
323         \begin{itemize}
324         \item \texttt{U+2460}--\texttt{U+24FF}: 圈状字母数字
325         \item \texttt{U+2E80}--\texttt{U+2EFF}: CJK部首补充
326         \item \texttt{U+3000}--\texttt{U+303F}: CJK标点符号
327         \item \texttt{U+3040}--\texttt{U+309F}: 平假名
328         \item \texttt{U+30A0}--\texttt{U+30FF}: 片假名
329         \item \texttt{U+3190}--\texttt{U+319F}: 汉文标注号
330         \item \texttt{U+31F0}--\texttt{U+31FF}: 片假名音标补充
331         \item \texttt{U+3200}--\texttt{U+32FF}: 圈状CJK字母及月份
332         \item \texttt{U+3300}--\texttt{U+33FF}: CJK兼容
333         \item \texttt{U+3400}--\texttt{U+4DBF}: CJK统一表意文字扩充A            \item \texttt{U+4E00}--\texttt{U+9FFF}: CJK统一表意文字
334         \item \texttt{U+F900}--\texttt{U+FAFF}: CJK兼容表意文字
335         \item \texttt{U+FE10}--\texttt{U+FE1F}: 直行标点
336         \item \texttt{U+FE30}--\texttt{U+FE4F}: CJK兼容形式
337         \item \texttt{U+FE50}--\texttt{U+FE6F}: 小写变体
338         \item \texttt{U+20000}--\texttt{U+2FFFF}: (补充字符)
339         \end{itemize}
340 \end{multicols}
341
342 \item[范围 $\mathbf{7^J}$] 不包含于Adobe-Japan1-6的CJK字符。
343 \begin{multicols}{2}
344         \begin{itemize}
345         \item \texttt{U+1100}--\texttt{U+11FF}: 谚文字母
346         \item \texttt{U+2F00}--\texttt{U+2FDF}: 康熙部首
347         \item \texttt{U+2FF0}--\texttt{U+2FFF}: 汉字结构描述字符
348         \item \texttt{U+3100}--\texttt{U+312F}: 注音字母
349         \item \texttt{U+3130}--\texttt{U+318F}: 谚文兼容字母
350         \item \texttt{U+31A0}--\texttt{U+31BF}: 注音字母扩充
351         \item \texttt{U+31C0}--\texttt{U+31EF}: CJK笔划
352         \item \texttt{U+A000}--\texttt{U+A48F}: 彝文音节
353         \item \texttt{U+A490}--\texttt{U+A4CF}: 彝文字母
354         \item \texttt{U+A830}--\texttt{U+A83F}: 一般印度数字
355         \item \texttt{U+AC00}--\texttt{U+D7AF}: 谚文音节
356         \item \texttt{U+D7B0}--\texttt{U+D7FF}: 谚文字母扩充-B
357         \end{itemize}
358 \end{multicols}
359 \end{description}
360 \subsection{\textsf{kanjiskip}和\textsf{xkanjiskip}}
361 \textbf{JAglue}分为下列三类范畴:
362 \begin{itemize}
363 \item JFM设定的胶或出格值。如果在一个日文字符附近使用\verb!\inhibitglue!,则胶便不会插入。
364 \item 两个\textbf{JAchar}之间默认插入的胶(\textsf{kanjiskip})
365 \item \textbf{JAchar}和\textbf{ALchar}之间默认插入的胶(\textsf{xkanjiskip})
366 \end{itemize}
367
368 \textsf{kanjiskip}和\textsf{xkanjiskip}的设定如下所示:
369 \begin{verbatim}
370 \ltjsetparameter{kanjiskip={0pt plus 0.4pt minus 0.4pt},
371                  xkanjiskip={0.25\zw plus 1pt minus 1pt}}
372 \end{verbatim}
373
374 当JFM包含“\textsf{kanjiskip}理想宽度”和/或“\textsf{xkanjiskip}理想宽度”数据时,上述设定产生作用。如果想用JFM中的数据,请设定\textsf{kanjiskip}或\textsf{xkanjiskip}为\verb!\maxdimen!。
375 \subsection{\textsf{xkanjiskip}插入设定}
376 并不是在所有的\textbf{JAchar}和\textbf{ALchar}周围插入\textsf{xkanjiskip}都是合适的。
377 比如,在开标点之后插入\textsf{xkanjiskip}并不合适[如,比较“(あ”和“(\hskip\ltjgetparameter{xkanjiskip}あ”]。
378 \LuaTeX-ja可以通过设定\textbf{JAchar}的\textsf{jaxspmode}以及\textbf{ALchar}的\textsf{alxspmode}来控制\textsf{xkanjiskip}在字符前后的插入。
379
380 \begin{LTXexample}[pos=r]
381 \ltjsetparameter{jaxspmode={`あ,preonly}, alxspmode={`\!,postonly}}
382 pあq い!う
383 \end{LTXexample}
384
385 第二个参数\textsf{preonly}表示的含义为“允许在该字符前插入\textsf{xkanjiskip},但不允许在该字符之后插入”。
386 其他参数还有\textsf{postonly},\textsf{allow}和\textsf{inhibit}。[TODO]
387
388 用户如果想开启/关闭\textsf{kanjiskip}和\textsf{xkanjiskip}的插入,设定\textsf{autospacing}和\textsf{autoxspacing}参数为\textsf{true}/\textsf{false}即可。
389 \subsection{基线浮动}
390 为了确保日文字体和西文字体能够对其,有时需要浮动其中一者的基线。
391 在\pTeX中,此项设定由设定\verb!\yabaselineshift!为非零长度(西文字体基线应向下浮动)。
392 不过,如果文档的中主要语言不是日文,那么最好上浮日文字体的基线,西文字体不变。
393 如上所述,\LuaTeX-ja可以独立设定西文字体的基线(\textsf{yabaselineshift}参数)和日文字体的基线(\textsf{yjabaselineshift}参数)。
394
395 \begin{LTXexample}[pos=r]
396 \vrule width 150pt height 0.4pt depth 0pt\hskip-120pt
397 \ltjsetparameter{yjabaselineshift=0pt, yalbaselineshift=0pt}abcあいう
398 \ltjsetparameter{yjabaselineshift=5pt, yalbaselineshift=2pt}abcあいう
399 \end{LTXexample}
400
401 上述水平线为此行基线。
402
403 这里还有一个有趣的副作用:不同大小的字符可以通过适当调整这两个参数而在一行中垂直居中。下面是一个例子(注意,参数值并没有精心调整):
404
405 \begin{LTXexample}[pos=r]
406 xyz漢字
407 {\scriptsize
408   \ltjsetparameter{yjabaselineshift=-1pt,
409     yalbaselineshift=-1pt}
410   XYZひらがな
411 }abcかな
412 \end{LTXexample}
413 \subsection{裁剪框标记}
414 裁剪框标记是在一页的四角和水平/垂直中央放置的标记。在日文中,裁剪框被称为“トンボ”。
415 \pLaTeX和\LuaTeX-ja均在底层支持裁剪框标记。需要下列步骤来实现:
416 \begin{enumerate}
417 \item 首先,首先定义页面左上角将会出现的注记。这由向\verb!@bannertoken!分配一个token列完成。\\
418 例如,下列所示将会设定注记为“\textsf{filename (YYYY-MM-DD hh:mm)}”:
419
420 \begin{verbatim}
421 \makeatletter
422
423 \hour\time \divide\hour by 60 \@tempcnta\hour \multiply\@tempcnta 60\relax
424 \minute\time \advance\minute-\@tempcnta
425 \@bannertoken{%
426    \jobname\space(\number\year-\two@digits\month-\two@digits\day
427    \space\two@digits\hour:\two@digits\minute)}%
428 \end{verbatim}
429
430 \item {[TODO]}
431 \end{enumerate}
432 \section{Lua\TeX-ja与Lua\TeX相关阅读材料}
433 \begin{itemize}
434 \item Lua\TeX官方主页:\verb!http://www.luatex.org!
435 \item Lua\TeX\ SVN:\verb!http://foundry.supelec.fr/gf/project/luatex/!
436 \item Lua\TeX:\verb!http://ja.wikipedia.org/wiki/LuaTeX!
437 \item Lua\TeX-ja官方主页:\verb!http://en.sourceforge.jp/projects/luatex-ja/!
438 \item p\TeX官方主页:\verb!http://ascii.asciimw.jp/pb/ptex/!
439 \item Publishing \TeX:\verb!http://ja.wikipedia.org/wiki/PTeX!
440 \item Vertical typesetting in \TeX:\verb!http://tug.org//TUGboat/Articles/tb11-3/tb29hamano.pdf!
441 \item up\TeX官方主页:\verb!http://homepage3.nifty.com/ttk/comp/tex/uptex.html!
442 \item “LuaTeX で日本語”:\verb!http://oku.edu.mie-u.ac.jp/tex/mod/forum/discuss.php?d=627!
443 \item luajalayout宏包:\verb!http://www-is.amp.i.kyoto-u.ac.jp/lab/kmaeda/lualatex/luajalayout/!
444 \item luafontcomp宏包:\verb!http://www-is.amp.i.kyoto-u.ac.jp/lab/kmaeda/lualatex/luafontcomp/!
445 \item 思わずLuaでLaTeXしてみた:\verb!http://zrbabbler.sp.land.to/lualatexlua.html!
446 \item luaums.sty:\verb!http://oku.edu.mie-u.ac.jp/tex/mod/forum/discuss.php?d=378!
447 \item koTeXは日本語LuaTeXへの先導役になるか?:\\\verb!http://oku.edu.mie-u.ac.jp/tex/mod/forum/discuss.php?d=485!
448 \end{itemize}
449 \end{document}