Пользовательский шрифт PowerPoint на Java

Загрузка пользовательских шрифтов

Aspose.Slides позволяет загружать шрифты, которые отображаются в презентациях, не устанавливая эти шрифты. Шрифты загружаются из пользовательского каталога.

  1. Создайте экземпляр класса FontsLoader и вызовите метод loadExternalFonts.
  2. Загрузите презентацию, которая будет отображена.
  3. Очистите кеш в классе FontsLoader.

Этот Java код демонстрирует процесс загрузки шрифтов:

// Папки для поиска шрифтов
String[] folders = new String[] { externalFontsDir };

// Загружает шрифты из пользовательского каталога
FontsLoader.loadExternalFonts(folders);

// Выполнение работы и рендеринг презентации/слайда
Presentation pres = new Presentation("DefaultFonts.pptx");
try {
    pres.save("NewFonts_out.pptx", SaveFormat.Pptx);
} finally {
    if (pres != null) pres.dispose();

    // Очищает кеш шрифтов
    FontsLoader.clearCache();
}

Получение папки пользовательских шрифтов

Aspose.Slides предоставляет метод getFontFolders для поиска папок с шрифтами. Этот метод возвращает папки, добавленные через метод LoadExternalFonts, и системные папки шрифтов.

Этот Java код показывает, как использовать getFontFolders:

// Эта строка выводит папки, где ищутся файлы шрифтов.
// Это папки, добавленные через метод LoadExternalFonts, и системные папки шрифтов.
String[] fontFolders = FontsLoader.getFontFolders();

Указание пользовательских шрифтов, используемых в презентации

Aspose.Slides предоставляет свойство setDocumentLevelFontSources для указания внешних шрифтов, которые будут использоваться в презентации.

Этот Java код показывает, как использовать свойство 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 {
    // Работа с презентацией
    // CustomFont1, CustomFont2 и шрифты из папок assets\fonts и global\fonts, а также их подкаталогов доступны для презентации
} finally {
    if (pres != null) pres.dispose();
}

Управление шрифтами извне

Aspose.Slides предоставляет метод loadExternalFont(byte[] data) для загрузки внешних шрифтов из двоичных данных.

Этот Java код демонстрирует процесс загрузки шрифтов из массива байтов:

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 {
        // внешний шрифт загружен в течение времени жизни презентации
    } finally {
        
    }
}
finally
{
    FontsLoader.clearCache();
}