problem with wm_gettext

Visual Basic

    Sponsored Links


  • 1. INet FTP Progress
    I am using the code below ( found via google ) to upload a file to a web site via FTP and it appears to work OK. ( VB5 Pro SP3 ) However, I have 3 basic questions : 1. Is this method any more / less secure and reliable ( data accuracy ) than using a commercial package like WS-Ftp or CuteFtp ? 2. Do I need to 'disconnect' the INet control after uploading the file ? If so, how do I do it ? 3. How can I get stats as the upload occurs : ie.. bytes transfered & transfer rate MANY THANKS for any responses, opinions and / or sample code. Regards Dave Private Sub cmdUploadNow_Click() With Inet1 .Execute "ftp://username : XXXX@XXXXX.COM ",_ "PUT c:\FileToUpload.txt _ /usr/www/users/myweb/TestDir/FileToUpload.txt" End With End Sub Private Sub Inet1_StateChanged(ByVal State As Integer) List1.AddItem "The Internet Control State Changed to " & State, 0 End Sub
  • 2. MaskColor property of ImageList control
    Hello Experts, I have VB6EE on Win98SE. I have following code in a project which I am using to experiment ImageList control: Private Sub Command1_Click() ImageList1.MaskColor = vbWhite Set Image1.Picture = ImageList1.ListImages(5).Picture 'bmp Set Picture1.Picture = ImageList1.ListImages(5).Picture 'bmp Set Picture2.Picture = ImageList1.ListImages(2).Picture 'ico Set Image2.Picture = ImageList1.ListImages(2).Picture 'ico Set Picture3.Picture = ImageList1.Overlay(2, 2) 'ico, ico Set Command2.Picture = ImageList1.ListImages(2).Picture MsgBox ImageList1.MaskColor End Sub This code works well except MaskColor has no effect on any image and all images are appearing with all of their colours without any transparency. What's wrong with the code? What else do I have to do to make MaskColor property effective? Thank you, ----------------------------------- Allah says to Mankind: "Then which of the favours of your Lord will ye deny?"
  • 3. OCX Missing
    One of my older programs no longer works. The error message says "CRYSTL32.OCX" not correctly registered. the file is present in my Windows\System directory. How do I get it re-registered. I am running Windows98, and the program was written in VB5. Thanks, Lenny
  • 4. Determine WSH version
    Does anyone know of a way to determine the version of WSH installed on a machine using VB? Thanks in advance.
  • 5. Open MSN messenger using VB
    I want to activate MSN messager and/or Remote Assistance from my program. Can I do that?

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 6 guest