VB6獲取Chrome地址欄的URL信息

上篇寫到了獲取IE8瀏覽器URL的通常方法,那這篇就寫下chrome的URL怎麼獲取。事實上,早期的chrome版本能夠經過跟IE8差很少方式獲取到URL信息。可是,如今chrome的控件都是DirectUI畫出來的,全部就沒有通常意義上hwnd能夠取。網上搜索了下,大多數都傾向於使用MSAA(Microsoft Active Accessibility)這種途徑來實現。感興趣的同窗能夠搜索下MSAA,這是一個頗有用的技術(由於不懂,我也就很少說了)。html

 

基於MSAA思想,windows下的UI程序均可以提供一種可供遍歷訪問的接口。而界面上各個控件都處於相似於樹的邏輯結構中,這使得第三方自動化控制成爲了可能。而MSAA是以COM形式存在,使用時只須要在「引用」中添加便可,很是方便。chrome

可能初次接觸MSAA的同窗還不能很好理解,關於UI結構的說明。但仔細思考下,本文這樣的遍歷和上篇根據hwnd的遍歷其實原理上是差很少的。windows

 

實現代碼以下:瀏覽器

  1 '使用IAccessible接口以前,請先引用Accessibility(oleacc.dll)
  2 '代碼參考了不少網上代碼,多數原做者無從考究,在此也就不列出了(請見諒)
  3 '@Advanced Miscrosoft Visual Basci 6.0
  4 'code by lichmama from cnblogs.com
  5 Private Type UUID
  6     Data1 As Long
  7     Data2 As Integer
  8     Data3 As Integer
  9     Data4(7) As Byte
 10 End Type
 11  
 12 Private Declare Function AccessibleObjectFromWindow Lib "oleacc" (ByVal hwnd As Long, _
 13     ByVal dwObjectID As Long, _
 14     ByRef riid As UUID, _
 15     ByRef ppvObject As Any) As Long
 16      
 17 Private Declare Function AccessibleChildren Lib "oleacc" (ByVal paccContainer As IAccessible, _
 18     ByVal iChildStart As Long, _
 19     ByVal cChildren As Long, _
 20     rgvarChildren As Variant, _
 21     pcObtained As Long) As Long
 22     
 23 '其實這一部分對整個程序來講沒什麼做用,在此列出僅僅方便別人查閱
 24 Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, _
 25     ByVal lpWindowName As String) As Long
 26     
 27 Private Enum NVADIRConstants
 28     NAVDIR_MIN = 0
 29     NAVDIR_UP = 1
 30     NAVDIR_DOWN = 2
 31     NAVDIR_LEFT = 3
 32     NAVDIR_RIGHT = 4
 33     NAVDIR_NEXT = 5
 34     NAVDIR_PREVIOUS = 6
 35     NAVIDR_FIRSTCHILD = 7
 36     NAVDIR_LASTCHILD = 8
 37     NAVDIR_MAX = 9
 38 End Enum
 39 
 40 'IAccessible Object Types
 41 Private Const CHILDID_SELF As Long = 0&
 42 Private Const ROLE_SYSTEM_TITLEBAR As Long = &H1&
 43 Private Const ROLE_SYSTEM_MENUBAR As Long = &H2&
 44 Private Const ROLE_SYSTEM_SCROLLBAR As Long = &H3&
 45 Private Const ROLE_SYSTEM_GRIP As Long = &H4&
 46 Private Const ROLE_SYSTEM_SOUND As Long = &H5&
 47 Private Const ROLE_SYSTEM_CURSOR As Long = &H6&
 48 Private Const ROLE_SYSTEM_CARET As Long = &H7&
 49 Private Const ROLE_SYSTEM_ALERT As Long = &H8&
 50 Private Const ROLE_SYSTEM_WINDOW As Long = &H9&
 51 Private Const ROLE_SYSTEM_CLIENT As Long = &HA&
 52 Private Const ROLE_SYSTEM_MENUPOPUP As Long = &HB&
 53 Private Const ROLE_SYSTEM_MENUITEM As Long = &HC&
 54 Private Const ROLE_SYSTEM_TOOLTIP As Long = &HD&
 55 Private Const ROLE_SYSTEM_APPLICATION As Long = &HE&
 56 Private Const ROLE_SYSTEM_DOCUMENT As Long = &HF&
 57 Private Const ROLE_SYSTEM_PANE As Long = &H10&
 58 Private Const ROLE_SYSTEM_CHART As Long = &H11&
 59 Private Const ROLE_SYSTEM_DIALOG As Long = &H12&
 60 Private Const ROLE_SYSTEM_BORDER As Long = &H13&
 61 Private Const ROLE_SYSTEM_GROUPING As Long = &H14&
 62 Private Const ROLE_SYSTEM_SEPARATOR As Long = &H15&
 63 Private Const ROLE_SYSTEM_TOOLBAR As Long = &H16&
 64 Private Const ROLE_SYSTEM_STATUSBAR As Long = &H17&
 65 Private Const ROLE_SYSTEM_TABLE As Long = &H18&
 66 Private Const ROLE_SYSTEM_COLUMNHEADER As Long = &H19&
 67 Private Const ROLE_SYSTEM_ROWHEADER As Long = &H1A&
 68 Private Const ROLE_SYSTEM_COLUMN As Long = &H1B&
 69 Private Const ROLE_SYSTEM_ROW As Long = &H1C&
 70 Private Const ROLE_SYSTEM_CELL As Long = &H1D&
 71 Private Const ROLE_SYSTEM_LINK As Long = &H1E&
 72 Private Const ROLE_SYSTEM_HELPBALLOON As Long = &H1F&
 73 Private Const ROLE_SYSTEM_CHARACTER As Long = &H20&
 74 Private Const ROLE_SYSTEM_LIST As Long = &H21&
 75 Private Const ROLE_SYSTEM_LISTITEM As Long = &H22&
 76 Private Const ROLE_SYSTEM_OUTLINE As Long = &H23&
 77 Private Const ROLE_SYSTEM_OUTLINEITEM As Long = &H24&
 78 Private Const ROLE_SYSTEM_PAGETAB As Long = &H25&
 79 Private Const ROLE_SYSTEM_PROPERTYPAGE As Long = &H26&
 80 Private Const ROLE_SYSTEM_INDICATOR As Long = &H27&
 81 Private Const ROLE_SYSTEM_GRAPHIC As Long = &H28&
 82 Private Const ROLE_SYSTEM_STATICTEXT As Long = &H29&
 83 Private Const ROLE_SYSTEM_TEXT As Long = &H2A&
 84 Private Const ROLE_SYSTEM_PUSHBUTTON As Long = &H2B&
 85 Private Const ROLE_SYSTEM_CHECKBUTTON As Long = &H2C&
 86 Private Const ROLE_SYSTEM_RADIOBUTTON As Long = &H2D&
 87 Private Const ROLE_SYSTEM_COMBOBOX As Long = &H2E&
 88 Private Const ROLE_SYSTEM_DROPLIST As Long = &H2F&
 89 Private Const ROLE_SYSTEM_PROGRESSBAR As Long = &H30&
 90 Private Const ROLE_SYSTEM_DIAL As Long = &H31&
 91 Private Const ROLE_SYSTEM_HOTKEYFIELD As Long = &H32&
 92 Private Const ROLE_SYSTEM_SLIDER As Long = &H33&
 93 Private Const ROLE_SYSTEM_SPINBUTTON As Long = &H34&
 94 Private Const ROLE_SYSTEM_DIAGRAM As Long = &H35&
 95 Private Const ROLE_SYSTEM_ANIMATION As Long = &H36&
 96 Private Const ROLE_SYSTEM_EQUATION As Long = &H37&
 97 Private Const ROLE_SYSTEM_BUTTONDROPDOWN As Long = &H38&
 98 Private Const ROLE_SYSTEM_BUTTONMENU As Long = &H39&
 99 Private Const ROLE_SYSTEM_BUTTONDROPDOWNGRID As Long = &H3A&
