problem with wm_gettext

Visual Basic

    Sponsored Links

    Next

  • 1. Selecting Graph Colours
    Hi I'm drawing a graph in a picture box, and would like to draw each line in a colour which is easily diffrentiated from the previous ones (in the same way Excel does). Is there an easy way to do this? Cheers Mark
  • 2. Implements statement question
    When using Implements statement, how can I assign the public variable in the class ? IN the example below, how can I assign the public variable Name and Address in class PersonalData ? Thank you. class PersonalData Public Name As String Public Address As String class Customer Implements PersonalData Private Property Get PersonalData_Address() As String PersonalData_Address = "CustomerAddress" End Property Private Property Let PersonalData_Address(ByVal RHS As String) End Property Private Property Let PersonalData_Name(ByVal RHS As String) End Property Private Property Get PersonalData_Name() As String PersonalData_Name = "CustomerName" End Property Form1 Dim clsPer As New PersonalData Dim clsCust As New Customer Set clsPer = clsCust clsPer.Address = "per address" clsPer.Name = "per name" MsgBox clsPer.Name & "" & clsPer.Address '-->> This returns "CustomerName" and "CustomerAddress" instead of "per name" and "per address".
  • 3. Form Closing Problem Help
    "ChrisP" < XXXX@XXXXX.COM > wrote in message news: XXXX@XXXXX.COM ... > I setup my form with a close button which executes code that checks if there > is unsaved data on my form. If there is unsaved data it will not allow them > to close without saving. > > However, the X at the top of the screen will bypass this check for unsaved > data. I tried putting the check in the Form Unload, but I had alot of errors > do to forms being open and the vbmodal errors. This was because the form > never unloaded it was still in the background. (1) How do you close the form > from the Form Unload? > > > the code works perfectly if it is in the Close command button. (2) How can I > do this check when the user clicks the X button, is this possible? > > Please help me with my 2 questions and then give me suggestions. thanks > ahead of time. > Chris > Check the help file for QueryUnload. It's a good place to put validation code. You can check to see why the form is closing and you can cancel the unload if your conditions aren't met. Jim Edgar
  • 4. creating TWAIN Datasource
    Hello Everybody, I am looking for a way to create a TWAIN datasource on a Terminal Server. This datasource only needs to provide images from a (user-)specified directory to an application that uses TWAIN datasources. So there would be no HW-driver involved. Does anybody know of a tool that already exists or a way to create such a tool with affordable effort? Thanks for reading Ole Weigelt
  • 5. Printer object question/problem
    I am troubleshooting a printer problem from VB6.0 The printer object calls work just fine, except when long strings are called. for example: Printer.Print "Some Very Long String goes here" The printer hardware is a receipt printer so the width of the paper is narrow and limited. I want the string to wrap to the next line(s) but am unable to locate information on how to accomplish this. Any suggestions? WB

problem with wm_gettext

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

Hello,
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.

***CODE***
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.

Ex:
Const WM_GETTEXT = &HD
Const WM_GETTEXTLENGTH = &HE
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

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

Similar Threads:

1.Problem with WM_STETEXT WM_GETTEXT

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

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 
continues.

Anyone have any thoughts on why this is happening?

Thanx in advance for your help
Steve 


2.no 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

5.WM_GETTEXT

Hi all,

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

Const WM_GETTEXT = &HD
Const WM_GETTEXTLENGTH = &HE

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?


6. ***** PROBLEM SOLVED ***** PROBLEM SOLVED ***** PROBLEM SOLVED *****

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

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



Return to Visual Basic

 

Who is online

Users browsing this forum: No registered users and 99 guest