ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作
Sub test()
MsgBox \设置工作表标签区域宽度为水平滚动条宽度的一半\ ActiveWindow.TabRatio = 0.5 End Sub
示例说明:TabRatio属性返回或设置工作簿中工作表标签区域的宽度与窗口水平滚动条的宽度比例(可为0到1之间的数字;默认值为0.6)。您可以改变上面程序中的数值进行测试。
示例02-13:设置激活窗口时运行的程序(OnWindow属性)
Sub testRunProcedure()
ThisWorkbook.Windows(1).OnWindow = \End Sub
‘********************************************************* Sub test()
MsgBox \您可以使用本窗口了!\End Sub
示例说明:本示例包括两个程序,主程序为testRunProcedure(),运行后,每当激活该窗口时,将会运行test()程序。其中,OnWindow属性返回或设置每当激活一个窗口时要运行的过程的名称,如本例中的test()程序。
示例02-14:获取指定窗口单元格区域地址(RangeSelection属性)
Sub testRangeSelection()
MsgBox \显示所选单元格地址\
MsgBox ActiveWindow.RangeSelection.Address End Sub
示例说明:本示例返回当前窗口中所选单元格区域的地址。RangeSelection属性返回指定窗口的工作表中的选定单元格(即使指定工作表中有图形对象处于活动状态,或者已选定图形对象,仍返回在图形对象被选定之前选定的单元格区域,这是该属性与Selection属性的区别)。
示例02-15:返回指定窗口中所选择的工作表(SelectedSheets属性)
Sub testSelectedSheet() Dim sh As Worksheet
For Each sh In ActiveWorkbook.Windows(1).SelectedSheets MsgBox \工作表\被选择\ Next End Sub
示例说明:SelectedSheets属性返回代表指定窗口中的所有选定工作表的集合。本示例中,如果您同时选择了活动工作簿中的工作表Sheet1和Sheet2,那么运行程序后,将会显示相应工作表被选择的信息。
示例02-16:排列窗口(Arrange方法)
2006年9月23日 - 7 - http://fanjy.blog.excelhome.net ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作
Sub testArrangeWindows()
MsgBox \请确保应用程序至少含有两个工作簿,这样才能看出效果\ MsgBox “窗口将平铺显示”
Windows.Arrange ArrangeStyle:=xlArrangeStyleTiled MsgBox “窗口将层叠显示”
Windows.Arrange ArrangeStyle:=xlArrangeStyleCascade MsgBox “窗口将水平排列显示”
Windows.Arrange ArrangeStyle:=xlArrangeStyleHorizontal MsgBox “窗口将垂直并排排列显示”
Windows.Arrange ArrangeStyle:=xlArrangeStyleVertical End Sub
示例说明:运行本程序后,将平铺应用程序中的所有窗口。Arrange方法用于对屏幕上的窗口进行排列,其语法为expression.Arrange(ArrangeStyle, ActiveWorkbook, SyncHorizontal, SyncVertical),所有的参数均为可选参数。其中,参数ArrangeStyle代表排列样式,可为以下常量:常量xlArrangeStyleTiled为缺省值,表示将平铺窗口;常量xlArrangeStyleCascade表示将窗口进行层叠;常量xlArrangeStyleHorizontal表示将水平排列所有窗口;常量xlArrangeStyleVertical表示将垂直并排排列所有窗口。您可以在上面的程序中测试这些常量,以体验效果。将参数ActiveWorkbook设置为True,则只对当前工作簿的可见窗口进行排列。如果为False,则对所有窗口进行排列。默认值为 False。设置参数SyncHorizontal为True,在水平滚动时同步滚动当前工作簿的所有窗口;如果为 False,则不同步滚动。设置参数SyncVertical为True,则在垂直滚动时同步滚动当前工作簿的所有窗口;如果为 False,则不同步滚动,默认值为 False。如果参数ActiveWorkbook为False或者省略,则参数SyncHorizontal和SyncVertical被忽略。
示例02-17:窗口尺寸(UsableHeight、UsableWidth、Height、Width属性)
Sub testActiveWindowSize()
MsgBox \当前窗口可用区域的高度为:\ MsgBox \当前窗口的高度为:\
MsgBox \当前窗口可用区域的宽度为:\ MsgBox \当前窗口的宽度为:\End Sub
示例02-18:水平排列两个窗口
Sub testWindowArrange()
Dim ah As Long, aw As Long
Windows.Arrange xlArrangeStyleTiled ah = Windows(1).Height
aw = Windows(1).Width + Windows(2).Width With Windows(1) .Width = aw .Height = ah / 2 .Left = 0 End With
2006年9月23日 - 8 - http://fanjy.blog.excelhome.net ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作
With Windows(2) .Width = aw .Height = ah / 2 .Top = ah / 2 .Left = 0 End With End Sub
示例说明:在运行本示例前,保证只打开了两个工作簿窗口。运行本示例后,将水平排列第一个窗口和第二个窗口,即每个窗口占用可使用的垂直空间的一半,占用所有水平空间。其中,Top属性表示从窗口顶端到可用区域顶端的距离,无法对最大化的窗口设置本属性;Left属性表示使用区域的左边界至窗口左边界的距离,如果窗口已最大化,则会返回一个负数;如果该属性被设置为0,则窗口的主边框刚好在屏幕上可见。
示例02-19:改变窗口的高度和宽度
Sub ChangeHeightAndWidth()
Dim iWinHeight As Long, iWinWidth As Long ActiveWindow.WindowState = xlNormal
MsgBox \将当前窗口的高度和宽度各减一半\ iWinHeight = ActiveWindow.Height iWinWidth = ActiveWindow.Width
ActiveWindow.Height = iWinHeight / 2 ActiveWindow.Width = iWinWidth / 2 MsgBox \恢复原窗口大小\
ActiveWindow.Height = iWinHeight ActiveWindow.Width = iWinWidth End Sub
示例说明:Height属性和Width属性必须在窗口处于正常显示状态(即不是最大化或最小化状态)时使用,否则会出错。
示例02-20:移动窗口
Sub SetWindowPosition()
Dim iTop As Long, iLeft As Long
MsgBox \将当前窗口向下移60,向右移90\ ActiveWindow.WindowState = xlNormal iTop = ActiveWindow.Top iLeft = ActiveWindow.Left
ActiveWindow.Top = iTop + 60 ActiveWindow.Left = iLeft + 90 MsgBox \恢复原来窗口的位置\ ActiveWindow.Top = iTop ActiveWindow.Left = iLeft End Sub
2006年9月23日 - 9 - http://fanjy.blog.excelhome.net ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作
示例说明:Top属性和Left属性必须在窗口处于正常显示状态(即不是最大化或最小化状态)时使用,否则会出错。
示例02-21:并排比较窗口
Sub testCompare()
MsgBox \与工作簿Book2进行并排比较\ Windows.CompareSideBySideWith \
MsgBox \启动窗口滚动功能,使两个窗口同时滚动\ Windows.SyncScrollingSideBySide = True MsgBox \将工作簿Book2最小化\
Windows(\ MsgBox \重置并排比较显示,恢复并排比较\ Windows.ResetPositionsSideBySide MsgBox \关闭并排比较\
ActiveWorkbook.Windows.BreakSideBySide End Sub
示例说明:在运行本示例前,确保在本窗口外还打开了一个名为Book2的窗口,或者您打开了一个其它命名的窗口,相应将上面程序中的Book2更换为您的窗口名。CompareSideBySideWith方法将以并排模式打开两个窗口,其中一个是当前活动窗口,另一个就是该方法所指定的窗口,如本例中的Book2。SyncScrollingSideBySide属性设置是否将两个窗口的滚动保持同步,如果为True,在对文档进行并排比较的同时启用窗口内容的滚动功能。若为False,则在对文档进行并排比较的同时禁用窗口内容的滚动功能。ResetPositionsSideBySide方法重置正在进行并排比较的两个工作表窗口的位置,例如,如果用户将正在进行比较的两个工作表窗口中的其中一个窗框最小化或最大化,就可以使用ResetPositionsSideBySide方法重置显示,以便这两个窗口再次并排显示。BreakSideBySide方法用来关闭并排比较。
示例02-22:返回或设置窗口中显示的视图(View属性)
Sub testView()
MsgBox \将视图切换为分页预览\
ActiveWindow.View = xlPageBreakPreview MsgBox \窗口视图为:\ MsgBox \将视图恢复正常\
ActiveWindow.View = xlNormalView
MsgBox \窗口视图为:\End Sub
示例02-23:返回窗口中可见单元格区域(VisibleRange属性)
Sub testVisibleRange()
MsgBox \当前窗口中共有\个单元格可见\End Sub
示例说明:如果窗口中有部分行列的单元格可见,也包括在可见单元格区域中。
2006年9月23日 - 10 - http://fanjy.blog.excelhome.net ExcelVBA>>ExcelVBA编程入门范例>>窗口(Window对象)基本操作
示例02-24:创建窗口(NewWindow方法)
Sub testNewWindow()
MsgBox \为活动窗口创建一个副本\ ActiveWindow.NewWindow
MsgBox \所创建窗口的窗口号为\End Sub
示例说明:本示例中,NewWindow方法为指定窗口(本例中为当前活动窗口)创建一个副本,然后显示该副本窗口的窗口号。注意,窗口号与窗口索引(Index属性)的不同,例如名称为“Book1.xls:2”的窗口,其窗口号为2,而窗口索引为该窗口在Windows集合中的位置,可以为窗口名称或编号。
示例02-25:设置窗口大小(Zoom属性)
Sub testWindowDisplaySize()
MsgBox \将窗口大小设置为与选定区域相适应的大小\ ActiveWindow.Zoom = True MsgBox \以双倍大小显示窗口\ ActiveWindow.Zoom = 200 MsgBox \以正常大小显示窗口\ ActiveWindow.Zoom = 100 End Sub
示例说明:Zoom属性将以百分数的形式(100表示正常大小,200表示双倍大小,以此类推)返回或设置窗口的显示大小。如果本属性为 True,则可将窗口大小设置成与当前选定区域相适应的大小。本功能仅对窗口中当前的活动工作表起作用,若要对其他工作表使用本属性,必须先激活该工作表。
示例02-26:激活窗口(ActivateNext方法和ActivatePrevious方法)
[示例02-26-01]
Sub testActivateWindow1()
MsgBox \若已打开Book1.xls、Book2.xls和Book3.xls三个工作簿且Book1.xls为当前窗口\则按Book3.xls-Book2.xls-Book1.xls依次激活窗口\ ActiveWindow.ActivateNext
MsgBox \激活工作簿:\ ActiveWindow.ActivateNext
MsgBox \激活工作簿:\ ActiveWindow.ActivateNext
MsgBox \激活工作簿:\End Sub
[示例02-26-02]
Sub testActivateWindow2()
MsgBox \若已打开Book1.xls、Book2.xls和Book3.xls三个工作簿且Book1.xls为当前窗口\则按Book2.xls-Book3.xls-Book1.xls依次激活窗口\ ActiveWindow.ActivatePrevious
2006年9月23日 - 11 - http://fanjy.blog.excelhome.net