在 C++ 中管理演示文稿主题

演示主题定义了设计元素的属性。选择演示主题时,实际上是选择一组特定的视觉元素及其属性。

在 PowerPoint 中,主题包括颜色、字体背景样式和效果。

theme-constituents

更改主题颜色

PowerPoint 主题为幻灯片上的不同元素使用特定的颜色集合。如果您不喜欢这些颜色,可以通过为主题应用新颜色来更改它们。为了让您选择新的主题颜色,Aspose.Slides 在 SchemeColor 枚举中提供了相应的值。

以下 C++ 代码演示了如何更改主题的强调色:

auto pres = System::MakeObject<Presentation>();

auto shape = pres->get_Slides()->idx_get(0)->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 10.0f, 10.0f, 100.0f, 100.0f);

shape->get_FillFormat()->set_FillType(FillType::Solid);
shape->get_FillFormat()->get_SolidFillColor()->set_SchemeColor(SchemeColor::Accent4);

您可以通过以下方式确定结果颜色的有效值:

auto fillEffective = shape->get_FillFormat()->GetEffective();
    
Console::WriteLine(u"{0} ({1})", fillEffective->get_SolidFillColor().get_Name(), fillEffective->get_SolidFillColor());
// ff8064a2 (颜色 [A=255, R=128, G=100, B=162])

为了进一步演示颜色更改操作,我们创建另一个元素并将强调色(来自首次操作)分配给它。随后我们在主题中更改颜色:

auto otherShape = pres->get_Slides()->idx_get(0)->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 10.0f, 120.0f, 100.0f, 100.0f);
    
otherShape->get_FillFormat()->set_FillType(FillType::Solid);
otherShape->get_FillFormat()->get_SolidFillColor()->set_SchemeColor(SchemeColor::Accent4);

pres->get_MasterTheme()->get_ColorScheme()->get_Accent4()->set_Color(Color::get_Red());

新颜色会自动应用到两个元素上。

从附加调色板设置主题颜色

当您对主主题颜色(1)应用亮度变换时,会生成来自附加调色板(2)的颜色。随后您可以设置和获取这些主题颜色。

additional-palette-colors

1- 主主题颜色
2- 来自附加调色板的颜色。

以下 C++ 代码演示了从主主题颜色获取附加调色板颜色并在形状中使用的操作:

auto presentation = System::MakeObject<Presentation>();

auto slide = presentation->get_Slide(0);
auto shapes = slide->get_Shapes();

// Accent 4
auto shape1 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 10.0f, 50.0f, 50.0f);
auto fillFormat1 = shape1->get_FillFormat();

fillFormat1->set_FillType(FillType::Solid);
fillFormat1->get_SolidFillColor()->set_SchemeColor(SchemeColor::Accent4);

// Accent 4, Lighter 80%
auto shape2 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 70.0f, 50.0f, 50.0f);
auto fillFormat2 = shape2->get_FillFormat();
auto solidFillColor2 = fillFormat2->get_SolidFillColor();

fillFormat2->set_FillType(FillType::Solid);
solidFillColor2->set_SchemeColor(SchemeColor::Accent4);
solidFillColor2->get_ColorTransform()->Add(ColorTransformOperation::MultiplyLuminance, 0.2f);
solidFillColor2->get_ColorTransform()->Add(ColorTransformOperation::AddLuminance, 0.8f);

// Accent 4, Lighter 60%
auto shape3 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 130.0f, 50.0f, 50.0f);
auto fillFormat3 = shape3->get_FillFormat();
auto solidFillColor3 = fillFormat3->get_SolidFillColor();

fillFormat3->set_FillType(FillType::Solid);
solidFillColor3->set_SchemeColor(SchemeColor::Accent4);
solidFillColor3->get_ColorTransform()->Add(ColorTransformOperation::MultiplyLuminance, 0.4f);
solidFillColor3->get_ColorTransform()->Add(ColorTransformOperation::AddLuminance, 0.6f);

// Accent 4, Lighter 40%
auto shape4 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 190.0f, 50.0f, 50.0f);
auto fillFormat4 = shape4->get_FillFormat();
auto solidFillColor4 = fillFormat4->get_SolidFillColor();

fillFormat4->set_FillType(FillType::Solid);
solidFillColor4->set_SchemeColor(SchemeColor::Accent4);
solidFillColor4->get_ColorTransform()->Add(ColorTransformOperation::MultiplyLuminance, 0.6f);
solidFillColor4->get_ColorTransform()->Add(ColorTransformOperation::AddLuminance, 0.4f);

// Accent 4, Darker 25%
auto shape5 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 250.0f, 50.0f, 50.0f);
auto fillFormat5 = shape5->get_FillFormat();
auto solidFillColor5 = fillFormat5->get_SolidFillColor();

fillFormat5->set_FillType(FillType::Solid);
solidFillColor5->set_SchemeColor(SchemeColor::Accent4);
solidFillColor5->get_ColorTransform()->Add(ColorTransformOperation::MultiplyLuminance, 0.75f);

