Combining character

In digital typography, combining characters are characters that are intended to modify other characters. The most common combining characters in the Latin script are the combining diacritical marks (including combining accents).

Cyrillic Y combined with breve gives ў.

Unicode also contains many precomposed characters, so that in many cases it is possible to use both combining diacritics and precomposed characters, at the user's or application's choice. This leads to a requirement to perform Unicode normalization before comparing two Unicode strings and to carefully design encoding converters to correctly map all of the valid ways to represent a character in Unicode to a legacy encoding to avoid data loss.[1]

In Unicode, the main block of combining diacritics for European languages and the International Phonetic Alphabet is U+0300–U+036F. Combining diacritical marks are also present in many other blocks of Unicode characters. In Unicode, diacritics are always added after the main character (in contrast to some older combining character sets such as ANSEL), and it is possible to add several diacritics to the same character, including stacked diacritics above and below, though some systems may not render these well.

Unicode ranges

The following blocks are dedicated specifically to combining characters:

  • Combining Diacritical Marks (0300–036F), since version 1.0, with modifications in subsequent versions down to 4.1
  • Combining Diacritical Marks Extended (1AB0–1AFF), version 7.0
  • Combining Diacritical Marks Supplement (1DC0–1DFF), versions 4.1 to 5.2
  • Combining Diacritical Marks for Symbols (20D0–20FF), since version 1.0, with modifications in subsequent versions down to 5.1
  • Combining Half Marks (FE20–FE2F), versions 1.0, with modifications in subsequent versions down to 8.0

Combining characters are not limited to these blocks; for instance, the combining dakuten (U+3099) and combining handakuten (U+309A) are in the Hiragana block, the Devanagari block contains combining vowel signs and other marks for use with that script, and so forth. Combining characters are assigned the Unicode major category "M" ("Mark").

Combining Diacritical Marks[1]
Official Unicode Consortium code chart (PDF)
 0123456789ABCDEF
U+030x ̀ ́ ̂ ̃ ̄ ̅ ̆ ̇ ̈ ̉ ̊ ̋ ̌ ̍ ̎ ̏
U+031x ̐ ̑ ̒ ̓ ̔ ̕ ̖ ̗ ̘ ̙ ̚ ̛ ̜ ̝ ̞ ̟
U+032x ̠ ̡ ̢ ̣ ̤ ̥ ̦ ̧ ̨ ̩ ̪ ̫ ̬ ̭ ̮ ̯
U+033x ̰ ̱ ̲ ̳ ̴ ̵ ̶ ̷ ̸ ̹ ̺ ̻ ̼ ̽ ̾ ̿
U+034x ̀ ́ ͂ ̓ ̈́ ͅ ͆ ͇ ͈ ͉ ͊ ͋ ͌ ͍ ͎  CGJ 
U+035x ͐ ͑ ͒ ͓ ͔ ͕ ͖ ͗ ͘ ͙ ͚ ͛ ͜ ͝ ͞ ͟
U+036x ͠ ͡ ͢ ͣ ͤ ͥ ͦ ͧ ͨ ͩ ͪ ͫ ͬ ͭ ͮ ͯ
Notes
1.^ As of Unicode version 13.0

Codepoints U+032A and U+0346034A are IPA symbols:

Codepoints U+034B034E are IPA diacritics for disordered speech:

  • U+034B ◌͋: nasal escape
  • U+034C ◌͌: velopharyngeal friction
  • U+034D ◌͍: labial spreading
  • U+034E ◌͎: whistled articulation

U+034F is the "combining grapheme joiner" (CGJ) and has no visible glyph.

Codepoints U+035C0362 are double diacritics, diacritic signs placed across two letters.

Codepoints U+0363036F are medieval superscript letter diacritics, letters written directly above other letters appearing in medieval Germanic manuscripts, but in some instances in use until as late as the 19th century. For example, U+0364 is an e written above the preceding letter, to be used for (Early) New High German umlaut notation, such as for Modern German ü.

Combining Diacritical Marks Extended[1][2]
Official Unicode Consortium code chart (PDF)
 0123456789ABCDEF
U+1ABx ᪿ
U+1ACx
U+1ADx
U+1AEx
U+1AFx
Notes
1.^ As of Unicode version 13.0
2.^ Grey areas indicate non-assigned code points
Combining Diacritical Marks Supplement[1][2]
Official Unicode Consortium code chart (PDF)
 0123456789ABCDEF
U+1DCx
U+1DDx
U+1DEx
U+1DFx ᷿
Notes
1.^ As of Unicode version 13.0
2.^ Grey area indicates non-assigned code point
Combining Diacritical Marks for Symbols[1][2]
Official Unicode Consortium code chart (PDF)
 0123456789ABCDEF
U+20Dx
U+20Ex
U+20Fx
Notes
1.^ As of Unicode version 13.0
2.^ Grey areas indicate non-assigned code points
Combining Half Marks[1]
Official Unicode Consortium code chart (PDF)
 0123456789ABCDEF
U+FE2x
Notes
1.^ As of Unicode version 13.0

OpenType

OpenType has the ccmp "feature tag" to define glyphs that are compositions or decompositions involving combining characters, the mark tag to define the positioning of combining characters onto base glyph, and mkmk for the positionings of combining characters onto each other.

Zalgo text

Zalgo text.

Combining characters have been used to create so-called "Zalgo text", which is text that appears "corrupted" or "creepy" due to an overuse of diacritics. This causes the text to extend vertically, overlapping other text.[2]

gollark: It's off by ONE SECOND per DAY!
gollark: I would really like one for my watch because its quartz-or-whatever oscillator keeps time terribly.
gollark: You can get chip-scale atomic clocks now apparently.
gollark: RTL-SDRs are cool and obviously an important\* and useful\*\* thing for calculators.
gollark: Although I do have a µSD/compact flash/SD/a bunch of other cards reader, and RTL-SDR.

See also

  • Dead key
  • Spacing Modifier Letters which shouldn't combine (although they do erroneously on some implementations where a developer has confused "combining" with "modifier")

Notes

  1. For example, when converting between windows-1258 and VISCII, the former uses combining diacritics whilst the latter has a large selection of precomposed characters so a converter using a simple mapping between code values and Unicode code points will corrupt text when converting between them.
  2. Korpela, Jukka K. "How does Zalgo text work?". Stack Overflow. Retrieved 11 April 2019.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.