在 PHP 中管理演示文稿主题

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

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

theme-constituents

更改主题颜色

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

下面的 PHP 代码演示了如何更改主题的强调颜色:

  $pres = new Presentation();
  try {
    $shape = $pres->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 10, 100, 100);
    $shape->getFillFormat()->setFillType(FillType::Solid);
    $shape->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

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

  $fillEffective = $shape->getFillFormat()->getEffective();
  $effectiveColor = $fillEffective->getSolidFillColor();
  echo(sprintf("Color [A=%d, R=%d, G=%d, B=%d]", $effectiveColor->getAlpha(), $effectiveColor->getRed(), $effectiveColor->getGreen(), $effectiveColor->getBlue()));

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

  $otherShape = $pres->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 120, 100, 100);
  $otherShape->getFillFormat()->setFillType(FillType::Solid);
  $otherShape->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
  $pres->getMasterTheme()->getColorScheme()->getAccent4()->setColor(java("java.awt.Color")->RED);

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

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

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

additional-palette-colors

1 - 主主题颜色

2 - 附加调色板中的颜色。

下面的 PHP 代码演示了从主主题颜色获取附加调色板颜色并将其用于形状的操作:

  $presentation = new Presentation();
  try {
    $slide = $presentation->getSlides()->get_Item(0);
    # 强调色 4
    $shape1 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 10, 50, 50);
    $shape1->getFillFormat()->setFillType(FillType::Solid);
    $shape1->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    # 强调色 4,亮度提升 80%
    $shape2 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 70, 50, 50);
    $shape2->getFillFormat()->setFillType(FillType::Solid);
    $shape2->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    $shape2->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->MultiplyLuminance, 0.2);
    $shape2->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->AddLuminance, 0.8);
    # 强调色 4,亮度提升 60%
    $shape3 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 130, 50, 50);
    $shape3->getFillFormat()->setFillType(FillType::Solid);
    $shape3->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    $shape3->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->MultiplyLuminance, 0.4);
    $shape3->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->AddLuminance, 0.6);
    # 强调色 4,亮度提升 40%
    $shape4 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 190, 50, 50);
    $shape4->getFillFormat()->setFillType(FillType::Solid);
    $shape4->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    $shape4->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->MultiplyLuminance, 0.6);
    $shape4->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->AddLuminance, 0.4);
    # 强调色 4,更暗 25%
    $shape5 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 250, 50, 50);
    $shape5->getFillFormat()->setFillType(FillType::Solid);
    $shape5->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    $shape5->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->MultiplyLuminance, 0.75);
    # 强调色 4,更暗 50%
    $shape6 = $slide->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 310, 50, 50);
    $shape6->getFillFormat()->setFillType(FillType::Solid);
    $shape6->getFillFormat()->getSolidFillColor()->setSchemeColor(SchemeColor->Accent4);
    $shape6->getFillFormat()->getSolidFillColor()->getColorTransform()->add(ColorTransformOperation->MultiplyLuminance, 0.5);
    $presentation->save($path . "example_accent4.pptx", SaveFormat::Pptx);
  } finally {
    if (!java_is_null($presentation)) {
      $presentation->dispose();
    }
  }

SchemeColor 映射到 ColorScheme 颜色

使用 SchemeColor 时,您可能会注意到它包含以下主题颜色值:Background1Background2Text1Text2

然而,Presentation::getMasterTheme()::getColorScheme() 返回 ColorScheme,它以以下方式公开相应的颜色:Dark1Dark2Light1Light2

此差异仅体现在命名上。这些值对应相同的主题颜色槽,映射是固定的:

  • Text1 = Dark1
  • Background1 = Light1
  • Text2 = Dark2
  • Background2 = Light2

Text/BackgroundDark/Light 之间没有动态转换。它们仅是相同主题颜色的交替名称。

此命名差异源自 Microsoft Office 的术语。旧版 Office 使用 Dark 1Light 1Dark 2Light 2,而新版 UI 将同样的槽显示为 Text 1Background 1Text 2Background 2

更改主题字体

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

  • +mn-lt - 正文字体 拉丁文(Minor Latin Font)
  • +mj-lt - 标题字体 拉丁文(Major Latin Font)
  • +mn-ea - 正文字体 东亚(Minor East Asian Font)
  • +mj-ea - 标题字体 东亚(Major East Asian Font)

下面的 PHP 代码演示了如何将拉丁字体分配给主题元素:

  $shape = $pres->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, 10, 10, 100, 100);
  $paragraph = new Paragraph();
  $portion = new Portion("Theme text format");
  $paragraph->getPortions()->add($portion);
  $shape->getTextFrame()->getParagraphs()->add($paragraph);
  $portion->getPortionFormat()->setLatinFont(new FontData("+mn-lt"));

下面的 PHP 代码演示了如何更改演示文稿的主题字体:

  $pres->getMasterTheme()->getFontScheme()->getMinor()->setLatinFont(new FontData("Arial"));

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

更改主题背景样式

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

todo:image_alt_text

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

  $pres = new Presentation("pres.pptx");
  try {
    $numberOfBackgroundFills = $pres->getMasterTheme()->getFormatScheme()->getBackgroundFillStyles()->size();
    echo("Number of background fill styles for theme is " . $numberOfBackgroundFills);
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

下面的 PHP 代码演示了如何为演示文稿设置背景:

  $pres->getMasters()->get_Item(0)->getBackground()->setStyleIndex(2);

索引说明:0 表示无填充。索引从 1 开始。

更改主题效果

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

todo:image_alt_text

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

下面的 PHP 代码演示了如何通过更改元素的部分来更改主题效果:

  $pres = new Presentation("Subtle_Moderate_Intense.pptx");
  try {
    $pres->getMasterTheme()->getFormatScheme()->getLineStyles()->get_Item(0)->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
    $pres->getMasterTheme()->getFormatScheme()->getFillStyles()->get_Item(2)->setFillType(FillType::Solid);
    $pres->getMasterTheme()->getFormatScheme()->getFillStyles()->get_Item(2)->getSolidFillColor()->setColor(java("java.awt.Color")->GREEN);
    $pres->getMasterTheme()->getFormatScheme()->getEffectStyles()->get_Item(2)->getEffectFormat()->getOuterShadowEffect()->setDistance(10.0);
    $pres->save("Design_04_Subtle_Moderate_Intense-out.pptx", SaveFormat::Pptx);
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

由此导致的填充颜色、填充类型、阴影效果等的变化如下:

todo:image_alt_text

常见问题

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

将主题从一个演示文稿迁移到另一个演示文稿的最安全方法是什么?
Clone slides 与其母版一起复制到目标演示文稿。这样可以保留原始母版、版式以及关联的主题,从而保持外观一致。

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