100 Private Const ROLE_SYSTEM_WHITESPACE As Long = &H3B&
101 Private Const ROLE_SYSTEM_PAGETABLIST As Long = &H3C&
102 Private Const ROLE_SYSTEM_CLOCK As Long = &H3D&
103 Private IID_IAccessible As UUID
104 Private Declare Function GetTickCount Lib "kernel32" () As Long
105 
106 Private Sub Form_Initialize()
107     With IID_IAccessible
108         .Data1 = &H618736E0
109         .Data2 = &H3C3D
110         .Data3 = &H11CF
111         .Data4(0) = &H81
112         .Data4(1) = &HC
113         .Data4(2) = &H0
114         .Data4(3) = &HAA
115         .Data4(4) = &H0
116         .Data4(5) = &H38
117         .Data4(6) = &H9B
118         .Data4(7) = &H71
119     End With
120 End Sub
121 
122 'using like: GetChromeUrl(FindWindow("Chrome_WidgetWin_1", vbNullString))
123 Private Function GetChromeUrl(ByVal hwnd As Long) As String
124     Dim objAcc As IAccessible
125 
126     Call AccessibleObjectFromWindow(hwnd, 0&, IID_IAccessible, objAcc)
127     If objAcc Is Nothing Then
128         Debug.Print "access failed"
129         Exit Function
130     End If
131     
132     GetChromeUrl = ViewAcc(objAcc)
133 End Function
134 
135 Private Function ViewAcc(ByVal objAcc As IAccessible) As String
136     On Error Resume Next
137     If objAcc.accName(CHILDID_SELF) = "地址和搜索欄" Then
138         ViewAcc = "http://" & objAcc.accValue(CHILDID_SELF)
139         Exit Function
140     ElseIf objAcc.accChildCount = 0 Then
141         Exit Function
142     End If
143     
144     Dim kids() As Variant
145     Dim kidscount As Long
146     Dim realcount As Long
147     
148     kidscount = objAcc.accChildCount
149     ReDim kids(kidscount - 1) As Variant
150     Call AccessibleChildren(objAcc, 0&, kidscount, kids(0), realcount)
151     For i = 0 To realcount - 1
152         If TypeName(kids(i)) = "IAccessible" Then
153             ViewAcc = ViewAcc(kids(i))
154             If ViewAcc <> "" Then Exit For
155         End If
156     Next
157 End Function

 

運行下看看效果:spa

1 Private Sub Command1_Click()
2     For i = 1 To 10
3         o = GetTickCount()
4         Debug.Print GetChromeUrl(FindWindow("Chrome_WidgetWin_1", vbNullString))
5         Debug.Print GetTickCount() - o & "ms"
6     Next
7 End Sub

看來這遞歸的效率有點低 code

http://www.cnblogs.com/lichmama/p/3824888.html
453ms
http://www.cnblogs.com/lichmama/p/3824888.html
422ms
http://www.cnblogs.com/lichmama/p/3824888.html
391ms
http://www.cnblogs.com/lichmama/p/3824888.html
406ms
http://www.cnblogs.com/lichmama/p/3824888.html
406ms
http://www.cnblogs.com/lichmama/p/3824888.html
391ms
http://www.cnblogs.com/lichmama/p/3824888.html
406ms
http://www.cnblogs.com/lichmama/p/3824888.html
406ms
http://www.cnblogs.com/lichmama/p/3824888.html
407ms
http://www.cnblogs.com/lichmama/p/3824888.html
390ms
相關文章
相關標籤/搜索