在 C++ 中管理演示文稿幻灯片母版

概述

幻灯片母版 定义了一组幻灯片的共享设计设置。它可以包含常用形状、徽标、背景、文字样式、主题设置和页脚设置。在 PowerPoint 中,编辑幻灯片母版是保持演示文稿一致性的常用方法,无需在每张幻灯片上重复相同的格式。

Aspose.Slides for C++ 支持相同的模型。一个演示文稿可以包含一个或多个母版幻灯片,每个母版幻灯片可以包含多个布局幻灯片。普通幻灯片通常不会直接引用母版幻灯片。相反,普通幻灯片使用布局幻灯片,而该布局幻灯片属于某个母版幻灯片。

层次结构如下:

  1. 幻灯片母版 - 定义共享的设计和主题。
  2. 布局幻灯片 - 定义占位符的具体排列以及布局级别的格式。
  3. 普通幻灯片 - 包含实际的演示内容并使用一个布局幻灯片。

母版幻灯片、布局幻灯片和普通幻灯片的层次结构

在 Aspose.Slides 中,幻灯片母版由 IMasterSlide 接口表示。演示文稿中的所有母版幻灯片可通过 Presentation::get_Masters 集合获取,该集合实现了 IMasterSlideCollection

访问幻灯片母版

在 PowerPoint 中,您可以通过 视图 > 幻灯片母版 打开幻灯片母版视图。

PowerPoint 视图选项卡上的幻灯片母版命令

在 Aspose.Slides 中,使用 get_Masters() 集合来访问母版幻灯片:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto firstMasterSlide = presentation->get_Master(0);
auto masterSlideCount = presentation->get_Masters()->get_Count();
auto firstMasterLayoutSlideCount = firstMasterSlide->get_LayoutSlides()->get_Count();

System::Console::WriteLine(System::String(u"Master slides: ") + masterSlideCount);
System::Console::WriteLine(System::String(u"Layouts in the first master: ") + firstMasterLayoutSlideCount);

presentation->Dispose();

您还可以通过布局获取普通幻灯片使用的母版幻灯片:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto slide = presentation->get_Slide(0);
auto layoutSlide = slide->get_LayoutSlide();
auto masterSlide = layoutSlide->get_MasterSlide();
auto masterSlideName = masterSlide->get_Name();

System::Console::WriteLine(masterSlideName);

presentation->Dispose();

幻灯片母版包含什么

母版幻灯片是一种类似幻灯片的对象。它实现了 IBaseSlide,因此公开了许多普通幻灯片和布局幻灯片使用的相同属性。母版特有的成员列在 IMasterSlide API 页面上。

常用的母版幻灯片成员包括:

成员 用途
get_Background() 设置母版级别的幻灯片背景。
get_Shapes() 存储放置在母版上的形状,例如徽标、图片框和共享文本。
get_LayoutSlides() 存储属于该母版的布局幻灯片。
get_ThemeManager() 提供对母版主题 API 的访问。
get_HeaderFooterManager() 控制母版及其子布局的页眉、页脚、日期和幻灯片编号。
GetDependingSlides() 返回通过其布局依赖于该母版的普通幻灯片。

向幻灯片母版添加图像

当您向母版幻灯片添加图像时,它会出现在使用该母版布局的幻灯片上。这对于徽标、水印、装饰带和其他重复的视觉元素非常有用。

以下示例向第一个母版幻灯片添加徽标:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto masterSlide = presentation->get_Master(0);
auto logoBytes = System::IO::File::ReadAllBytes(u"logo.png");
auto logoImage = presentation->get_Images()->AddImage(logoBytes);

masterSlide->get_Shapes()->AddPictureFrame(
    ShapeType::Rectangle,
    20.0f,
    20.0f,
    80.0f,
    80.0f,
    logoImage);

presentation->Save(u"presentation-with-logo.pptx", SaveFormat::Pptx);
presentation->Dispose();

有关图片框的更多信息,请参阅 Picture Frame

使用占位符

占位符通常在布局幻灯片上定义。母版幻灯片提供共享的样式和主题,供这些布局继承,而每个布局决定哪些占位符可用以及它们放置的位置。

在 PowerPoint 中,占位符命令可在幻灯片母版视图中使用。

PowerPoint 幻灯片母版视图中的插入占位符命令

要使用 Aspose.Slides 添加新占位符,请操作属于该母版的布局幻灯片:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto masterSlide = presentation->get_Master(0);
auto blankLayoutSlide = masterSlide->get_LayoutSlides()->GetByType(SlideLayoutType::Blank);

