Fitur Font yang Dapat Didownload memungkinkan API meminta font dari aplikasi penyedia, bukan memaketkan file dalam aplikasi atau membiarkan aplikasi mendownload font. Font yang Dapat Didownload tersedia di perangkat yang menjalankan Android API versi 14 dan yang lebih tinggi melalui library AndroidX Core.
Font yang Dapat Didownload menawarkan manfaat sebagai berikut:
Mengurangi ukuran aplikasi, sehingga meningkatkan tingkat keberhasilan penginstalan aplikasi.
Meningkatkan kesehatan sistem secara keseluruhan karena beberapa aplikasi dapat berbagi font yang sama melalui a
penyedia. Tindakan ini akan menghemat data seluler pengguna, memori ponsel, dan kapasitas disk. Dalam model ini, the
font dikirim melalui jaringan jika diperlukan.
Untuk mendapatkan pengalaman langsung dengan Font yang Dapat Didownload, lihat
DownloadableFonts
aplikasi contoh.
Bagaimana cara kerja Font yang Dapat Didownload?
Penyedia font adalah aplikasi yang mengambil font dan membuat cache secara lokal sehingga aplikasi lain dapat meminta dan berbagi font. Gambar berikut mengilustrasikan prosesnya.
Gambar 1. Proses Font yang Dapat Didownload.
Dasar-dasar
Anda dapat menggunakan fitur Font yang Dapat Didownload dengan cara berikut, yang akan dibahas secara mendetail di bagian selanjutnya:
Menggunakan Font yang Dapat Didownload dengan Android Studio dan layanan Google Play
Anda dapat menyetel aplikasi Anda untuk mendownload font dengan menggunakan Android Studio 3.0 atau yang lebih tinggi. Guna membantu Anda menggunakan fitur Font yang Dapat Didownload, Anda dapat menggunakan penyedia font dari layanan Google Play.
Di Layout Editor, pilih TextView. Kemudian, di bagian Attributes,
pilih fontFamily > More Fonts.
Gambar 2. Menggunakan Layout Editor.
Jendela Resources akan muncul.
Di menu Source, pilih Google Fonts.
Dalam kotak Fonts, pilih font di bagian "Downloadable".
Pilih Create downloadable font , lalu klik OK.
Gambar 3. Memilih font dari jendela Resources.
Android Studio otomatis membuat file XML relevan yang diperlukan untuk merender font dengan benar di aplikasi Anda.
Gambar 4. Melihat pratinjau file font.
Menggunakan Font yang Dapat Didownload secara terprogram
Mulai Android 8.0 (API level 26), AndroidX Core menyediakan dukungan penuh untuk Font yang Dapat Didownload. Untuk mengetahui informasi selengkapnya tentang cara menggunakan library AndroidX Core, lihat bagian
library AndroidX Core Font yang Dapat Didownload di halaman ini.
Untuk menggunakan fitur Font yang Dapat Didownload secara terprogram, berinteraksi dengan dua class utama:
Aplikasi Anda mengambil font dari penyedia font dengan menggunakan FontsContract API. Setiap penyedia memiliki serangkaian batasan tersendiri pada versi Android dan bahasa kueri yang didukungnya. Untuk informasi selengkapnya tentang versi Android dan format kueri, lihat dokumentasi penyedia Anda.
Untuk mendownload font, selesaikan langkah-langkah berikut:
Buat instance class android.graphics.fonts.FontRequest untuk meminta font dari penyedia. Untuk membuat permintaan, teruskan parameter berikut:
Otoritas penyedia font.
Paket penyedia font untuk memverifikasi identitas penyedia.
Kueri string font. Untuk mengetahui informasi selengkapnya tentang format kueri, lihat dokumentasi penyedia font Anda, seperti Google Fonts.
Daftar serangkaian hash untuk sertifikat guna memverifikasi identitas penyedia.
Ganti metode
onTypefaceRetrieved()
untuk menunjukkan bahwa permintaan font telah selesai. Masukkan font yang diambil sebagai parameter.
Anda dapat menggunakan metode ini untuk menetapkan font, sesuai kebutuhan. Misalnya, Anda dapat menetapkan font pada
TextView.
Ganti metode
onTypefaceRequestFailed()
untuk menerima informasi tentang error dalam proses permintaan font. Untuk mengetahui informasi selengkapnya
tentang kode error, lihat
konstanta kode error.
Panggil metode FontsContract.requestFont() untuk mengambil font dari penyedia font. Metode ini memulai pemeriksaan untuk menentukan apakah font ada dalam cache. Jika
font tidak tersedia secara lokal, metode akan memanggil penyedia font, mengambil font
secara asinkron, dan meneruskan hasilnya ke callback. Teruskan parameter berikut:
Kode contoh berikut mengilustrasikan proses Font yang Dapat Didownload secara keseluruhan:
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);
Untuk mengetahui informasi selengkapnya tentang cara mendownload font dari penyedia font, lihat aplikasi contoh
DownloadableFonts.
Menggunakan Font yang Dapat Didownload dengan AndroidX Core
AndroidX Core memberikan dukungan untuk fitur Font yang Dapat Didownload pada perangkat yang menjalankan Android
API versi 14 atau yang lebih tinggi. Paket androidx.core.provider berisi class FontsContractCompat dan FontRequest untuk mengimplementasikan dukungan fitur kompatibilitas mundur Font yang Dapat Didownload. Class AndroidX berisi metode
yang mirip dengan metode framework, dan proses mendownload font mirip dengan yang
dijelaskan di bagian halaman ini tentang
cara menggunakan Font yang Dapat Didownload secara terprogram.
Untuk mendownload font menggunakan AndroidX, impor class FontsContractCompat dan FontRequest dari paket androidx.core.provider. Buat instance untuk class ini, bukan class framework FontsContract dan android.graphics.fonts.FontRequest.
Menambahkan dependensi AndroidX Core
Untuk menggunakan class FontsContractCompat dan FontRequest, Anda harus mengubah dependensi classpath project aplikasi di dalam lingkungan pengembangan Anda.
Untuk menambahkan AndroidX Core ke project aplikasi Anda, tambahkan dependensi berikut ke file build.gradle aplikasi Anda:
Menggunakan Font yang Dapat Didownload sebagai resource dalam XML
Android 8.0 (API level 26) dan AndroidX Core menawarkan cara yang lebih cepat dan praktis untuk mendeklarasikan font kustom sebagai resource dalam tata letak XML. Artinya, font tidak perlu dipaketkan sebagai aset. Anda dapat menentukan font kustom untuk seluruh tema, yang mempercepat kegunaan untuk beberapa bobot dan gaya, seperti tebal, sedang, atau ringan, jika disediakan.
Buat file XML baru di folder res/font.
Tambahkan elemen root <font-family> dan tetapkan atribut terkait font, seperti yang
ditampilkan dalam contoh file XML berikut:
Lihat file sebagai @font/font_file_name pada file XML tata letak. Anda juga dapat
menggunakan metode
getFont()
untuk mengambil file secara terprogram, seperti
getFont(R.font.font_file_name).
Mendeklarasikan font sebelumnya di dalam manifes
Perluasan tata letak dan pengambilan resource adalah tugas tersinkron. Secara default, upaya pertama untuk mengambil font memicu permintaan ke penyedia font, sehingga meningkatkan waktu proses tata letak pertama. Untuk menghindari penundaan, Anda dapat mendeklarasikan di awal font yang perlu diambil di dalam manifes.
Setelah sistem mengambil font dari penyedia, font akan langsung tersedia. Jika pengambilan font memerlukan waktu lebih lama dari yang diperkirakan, sistem akan membatalkan proses pengambilan dan menggunakan font default.
Untuk melakukan pradeklarasi font dalam manifes, selesaikan langkah-langkah berikut:
Buat array resource dalam res/values/arrays.xml dan deklarasikan font yang ingin Anda ambil lebih dulu.
Jika penyedia font belum terinstal, atau jika Anda menggunakan library AndroidX Core, deklarasikan sertifikat yang telah ditandatangani dengan penyedia font. Sistem menggunakan sertifikat untuk memverifikasi identitas penyedia font.
Lakukan langkah-langkah berikut untuk menambahkan sertifikat:
Buat array string dengan detail sertifikat. Untuk mengetahui informasi selengkapnya tentang detail sertifikat, lihat dokumentasi penyedia font Anda.
Konten dan contoh kode di halaman ini tunduk kepada lisensi yang dijelaskan dalam Lisensi Konten. Java dan OpenJDK adalah merek dagang atau merek dagang terdaftar dari Oracle dan/atau afiliasinya.
Terakhir diperbarui pada 2026-04-26 UTC.
[null,null,["Terakhir diperbarui pada 2026-04-26 UTC."],[],[]]