problem with wm_gettext

Visual Basic

    Sponsored Links


  • 1. User Event won't fire.
    I followed the "RaiseEvent" example provided in the VB6 help, and the event won't fire. Does anyone see the problem in the code that follows: Event Sink; Option Explicit Private WithEvents X As MyEvents Dim E As MyEvents Private Sub Form_Load() Set E = New MyEvents End Sub Private Sub Form_Click() E.dspMsgTime InputBox("Enter Message:") End Sub Private Sub X_MsgTime(ByVal Msg As String, ByVal timeMsg As Date) MsgBox "X_MsgTime: " & Msg & " @" & timeMsg MyLabel.Caption = Msg & " @" & timeMsg End Sub Event Source (in class module named MyEvents); Option Explicit Public Event MsgTime(ByVal Msg As String, ByVal timeMsg As Date) Public Sub dspMsgTime(Msg As String) MsgBox "dspMsgTime: Pre-RaiseEvent; Msg = " & Msg RaiseEvent MsgTime(Msg, Now) MsgBox "dspMsgTime: Post-RaiseEvent" End Sub The various MsgBox calls are provided as diagnostics; the MsgBox in X_MsgTime is not displayed, nor is the label (MyLabel) changed. X.
  • 2. Mike Williams, your services are required in Aisle Graphics
    Or anyone who is available: news://
  • 3. Component Handles
    I have a form with three visable items: a textbox, a label, and a button. I'm simply trying to retrieve the handle of the textbox. I've used FindWindow to retrieve the handle of the form, and have been using FindWindowsEx to try and retrieve the handle of the Textbox. This works if the textbox is the only entity on the form, but fails when there are other items on the form. The only way I have been able to get FindWindowEx to return anything is with the following format: FindWindowEx (hndl, vbNullString, vbNullString). According to "Appleman" I should be able to enter the title of the item in the third parameter (eg. "myTextBox"), but that only returns 0, I've tried entering "TextBox" for the class in the second parameter, but again that returns 0. This seems like it should be easy BUT? Does anyone have any suggestions? X.
  • 4. For Each
    Is there a way to write a For Each like this? This one errors out but I hope you get the idea. Dim ctrl As Timer ' <- need timer collection For Each ctrl In Controls Debug.Print If TypeName(ctrl) = "Timer" Then ' would not need this ctrl.Enabled = False End If Next It loops and shows some of the Timers then errors out at the Next. This works but cycles through all controls. Dim ctrl As Control For Each ctrl In Controls Debug.Print If TypeName(ctrl) = "Timer" Then ctrl.Enabled = False End If Next

problem with wm_gettext

Postby Jim Bauer » Sun, 25 Apr 2004 03:57:00 GMT

I am trying to get the text of a window by sending that window a
WM_GETTEXT message.
The below code compiles correctly, but the "buffer" string variable
I've declared is blank.

Private Declare Function SendMessage Lib "user32" Alias_
"SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam_
As Long, ByVal lParam As Long) As Long

Private Const WM_GETTEXT = &HD
Private Const wm_gettextlen = &HE

public function GetText(hwnd as long) as string
Dim buffer As String
SendMessage hwnd, WM_GETTEXT, wm_gettextlen, ByVal buffer
GetText = buffer
End Function

***END of code***
Any pointers as to what I'm doing wrong?
Cheers, Jim

Re: problem with wm_gettext

Postby Tom Esh » Sun, 25 Apr 2004 04:48:57 GMT

On Fri, 23 Apr 2004 18:57:00 GMT, Jim Bauer < XXXX@XXXXX.COM >

1) Your SendMessage declare is wrong for this case. lParam should be
ByVal As String, or simply As Any (specify ByVal in the call).

2) You must pre-allocate buffer to at least the number of chars
expected, iow at least what you tell it the size is in wParam. If
you've really no idea of the required size, you can use the
WM_GETTEXTLENGTH message. Note however this is a separate message and
requires a separate call. (Your wm_gettextlen const declare and usage
indicates you may be confused on this point.)

