• 在PowerPoint中用VBA代码实现幻灯片随机切换功能
  • 发布于 2个月前
  • 623 热度
    0 评论
本文介绍让幻灯片能够随机切换的VBA代码。
在PowerPoint中,打开VBE,插入一个标准模块,在其中输入下面的代码:
Sub RandomSlides()
 Dim i As Long
 Dim FirstSlide As Long
 Dim LastSlide As Long
 Dim RndSlide As Long
 
 FirstSlide = 2
 LastSlide = 6
 
 Randomize
 
 For i = FirstSlide To LastSlide
   RndSlide = Int((LastSlide - FirstSlide + 1) * Rnd + FirstSlide)
   ActivePresentation.Slides(i).MoveTo (RndSlide)
 Next i
End Sub
代码中,假设只有5张需要随机切换的幻灯片,如果你的幻灯片数量不只这些,可以结合实际调整变量FirstSlide和LastSlide的值。这样,每次运行RandomSlides过程后,幻灯片的顺序都会变化。你可以在第一张幻灯片中绘制一个形状,然后关联该过程,如下图1所示。

选取绘制的形状,单击功能区“插入”选项卡“链接”组中的“动作”按钮,在弹出的“操作设置”对话框中,选取“运行宏”单选按钮并从下拉列表中选取RandomSlides过程,如下图2所示。

这样,每次放映该PPT时,单击第一页中的箭头,就会按不同的顺序放映幻灯片。
如果只想随机放映偶数幻灯片或奇数幻灯片,那么可以使用以下VBA代码:
Sub RandomEvenSlides()
 Dim i As Long
 Dim FirstSlide As Long
 Dim LastSlide As Long
 Dim RndSlide As Long
 Dim EvenSlide As Boolean
 //堆代码 duidaima.com
 //False则仅奇数幻灯片随机排列
 EvenSlide = True
 
 FirstSlide = 2
 LastSlide = 6
 
 Randomize
 
 For i = FirstSlide To LastSlide Step 2
Generate:
   RndSlide = Int((LastSlide - FirstSlide + 1) * Rnd + FirstSlide)
   If EvenSlide = True Then
     If RndSlide Mod 2 = 1 Then GoTo Generate
   Else
     If RndSlide Mod 2 = 0 Then GoTo Generate
   End If
   ActivePresentation.Slides(i).MoveTo (RndSlide)
   If i < RndSlide Then ActivePresentation.Slides(RndSlide - 1).MoveTo (i)
   If i > RndSlide Then ActivePresentation.Slides(RndSlide + 1).MoveTo (i)
 Next i
End Sub
下面的VBA代码将反转PPT中的幻灯片,即颠倒幻灯片顺序:
Sub ReverseSlideOrder()
 Dim i As Long
 
 For i = 2 To 6
   ActivePresentation.Slides(6).MoveTo (i)
 Next i
End Sub
可以在幻灯片放映模式下自动无限循环浏览所有幻灯片,每次循环都有一个新的随机顺序,VBA代码如下:
Public Position As Integer
Public Range As Integer
Public AllSlides() As Integer
Sub ShuffleAndBegin()
 Dim i As Integer
 Dim j As Integer
 Dim n As Integer
 Dim temp As Integer
 Dim FirstSlide As Integer
 Dim LastSlide As Integer
 Dim RndSlide As Integer
 Dim EvenSlide As Boolean
 '根据实际修改值
 FirstSlide = 2
 LastSlide = 6
 Range = (LastSlide - FirstSlide)
 ReDim AllSlides(0 To Range)
 For i = 0 To Range
   AllSlides(i) = FirstSlide + i
 Next i
 Randomize
 For n = 0 To Range
   j = Int((Range + 1) * Rnd)
   temp = AllSlides(n)
   AllSlides(n) = AllSlides(j)
   AllSlides(j) = temp
 Next n
 Position = 0
 ActivePresentation.SlideShowWindow.View.GotoSlide AllSlides(Position)
End Sub
Sub Advance()
 Position = Position + 1
 If Position > Range Then
   ShuffleAndBegin
 Else
   ActivePresentation.SlideShowWindow.View.GotoSlide AllSlides(Position)
 End If
End Sub
标题幻灯片必须带有一个运行ShuffleAndBegin过程并初始化代码的按钮。在我们的范围内所有将被打乱的幻灯片中,必须在所有这些幻灯片上放置一个形状,并且该形状必须在单击时运行Advance过程。随机幻灯片的第一个循环将在单击形状时出现。第一个循环结束后,幻灯片将再次洗牌,单击该形状后,将出现新随机循环的下一张幻灯片。
用户评论