官术网_书友最值得收藏!

Improving justification and hyphenation

Sometimes, you may get warnings like overfull \hbox, or you may notice words hanging in the margin. This is a sign that LaTeX has had serious problems with justification. Now, we will take a look at how to improve that.

How to do it...

You can start with any document. We will optimize it with settings in the preamble. If you don't have one at hand, you can take one from the code package for this book, specifically for the first chapter, or download one at http://latex-cookbook.net. Let's proceed:

  1. Load the package babel with your document languages as options. Use the preferred language as the last option:
    \usepackage[ngerman,english]{babel}
  2. If you would like to use handy shortcuts of the ngerman package with English too, add the following lines of code:
    \useshorthands{"}
    \addto\extrasenglish{\languageshorthands{ngerman}}
  3. Load the fontenc package with the T1 option set:
    \usepackage[T1]{fontenc}
  4. Load the microtype package for improved micro-typography:
    \usepackage{microtype}

How it works...

With the babel package, LaTeX uses the hyphenation patterns for the chosen language. Even for the English language it could be useful. As you have seen, the babel package can additionally load the handy ngerman shortcuts for hyphenation commands. You can find such shorthand commands in the babel manual. You can open it by typing the texdoc babel command in Command Prompt, or you can find it online at http://texdoc.net/pkg/babel.

The modern font encoding T1 improves the situation further. When TeX and LaTeX were introduced, fonts did not contain glyphs for accented characters. They were printed as two characters, one being the actual accent. That's bad for copying and pasting from the final PDF output. It also interfered with hyphenation.

The default encoding is called OT1, and covers 128 glyphs, which means that it encodes 128 characters. T1 provides 256 glyphs, so many accented characters are included. That's why T1 is recommended for Western European languages. There are further encodings for other languages, such as for Cyrillic and for Asian languages. If you would like to work with them, take a look at the fontenc manual by typing the texdoc fontenc command in Command Prompt, or you can read it online at http://texdoc.net/pkg/fontenc.

Finally, we let the microtype package apply micro-typographic extensions. For example, the font size, even of single letters, might be scaled a little bit in favor of better full justification. You hardly can notice this with the naked eye, but you can see the effect of less hyphenation and better overall greyness of the text. Therefore, there should be smaller white gaps between words.

Furthermore, the microtype package subtly adjusts punctuation at the margin for better optical alignment, instead of just mechanical justification.

主站蜘蛛池模板: 西充县| 桑植县| 深圳市| 台东县| 德庆县| 南开区| 鲁甸县| 磐石市| 东乡族自治县| 潍坊市| 乌鲁木齐市| 万安县| 韩城市| 卓资县| 城步| 万荣县| 根河市| 探索| 西青区| 木兰县| 临湘市| 兴山县| 河源市| 平乐县| 三台县| 桐梓县| 尖扎县| 长白| 庆阳市| 瑞安市| 兴和县| 湟中县| 保靖县| 大宁县| 临夏市| 贵溪市| 正定县| 崇仁县| 石景山区| 宜城市| 甘泉县|