Aspose::Words::FontSubstitutionWarningInfo class

FontSubstitutionWarningInfo class

Contains information about a font substitution warning that Aspose.Words issued during document loading or saving.

class FontSubstitutionWarningInfo : public Aspose::Words::WarningInfo

Methods

MethodDescription
get_Description() constReturns the description of the warning.
get_Reason() constFont substitution reason.
get_RequestedBold() constIndicates whether bold style was requested.
get_RequestedFamilyName() constRequested font family name.
get_RequestedItalic() constIndicates whether italic style was requested.
get_ResolvedFont() constResolved font.
get_Source() constReturns the source of the warning.
get_WarningType() constReturns the type of the warning.
GetType() const override
Is(const System::TypeInfo&) const override
static Type()

Examples

Shows how to get additional information about font substitution.

auto doc = System::MakeObject<Aspose::Words::Document>(get_MyDir() + u"Rendering.docx");

auto callback = System::MakeObject<Aspose::Words::WarningInfoCollection>();
doc->set_WarningCallback(callback);

auto fontSettings = System::MakeObject<Aspose::Words::Fonts::FontSettings>();
fontSettings->get_SubstitutionSettings()->get_DefaultFontSubstitution()->set_DefaultFontName(u"Arial");
fontSettings->SetFontsFolder(get_FontsDir(), false);
fontSettings->get_SubstitutionSettings()->get_TableSubstitution()->AddSubstitutes(u"Arial", System::MakeArray<System::String>({u"Arvo", u"Slab"}));

doc->set_FontSettings(fontSettings);
doc->Save(get_ArtifactsDir() + u"FontSettings.SubstitutionWarnings.pdf");

auto warningInfo = System::ExplicitCast<Aspose::Words::FontSubstitutionWarningInfo>(callback->idx_get(0));
ASSERT_EQ(Aspose::Words::WarningSource::Layout, warningInfo->get_Source());
ASSERT_EQ(Aspose::Words::WarningType::FontSubstitution, warningInfo->get_WarningType());
ASSERT_EQ(Aspose::Words::FontSubstitutionReason::TableSubstitutionRule, warningInfo->get_Reason());
ASSERT_EQ(u"Font \'Arial\' has not been found. Using \'Arvo\' font instead. Reason: table substitution.", warningInfo->get_Description());
ASSERT_TRUE(warningInfo->get_RequestedBold());
ASSERT_FALSE(warningInfo->get_RequestedItalic());
ASSERT_EQ(u"Arial", warningInfo->get_RequestedFamilyName());

See Also