Funkcja czcionek do pobrania umożliwia interfejsom API żądanie czcionek z aplikacji dostawcy zamiast dołączania plików do aplikacji lub pobierania czcionek przez aplikację. Czcionki do pobrania są dostępne na urządzeniach z Androidem w wersji 14 lub nowszej dzięki bibliotece AndroidX Core.
Czcionki do pobrania oferują następujące korzyści:
Zmniejszają rozmiar aplikacji, co zwiększa skuteczność instalacji.
Poprawiają ogólną kondycję systemu, ponieważ wiele aplikacji może udostępniać tę samą czcionkę za pomocą
dostawcy. Dzięki temu użytkownicy oszczędzają komórkową transmisję danych, pamięć telefonu i miejsce na dysku. W tym modelu czcionka jest pobierana przez sieć w razie potrzeby.
Aby zapoznać się z czcionkami do pobrania, zobacz
przykładową aplikację
DownloadableFonts.
Jak działają czcionki do pobrania?
Dostawca czcionek to aplikacja, która pobiera czcionki i zapisuje je w pamięci podręcznej lokalnie, aby inne aplikacje mogły żądać i udostępniać czcionki. Proces ten ilustruje rysunek poniżej.
Rysunek 1. Proces czcionek do pobrania.
Podstawy
Funkcji czcionek do pobrania możesz używać na te sposoby, które zostały szczegółowo opisane w dalszych sekcjach:
Korzystanie z czcionek do pobrania w Androidzie Studio i Usługach Google Play
Możesz skonfigurować aplikację tak, aby pobierała czcionki za pomocą Androida Studio w wersji 3.0 lub nowszej. Aby ułatwić Ci rozpoczęcie pracy z funkcjami czcionek do pobrania, możesz użyć dostawcy czcionek z Usług Google Play.
W narzędziu Layout Editor wybierz TextView. Następnie w sekcji Atrybuty,
wybierz fontFamily > Więcej czcionek.
Rysunek 2. Korzystanie z Edytora układu.
Otworzy się okno Zasoby.
W menu Źródło wybierz Google Fonts.
W polu Czcionki wybierz czcionkę w sekcji „Do pobrania”.
Kliknij Utwórz czcionkę do pobrania i OK.
Rysunek 3. Wybieranie czcionki w oknie Zasoby.
Android Studio automatycznie generuje odpowiednie pliki XML, które są potrzebne do prawidłowego renderowania czcionki w aplikacji.
Rysunek 4. Wyświetlanie podglądu pliku czcionki.
Programowe korzystanie z czcionek do pobrania
Od Androida 8.0 (interfejs API na poziomie 26) AndroidX Core zapewnia pełną obsługę czcionek do pobrania. Więcej informacji o korzystaniu z biblioteki AndroidX Core znajdziesz w sekcji
Czcionki do pobrania w bibliotece AndroidX Core na tej stronie.
Aby programowo korzystać z funkcji czcionek do pobrania, musisz używać 2 kluczowych klas:
Twoja aplikacja pobiera czcionki od dostawcy czcionek za pomocą interfejsu FontsContract API. Każdy dostawca ma własny zestaw ograniczeń dotyczących wersji Androida i języka zapytań, które obsługuje. Więcej informacji o wersjach Androida i formacie zapytań znajdziesz w dokumentacji dostawcy.
Aby pobrać czcionkę, wykonaj te czynności:
Utwórz instancję klasy android.graphics.fonts.FontRequest, aby poprosić dostawcę o
czcionkę. Aby utworzyć żądanie, przekaż te parametry:
Organ dostawcy czcionek.
Pakiet dostawcy czcionek, aby zweryfikować tożsamość dostawcy.
Ciąg zapytania o czcionkę. Więcej informacji o formatach zapytań znajdziesz w dokumentacji dostawcy czcionek, np. Google Fonts.
Lista zestawów skrótów certyfikatów, aby zweryfikować tożsamość dostawcy.
Zastąp metodę, aby wskazać, że żądanie czcionki zostało zakończone.onTypefaceRetrieved() Podaj pobraną czcionkę jako parametr.
Za pomocą tej metody możesz ustawić czcionkę zgodnie z potrzebami. Możesz np. ustawić czcionkę w
TextView.
Aby pobrać czcionkę od dostawcy czcionek
, wywołaj metodę FontsContract.requestFont(). Metoda inicjuje sprawdzenie, czy czcionka istnieje w pamięci podręcznej. Jeśli
czcionka nie jest dostępna lokalnie, wywołuje dostawcę czcionek, pobiera czcionkę
asynchronicznie i przekazuje wynik do wywołania zwrotnego. Przekaż te parametry:
Instancja klasy android.graphics.fonts.FontRequest
Wywołanie zwrotne, aby otrzymywać wyniki żądania czcionki
Uchwyt do pobierania czcionek w wątku
Poniższy przykładowy kod ilustruje ogólny proces czcionek do pobrania:
Kotlin
valrequest=FontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs)valcallback=object:FontsContract.FontRequestCallback(){overridefunonTypefaceRetrieved(typeface:Typeface){// Your code to use the font goes here....}overridefunonTypefaceRequestFailed(reason:Int){// Your code to deal with the failure goes here....}}FontsContract.requestFonts(context,request,handler,null,callback)
Java
FontRequestrequest=newFontRequest("com.example.fontprovider.authority","com.example.fontprovider","my font",certs);FontsContract.FontRequestCallbackcallback=newFontsContract.FontRequestCallback(){@OverridepublicvoidonTypefaceRetrieved(Typefacetypeface){// Your code to use the font goes here....}@OverridepublicvoidonTypefaceRequestFailed(intreason){// Your code to deal with the failure goes here....}};FontsContract.requestFonts(context,request,handler,null,callback);
Korzystanie z czcionek do pobrania w AndroidX Core
AndroidX Core obsługuje funkcję czcionek do pobrania na urządzeniach z Androidem w wersji
14 lub nowszej. Pakiet androidx.core.provider zawiera klasy FontsContractCompat i FontRequest, które umożliwiają implementację obsługi czcionek do pobrania z zachowaniem zgodności wstecznej. Klasy AndroidX zawierają metody podobne do metod frameworka, a proces pobierania czcionek jest podobny do opisanego w sekcji na tej stronie dotyczącej programowego korzystania z czcionek do pobrania.
Aby pobierać czcionki za pomocą AndroidX, zaimportuj klasy FontsContractCompat i FontRequest z pakietu androidx.core.provider. Zamiast klas frameworka FontsContract i android.graphics.fonts.FontRequest utwórz instancje tych klas.
Dodawanie zależności AndroidX Core
Aby używać klas FontsContractCompat i FontRequest, musisz zmodyfikować zależności classpath projektu aplikacji w środowisku programistycznym.
Aby dodać AndroidX Core do projektu aplikacji, dodaj tę zależność do pliku build.gradle aplikacji:
Korzystanie z czcionek do pobrania jako zasobów w XML
Android 8.0 (interfejs API na poziomie 26) i AndroidX Core oferują szybszy i wygodniejszy sposób deklarowania czcionki niestandardowej jako zasobu w układzie XML. Oznacza to, że nie musisz dołączać czcionki jako zasobu. Możesz zdefiniować czcionkę niestandardową dla całego motywu, co przyspiesza użyteczność w przypadku wielu grubości i stylów, takich jak pogrubiony, średni lub cienki.
Utwórz nowy plik XML w folderze res/font.
Dodaj element główny <font-family> i ustaw atrybuty związane z czcionką, jak
pokazano w tym przykładowym pliku XML:
W pliku XML układu odwołaj się do pliku jako @font/font_file_name. Możesz też
użyć
getFont()
metody do programowego pobierania pliku, np.
getFont(R.font.font_file_name).
Wstępne deklarowanie czcionek w pliku manifestu
Rozszerzanie układu i pobieranie zasobów to zadania synchroniczne. Domyślnie pierwsza próba pobrania czcionek powoduje wysłanie żądania do dostawcy czcionek, co zwiększa czas pierwszego układu. Aby uniknąć opóźnienia, możesz wstępnie zadeklarować czcionki, które mają zostać pobrane, w pliku manifestu.
Gdy system pobierze czcionkę od dostawcy, jest ona od razu dostępna. Jeśli pobieranie czcionki trwa dłużej niż oczekiwano, system przerywa proces pobierania i używa czcionki domyślnej.
Aby wstępnie zadeklarować czcionki w pliku manifestu, wykonaj te czynności:
Utwórz tablicę zasobów w res/values/arrays.xml i zadeklaruj czcionki, które chcesz wstępnie pobrać.
Jeśli dostawca czcionek nie jest wstępnie zainstalowany lub używasz biblioteki AndroidX Core, zadeklaruj certyfikaty, którymi jest podpisany dostawca czcionek. System używa certyfikatów do weryfikacji tożsamości dostawcy czcionek.
Aby dodać certyfikaty, wykonaj te czynności:
Utwórz tablicę tekstową ze szczegółami certyfikatu. Więcej informacji o szczegółach certyfikatu
znajdziesz w dokumentacji dostawcy czcionek.
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.