字体资源

字体资源定义可在应用中使用的自定义字体。字体可以是单个字体文件,也可以是字体文件的集合(称为字体系列),并以 XML 定义。

另请参阅如何定义XML 中的字体或改用可下载字体

捆绑字体

您可以将字体捆绑为应用中的资源。字体在R文件中编译,并作为资源自动在系统中可用。然后,您可以借助font资源类型访问这些字体。

文件位置
res/font/filename.ttf (.ttf.ttc.otf.xml)
文件名用作资源 ID。
资源引用
在 XML 中:@[package:]font/font_name
语法
<?xml version="1.0" encoding="utf-8"?>
<font-family>
  <font
    android:font="@[package:]font/font_to_include"
    android:fontStyle=["normal" | "italic"]
    android:fontWeight="weight_value" />
</font-family>
元素
<font-family>
必需。这必须是根节点。

无属性。

<font>
定义字体系列中的单个字体。不包含子节点。

属性

android:fontStyle
关键字。定义字体样式。将字体加载到字体堆栈时会使用此属性,并覆盖字体标头表中的任何样式信息。如果您未指定此属性,则应用将使用字体标头表中的值。常量值是normalitalic
android:fontWeight
整数。字体的粗细。将字体加载到字体堆栈时会使用此属性,并覆盖字体标头表中的任何粗细信息。属性值必须是 100 到 900(含)之间的 100 的倍数。如果您未指定此属性,则应用将使用字体标头表中的值。最常用的值是常规粗细的 400 和粗体的 700。
示例
保存在 res/font/lobster.xml 中的 XML 文件
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:android="http://schemas.android.com/apk/res/android">
    <font
        android:fontStyle="normal"
        android:fontWeight="400"
        android:font="@font/lobster_regular" />
    <font
        android:fontStyle="italic"
        android:fontWeight="400"
        android:font="@font/lobster_italic" />
</font-family>

保存在 res/layout/ 中的 XML 文件,它将字体应用于 TextView

<?xml version="1.0" encoding="utf-8"?>
<EditText
    android:fontFamily="@font/lobster"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Hello, World!" />

可下载字体

可下载字体资源定义可在应用中使用的自定义字体。此字体本身并不在应用中可用。相反,字体是从字体提供程序检索的。

文件位置
res/font/filename.xml 文件名是资源 ID。
资源引用
在 XML 中:@[package:]font/font_name
语法
<?xml version="1.0" encoding="utf-8"?>
<font-family
    android:fontProviderAuthority="authority"
    android:fontProviderPackage="package"
    android:fontProviderQuery="query"
    android:fontProviderCerts="@[package:]array/array_resource" />
元素
<font-family>
必需。这必须是根节点。

属性

android:fontProviderAuthority
字符串必需。定义字体请求的字体提供程序的权限。
android:fontProviderPackage
字符串必需。要用于请求的字体提供程序的包名称。这用于验证提供程序的身份。
android:fontProviderQuery
字符串必需。字体的字符串查询。请参阅您的字体提供程序的文档以了解此字符串的格式。
android:fontProviderCerts
数组资源必需。定义用于签署此提供程序的证书的哈希集。这用于验证提供程序的身份,并且仅在提供程序不是系统映像的一部分时才需要。该值可以指向单个列表(字符串数组资源)或列表的列表(数组资源),其中每个单个列表代表一个签名哈希集合。请参阅您的字体提供程序的文档以了解这些值。
示例
保存在 res/font/lobster.xml 中的 XML 文件
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:android="http://schemas.android.com/apk/res/android"
    android:fontProviderAuthority="com.example.fontprovider.authority"
    android:fontProviderPackage="com.example.fontprovider"
    android:fontProviderQuery="Lobster"
    android:fontProviderCerts="@array/certs">
</font-family>

保存在 res/values/ 中的 XML 文件,该文件定义了证书数组

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string-array name="certs">
      <item>MIIEqDCCA5CgAwIBAgIJA071MA0GCSqGSIb3DQEBBAUAMIGUMQsww...</item>
    </string-array>
</resources>

保存在 res/layout/ 中的 XML 文件,它将字体应用于 TextView

<?xml version="1.0" encoding="utf-8"?>
<EditText
    android:fontFamily="@font/lobster"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="Hello, World!" />