Пользовательский шрифт в C++
Aspose Slides позволяет загружать эти шрифты с помощью FontsLoader::LoadExternalFonts:
Загрузка пользовательских шрифтов
Aspose.Slides позволяет загружать шрифты, которые отображаются в презентациях, без необходимости их установки. Шрифты загружаются из пользовательского каталога.
- Создайте экземпляр класса FontsLoader и вызовите метод FontsLoader::LoadExternalFonts.
- Загрузите презентацию, которая будет отображаться.
- Очистите кэш в классе FontsLoader.
Этот код на C++ демонстрирует процесс загрузки шрифтов:
const String fontPath = u"../templates/";
const String outPath = u"../out/UseCustomFonts_out.pptx";
const String templatePath = u"../templates/DefaultFonts.pptx";
// Устанавливает путь к шрифтам
ArrayPtr<String> folders = System::MakeObject<Array<String>>(1, fontPath);
// Загружает шрифты из пользовательского каталога
FontsLoader::LoadExternalFonts(folders);
// Выполните какую-нибудь работу и отрисуйте презентацию/слайды
SharedPtr<Presentation> pres = MakeObject<Presentation>(templatePath);
pres->Save(outPath, Export::SaveFormat::Pptx);
// Очищает кэш шрифтов
FontsLoader::ClearCache();
Получение папки пользовательских шрифтов
Aspose.Slides предоставляет FontsLoader::GetFontFolders() для того, чтобы позволить вам находить папки шрифтов. Этот метод возвращает папки, добавленные через метод LoadExternalFonts
, и системные папки шрифтов.
Этот код на C++ показывает, как использовать метод FontsLoader::GetFontFolders():
// Эта строка выводит папки, которые проверяются на наличие файлов шрифтов.
// Это папки, добавленные через метод LoadExternalFonts и системные папки шрифтов.
auto fontFolders = FontsLoader::GetFontFolders();
Укажите пользовательские шрифты, используемые с презентацией
Aspose.Slides предоставляет свойство LoadOptions::set_DocumentLevelFontSources, чтобы вы могли указать внешние шрифты, которые будут использоваться с презентацией.
Этот код на C++ показывает, как использовать свойство LoadOptions::set_DocumentLevelFontSources:
auto memoryFont1 = File::ReadAllBytes(u"customfonts\\CustomFont1.ttf");
auto memoryFont2 = File::ReadAllBytes(u"customfonts\\CustomFont2.ttf");
auto loadOptions = System::MakeObject<LoadOptions>();
loadOptions->get_DocumentLevelFontSources()->set_FontFolders(System::MakeArray<String>({u"assets\\fonts", u"global\\fonts"}));
loadOptions->get_DocumentLevelFontSources()->set_MemoryFonts(System::MakeArray<ArrayPtr<uint8_t>>({memoryFont1, memoryFont2}));
{
auto presentation = System::MakeObject<Presentation>(u"MyPresentation.pptx", loadOptions);
//работа с презентацией
//CustomFont1, CustomFont2, а также шрифты из папок assets\fonts и global\fonts и их подкаталогов доступны для презентации
}
Управление шрифтами извне
Aspose.Slides предоставляет метод FontsLoader::LoadExternalFont, который позволяет вам загружать внешние шрифты в массив байтов.
Этот код на C++ демонстрирует процесс загрузки шрифтов в массив байтов:
// Путь к каталогу документов
const String outPath = u"../out/SpecifyFontsUsedWithPresentation.pptx";
const String templatePath = u"../templates/AccessSlides.pptx";
ArrayPtr<String> fontsLocation = MakeArray<System::String>({ u"assets\\fonts", u"global\\fonts" });// ;
ArrayPtr<ArrayPtr<uint8_t>> memoryfontsLocation = MakeArray < ArrayPtr<uint8_t>>({ File::ReadAllBytes(u"../templates/CustomFont1.ttf"), File::ReadAllBytes(u"../templates/CustomFont2.ttf") });
SharedPtr < Aspose::Slides::LoadOptions > loadOptions = MakeObject <Aspose::Slides::LoadOptions>();
loadOptions->get_DocumentLevelFontSources()->set_FontFolders(fontsLocation);
loadOptions->get_DocumentLevelFontSources()->set_MemoryFonts(memoryfontsLocation);
SharedPtr<Presentation> pres = MakeObject<Presentation>(templatePath, loadOptions);