3) wParam should be the pre-allocated buffer size.

Declare Function SendMessage Lib "user32" Alias "SendMessageA" _
	(ByVal hWnd As Long, ByVal wMsg As Long, _
	ByVal wParam As Long, lParam As Any) As Long

Dim Buffer As String
Dim lSize As Long
Dim lRet As Long

lSize = SendMessage(hwnd, WM_GETTEXTLENGTH, 0&, ByVal 0&)
Buffer = String(lSize + 1, 0)
lRet = SendMessage(hwnd, WM_GETTEXT, lSize, ByVal Buffer)
If lRet > 0 Then
	Buffer = Left$(Buffer, lRet)
End If

MVP - Visual Basic
(please post replies to the newsgroup)

Similar Threads:


I have written two standard apps (not ActiveX) in VB6 SP6.  These apps 
communicate with one another via SendMessage API utilizing hidden text boxes 

The scenario is the "server" app has a few hidden textboxes (channels) which 
it uses to send various commands to the "client" app.  When the server 
starts the client app (Shell, not ActiveX) it passes the wHnd to those 
textboxes as command line args.  The client app then while running (this app 
runs a never ending loop) at regular frequent intervals issues a SendMessage 
WM_GETXT to the various channels (depending on where in the processing loop 
it is) to get instructions from the server.  The client also issues 
SendMessage WM_SETTEXT messages (to a different window on the server) to 
provide status and progress info back to the server.

The problem is that it appears as though the client app hangs after issuing 
the WM_GETTEXT message until some event occurs on the client.  The event 
that I know will wake the client back up is a mouse_move over its form. 
This is a problem since the client has no reason to have a UI (it is a 
background process).  Any way here is the scenario; App1 (the server) starts 
and shell starts App2 (the client). App2 then goes into a polling loop 
polling the hidden text boxes on App1 for instructions.  For debugging 
purposes I have added a form to App2 that simply displays one text box for 
each hidden text box in App1 and populates those text boxes with the text 
commands received via SendMessage WM_GETTEXT calls.  With both windows 
(App1s and App2s) visible I click a button on App1 which sends a command to 
one of the hidden communication textboxes.  In the App2 window I should see 
the text displayed in the corresponding textbox.  I do not though, and 
infact it appears (from other debug messages which should but are not being 
shown in another textbox on App2) as though App2 is hung, however if I then 
move the mouse over App2's window the app un-hangs receives the command and 

Anyone have any thoughts on why this is happening?

Thanx in advance for your help
Steve result with WM_GETTEXT

3.WM_GETTEXT hangs up

Hi all

I noticed that when I try to get text from one particular window calling 
SendMessage(hWnd, WM_GETTEXT...
the application hangs up until I close it using Task Manager.
For all other windows this call works fine.
The window's class = "Shell Embedding", invisible, RECT=0,0,0,0
Any ideas?
Definitely, I didn't have this problem yesterday, because I tested my 
application sending this message to all windows in the desktop tree (about 
1060 of them).
By the way I've got only one window of this class.

Thank you

4.WM_GETTEXT function


Hi all,

I'm trying to capture the text from a popup window (i.e. a MsgBox). The code


Dim lHandle As Long
Dim length  As Long
Dim result  As Long
Dim strtmp  As String

lHandle = FindWindow(vbNullString, "Some Popup")

 If lHandle <> 0 Then

    length = SendMessage(lHandle, WM_GETTEXTLENGTH, ByVal 0, ByVal 0) + 1

    strtmp = Space(length - 1)
    result = SendMessage(lHandle, WM_GETTEXT, ByVal length, ByVal strtmp)

 End If

gives me the title of the popup window ('Some Popup') but not the msg on the
popup. How kan I get the message?


7. Unknown pointer problem between Visual Basic and C (problem solved)

8. problems converting C# code to (MSMQ formatter problem)

Return to Visual Basic


Who is online

Users browsing this forum: No registered users and 31 guest