字体资源

字体资源定义了您可以在应用中使用的自定义字体。字体可以是单个字体文件,也可以是字体文件的集合,称为字体系列,并以 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!" />