La función Fuentes descargables permite que las APIs soliciten fuentes de una aplicación de proveedor en lugar de agrupar archivos en la app o permitir que esta descargue fuentes. Fuentes para descargar está disponible en dispositivos que ejecutan la versión 14 y posteriores de las APIs de Android a través de la biblioteca principal de AndroidX.
Fuentes para descargar ofrece los siguientes beneficios:
Reduce el tamaño de la app y, por ende, aumenta la tasa de éxito de la instalación de la app.
Mejora el estado general del sistema, ya que varias apps pueden compartir la misma fuente a través de un
proveedor. Esto permite que los usuarios ahorren datos móviles, memoria del teléfono y espacio en disco. En este modelo, la
fuente se obtiene mediante la red cuando es necesario.
Para obtener experiencia práctica con Fuentes para descargar, consulta la
DownloadableFonts
app de ejemplo.
¿Cómo funciona Fuentes para descargar?
Un proveedor de fuentes es una aplicación que recupera fuentes y las almacena en caché de forma local para que otras apps puedan solicitarlas y compartirlas. En la siguiente figura, se ilustra el proceso.
Figura 1. Proceso de Fuentes para descargar
Conceptos básicos
Puedes usar la función Fuentes para descargar de las siguientes maneras, que se analizan en detalle en las secciones posteriores:
Cómo usar Fuentes para descargar con Android Studio y Servicios de Google Play
Puedes configurar tu aplicación para que descargue fuentes con Android Studio 3.0 o versiones posteriores. Para ayudarte a comenzar con la función Fuentes para descargar, puedes usar el proveedor de fuentes de los Servicios de Google Play.
En el Editor de diseño, selecciona un elemento TextView. Luego, en Atributos,
selecciona fontFamily > More Fonts.
Figura 2: Usa el Editor de diseño.
Aparecerá la ventana Recursos.
En el menú Fuente, selecciona Google Fonts.
En el cuadro Fuentes, selecciona una fuente en el área "Descargable".
Selecciona Create downloadable font y haz clic en OK.
Figura 3. Selecciona una fuente en la ventana Recursos.
Android Studio genera automáticamente los archivos en formato XML relevantes que se necesitan para procesar la fuente en tu app de forma correcta.
Figura 4. Vista previa del archivo de fuente
Cómo usar Fuentes para descargar de manera programática
A partir de Android 8.0 (nivel de API 26), AndroidX Core ofrece total compatibilidad para Fuentes para descargar. Para
obtener más información sobre el uso de la biblioteca principal de AndroidX, consulta la
sección Biblioteca principal de AndroidX de Fuentes descargables en esta página.
Para usar la función Fuentes para descargar de manera programática, interactúa con dos clases clave:
Tu app recupera fuentes del proveedor mediante la API FontsContract. Cada proveedor tiene su propio conjunto de restricciones en las versiones de Android y el idioma de búsqueda que admite. Para obtener más información sobre las versiones de Android y el formato de búsqueda, consulta la documentación de tu proveedor.
Para descargar una fuente, sigue estos pasos:
Crea una instancia de la clase android.graphics.fonts.FontRequest para solicitar la fuente al proveedor. Para crear una solicitud, pasa los siguientes parámetros:
La autoridad del proveedor de fuentes
El paquete del proveedor de fuentes para verificar su identidad
La búsqueda de string de la fuente (para obtener más información sobre los formatos de búsqueda, revisa la documentación de tu proveedor de fuentes, como Google Fonts)
Una lista de conjuntos de hashes para los certificados a fin de verificar la identidad del proveedor
Anula el
onTypefaceRetrieved()
método para indicar que la solicitud de fuente está completa. Proporciona la fuente recuperada como parámetro.
Puedes usar este método para configurar la fuente según sea necesario. Por ejemplo, puedes configurar la fuente en un
TextView.
Anula el
onTypefaceRequestFailed()
método para recibir información sobre errores en el proceso de solicitud de fuentes. Para obtener más información
sobre los códigos de error, consulta las
constantes de código de error.
Llama al método FontsContract.requestFont() para recuperar la fuente del proveedor. El método inicia una verificación para determinar si la fuente existe en la memoria caché. Si
la fuente no está disponible de forma local, llama al proveedor de fuentes, recupera la fuente
de forma asíncrona y pasa el resultado a la devolución de llamada. Pasa los siguientes parámetros:
Una instancia de la clase android.graphics.fonts.FontRequest
Una devolución de llamada para recibir los resultados de la solicitud de fuente
Un controlador para recuperar fuentes en un subproceso
En el siguiente código de muestra, se ilustra el proceso general de la función Fuentes para descargar:
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);
Si deseas obtener más información para descargar una fuente de un proveedor de fuentes, consulta la
app de ejemplo DownloadableFonts.
Cómo usar Fuentes para descargar con AndroidX Core
AndroidX Core admite la función Fuentes para descargar en dispositivos que ejecutan la versión 14 o una posterior de la
API de Android. El paquete androidx.core.provider contiene las clases FontsContractCompat y FontRequest para implementar la retrocompatibilidad de la función Fuentes para descargar. Las clases de AndroidX contienen métodos
similares a los métodos del framework, y el proceso para descargar fuentes es similar al que se
describe en la sección de esta página sobre
el uso de Fuentes para descargar de manera programática.
Para descargar fuentes con AndroidX, importa las clases FontsContractCompat y FontRequest del paquete androidx.core.provider. Crea las instancias de estas clases en lugar de las clases del framework FontsContract y android.graphics.fonts.FontRequest.
Agrega la dependencia de AndroidX Core
Para usar las clases FontsContractCompat y FontRequest, debes modificar las dependencias de ruta de clase del proyecto de tu app dentro del entorno de desarrollo.
Para agregar AndroidX Core a tu proyecto de aplicación, agrega la siguiente dependencia al archivo build.gradle de tu app:
Cómo usar Fuentes para descargar como recursos en XML
Android 8.0 (nivel de API 26) y AndroidX Core ofrecen una manera más rápida y conveniente de declarar una fuente personalizada como un recurso en el diseño XML. De esta manera, no es necesario empaquetar las fuentes como un elemento. Puedes definir una fuente personalizada para todo tu tema, lo que acelera la usabilidad para varios pesos y estilos, como negrita, media o clara, cuando se proporcionan.
Crea un nuevo archivo en formato XML en la carpeta res/font.
Agrega el elemento raíz <font-family> y configura los atributos relacionados con la fuente, como se
muestra en el siguiente archivo en formato XML de ejemplo:
Haz referencia al archivo como @font/font_file_name en el archivo en formato XML de diseño. También puedes
usar el
getFont()
método para recuperar el archivo de manera programática, como
getFont(R.font.font_file_name).
Cómo declarar previamente las fuentes en el manifiesto
El aumento del diseño y la recuperación de recursos son tareas sincrónicas. De forma predeterminada, el primer intento para recuperar fuentes activa una solicitud al proveedor de fuentes y, por lo tanto, aumenta el tiempo del primer diseño. Para evitar un retraso, puedes declarar previamente las fuentes que se deben recuperar en tu manifiesto.
Cuando el sistema recupera la fuente del proveedor, está disponible de inmediato. Si la recuperación de fuentes tarda más de lo esperado, el sistema anula el proceso de obtención y usa la fuente predeterminada.
Para declarar previamente las fuentes en el manifiesto, sigue estos pasos:
Crea un array de recursos en res/values/arrays.xml y declara las fuentes que deseas obtener previamente.
Cuando un proveedor de fuentes no está preinstalado o si estás usando la biblioteca principal de AndroidX, declara los certificados con los que está firmado el proveedor de fuentes. El sistema usa los certificados para verificar la identidad del proveedor de fuentes.
Sigue estos pasos para agregar certificados:
Crea un array de cadenas con los detalles del certificado. Para obtener más información sobre los detalles del certificado, consulta la documentación de tu proveedor de fuentes.
Configura el atributo fontProviderCerts para el array.
android:fontProviderCerts="@array/certs"
Fuentes descargables en Compose
El contenido y las muestras de código que aparecen en esta página están sujetas a las licencias que se describen en la Licencia de Contenido. Java y OpenJDK son marcas registradas de Oracle o sus afiliados.
Última actualización: 2026-04-28 (UTC)
[[["Fácil de comprender","easyToUnderstand","thumb-up"],["Resolvió mi problema","solvedMyProblem","thumb-up"],["Otro","otherUp","thumb-up"]],[["Falta la información que necesito","missingTheInformationINeed","thumb-down"],["Muy complicado o demasiados pasos","tooComplicatedTooManySteps","thumb-down"],["Desactualizado","outOfDate","thumb-down"],["Problema de traducción","translationIssue","thumb-down"],["Problema con las muestras o los códigos","samplesCodeIssue","thumb-down"],["Otro","otherDown","thumb-down"]],["Última actualización: 2026-04-28 (UTC)"],[],[]]