Result
property meaning:
Specifies the value that is returned to window in response to handling the message
But MSDN
does not says anymore:
http://msdn.microsoft.com/en-us/library/system.windows.forms.message.result%28v=vs.110%29.aspx
I will remark this quote words from the user @Idle_Mind in this question Trying to write a better WndProc Handling:
You can set the Result() property to change the way the message is handled.
It is just like a winapi function return success value? Zero = true and non-zero = false, or what is?
Someone could explain me really what means the value of that propertie, in which circunstances I should need to use this value, and show me a code example of how I can use it handling messages from a wndproc
sub?
UPDATE:
Example of how I'm trying to handle WM_CREATE message...
Protected Overrides Sub WndProc(ByRef m As Message)
Select Case m.Msg
Case &H1 ' WM_CREATE
m.Result = -1
End Select
MyBase.WndProc(m)
End Sub
Every window message (WM_CREATE, WM_DESTROY, WM_PAINT, WM_USER, etc, etc) is sent by something. Most message are sent by Windows in response to some user interaction or some API call. Others are sent by 3rd-party code (for example, when you call the Win32 API SendMessage
, it's the caller of SendMessage
that is directly sending the message). In any case, the sender of the message probably expects something in response. The expected response depends on the sender of the message and the message type.
In most cases, you'll probably want to follow the rules defined by Microsoft for the window message. For example, in the documentation for WM_CREATE, it says:
If an application processes this message, it should return zero to continue creation of the window. If the application returns –1, the window is destroyed and the CreateWindowEx or CreateWindow function returns a NULL handle.
When handling WM_CREATE messages, you should return the appropriate value as defined above. When handling other messages, you should return whatever the documentation says about that message. When handing a 3rd-party message such as WM_USER, the 3rd-party should clearly indicate what it expects.