フォント属性とグリフメトリクスの探索

Beginner

This tutorial is from open-source community. Access the source code

はじめに

この実験では、グローバルなフォントプロパティを表す.FT2Fontオブジェクトの属性について学びます。また、.load_charによって返される.Glyphオブジェクトを使って個々の文字のメトリックをどのように使うかも学びます。

VM のヒント

VM の起動が完了したら、左上隅をクリックしてノートブックタブに切り替え、Jupyter Notebook を使って練習しましょう。

時々、Jupyter Notebook が読み込み終わるまで数秒待つ必要がある場合があります。Jupyter Notebook の制限により、操作の検証を自動化することはできません。

学習中に問題に遭遇した場合は、Labby にお問い合わせください。セッション後にフィードバックを提供してください。すぐに問題を解決いたします。

必要なライブラリをインポートする

このステップでは、必要なライブラリをインポートします。

import os
import matplotlib
import matplotlib.ft2font as ft

フォントを読み込む

このステップでは、使用するフォントを読み込みます。Matplotlib に同梱されているフォントを使用します。

font = ft.FT2Font(
    os.path.join(matplotlib.get_data_path(),
                 'fonts/ttf/DejaVuSans-Oblique.ttf'))

フォントのプロパティを表示する

このステップでは、フォントのプロパティを表示します。

print('Num faces:  ', font.num_faces)        ## ファイル内のフェイス数
print('Num glyphs: ', font.num_glyphs)       ## フェイス内のグリフ数
print('Family name:', font.family_name)      ## フェイスのファミリ名
print('Style name: ', font.style_name)       ## フェイスのスタイル名
print('PS name:    ', font.postscript_name)  ## ポストスクリプト名
print('Num fixed:  ', font.num_fixed_sizes)  ## 埋め込まれたビットマップの数

追加のフォントプロパティを表示する

このステップでは、フェイスが拡大可能な場合にのみ利用可能な追加のフォントプロパティを表示します。

if font.scalable:
    ## フェイスのグローバルな境界ボックス (xmin, ymin, xmax, ymax)
    print('Bbox:               ', font.bbox)
    ## EM で覆われるフォント単位の数
    print('EM:                 ', font.units_per_EM)
    ## 26.6 単位での昇格部
    print('Ascender:           ', font.ascender)
    ## 26.6 単位での降格部
    print('Descender:          ', font.descender)
    ## 26.6 単位での高さ
    print('Height:             ', font.height)
    ## 最大水平カーソル進行量
    print('Max adv width:      ', font.max_advance_width)
    ## 垂直レイアウトの場合も同様
    print('Max adv height:     ', font.max_advance_height)
    ## 下線の垂直位置
    print('Underline pos:      ', font.underline_position)
    ## 下線の垂直太さ
    print('Underline thickness:', font.underline_thickness)

フォントスタイルを表示する

このステップでは、フォントスタイルを表示します。

for style in ('Italic',
              'Bold',
              'Scalable',
              'Fixed sizes',
              'Fixed width',
              'SFNT',
              'Horizontal',
              'Vertical',
              'Kerning',
              'Fast glyphs',
              'Multiple masters',
              'Glyph names',
              'External stream'):
    bitpos = getattr(ft, style.replace(' ', '_').upper()) - 1
    print(f"{style+':':17}", bool(font.style_flags & (1 << bitpos)))

まとめ

この実験では、グローバルなフォントプロパティを記述する.FT2Fontオブジェクトの属性について学びました。また、.load_charによって返される.Glyphオブジェクトを使用して個々の文字メトリクスをどのように使用するかも学びました。