[Unicode]  Technical Reports
 

Unicode® Technical Report #50

Unicode Vertical Text Layout

Editor Koji Ishii 石井宏治 (Google Inc.)
Date 2016-11-23
This Version http://www.unicode.org/reports/tr50/tr50-17.html
Previous Version http://www.unicode.org/reports/tr50/tr50-15.html
Latest Version http://www.unicode.org/reports/tr50/
Latest Proposed Update http://www.unicode.org/reports/tr50/proposed.html
Data http://www.unicode.org/Public/vertical/revision-17/
Revision 17

Summary

The Unicode code charts generally show characters oriented for horizontal presentation. However, some of the glyphs are actually oriented for vertical presentation. A few characters change shape or orientation when the text is rotated from horizontal to vertical.

When text is presented, there are various conventions for the orientation of the characters with respect to the line. In most cases, characters are oriented in an upright manner similar to their presentation in the Unicode code charts. In a few cases, when presented in vertical lines, the characters will appear rotated or transformed in various ways. For example, in East Asia, Han ideographs, Kana syllables, Hangul syllables, and Latin letters in acronyms are upright, while words and sentences in the Latin script are typically sideways. This report describes a Unicode character property which can serve as a stable default orientation of characters for reliable document interchange.

Status

This document has been reviewed by Unicode members and other interested parties, and has been approved for publication by the Unicode Consortium. This is a stable document and may be used as reference material or cited as a normative reference by other specifications.

A Unicode Technical Report (UTR) contains informative material. Conformance to the Unicode Standard does not imply conformance to any UTR. Other specifications, however, are free to make normative references to a UTR.

Please submit corrigenda and other comments with the online reporting form [Feedback]. Related information that is useful in understanding this document is found in References. For the latest version of the Unicode Standard, see [Unicode]. For a list of current Unicode Technical Reports, see [Reports]. For more information about versions of the Unicode Standard, see [Versions]. For any errata which may apply to this document, see [Errata].

Contents


1 Overview and Scope

When text is displayed in vertical lines, there are various conventions for the orientation of the characters with respect to the line. In East Asia, Han ideographs, Kana syllables, and Hangul syllables, along with Latin letters of acronyms, remain upright, meaning that they appear with the same orientation as in the code charts, but words and sentences that are composed of characters of the Latin script are typically oriented sideways, as can be seen in figure 1.

Figure 1. Japanese vertical text

In many parts of the world, most characters are upright, as can be seen in figure 2.

Figure 2. Western vertical text

Most languages and scripts are written horizontally and vertical presentation is a special case, usually used for short runs of text (as in figure 2). Some languages, however, have publishing traditions that provide for long-format vertical text presentation, notably East Asian languages such as Japanese. In those languages, the orientation in which characters are laid out can vary, depending on the scripts, the style, and sometimes the context. The preferred or desired orientation may also change over time.

While the choice of orientation for a character can vary across documents, it is important that the choice made by an author for a specific document be clearly established, so that a rendering system can display what the author intended. It is also important that this choice be established independently of the font resources, as the rendering systems may have to use other fonts than those intended or specified in the document. Finally, the expression of the author’s choice should be relatively concise, to facilitate document authoring and minimize document size.

This report describes a Unicode character property which can serve as a stable default character orientation for the purpose of reliable document interchange.

For the purpose of reliable document interchange, this property defines an unambiguous default value, so that implementations could reliably render a character stream based solely on the property values, without depending on other information such as provided in the tables of the selected font.

The intent is that document formats should offer to the author the possibility of specifying the desired orientation of a given character (either all occurrences or a particular occurrence), and that in the absence of an explicit specification, the orientation is implicitly that defined by the property presented in this report.

In plain text, which by definition does not allow the recording of any data beyond the characters, the orientations are by necessity those specified by the property.

The actual choice for the property values should result in a reasonable or legible default, but it may not be publishing-material quality, and it may not be a good choice if used in a specific style or context.

The property values are chosen first to match existing practice in Japanese context in Japan and then in other East Asian contexts in their respective environments. For characters that are not generally used in such environments, similarity to existing characters has been taken into consideration. Commonly used characters of Latin and other scripts that appear in Japanese and other East Asian environments are also taken into account, but with the lower priority.

