首页 > 单独文章 > 正文

Word中以VBA实现的自动翻页功能与文档结构图显示不同步

时间:2012-05-11 09:22:57 作者:officeba 【认证】

题目:我是VBA的初学者,手上有长Word文档需浏览,为逼迫本身可以或许看完,欲实现主动翻页功能,用了以下两种编制:
编制一

  1. Option Explicit  
  2. Dim 结束翻页 As Boolean  
  3. Dim SSS As Integer  
  4.  
  5. Sub stop()  
  6.     结束翻页 = True  
  7. End Sub  
  8.  
  9. Sub start()  
  10.   SSS = Timer 
  11.   结束翻页 = false  
  12.   Do  
  13.     If 结束翻页=true Then Exit Do  
  14.     If Timer >= SSS + 5 Then  
  15.         Application.Browser.Next  
  16.         SSS = Timer 
  17.         End If  
  18.         DoEvents  
  19.   Loop  
  20. End Sub 
  21.  
  22. ========编制二  
  23. Option Explicit  
  24. Dim 结束翻页 As Boolean  
  25.  
  26. Sub stop()  
  27.     结束翻页 = True  
  28. End Sub  
  29.  
  30. Sub start()  
  31.   结束翻页 = False  
  32.   Application.OnTime Now + TimeValue("00:00:05"), "do_it"  
  33. End Sub  
  34.  
  35. Sub do_it()  
  36.   If 结束翻页 = False Then  
  37.   Application.Browser.Next  
  38.   start  
  39.   End If  
  40. End Sub 

两种编制都可实现翻页的功能,但第一种编制用起来太夸大,CPU总是100%;第二种编制比较抱负,绝对的轻松。
但是题目是,我的Word文档都设有九级目次,看书的时辰习惯于将正文与文档布局图对比着看,以理清本身的思路。在快速速读的时辰,这个功能就更有感化。
第一种编制,随着主动翻页,文档布局图中的各级目次也会随着跳转,书翻到哪里,目次的反蓝显示也就跳到哪里。
第二种编制,却没法实现这个功能,目次的反蓝显示永久只在初始的位置。除非书主动翻页今后,在页面中用鼠标点一下,反蓝的目次才会跳转。
这个题目我想是出在利用时候控件的时辰,闪动的光标的性质和正常的光标插入点的性质有点不一样,在翻页后用了插入“”的语句也不可。
请各位前辈帮忙解决文档布局图中目次反蓝显示随主动翻页跳转的题目。

解答:
可以试下:

  1. Option Explicit  
  2. Dim myByte As Byte  
  3. Sub myStart()  
  4.     If Selection.Paragraphs(1).Range.IsEqual(ActiveDocument.Content.Paragraphs.Last.Range) = True Then  
  5.         myByte = 100 
  6.     Else  
  7.         myByte = 10 
  8.     End If  
  9.     Application.OnTime Now + TimeValue("00:00:05"), "Do_it"  
  10.     Application.ScreenUpdating = False 
  11.     ActiveDocument.ActiveWindow.DocumentMap = False 
  12.     ActiveDocument.ActiveWindow.DocumentMap = True 
  13.     Application.ScreenUpdating = True 
  14. End Sub  
  15. Sub Do_it()  
  16.     If myByte = 0 Then  
  17.         Selection.HomeKey wdStory  
  18.         myStart  
  19.     ElseIf myByte = 10 Then  
  20.         Selection.MoveDown Unit:=wdScreenCount:=1 
  21.         myStart  
  22.     Else  
  23.         myByte = 0 
  24.     End If  
  25. End Sub  
  26. Sub myStop()  
  27.     myByte = 100 
  28. End Sub 

相关文章

同类最新