返回介绍

Range 方法

发布于 2019-10-04 14:07:59 字数 4926 浏览 1148 评论 0 收藏 0

全部显示

应用于Shapes 对象的 Range 方法。

返回ShapeRange 对象,该对象代表一个 Shapes 集合中的形状子集。

expression.Range(Index)

expression必选。该表达式返回一个Shapes 集合对象。

Index可选。Variant 类型。要包含在范围内的单个形状。可以是 Integer 类型值(指定形状的索引号)、String 类型值(指定形状的名称)或者数组(包括整数或字符串)。如果忽略此参数,则Range 方法返回指定集合中的所有对象。

应用于GroupShapes 对象的 Range 方法。

返回一个ShapeRange 对象。

expression.Range(Index)

expression必选。该表达式返回上述对象之一。

Index必选。Variant 类型。要包含在范围内的单个形状。可以是 Integer 类型值(指定形状的索引号)、String 类型值(指定形状的名称)或者数组(包括整数或字符串)。如果忽略此参数,则Range 方法返回指定集合中的所有对象。

应用于Slides 对象的 Range 方法。

返回SlideRange 对象,该对象代表一个Slides 集合中的幻灯片子集。

expression.Range(Index)

expression必选。该表达式返回一个 Slides 集合对象。

Index可选。Variant 类型。要包含在范围内的单张幻灯片。可以是 Integer 类型值(指定形状的索引号)、String 类型值(指定形状的名称)或者数组(包括整数或字符串)。如果忽略此参数,则Range 方法返回指定集合中的所有对象。

说明

虽然用Range 方法可以返回任意数量的形状或幻灯片,但是如果只想返回集合中的单个成员,则使用Item 方法更简单。例如,Shapes(1)Shapes.Range(1) 简单,Slides(2)Slides.Range(2) 简单。

若要为Index 指定一个整数或字符串数组,可以使用 Array 函数。例如,以下指令返回用名称指定的两个形状。

Dim myArray() As Variant, myRange As Object
myArray = Array("Oval 4", "Rectangle 5")
Set myRange = ActivePresentation.Slides(1).Shapes.Range(myArray)

示例

应用于 Shapes 对象。

本示例设置 myDocument 中第一个形状和第三个形状的填充图案。

Set myDocument = ActivePresentation.Slides(1)
myDocument.Shapes.Range(Array(1, 3)).Fill _
 .Patterned msoPatternHorizontalBrick

本示例设置第一张幻灯片中形状 Oval 4 和 Rectangle 5 的填充图案。

Dim myArray() As Variant, myRange As Object
myArray = Array("Oval 4", "Rectangle 5")
Set myRange = ActivePresentation.Slides(1).Shapes.Range(myArray)
myRange.Fill.Patterned msoPatternHorizontalBrick

本示例设置第一张幻灯片中所有形状的填充图案。

ActivePresentation.Slides(1).Shapes.Range.Fill _
    .Patterned Pattern:=msoPatternHorizontalBrick

本示例设置第一张幻灯片中第一个形状的填充图案。

Set myDocument = ActivePresentation.Slides(1)
Set myRange = myDocument.Shapes.Range(1)
myRange.Fill.Patterned msoPatternHorizontalBrick

本示例创建一个包含第一张幻灯片中所有自选图形的数组,并用它定义一个形状范围,然后在该范围内水平地分布所有这些形状。

With myDocument.Shapes
    numShapes = .Count

    'Continues if there are shapes on the slide
    If numShapes > 1 Then
        numAutoShapes = 0
        ReDim autoShpArray(1 To numShapes)
        For i = 1 To numShapes

            'Counts the number of AutoShapes on the Slide
            If .Item(i).Type = msoAutoShape Then
                numAutoShapes = numAutoShapes + 1
                autoShpArray(numAutoShapes) = .Item(i).Name
            End If
        Next

        'Adds AutoShapes to ShapeRange
        If numAutoShapes > 1 Then
            ReDim Preserve autoShpArray(1 To numAutoShapes)
            Set asRange = .Range(autoShpArray)
            asRange.Distribute msoDistributeHorizontally, False
        End If
    End If
End With

应用于 Slides 对象。

本示例设置第一张幻灯片和第三张幻灯片的标题颜色。

Set mySlides = ActivePresentation.Slides.Range(Array(1, 3))
mySlides.ColorScheme.Colors(ppTitle).RGB = RGB(0, 255, 0)

本示例设置幻灯片“Slide6”和幻灯片“Slide8”的标题颜色。

Set mySlides = ActivePresentation.Slides _
 .Range(Array("Slide6", "Slide8"))
mySlides.ColorScheme.Colors(ppTitle).RGB = RGB(0, 255, 0)

本示例设置当前演示文稿中所有幻灯片的标题颜色。

Set mySlides = ActivePresentation.Slides.Range
mySlides.ColorScheme.Colors(ppTitle).RGB = RGB(255, 0, 0)

本示例创建一个包含当前演示文稿中所有标题幻灯片的数组,并用它定义一个幻灯片范围,然后设置该范围内所有幻灯片的标题颜色。

Dim MyTitleArray() As Long
Set pSlides = ActivePresentation.Slides
ReDim MyTitleArray(1 To pSlides.Count)
For Each pSlide In pSlides
 If pSlide.Layout = ppLayoutTitle Then
 nCounter = nCounter + 1
 MyTitleArray(nCounter) = pSlide.SlideIndex
 End If
Next pSlide
ReDim Preserve MyTitleArray(1 To nCounter)

Set rngTitleSlides = ActivePresentation.Slides.Range(MyTitleArray)
rngTitleSlides.ColorScheme.Colors(ppTitle).RGB = RGB(255, 123, 99)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文