// Accent 4, Darker 50%
auto shape6 = shapes->AddAutoShape(ShapeType::Rectangle, 10.0f, 310.0f, 50.0f, 50.0f);
auto fillFormat6 = shape6->get_FillFormat();
auto solidFillColor6 = fillFormat6->get_SolidFillColor();

fillFormat6->set_FillType(FillType::Solid);
solidFillColor6->set_SchemeColor(SchemeColor::Accent4);
solidFillColor6->get_ColorTransform()->Add(ColorTransformOperation::MultiplyLuminance, 0.5f);

presentation->Save(u"example.pptx", Export::SaveFormat::Pptx);

更改主题字体

为了让您为主题及其他用途选择字体,Aspose.Slides 使用了以下特殊标识符(类似于 PowerPoint 中使用的标识符):

  • +mn-lt - 正文字体拉丁文(次要拉丁字体)
  • +mj-lt - 标题字体拉丁文(主要拉丁字体)
  • +mn-ea - 正文字体东亚(次要东亚字体)
  • +mj-ea - 标题字体东亚(主要东亚字体)

以下 C++ 代码演示了如何为主题元素分配拉丁字体:

auto shape = pres->get_Slides()->idx_get(0)->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 10.0f, 10.0f, 100.0f, 100.0f);

auto paragraph = System::MakeObject<Paragraph>();
auto portion = System::MakeObject<Portion>(u"Theme text format");

paragraph->get_Portions()->Add(portion);
shape->get_TextFrame()->get_Paragraphs()->Add(paragraph);

portion->get_PortionFormat()->set_LatinFont(System::MakeObject<FontData>(u"+mn-lt"));

以下 C++ 代码演示了如何更改演示文稿的主题字体:

pres->get_MasterTheme()->get_FontScheme()->get_Minor()->set_LatinFont(MakeObject<FontData>(u"Arial"));

所有文本框中的字体都会被更新。

更改主题背景样式

默认情况下,PowerPoint 应用提供 12 种预定义背景,但在典型的演示文稿中只会保存其中的 3 种背景。

todo:image_alt_text

例如,在 PowerPoint 应用中保存演示文稿后,您可以运行以下 C++ 代码来获取演示文稿中预定义背景的数量:

auto pres = MakeObject<Presentation>(u"pres.pptx");
        
int32_t numberOfBackgroundFills = pres->get_MasterTheme()->get_FormatScheme()->get_BackgroundFillStyles()->get_Count();

Console::WriteLine(u"Number of background fill styles for theme is {0}", numberOfBackgroundFills);

以下 C++ 代码演示了如何为演示文稿设置背景:

pres->get_Masters()->idx_get(0)->get_Background()->set_StyleIndex(2);

索引指南:0 表示无填充。索引从 1 开始。

更改主题效果

PowerPoint 主题通常为每个样式数组包含 3 个值。这些数组组合形成三个效果:细微、适中和强烈。例如,将这些效果应用于特定形状时的结果如下:

todo:image_alt_text

使用来自 FormatScheme 类的三个属性(FillStylesLineStylesEffectStyles),您可以更改主题中的元素(比 PowerPoint 中的选项更加灵活)。

以下 C++ 代码演示了如何通过更改元素的部分属性来更改主题效果:

auto pres = System::MakeObject<Presentation>(u"Subtle_Moderate_Intense.pptx");
        
pres->get_MasterTheme()->get_FormatScheme()->get_LineStyles()->idx_get(0)->get_FillFormat()->get_SolidFillColor()->set_Color(Color::get_Red());

pres->get_MasterTheme()->get_FormatScheme()->get_FillStyles()->idx_get(2)->set_FillType(FillType::Solid);

pres->get_MasterTheme()->get_FormatScheme()->get_FillStyles()->idx_get(2)->get_SolidFillColor()->set_Color(Color::get_ForestGreen());

pres->get_MasterTheme()->get_FormatScheme()->get_EffectStyles()->idx_get(2)->get_EffectFormat()->get_OuterShadowEffect()->set_Distance(10.f);

pres->Save(u"Design_04_Subtle_Moderate_Intense-out.pptx", SaveFormat::Pptx);

产生的填充颜色、填充类型、阴影效果等变化如下:

todo:image_alt_text

常见问题

我可以在不更改母版的情况下将主题应用于单个幻灯片吗?
是的。Aspose.Slides 支持幻灯片级别的主题覆盖,因此您可以仅在该幻灯片上应用本地主题,而保持母版主题不变(通过 SlideThemeManager)。

将主题从一个演示文稿迁移到另一个演示文稿的最安全方法是什么?
将幻灯片(含其母版)克隆到目标演示文稿中。这会保留原始的母版、布局以及关联的主题,从而保持外观一致。

如何查看所有继承和覆盖后的“有效”值?
使用 API 的“有效”视图(针对主题/颜色/字体/效果)。这些视图会返回在应用母版及任何本地覆盖后解析得到的最终属性。