ntg-context - mailing list for ConTeXt users
 help / color / mirror / Atom feed
From: Georg Duffner <g.duffner@gmail.com>
To: ntg-context@ntg.nl
Subject: Problems with contextual kerning
Date: Tue, 15 Jan 2013 10:08:26 +0100	[thread overview]
Message-ID: <50F51C8A.8010208@gmail.com> (raw)

[-- Attachment #1: Type: text/plain, Size: 2058 bytes --]

Hello,

In EB Garamond I’ve implemented decomposition for all composed glyphs. 
For uppercase greek I had to use contextual kerning rules: accents like 
grave or acute and aspiration marks are placed left of the letter, so 
the glyph has to be placed more to the right and its advance increased. 
The code in the feature file looks like this:
    pos [ Epsilon Eta Iota Rho ]' <79 0 79 0> @grk_tlAcc1;

Iota adscriptum needs extra space on the right of the base glyph, so 
there are position rules for that too:
    pos Eta' <0 0 200 0> uni0345.cap1;
and
    pos Eta' <79 0 279 0> uni0345.cap1 @grk_tlAcc1;

Context (and LuaLaTeX too) doesn’t do the positioning correctly. I’ve 
prepared a minimal example of uppercase etas. The first row without 
decomposition, the second decomposed, the third with alternate 
uni0345.cap1 (iota adscriptum). The first two should look exactly the same:

\usemodule[simplefonts]
\setmainfont[ebgaramond]
\definefontfeature[decomp][ss20=yes]
\definefontfeature[iota1][ss20=yes,cv81=1]
\starttext
ἨἩἪἫἬἭἮἯᾘᾙᾚᾛᾜᾝᾞᾟῌ \par
\addff{decomp}ἨἩἪἫἬἭἮἯᾘᾙᾚᾛᾜᾝᾞᾟῌ \par
\addff{iota1}ἨἩἪἫἬἭἮἯᾘᾙᾚᾛᾜᾝᾞᾟῌ \par
\stoptext

I use ss20 for full decomposition because it should be selected by the 
user explicitly only when needed, while ccmp should be enabled by 
default. The attached ctx_test.pdf shows its output. The font used can 
be downloaded at 
http://georgduffner.at/ebgaramond/fonts/EBGaramond12-Regular.otf. For 
comparison, there’s a test page at 
http://georgduffner.at/ebgaramond/etatests.html – current Firefox and 
Chromium show what is expected.

There’s a second testfile at 
https://github.com/georgd/EB-Garamond/blob/master/tests/context_greektests.tex 
with the complete Unicode block of greek polyphonic characters, its pdf 
output is attached to this mail too, a comparison html page is at 
http://georgduffner.at/ebgaramond/greektests.html

Best regards,
Georg

[-- Attachment #2: ctx_test.pdf --]
[-- Type: application/pdf, Size: 6461 bytes --]

[-- Attachment #3: context_greektests.pdf --]
[-- Type: application/pdf, Size: 41866 bytes --]

[-- Attachment #4: Type: text/plain, Size: 485 bytes --]

___________________________________________________________________________________
If your question is of interest to others as well, please add an entry to the Wiki!

maillist : ntg-context@ntg.nl / http://www.ntg.nl/mailman/listinfo/ntg-context
webpage  : http://www.pragma-ade.nl / http://tex.aanhet.net
archive  : http://foundry.supelec.fr/projects/contextrev/
wiki     : http://contextgarden.net
___________________________________________________________________________________

                 reply	other threads:[~2013-01-15  9:08 UTC|newest]

Thread overview: [no followups] expand[flat|nested]  mbox.gz  Atom feed

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50F51C8A.8010208@gmail.com \
    --to=g.duffner@gmail.com \
    --cc=ntg-context@ntg.nl \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).