2013-07-08 111 views
3

我有一个Qt 4.8应用程序,它的前端UI全部通过QML在QDeclarativeView中完成。QML字体/样式命名问题:Mac/Linux平台差异

在(原)Linux版本的应用程序,也有通过指定

font.family: "ReykjavikOne OT AGauge" 

font.family: "ReykjavikOne OT CGauge" 

这些工作按预期一对夫妇它在文本的项目将使用QML字体(CGauge是一种胖胖的大胆版本)。

但是,在Mac端口,这两个这些似乎回落到一些丑陋的默认回退无字体。但是,使用

font.family: "ReykjavikOne OT" 

并获得 “AGauge”。

在Linux系统中,fc-list | grep ReykjavikOne让我

/usr/share/fonts/opentype/ReykjavikOneCGaugeItalic.otf: ReykjavikOne OT,ReykjavikOne OT CGaugeItalic:style=CGaugeItalic 
/usr/share/fonts/opentype/ReykjavikOneCGauge.otf: ReykjavikOne OT,ReykjavikOne OT CGauge:style=CGauge 
/usr/share/fonts/opentype/ReykjavikOneAGauge.otf: ReykjavikOne OT,ReykjavikOne OT AGauge:style=AGauge 
/usr/share/fonts/opentype/ReykjavikOneAGaugeItalic.otf: ReykjavikOne OT,ReykjavikOne OT AGaugeItalic:style=AGaugeItalic 

,并在Mac上,FontBook显示列为下一个 “ReykjavikOne OT” 项子项4组的样式。 CGauge字体似乎在Mac上的其他应用程序中完全可用,所以我认为这是Qt/QML特有的问题。

似乎没有任何QML文本/字体机制(至少我没有发现),通过它我可以选择样式名称为“CGauge”的字体样式。乱七八糟的粗体/字体重量似乎让我更大胆的AGauge,或默认字体。

对于QML RichText内容也是如此。 <style></style>包含font-family: 'ReykjavikOne OT CGauge'元素的文本在Linux上正常工作,但在Mac上它恢复为后备字体,'ReykjavikOne OT'是最好的,可以获得AGauge。 (增加一个font-weight: bold;确实会得到一个大胆的AGauge,但是CGauge显然更胖)。

Mac和Linux(Debian/Wheezy)系统都有从相同的.otf文件安装的字体。

对于这个问题,我最大的希望是什么,让字体的CGauge样式在Mac上按照预期显示? (注意,我是字体和Mac的新手)。

回答

6

恐怕核心问题是字体元数据。 AGauge/CGauge位不应该泄露在字体名称中。尽管许多字体编辑器让字体作者在面部(样式)字段中放置了他们想要的任何字符串,但实际上,如果您希望应用程序能够理解它们,则存在严格的规则。

几年前,微软对其应用程序使用类似css的样式进行了认真的研究,并被所有具有创造性命名的字体咬伤。所以他们写了关于应用中实际工作的严格指导方针,包括来自Adobe和其他主要字体播放器的买入(请注意,Microsoft是OpenType规范的共同维护者,而uniscribe几乎是参考OpenType引擎)。您的字体不尊重这些准则

请阅读Microsoft白皮书。它描述了Microsoft管理打捞的字体类型,使用的启发式以及启发式生成的规范名称。一个好的字体不会触及这些启发式,因为它的命名已经使用规范形式,不需要更正。一个糟糕的字体最多会在微软平台上默默无误地更正其命名。在其他平台(如Linux或OSX)中,不会有任何更正,所以野生命名会产生非常大的结果,包括您遇到的故障。

https://blogs.msdn.com/cfs-filesystemfile.ashx/__key/communityserver-components-postattachments/00-02-24-90-36/WPF-Font-Selection-Model.pdf http://blogs.adobe.com/typblography/typotechnica2007/Font%20names.pdf

例如,您的fontconfig输出显示ReykjavikOneCGauge.otf作为姓氏声明或者ReykjavikOne OT或ReykjavikOne OT CGauge(以优先顺序),CGauge脸部名。根据微软的白皮书,CGauge不是一个有效的脸名,所以字体应该使用ReykjavikOne OT CGauge作为系列名称,并从相应的WWS(Weight Width Slope)限定符中构建一个脸名。不幸的是,它宣称ReykjavikOne OT(没有CGauge)为主要名称,而CGauge为无用的面名。

需要注意的是较旧的软件不读这些新的OpenType命名字段,所以不管什么样的作者提出在那里,它可以排序的工作,只要你的字体堆栈是足够古。

+0

谢谢!迷人! – timday

2

我设法在Debian系统中fontforge打开ReykjavikOneCGauge.otf文件,改变字体名称/字体系列名称的任何提及到ReykjavikCGauge,它的这种字体是“正常”的风格轮这个工作,再生一个新的ReykjavikCGauge.otf并将其安装在Debian和Mac系统上。在Mac上,它现在显示为与原始字体完全分离的字体,并使用font-family:ReykjavikCGauge现在可以按预期访问它。

+2

用字体OpenSans为我工作。 只需将所有样式编辑为“正常”并为其指定新名称即可。 – Haselnussstrauch