Personalizar fuentes de PowerPoint en Android
Aspose Slides permite cargar estas fuentes mediante el método loadExternalFonts:
Load Custom Fonts
Aspose.Slides permite cargar fuentes usadas en una presentación sin instalarlas en el sistema. Esto afecta la salida de exportación —como PDF, imágenes y otros formatos compatibles— de modo que los documentos resultantes tengan el mismo aspecto en distintos entornos. Las fuentes se cargan desde directorios personalizados.
- Especifique una o más carpetas que contengan los archivos de fuentes.
- Llame al método estático FontsLoader.loadExternalFonts para cargar fuentes desde esas carpetas.
- Cargue y renderice/expórtela presentación.
- Llame a FontsLoader.clearCache para vaciar la caché de fuentes.
El siguiente ejemplo de código muestra el proceso de carga de fuentes:
// Defina carpetas que contienen archivos de fuentes personalizadas.
String[] fontFolders = new String[] { externalFontFolder1, externalFontFolder2 };
// Cargue fuentes personalizadas de las carpetas especificadas.
FontsLoader.loadExternalFonts(fontFolders);
Presentation presentation = null;
try {
presentation = new Presentation("sample.pptx");
// Renderice/exporte la presentación (p.ej., a PDF, imágenes u otros formatos) usando las fuentes cargadas.
presentation.save("output.pdf", SaveFormat.Pdf);
} finally {
if (presentation != null) presentation.dispose();
// Vacíe la caché de fuentes después de que se haya terminado el trabajo.
FontsLoader.clearCache();
}
Note
FontsLoader.loadExternalFonts agrega carpetas adicionales a las rutas de búsqueda de fuentes, pero no cambia el orden de inicialización de las fuentes. Las fuentes se inicializan en el siguiente orden:
- La ruta de fuentes predeterminada del sistema operativo.
- Las rutas cargadas a través de FontsLoader.
Get Custom Font Folders
Aspose.Slides proporciona el método getFontFolders para permitirle encontrar carpetas de fuentes. Este método devuelve las carpetas añadidas mediante el método LoadExternalFonts y las carpetas de fuentes del sistema.
Este código Java le muestra cómo usar getFontFolders:
// Esta línea muestra las carpetas donde se buscan los archivos de fuentes.
// Son carpetas añadidas mediante el método LoadExternalFonts y las carpetas de fuentes del sistema.
String[] fontFolders = FontsLoader.getFontFolders();
Specify Custom Fonts Used with a Presentation
Aspose.Slides proporciona la propiedad setDocumentLevelFontSources para permitirle especificar fuentes externas que se utilizarán con la presentación.
Este código Java le muestra cómo usar la propiedad setDocumentLevelFontSources:
byte[] memoryFont1 = Files.readAllBytes("customfonts/CustomFont1.ttf");
byte[] memoryFont2 = Files.readAllBytes("customfonts/CustomFont2.ttf");
LoadOptions loadOptions = new LoadOptions();
loadOptions.getDocumentLevelFontSources().setFontFolders(new String[] { "assets/fonts", "global/fonts" });
loadOptions.getDocumentLevelFontSources().setMemoryFonts(new byte[][] { memoryFont1, memoryFont2 });
Presentation pres = new Presentation("MyPresentation.pptx", loadOptions);
try {
// Trabajar con la presentación
// CustomFont1, CustomFont2 y las fuentes de las carpetas assets\fonts & global\fonts y sus subcarpetas están disponibles para la presentación
} finally {
if (pres != null) pres.dispose();
}
Manage Fonts Externally
Aspose.Slides proporciona el método loadExternalFont(byte[] data) para permitirle cargar fuentes externas a partir de datos binarios.
Este código Java demuestra el proceso de carga de fuentes a partir de una matriz de bytes:
FontsLoader.loadExternalFont(Files.readAllBytes(Paths.get("ARIALN.TTF")));
FontsLoader.loadExternalFont(Files.readAllBytes(Paths.get("ARIALNBI.TTF")));
FontsLoader.loadExternalFont(Files.readAllBytes(Paths.get("ARIALNI.TTF")));
try
{
Presentation pres = new Presentation("");
try {
// fuente externa cargada durante la vida de la presentación
} finally {
}
}
finally
{
FontsLoader.clearCache();
}
FAQ
¿Las fuentes personalizadas afectan la exportación a todos los formatos (PDF, PNG, SVG, HTML)?
Sí. Las fuentes conectadas son utilizadas por el motor de renderizado en todos los formatos de exportación.
¿Las fuentes personalizadas se incrustan automáticamente en el PPTX resultante?
No. Registrar una fuente para el renderizado no es lo mismo que incrustarla en un PPTX. Si necesita que la fuente esté incluida dentro del archivo de la presentación, debe usar las funciones de incrustación.
¿Puedo controlar el comportamiento de sustitución cuando una fuente personalizada carece de algunos glifos?
Sí. Configure la sustitución de fuentes, las reglas de reemplazo y los conjuntos de retroceso para definir exactamente qué fuente se usa cuando falta el glifo solicitado.
¿Puedo usar fuentes en contenedores Linux/Docker sin instalarlas a nivel del sistema?
Sí. Apunte a sus propias carpetas de fuentes o cargue fuentes desde matrices de bytes. Esto elimina cualquier dependencia de los directorios de fuentes del sistema en la imagen del contenedor.
¿Qué pasa con la licencia: puedo incrustar cualquier fuente personalizada sin restricciones?
Usted es responsable del cumplimiento de la licencia de las fuentes. Los términos varían; algunas licencias prohíben la incrustación o el uso comercial. Siempre revise el EULA de la fuente antes de distribuir los resultados.