使用 PHP 管理演示文稿中的幻灯片切换

概述

为了更容易理解,我们演示了使用 Aspose.Slides for PHP via Java 管理简单幻灯片切换。开发人员不仅可以在幻灯片上应用不同的切换效果,还可以自定义这些切换效果的行为。

添加幻灯片切换

要创建一个简单的幻灯片切换效果,请按以下步骤操作:

  1. 创建一个 Presentation 类的实例。
  2. 通过 TransitionType 枚举,从 Aspose.Slides for PHP via Java 提供的切换效果中,对幻灯片应用 Slide Transition Type。
  3. 写入修改后的演示文稿文件。
  # 实例化 Presentation 类以加载源演示文稿文件
  $presentation = new Presentation("AccessSlides.pptx");
  try {
    # 对第 1 张幻灯片应用圆形过渡
    $presentation->getSlides()->get_Item(0)->getSlideShowTransition()->setType(TransitionType::Circle);
    # 对第 2 张幻灯片应用梳形过渡
    $presentation->getSlides()->get_Item(1)->getSlideShowTransition()->setType(TransitionType::Comb);
    # 将演示文稿写入磁盘
    $presentation->save("SampleTransition_out.pptx", SaveFormat::Pptx);
  } finally {
    $presentation->dispose();
  }

添加高级幻灯片切换

在上述部分中,我们只应用了一个简单的切换效果。现在,为了使该简单切换效果更好且可控,请按以下步骤操作:

  1. 创建一个 Presentation 类的实例。
  2. 从 Aspose.Slides for PHP via Java 提供的切换效果中,对幻灯片应用 Slide Transition Type。
  3. 您还可以将切换设置为单击时前进、特定时间后前进,或两者兼有。
  4. 如果幻灯片切换被设置为单击时前进,则仅在点击鼠标时才会前进。此外,如果设置了 Advance After Time 属性,则在指定的等待时间过去后,切换将自动前进。
  5. 将修改后的演示文稿写入为演示文稿文件。
  # 实例化表示演示文稿文件的 Presentation 类
  $pres = new Presentation("BetterSlideTransitions.pptx");
  try {
    # 在第 1 张幻灯片上应用圆形过渡
    $pres->getSlides()->get_Item(0)->getSlideShowTransition()->setType(TransitionType::Circle);
    # 设置 3 秒的切换时间
    $pres->getSlides()->get_Item(0)->getSlideShowTransition()->setAdvanceOnClick(true);
    $pres->getSlides()->get_Item(0)->getSlideShowTransition()->setAdvanceAfterTime(3000);
    # 在第 2 张幻灯片上应用梳形过渡
    $pres->getSlides()->get_Item(1)->getSlideShowTransition()->setType(TransitionType::Comb);
    # 设置 5 秒的切换时间
    $pres->getSlides()->get_Item(1)->getSlideShowTransition()->setAdvanceOnClick(true);
    $pres->getSlides()->get_Item(1)->getSlideShowTransition()->setAdvanceAfterTime(5000);
    # 在第 3 张幻灯片上应用缩放过渡
    $pres->getSlides()->get_Item(2)->getSlideShowTransition()->setType(TransitionType::Zoom);
    # 设置 7 秒的切换时间
    $pres->getSlides()->get_Item(2)->getSlideShowTransition()->setAdvanceOnClick(true);
    $pres->getSlides()->get_Item(2)->getSlideShowTransition()->setAdvanceAfterTime(7000);
    # 将演示文稿写入磁盘
    $pres->save("SampleTransition_out.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

Morph 过渡

Morph 过渡允许您在幻灯片之间实现平滑的运动动画。本文介绍了该概念以及如何使用 Morph 过渡。要有效使用 Morph 过渡,您需要拥有两张至少有一个共同对象的幻灯片。最简单的方法是复制幻灯片,然后在第二张幻灯片上将对象移动到不同的位置。

下面的代码片段演示了如何向演示文稿中添加包含文本的幻灯片副本,并为第二张幻灯片设置 morph type 过渡。

  $presentation = new Presentation();
  try {
    $autoshape = $presentation->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, 100, 100, 400, 100);
    $autoshape->getTextFrame()->setText("Morph Transition in PowerPoint Presentations");
    $presentation->getSlides()->addClone($presentation->getSlides()->get_Item(0));
    $shape = $presentation->getSlides()->get_Item(1)->getShapes()->get_Item(0);
    $shape->setX($shape->getX() + 100);
    $shape->setY($shape->getY() + 50);
    $shape->setWidth($shape->getWidth() - 200);
    $shape->setHeight($shape->getHeight() - 10);
    $presentation->getSlides()->get_Item(1)->getSlideShowTransition()->setType(TransitionType::Morph);
    $presentation->save("presentation-out.pptx", SaveFormat::Pptx);
  } finally {
    $presentation->dispose();
  }

Morph 过渡类型

新增的 TransitionMorphType 枚举表示不同的 Morph 幻灯片过渡类型。

TransitionMorphType 枚举有三个成员:

  • ByObject:Morph 过渡将在将形状视为不可分割对象的情况下执行。
  • ByWord:Morph 过渡将在可能的情况下按单词转移文本。
  • ByChar:Morph 过渡将在可能的情况下按字符转移文本。

下面的代码片段演示了如何为幻灯片设置 Morph 过渡并更改 Morph 类型:

  $presentation = new Presentation("presentation.pptx");
  try {
    $presentation->getSlides()->get_Item(0)->getSlideShowTransition()->setType(TransitionType::Morph);
    $presentation->getSlides()->get_Item(0)->getSlideShowTransition()->getValue()->setMorphType(TransitionMorphType::ByWord);
    $presentation->save("presentation-out.pptx", SaveFormat::Pptx);
  } finally {
    $presentation->dispose();
  }

设置切换效果

Aspose.Slides for PHP via Java 支持设置诸如“从黑色”“从左侧”“从右侧”等切换效果。要设置切换效果,请按以下步骤操作:

  • 创建一个 Presentation 类的实例。
  • 获取幻灯片的引用。
  • 设置切换效果。
  • 将演示文稿写入为 PPTX 文件。

下面的示例中,我们已经设置了切换效果。

  # 创建 Presentation 类的实例
  $presentation = new Presentation("AccessSlides.pptx");
  try {
    # 设置效果
    $presentation->getSlides()->get_Item(0)->getSlideShowTransition()->setType(TransitionType::Cut);
    $presentation->getSlides()->get_Item(0)->getSlideShowTransition()->getValue()->setFromBlack(true);
    # 将演示文稿写入磁盘
    $presentation->save("SetTransitionEffects_out.pptx", SaveFormat::Pptx);
  } finally {
    $presentation->dispose();
  }

FAQ

我可以控制幻灯片切换的播放速度吗?

可以。使用 TransitionSpeed 设置(例如 slow/medium/fast)来设置切换的 speed

我可以将音频附加到切换并使其循环吗?

可以。您可以为切换嵌入音频,并通过诸如 setSoundsetSoundModesetSoundLoop 等设置来控制行为,还可以使用 setSoundIsBuiltInsetSoundName 等元数据。

将相同的切换应用于每张幻灯片的最快方法是什么?

在每张幻灯片的切换设置中配置所需的切换类型;切换是按幻灯片存储的,因此在所有幻灯片上使用相同的类型即可实现一致的效果。

我如何检查幻灯片上当前设置的切换?

检查幻灯片的 transition settings 并读取其 transition type;该值会明确指示当前使用的效果。