如何使用vba在powerpoint中应用特定布局?

时间:2012-02-05 07:20:26

标签: vba powerpoint-vba

我正在研究一个项目。在那里,我制作了一个自定义主题,其中包括一个主幻灯片和可能的布局。 所以基本上我想将特定的布局应用于特定的幻灯片。那么有没有办法通过编程方式来做到这一点。 喜欢:

  

activepresentation.Slides(1).Layout = “layoutname”

我知道上面的代码是错误的,但我希望这样的东西通过名称来调用特定的布局。为了您的信息,我的布局名称是“没有客户标识的标题”。

由于

2 个答案:

答案 0 :(得分:5)

ActivePresentation.Slides(1).CustomLayout = ActivePresentation.Designs(1).SlideMaster.CustomLayouts(x)

其中x是表示自定义布局的布局集合的索引。

与PPT OM中的大多数其他此类集合不同,这个集合似乎无法接受索引或名称。它必须是一个索引。

如果您需要使用该名称,请编写一个迭代CustomLayouts集合的函数,直到找到您所在的名称并返回索引。

答案 1 :(得分:3)

使用以下代码

Sub ApplyLayoutByIndex()

    Dim sld As Slide
    Dim shp As Shape
    Dim xName As String
    Set sld = Application.ActiveWindow.View.Slide
    Dim xIndex As Integer

    xName = "A final slide"

    xIndex = getLayoutIndexByName(xName)

    If xIndex = 0 Then
    MsgBox "The layout name" & xName & "not found. Check the name of the layout", vbOKOnly
    Exit Sub
    End If

    sld.CustomLayout = ActivePresentation.Designs(1).SlideMaster.CustomLayouts(xIndex)

    End Sub

    Function getLayoutIndexByName(xName As String) As Integer
    ActivePresentation.Designs(1).SlideMaster.CustomLayouts.Item (1)
    With ActivePresentation.Designs(1).SlideMaster.CustomLayouts
        For i = 1 To .Count
            If .Item(i).Name = xName Then
            getLayoutIndexByName = i
            Exit Function
            End If
        Next
    End With

    End Function

谢谢!