Od 27 marca 2025 r. zalecamy używanie android-latest-release
zamiast aosp-main
do kompilowania i wspołtworzenia AOSP. Więcej informacji znajdziesz w artykule o zmianach w AOSP.
Dodawanie czcionek niestandardowych
Zadbaj o dobrą organizację dzięki kolekcji
Zapisuj i kategoryzuj treści zgodnie ze swoimi preferencjami.
Teraz możesz używać nakładek zasobów w czasie wykonywania (RRO) do zmiany czcionek. Dodając czcionki niestandardowe, aby utworzyć pakiet czcionek, możesz używać czcionek w motywach i stosować niestandardowe zmiany za pomocą plików RRO.
Wykonaj te czynności:
Przykładową strukturę plików i pliki znajdziesz w pliku custom-fonts.zip.
Pobierz i wyodrębnij ten plik lokalnie na potrzeby własne.
Tworzenie pakietu czcionek
Aby utworzyć pakiet czcionek:
- Dodaj wszystkie pliki czcionki
ttf
do pakietu czcionek na partycji vendor
. Przykład:
vendor/[oem]/fonts/[oem]-sans/
- Utwórz plik
Android.mk
dla pakietu czcionek. Przykład:
vendor/[oem]/fonts/[oem]-[fontname]/Android.mk
- Upewnij się, że moduł zostanie zainstalowany na partycji
product
w folderze etc
. Aby to zrobić, sprawdź, czy moduł ma te flagi:
LOCAL_MODULE_CLASS := ETC
LOCAL_PRODUCT_MODULE := true
LOCAL_MODULE_PATH := $(TARGET_OUT_PRODUCT)/fonts
Podany powyżej przykładowy kod ilustruje pełną definicję modułu pakietu czcionek.
- Utwórz plik o nazwie
fonts.mk
dla pakietu czcionek, a potem dodaj do niego pliki ttf
.PRODUCT_PACKAGES
Przykład:
vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk
Przykład:
PRODUCT_PACKAGES := \
[font name].ttf \
Tworzenie pakietu nakładki na urządzenie
- Dodaj do kompilacji moduł o nazwie
fonts_customization.xml
.
Ten moduł wskazuje plik fonts_customization.xml
zawierający rodziny czcionek i wywołuje pliki make wszystkich pakietów czcionek. Przykład:
vendor/[oem]/[device]_overlay/fonts/Android.mk
- Utwórz rodziny czcionek:
vendor/[oem]/[device]_overlay/fonts/fonts_customization.xml
Poziom główny pliku musi być tagiem fonts-modification
. Dodaj rodziny czcionek dla każdego pakietu czcionek w ramach tego elementu. Dodatkowo dodaj customizationType="new-named-family"
do każdej rodziny czcionek i upewnij się, że każda z nich ma atrybut name
. Ta nazwa jest później używana do uzyskiwania dostępu do rodziny czcionek. Ten plik musi zostać dodany do modułu fonts_customizations.xml
zdefiniowanego wcześniej w pliku Android.mk
.
Podany powyżej przykład zawiera prawidłowy plik fonts_customization.xml
.
- Utwórz
fonts.mk
. Przykład:
vendor/[oem]/[device]_overlay/fonts/fonts.mk
- Dodaj
fonts_customization.xml
pod flagą PRODUCT_PACKAGES
.
- Wywołaj każdy z utworzonych wcześniej pakietów czcionek.
$(call inherit-product-if-exists, vendor/[oem]/fonts/[oem]-[fontname]/fonts.mk)
- Dodaj moduł czcionki do kompilacji w sekcji
PRODUCT_PACKAGES
, a następnie ponownie skompiluj.
Czcionki zostaną zainstalowane w systemie.
- Sprawdź, czy pliki czcionek
ttf
znajdują się w folderze /product/fonts
na urządzeniu.
- Sprawdź, czy na urządzeniu
fonts_customization.xml
jest w pozycji /product/etc/
.
Używanie nowej rodziny czcionek systemowych
Aby korzystać z nowej rodziny czcionek systemowych:
<style name="customstyle">
<item name="android:fontFamily">customfontfamily</item>
</style>
Treść strony i umieszczone na niej fragmenty kodu podlegają licencjom opisanym w Licencji na treści. Java i OpenJDK są znakami towarowymi lub zastrzeżonymi znakami towarowymi należącymi do firmy Oracle lub jej podmiotów stowarzyszonych.
Ostatnia aktualizacja: 2025-08-10 UTC.
[[["Łatwo zrozumieć","easyToUnderstand","thumb-up"],["Rozwiązało to mój problem","solvedMyProblem","thumb-up"],["Inne","otherUp","thumb-up"]],[["Brak potrzebnych mi informacji","missingTheInformationINeed","thumb-down"],["Zbyt skomplikowane / zbyt wiele czynności do wykonania","tooComplicatedTooManySteps","thumb-down"],["Nieaktualne treści","outOfDate","thumb-down"],["Problem z tłumaczeniem","translationIssue","thumb-down"],["Problem z przykładami/kodem","samplesCodeIssue","thumb-down"],["Inne","otherDown","thumb-down"]],["Ostatnia aktualizacja: 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```"]]