The scope of the property is limited by the scope of Unicode. For example, Unicode does not directly support the representation of texts and inscriptions using Egyptian Hieroglyphs. Instead, Unicode provides characters intended for use when writing about such texts or inscriptions, or for use in conjunction with a markup system such as the Manuel de Codage. While the property values are defined for Egyptian Hieroglyphs, they are meaningful only for occurrences of these characters in discursive texts; when the characters are used with markup, the markup ultimately controls the orientation. See [Unicode], Section 11.4 for a more complete discussion of the scope of Egyptian Hieroglyph characters.

2 Conformance

The property defined in this report is informative. The intent of this report is to provide, in the absence of other information, a reasonable way to determine the correct orientation of characters, but this behavior can be overridden by a higher-level protocol, such as through markup or by the preferences of a layout application. This default determination is defined in the accompanying data file, but in no way implies that the character is used only in that orientation.

For more information on the conformance implications, see [Unicode], Section 3.5, Properties, in particular the definition (D35) of an informative property.

Note that the property is not part of the Unicode Character Database [UCD].

3 The Vertical_Orientation Property (vo)

3.1 Property values

The possible property values are given in table 1.

Table 1. Property Values

U Characters which are displayed upright, with the same orientation that appears in the code charts.
R Characters which are displayed sideways, rotated 90 degrees clockwise compared to the code charts.
Tu Characters which are not just upright or sideways, but generally require a different glyph than in the code charts when used in vertical texts. In addition, as a fallback, the character can be displayed with the code chart glyph upright.
Tr Same as Tu except that, as a fallback, the character can be displayed with the code chart glyph rotated 90 degrees clockwise.

Note that the orientation is described with respect to the appearance in the code charts.

3.2 Grapheme Clusters

As in all matters of typography, the interesting unit of text is not the character, but a grapheme cluster: it does not make sense to use a base character upright and a combining mark attached to it sideways. Implementations should apply the orientation to each grapheme cluster.

A possible choice for the notion of grapheme cluster is either that of legacy grapheme cluster or that of extended grapheme cluster, as defined in [UAX29].

The orientation for a grapheme cluster as a whole is then determined by taking the orientation of the first character in the cluster, with the following exception:

If the cluster contains an enclosing combining mark (general category Me), then the whole cluster has the Vertical_Orientation value U.

3.3 Vertical Glyphs in the Code Charts

The Unicode code charts generally show characters in the orientation they take when used in horizontal lines. However, prior to Unicode 7.0, there were a few exceptions, mostly for characters or scripts which are normally written in vertical lines; in those cases, the code charts used to show the characters in the same orientation as in vertical lines. Furthermore, such characters are often rotated when displayed in horizontal lines; figure 3 shows an example of Mongolian text in horizontal lines in which the Mongolian characters are rotated 90 degrees counterclockwise with respect to the code charts prior to Unicode 7.0.

Figure 3. Mongolian text on horizontal lines

The Unicode 7.0 code charts changed the orientation of characters for Mongolian and Phags-pa by rotating counterclockwise so that they match the orientation in horizontal lines. This change makes the code charts more consistent with other scripts in terms of the orientation of characters. It also aligns the code charts with many recent rendering systems such as OpenType, and therefore it is expected to make implementations of the property easier. However, implementations should be aware that underlying rendering systems may not have exactly the same orientation of characters as the code charts.

While this property defines only default orientations compared to the code charts, high-level protocols or applications could combine information provided in a font's tables with the property values to more reliably calculate in which orientation they should render such glyphs, in order to achieve the desired visual result.

4 Tailorings

To facilitate tailorings, this report identifies sets of characters which behave similarly, and for which it can useful to tailor the orientation as a group.

4.1 The brackets

This set contains brackets, which while they appear rotated, are commonly implemented as if they were transformed.

Table 2. The brackets set

00AB
00BB
201C..201F
2039..203A
2045..2046
3008..3011
3014..301B
FE59..FE5E
FF08..FF09
FF3B
FF3D
FF5B
FF5D
FF5F..FF60
FF62..FF63

4.2 The arrows

This set contains arrows.

Table 3. The arrows set

2190..21FF
261A..261F
2794
2798..27AF
27B1..27BE
27F0..27FF
2900..297F
2B00..2B11
2B30..2B4F
2B5A..2BB7
2BEC..2BEF
FFE9..FFEC
1F800..1F80B
1F810..1F847
1F850..1F859
1F860..1F887
1F890..1F8AD