if (blankLayoutSlide == nullptr)
{
    blankLayoutSlide = masterSlide->get_LayoutSlides()->Add(SlideLayoutType::Blank, u"Blank");
}

blankLayoutSlide->get_PlaceholderManager()->AddTextPlaceholder(
    60.0f,
    120.0f,
    600.0f,
    80.0f);

presentation->get_Slides()->AddEmptySlide(blankLayoutSlide);
presentation->Save(u"presentation-with-placeholder.pptx", SaveFormat::Pptx);
presentation->Dispose();

您还可以格式化已存在于母版幻灯片上的占位符形状。以下示例找到标题占位符并应用线性渐变填充:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto masterSlide = presentation->get_Master(0);
System::SharedPtr<IAutoShape> titlePlaceholder;

for (auto&& shape : masterSlide->get_Shapes())
{
    auto autoShape = System::AsCast<IAutoShape>(shape);

    if (autoShape != nullptr &&
        autoShape->get_Placeholder() != nullptr &&
        autoShape->get_Placeholder()->get_Type() == PlaceholderType::Title)
    {
        titlePlaceholder = autoShape;
        break;
    }
}

if (titlePlaceholder != nullptr)
{
    auto fillFormat = titlePlaceholder->get_FillFormat();
    fillFormat->set_FillType(FillType::Gradient);

    auto gradientFormat = fillFormat->get_GradientFormat();
    gradientFormat->set_GradientShape(GradientShape::Linear);

    auto gradientStops = gradientFormat->get_GradientStops();
    auto redGradientColor = System::Drawing::Color::FromArgb(255, 0, 0);
    auto purpleGradientColor = System::Drawing::Color::FromArgb(128, 0, 128);

    gradientStops->Add(0.0f, redGradientColor);
    gradientStops->Add(255.0f, purpleGradientColor);
}

presentation->Save(u"presentation-title-style.pptx", SaveFormat::Pptx);
presentation->Dispose();

普通幻灯片继承的已格式化标题占位符

有关更多占位符和文本格式化选项,请参阅 Set Prompt Text in PlaceholderText Formatting

更改幻灯片母版背景

母版背景会被未覆盖的布局和幻灯片继承。以下示例为第一个母版幻灯片设置纯色背景:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto masterSlide = presentation->get_Master(0);
auto masterBackgroundColor = System::Drawing::Color::get_ForestGreen();

masterSlide->get_Background()->set_Type(BackgroundType::OwnBackground);
masterSlide->get_Background()->get_FillFormat()->set_FillType(FillType::Solid);
masterSlide->get_Background()->get_FillFormat()->get_SolidFillColor()->set_Color(masterBackgroundColor);

presentation->Save(u"presentation-master-background.pptx", SaveFormat::Pptx);
presentation->Dispose();

相关主题,请参阅 Presentation BackgroundPresentation Theme

将幻灯片母版克隆到另一个演示文稿

使用 IMasterSlideCollection::AddClone 将母版幻灯片复制到另一个演示文稿中。复制的母版随后可以被目标演示文稿中的布局和幻灯片使用。

auto sourcePresentation = System::MakeObject<Presentation>(u"source.pptx");
auto destinationPresentation = System::MakeObject<Presentation>(u"destination.pptx");

auto sourceMasterSlide = sourcePresentation->get_Master(0);
auto clonedMasterSlide = destinationPresentation->get_Masters()->AddClone(sourceMasterSlide);

destinationPresentation->Save(u"destination-with-master.pptx", SaveFormat::Pptx);
destinationPresentation->Dispose();
sourcePresentation->Dispose();

如果需要连同其母版一起克隆普通幻灯片,请参阅 Clone Slides

添加多个幻灯片母版

一个演示文稿可以包含多个母版幻灯片。当不同章节需要不同的品牌、页面结构或主题设置时,这非常有用。

PowerPoint 插入和管理母版幻灯片的命令

以下示例克隆默认母版,为克隆体设置不同的背景,在该克隆母版下创建布局,并基于该布局添加新幻灯片:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

auto defaultMasterSlide = presentation->get_Master(0);
auto sectionMasterSlide = presentation->get_Masters()->AddClone(defaultMasterSlide);
auto sectionMasterBackgroundColor = System::Drawing::Color::get_LightSteelBlue();

sectionMasterSlide->get_Background()->set_Type(BackgroundType::OwnBackground);
sectionMasterSlide->get_Background()->get_FillFormat()->set_FillType(FillType::Solid);
sectionMasterSlide->get_Background()->get_FillFormat()->get_SolidFillColor()->set_Color(sectionMasterBackgroundColor);

