Solved

VB6.0, get the handle of an activex control on a form

Posted on 2011-02-22
11
1,380 Views
Last Modified: 2012-05-11
Hello,

I have a form with an ActiveX control on it for a html editor window.  The activex control does not have an inbuilt hWnd property.

How do I find the handle of thso control so I can pass it to a spellchecker etc that requires the handle.

Code samples would be appreciated.

Thank-you.
0
Comment
Question by:jcwiatr
  • 5
  • 4
  • 2
11 Comments
 
LVL 30

Expert Comment

by:SiddharthRout
Comment Utility
Use FindWindow API to get the hwnd of the form and then either use FindwindowEx API or EnumWindows API to get the hwnd of the activex control.

If you are unable to do it then upload the form.

Sid

ps: If you are an API fan like me, then I would suggest you to bookmark this page :)

http://allapi.mentalis.org/agnet/apiguide.shtml
0
 
LVL 45

Expert Comment

by:aikimark
Comment Utility
have you tried iterating through the CONTROLS collection?  If not mistaken, most controls should have an hwnd property.
Dim ctlThing As Control
For Each ctlThing In Me.Controls
  If ctlThing.Name = "the activex control you are seeking" Then
    Debug.Print ctlThing.Name, ctlThing.hWnd
  End If
Next

Open in new window

0
 
LVL 1

Author Comment

by:jcwiatr
Comment Utility
hi aikimark - sounds easy - on testing the statement -
For Each ctlThing In Me.Controls

generates an error on me.controls..

method or data method not found
0
 
LVL 1

Author Comment

by:jcwiatr
Comment Utility
aikimark, my mistake, i got it working and am getting the name of the control but when I add, ctlThing.hwnd I am getting the error Object does not support this property or method.  This makes sense I guess given there is no internal hWnd for this control.  I will give the API calls a go.
0
 
LVL 30

Expert Comment

by:SiddharthRout
Comment Utility
Can you upload your userform?

Sid
0
IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

 
LVL 30

Expert Comment

by:SiddharthRout
Comment Utility
Also what type of control is it?

Sid
0
 
LVL 1

Author Comment

by:jcwiatr
Comment Utility
just a basic form at this stage with an ActiveX control pinedit.ocx which is a html editor control.  I need the handle so I can bind a spell checker to it.

I have uploaded the form and control.  The file pinedit.txt in the archive needs to be renamed to pinedit.ocx and registerd.

Cheers. Form1.zip
0
 
LVL 30

Accepted Solution

by:
SiddharthRout earned 250 total points
Comment Utility
It seems like a user defined control created with IE and Scrollbars.

It doesn't have a property "hwnd" but spy++ did give me a hwnd.

I tried this code but since that control doesn't have a caption, I couldn't get the caption.

Here is the code that I tried.

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" _
(ByVal lpClassName As String, ByVal lpWindowName As String) As Long

Private Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" _
(ByVal hWnd1 As Long, ByVal hWnd2 As Long, _
ByVal lpsz1 As String, ByVal lpsz2 As String) As Long

Private Declare Function GetWindowTextLength Lib "user32.dll" Alias _
"GetWindowTextLengthA" (ByVal hwnd As Long) As Long

Private Declare Function GetWindowText Lib "user32.dll" Alias _
"GetWindowTextA" (ByVal hwnd As Long, ByVal lpString As _
String, ByVal cch As Long) As Long

Dim sInput As String
Dim hhhdc As Long, lhWndChild As Long
Dim textlen As Long '<~~ Length of text of title
Dim titleText As String '<~~ Text of the title
Dim slength As Long '<~~ Length of the returned string



Private Sub Command1_Click()
    '~~> Form Caption
    sInput = "Form1"
    
    '~~> Get Handle of the Form
    hhhdc = FindWindow(vbNullString, sInput)
    
    Debug.Print "Value of Parent Window " & titleText; " is , " & hhhdc
    
    '~~> loop through the Child Windows
    Do
        lhWndChild = FindWindowEx(hhhdc, lhWndChild, vbNullString, vbNullString)
        
        textlen = GetWindowTextLength(lhWndChild)
        titleText = Space(textlen + 1)
        '~~> Get the text of the window
        slength = GetWindowText(lhWndChild, titleText, textlen + 1)
        
        '~~> Extract information from the buffer
        titleText = Left(titleText, slength)
        
        Debug.Print "Value of Child Window " & titleText; " is , " & lhWndChild

    Loop While lhWndChild

End Sub

Open in new window


Sid
0
 
LVL 45

Expert Comment

by:aikimark
Comment Utility
I wonder if the ActiveX control is merely a container and might not be capable of handling messages, so doesn't have hWnd.
0
 
LVL 30

Expert Comment

by:SiddharthRout
Comment Utility
Yeah, seems like it is. It definitely has IE in it.

Sid
0
 
LVL 1

Author Comment

by:jcwiatr
Comment Utility
Thanks guys. I think you are right about the container.  Points awarded based on code to get the handle.  But I dont think i will be able to bind our spellchecker to it because of its internals.
Thanks for all the input.

0

Featured Post

Why You Should Analyze Threat Actor TTPs

After years of analyzing threat actor behavior, it’s become clear that at any given time there are specific tactics, techniques, and procedures (TTPs) that are particularly prevalent. By analyzing and understanding these TTPs, you can dramatically enhance your security program.

Join & Write a Comment

The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…

763 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

9 Experts available now in Live!

Get 1:1 Help Now