5 Glyphs Changes for Vertical Orientation

Table 4 provides representative glyphs for the horizontal and vertical appearance of characters with the property value Tu and Tr.

The vertical glyphs that are shown in the table are exemplary, and their presence does not imply that font implementations should necessarily support them. Font developers should instead research the vertical glyph conventions for the intended regions to determine whether a vertical glyph is necessary for a particular character, and what the appropriate vertical glyph should be.

The Horizontal column may also specify more than one glyph when regional or other differences exist. Font developers should adhere to regional conventions when determining the appearance of horizontal glyphs.

Table 4. Glyph Changes for Vertical Orientation

Character Horizontal Vertical
U+2329 LEFT-POINTING ANGLE BRACKET
U+232A RIGHT-POINTING ANGLE BRACKET
U+3001 IDEOGRAPHIC COMMA
U+3002 IDEOGRAPHIC FULL STOP
U+3008 LEFT ANGLE BRACKET
U+3009 RIGHT ANGLE BRACKET
U+300A LEFT DOUBLE ANGLE BRACKET
U+300B RIGHT DOUBLE ANGLE BRACKET
U+300C LEFT CORNER BRACKET
U+300D RIGHT CORNER BRACKET
U+300E LEFT WHITE CORNER BRACKET
U+300F RIGHT WHITE CORNER BRACKET
U+3010 LEFT BLACK LENTICULAR BRACKET
U+3011 RIGHT BLACK LENTICULAR BRACKET
U+3014 LEFT TORTOISE SHELL BRACKET
U+3015 RIGHT TORTOISE SHELL BRACKET
U+3016 LEFT WHITE LENTICULAR BRACKET
U+3017 RIGHT WHITE LENTICULAR BRACKET
U+3018 LEFT WHITE TORTOISE SHELL BRACKET
U+3019 RIGHT WHITE TORTOISE SHELL BRACKET
U+301A LEFT WHITE SQUARE BRACKET
U+301B RIGHT WHITE SQUARE BRACKET
U+301C WAVE DASH
U+301D REVERSED DOUBLE PRIME QUOTATION MARK
U+301E DOUBLE PRIME QUOTATION MARK
U+301F LOW DOUBLE PRIME QUOTATION MARK
U+3030 WAVY DASH
U+3041 HIRAGANA LETTER SMALL A
U+3043 HIRAGANA LETTER SMALL I
U+3045 HIRAGANA LETTER SMALL U
U+3047 HIRAGANA LETTER SMALL E
U+3049 HIRAGANA LETTER SMALL O
U+3063 HIRAGANA LETTER SMALL TU
U+3083 HIRAGANA LETTER SMALL YA
U+3085 HIRAGANA LETTER SMALL YU
U+3087 HIRAGANA LETTER SMALL YO
U+308E HIRAGANA LETTER SMALL WA
U+3095 HIRAGANA LETTER SMALL KA
U+3096 HIRAGANA LETTER SMALL KE
U+309B KATAKANA-HIRAGANA VOICED SOUND MARK
U+309C KATAKANA-HIRAGANA SEMI-VOICED SOUND MARK
U+30A0 KATAKANA-HIRAGANA DOUBLE HYPHEN
U+30A1 KATAKANA LETTER SMALL A
U+30A3 KATAKANA LETTER SMALL I
U+30A5 KATAKANA LETTER SMALL U
U+30A7 KATAKANA LETTER SMALL E
U+30A9 KATAKANA LETTER SMALL O
U+30C3 KATAKANA LETTER SMALL TU
U+30E3 KATAKANA LETTER SMALL YA
U+30E5 KATAKANA LETTER SMALL YU
U+30E7 KATAKANA LETTER SMALL YO
U+30EE KATAKANA LETTER SMALL WA
U+30F5 KATAKANA LETTER SMALL KA
U+30F6 KATAKANA LETTER SMALL KE
U+30FC KATAKANA-HIRAGANA PROLONGED SOUND MARK
U+3127 BOPOMOFO LETTER I
U+31F0 KATAKANA LETTER SMALL KU
U+31F1 KATAKANA LETTER SMALL SI
U+31F2 KATAKANA LETTER SMALL SU
U+31F3 KATAKANA LETTER SMALL TO
U+31F4 KATAKANA LETTER SMALL NU
U+31F5 KATAKANA LETTER SMALL HA
U+31F6 KATAKANA LETTER SMALL HI
U+31F7 KATAKANA LETTER SMALL HU
U+31F8 KATAKANA LETTER SMALL HE
U+31F9 KATAKANA LETTER SMALL HO
U+31FA KATAKANA LETTER SMALL MU
U+31FB KATAKANA LETTER SMALL RA
U+31FC KATAKANA LETTER SMALL RI
U+31FD KATAKANA LETTER SMALL RU
U+31FE KATAKANA LETTER SMALL RE
U+31FF KATAKANA LETTER SMALL RO
U+3300 SQUARE APAATO
U+3301 SQUARE ARUHUA
U+3302 SQUARE ANPEA
U+3303 SQUARE AARU
U+3304 SQUARE ININGU
U+3305 SQUARE INTI
U+3306 SQUARE UON
U+3307 SQUARE ESUKUUDO
U+3308 SQUARE EEKAA
U+3309 SQUARE ONSU
U+330A SQUARE OOMU
U+330B SQUARE KAIRI
U+330C SQUARE KARATTO
U+330D SQUARE KARORII
U+330E SQUARE GARON
U+330F SQUARE GANMA
U+3310 SQUARE GIGA
U+3311 SQUARE GINII
U+3312 SQUARE KYURII
U+3313 SQUARE GIRUDAA
U+3314 SQUARE KIRO
U+3315 SQUARE KIROGURAMU
U+3316 SQUARE KIROMEETORU
U+3317 SQUARE KIROWATTO
U+3318 SQUARE GURAMU
U+3319 SQUARE GURAMUTON
U+331A SQUARE KURUZEIRO
U+331B SQUARE KUROONE
U+331C SQUARE KEESU
U+331D SQUARE KORUNA
U+331E SQUARE KOOPO
U+331F SQUARE SAIKURU
U+3320 SQUARE SANTIIMU
U+3321 SQUARE SIRINGU
U+3322 SQUARE SENTI
U+3323 SQUARE SENTO
U+3324 SQUARE DAASU
U+3325 SQUARE DESI
U+3326 SQUARE DORU
U+3327 SQUARE TON
U+3328 SQUARE NANO
U+3329 SQUARE NOTTO
U+332A SQUARE HAITU
U+332B SQUARE PAASENTO
U+332C SQUARE PAATU
U+332D SQUARE BAARERU
U+332E SQUARE PIASUTORU
U+332F SQUARE PIKURU
U+3330 SQUARE PIKO
U+3331 SQUARE BIRU
U+3332 SQUARE HUARADDO
U+3333 SQUARE HUIITO
U+3334 SQUARE BUSSYERU
U+3335 SQUARE HURAN
U+3336 SQUARE HEKUTAARU
U+3337 SQUARE PESO
U+3338 SQUARE PENIHI
U+3339 SQUARE HERUTU
U+333A SQUARE PENSU
U+333B SQUARE PEEZI
U+333C SQUARE BEETA
U+333D SQUARE POINTO
U+333E SQUARE BORUTO
U+333F SQUARE HON
U+3340 SQUARE PONDO
U+3341 SQUARE HOORU
U+3342 SQUARE HOON
U+3343 SQUARE MAIKURO
U+3344 SQUARE MAIRU
U+3345 SQUARE MAHHA
U+3346 SQUARE MARUKU
U+3347 SQUARE MANSYON
U+3348 SQUARE MIKURON
U+3349 SQUARE MIRI
U+334A SQUARE MIRIBAARU
U+334B SQUARE MEGA
U+334C SQUARE MEGATON
U+334D SQUARE MEETORU
U+334E SQUARE YAADO
U+334F SQUARE YAARU
U+3350 SQUARE YUAN
U+3351 SQUARE RITTORU
U+3352 SQUARE RIRA
U+3353 SQUARE RUPII
U+3354 SQUARE RUUBURU
U+3355 SQUARE REMU
U+3356 SQUARE RENTOGEN
U+3357 SQUARE WATTO
U+337B SQUARE ERA NAME HEISEI
U+337C SQUARE ERA NAME SYOUWA
U+337D SQUARE ERA NAME TAISYOU
U+337E SQUARE ERA NAME MEIZI
U+337F SQUARE CORPORATION
U+FE50 SMALL COMMA
U+FE51 SMALL IDEOGRAPHIC COMMA
U+FE52 SMALL FULL STOP
U+FE59 SMALL LEFT PARENTHESIS
U+FE5A SMALL RIGHT PARENTHESIS
U+FE5B SMALL LEFT CURLY BRACKET
U+FE5C SMALL RIGHT CURLY BRACKET
U+FE5D SMALL LEFT TORTOISE SHELL BRACKET
U+FE5E SMALL RIGHT TORTOISE SHELL BRACKET
U+FF01 FULLWIDTH EXCLAMATION MARK
U+FF08 FULLWIDTH LEFT PARENTHESIS
U+FF09 FULLWIDTH RIGHT PARENTHESIS
U+FF0C FULLWIDTH COMMA
U+FF0E FULLWIDTH FULL STOP
U+FF1A FULLWIDTH COLON
U+FF1B FULLWIDTH SEMICOLON
U+FF1F FULLWIDTH QUESTION MARK
U+FF3B FULLWIDTH LEFT SQUARE BRACKET
U+FF3D FULLWIDTH RIGHT SQUARE BRACKET
U+FF3F FULLWIDTH LOW LINE
U+FF5B FULLWIDTH LEFT CURLY BRACKET
U+FF5C FULLWIDTH VERTICAL LINE
U+FF5D FULLWIDTH RIGHT CURLY BRACKET
U+FF5E FULLWIDTH TILDE
U+FF5F FULLWIDTH LEFT WHITE PARENTHESIS
U+FF60 FULLWIDTH RIGHT WHITE PARENTHESIS
U+FFE3 FULLWIDTH MACRON
U+1F200 SQUARE HIRAGANA HOKA
U+1F201 SQUARED KATAKANA KOKO

