Начиная с 27 марта 2025 г. мы рекомендуем использовать android-latest-release
вместо aosp-main
для создания и участия в AOSP. Дополнительные сведения см. в разделе Изменения в AOSP .
Добавить пользовательские шрифты
Оптимизируйте свои подборки
Сохраняйте и классифицируйте контент в соответствии со своими настройками.
Теперь вы можете использовать наложения ресурсов времени выполнения (RRO) для изменения шрифтов. Добавляя пользовательские шрифты для создания пакета шрифтов, вы можете использовать шрифты в темах и использовать RRO для применения настроек.
Выполните следующие задачи:
Примеры файловой структуры и примеры файлов представлены в файле custom-fonts.zip . Загрузите и затем извлеките этот файл локально для собственного использования.
Создать пакет шрифтов
Чтобы создать пакет шрифтов:
- Добавьте все файлы шрифтов
ttf
в пакет шрифтов в разделе vendor
. Например: vendor/[oem]/fonts/[oem]-sans/
- Создайте файл
Android.mk
для пакета шрифтов. Например: vendor/[oem]/fonts/[oem]-[fontname]/Android.mk
- Убедитесь, что модуль будет установлен в раздел
product
в папке etc
Для этого убедитесь, что модуль имеет следующие флаги:LOCAL_MODULE_CLASS := ETC
LOCAL_PRODUCT_MODULE := true
LOCAL_MODULE_PATH := $(TARGET_OUT_PRODUCT)/fonts
Приведенный выше пример кода иллюстрирует полное определение модуля пакета шрифтов.
- Создайте файл с именем
fonts.mk
для пакета шрифтов, а затем добавьте файлы шрифтов ttf
в PRODUCT_PACKAGES
. Например: vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk
Например:
PRODUCT_PACKAGES := \
[font name].ttf \
Создание пакета наложения устройств
- Создайте модуль с именем
fonts_customization.xml
, который будет добавлен в сборку. Этот модуль указывает на файл fonts_customization.xml
, содержащий семейства шрифтов, и вызывает файлы make всех пакетов шрифтов. Например: vendor/[oem]/[device]_overlay/fonts/Android.mk
- Создайте семейства шрифтов:
vendor/[oem]/[device]_overlay/fonts/fonts_customization.xml
Корневым уровнем файла должен быть тег fonts-modification
. Добавьте семейства шрифтов для каждого пакета шрифтов в этом элементе. Кроме того, добавьте customizationType="new-named-family"
к каждому семейству шрифтов и убедитесь, что у каждого есть атрибут name
. Это имя используется позже для доступа к семейству шрифтов. Этот файл необходимо добавить в модуль fonts_customizations.xml
, определенный ранее в Android.mk
.
Приведенный выше образец содержит действительный файл fonts_customization.xml
.
- Создайте
fonts.mk
. Например: vendor/[oem]/[device]_overlay/fonts/fonts.mk
- Добавьте
fonts_customization.xml
под флагом PRODUCT_PACKAGES
. - Вызовите каждый из ранее созданных пакетов шрифтов.
$(call inherit-product-if-exists, vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk)
- Добавьте модуль шрифта в сборку в разделе
PRODUCT_PACKAGES
, а затем пересоберите. Шрифты будут установлены в систему. - Убедитесь, что файлы шрифтов
ttf
находятся в папке /product/fonts
на устройстве. - Убедитесь, что
fonts_customization.xml
находится в каталоге /product/etc/
на устройстве.
Используйте новое семейство системных шрифтов
Чтобы использовать новое семейство системных шрифтов:
<style name="customstyle">
<item name="android:fontFamily">customfontfamily</item>
</style>
Контент и образцы кода на этой странице предоставлены по лицензиям. Java и OpenJDK – это зарегистрированные товарные знаки корпорации Oracle и ее аффилированных лиц.
Последнее обновление: 2025-08-10 UTC.
[[["Прост для понимания","easyToUnderstand","thumb-up"],["Помог мне решить мою проблему","solvedMyProblem","thumb-up"],["Другое","otherUp","thumb-up"]],[["Отсутствует нужная мне информация","missingTheInformationINeed","thumb-down"],["Слишком сложен/слишком много шагов","tooComplicatedTooManySteps","thumb-down"],["Устарел","outOfDate","thumb-down"],["Проблема с переводом текста","translationIssue","thumb-down"],["Проблемы образцов/кода","samplesCodeIssue","thumb-down"],["Другое","otherDown","thumb-down"]],["Последнее обновление: 2025-08-10 UTC."],[],[],null,["# Add custom fonts\n\nYou can now use runtime resource overlays (RROs) to change fonts. By adding custom\nfonts to make a font package, you can use fonts in themes and use RROs to apply the\ncustomizations.\n\nComplete these tasks:\n\n- [Make a font package](/docs/automotive/hmi/car_ui/fonts#make)\n- [Create a device overlay package](/docs/automotive/hmi/car_ui/fonts#create)\n- [Use the added system fonts family](/docs/automotive/hmi/car_ui/fonts#use)\n\nA sample file structure and sample files are provided in\n[custom-fonts.zip](/static/docs/automotive/hmi/car_ui/custom-fonts.zip).\nDownload and then extract this file locally for your own use.\n\nMake a font package\n-------------------\n\nTo make a font package:\n\n1. Add all the font `ttf` files to the font package in the `vendor` partition. For example:\n\n `vendor/[oem]/fonts/[oem]-sans/`\n2. Create the `Android.mk` file for the font package. For example:\n\n `vendor/[oem]/fonts/[oem]-[fontname]/Android.mk`\n3. Make sure the module will be installed in the `product` partition in the `etc` folder. To do so, confirm the module has the following flags: \n\n ```makefile\n LOCAL_MODULE_CLASS := ETC\n LOCAL_PRODUCT_MODULE := true\n LOCAL_MODULE_PATH := $(TARGET_OUT_PRODUCT)/fonts\n ```\n\n The sample code provided above illustrates a complete definition of a font package module.\n4. Create a file named `fonts.mk` for the font package and then add the font `ttf` files to `PRODUCT_PACKAGES`. For example:\n\n `vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk`\n\n For example: \n\n ```objective-c\n PRODUCT_PACKAGES := \\\n [font name].ttf \\\n ```\n\nCreate a device overlay package\n-------------------------------\n\n1. Make a module called `fonts_customization.xml` to be added to the build. This module points to the `fonts_customization.xml` file that contains the font families and calls the make files of all the font packages. For example:\n\n `vendor/[oem]/[device]_overlay/fonts/Android.mk`\n2. Create the font families: `vendor/[oem]/[device]_overlay/fonts/fonts_customization.xml`\n\n The root level of the file must be a `fonts-modification` tag. Add\n font families for each of the font packages under this element. In addition, add\n `customizationType=\"new-named-family\"` to every font family, and make\n sure each has a `name` attribute. This name is used later to access the\n font family. This file must be added to the `fonts_customizations.xml`\n module defined previously in `Android.mk`.\n\n The sample provided above contains a valid `fonts_customization.xml` file.\n3. Create `fonts.mk`. For example:\n\n `vendor/[oem]/[device]_overlay/fonts/fonts.mk`\n4. Add `fonts_customization.xml` under the `PRODUCT_PACKAGES` flag.\n5. Call into each of the previously created font packages.\n `$(call inherit-product-if-exists, vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk)`\n\n6. Add the font module to the build under `PRODUCT_PACKAGES` and then rebuild. The fonts will be installed on the system.\n7. Verify that the `ttf` fonts files are in the `/product/fonts` folder on the device.\n8. Verify that `fonts_customization.xml` is in `/product/etc/` on the device.\n\nUse the new system fonts family\n-------------------------------\n\nTo use the new system fonts family: \n\n```text\n\u003cstyle name=\"customstyle\"\u003e\n \u003citem name=\"android:fontFamily\"\u003ecustomfontfamily\u003c/item\u003e\n\u003c/style\u003e\n```"]]