auto sourceBlankLayout = defaultMasterSlide->get_LayoutSlides()->GetByType(SlideLayoutType::Blank);

if (sourceBlankLayout == nullptr)
{
    sourceBlankLayout = defaultMasterSlide->get_LayoutSlide(0);
}

auto sectionBlankLayout = sectionMasterSlide->get_LayoutSlides()->AddClone(sourceBlankLayout);

presentation->get_Slides()->AddEmptySlide(sectionBlankLayout);
presentation->Save(u"presentation-with-multiple-masters.pptx", SaveFormat::Pptx);
presentation->Dispose();

比较幻灯片母版

可以使用从 IBaseSlide 继承的 Equals 方法比较母版幻灯片。比较会检查结构和静态内容,如形状、文本、格式、动画以及其他幻灯片设置。它不会比较唯一标识符(如幻灯片 ID)或动态占位符值(如当前日期)。

auto firstPresentation = System::MakeObject<Presentation>(u"first.pptx");
auto secondPresentation = System::MakeObject<Presentation>(u"second.pptx");
auto firstPresentationMasterCount = firstPresentation->get_Masters()->get_Count();
auto secondPresentationMasterCount = secondPresentation->get_Masters()->get_Count();

for (int32_t firstMasterIndex = 0;
     firstMasterIndex < firstPresentationMasterCount;
     firstMasterIndex++)
{
    for (int32_t secondMasterIndex = 0;
         secondMasterIndex < secondPresentationMasterCount;
         secondMasterIndex++)
    {
        auto firstMasterSlide = firstPresentation->get_Master(firstMasterIndex);
        auto secondMasterSlide = secondPresentation->get_Master(secondMasterIndex);
        auto areMasterSlidesEqual = firstMasterSlide->Equals(secondMasterSlide);

        if (areMasterSlidesEqual)
        {
            System::Console::WriteLine(
                System::String::Format(
                    u"first.pptx master #{0} equals second.pptx master #{1}",
                    firstMasterIndex,
                    secondMasterIndex));
        }
    }
}

secondPresentation->Dispose();
firstPresentation->Dispose();

更多信息,请参阅 Compare Presentation Slides

将幻灯片母版视图设为默认视图

使用 ViewProperties 上的 set_LastView 方法来控制 PowerPoint 首次打开的视图。以下示例以幻灯片母版视图打开演示文稿:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

presentation->get_ViewProperties()->set_LastView(ViewType::SlideMasterView);
presentation->Save(u"presentation-master-view.pptx", SaveFormat::Pptx);
presentation->Dispose();

有关更多视图设置,请参阅 Save Presentation

删除未使用的母版幻灯片

演示文稿有时会包含不再被任何普通幻灯片使用的母版幻灯片。删除未使用的母版可以减小文件大小并简化模板维护。

使用 MasterSlideCollection::RemoveUnusedget_Masters() 集合中删除未使用的母版:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

presentation->get_Masters()->RemoveUnused(true);
presentation->Save(u"presentation-clean.pptx", SaveFormat::Pptx);
presentation->Dispose();

您也可以使用低代码的 Compress::RemoveUnusedMasterSlides 方法:

auto presentation = System::MakeObject<Presentation>(u"presentation.pptx");

LowCode::Compress::RemoveUnusedMasterSlides(presentation);
presentation->Save(u"presentation-clean.pptx", SaveFormat::Pptx);
presentation->Dispose();

常见问题

幻灯片母版和布局幻灯片有什么区别?

幻灯片母版定义了共享的设计设置,如主题、背景、常见形状和文字样式。布局幻灯片属于某个母版幻灯片,定义了占位符的具体排列。普通幻灯片使用布局幻灯片,因此它既继承布局的设置,也继承母版的设置。

一个演示文稿可以包含多个幻灯片母版吗?

可以。一个演示文稿可以包含多个幻灯片母版。当不同章节需要不同的视觉系统或品牌时,请使用多个母版。

我应该在母版幻灯片还是布局幻灯片上添加占位符?

大多数情况下,应在布局幻灯片上添加占位符。将共享的视觉元素和共享的格式放在母版幻灯片上,然后在普通幻灯片将使用的布局上放置内容占位符。

我可以删除仍在使用的母版幻灯片吗?

不能。具有依赖幻灯片的母版幻灯片不能直接安全地删除。请先将这些幻灯片移动到另一个母版下的布局,或使用仅删除未使用母版的清理方法。