6 Data File

The data file is in versioned directories under [Data50]. The character repertoire of this revision is the repertoire of Unicode Version 9.0.

Acknowledgments

Thanks to the original editor Eric Muller, and reviewers: Julie Allen, Van Anderson, John Cowan, John Daggett, Mark Davis, Martin Dürst, Elika J. Etemad, Michael Everson, Asmus Freytag, Laurențiu Iancu, Soji Ikeda, Norikazu Ishizu, Nozomu Katō, Yasuo Kida, Ken Lunde, Nat McCully, Shinyu Murakami, Addison Phillips, Roozbeh Pournader, Dwayne Robinson, Kyoko Sato, Hiroshi Takenaka, Bobby Tung, Philippe Verdy, Ken Whistler, Taro Yamamoto, the W3C CSS Working Group, the W3C I18N Interest Group, and the W3C Internationalization Working Group.

References

[Data50] http://www.unicode.org/Public/vertical/revision-17/
[Errata] Updates and Errata
http://www.unicode.org/errata/
[Feedback] http://www.unicode.org/reporting.html
For reporting errors and requesting information online.
[JLREQ] Requirements for Japanese Text layout, W3C Working Group Note
[Reports] Unicode Technical Reports
http://www.unicode.org/reports/
For information on the status and development process for technical reports, and for a list of technical reports.
[UAX29] UAX #29: Unicode Text Segmentation
http://www.unicode.org/reports/tr29/
[UCD] Unicode Character Database
http://www.unicode.org/ucd/
For detailed documentation about the Unicode Character Database, see Unicode Standard Annex #44: Unicode Character Database
http://www.unicode.org/reports/tr44/
[Unicode] The Unicode Standard, Version 9.0.0, (Mountain View, CA: The Unicode Consortium, 2016. ISBN 978-1-936213-13-9
http://www.unicode.org/versions/Unicode9.0.0/
[Versions] Versions of the Unicode Standard
http://www.unicode.org/versions/
For details on the precise contents of each version of the Unicode Standard, and how to cite them.

Modifications

This section indicates the changes introduced by each revision.

Revision 17

Revision 16 being a proposed update, only changes between revisions 15 and 17 are listed here.

Revision 15

Revision 14 being a proposed update, only changes between revisions 13 and 15 are listed here.

Revision 13

Revision 12 being a proposed update, only changes between revisions 11 and 13 are listed here.

Revision 11

Revision 10

Revision 9

Revision 8

Editorial changes.

Revision 7

Revision 6

Data updated. No change to the text.

Revision 5

Revision 4

Revision 3

Revision 2

Revision 1

First working draft.