Jump to content

Recommended Posts

Posted

Hi everybody :)
Concerning GUIRegisterMsg, we read this in the Wiki tutorial :

There are 2 ways we can still run something long and complicated but still leave the handler quickly: either set a flag or action a dummy control.

If we set a flag inside the handler, we can then look for it within our idle loop and run our blocking code from here without affecting the handler at all.

If we action a dummy control then we do not even have to look for the flag!

Reading this, we might think that the dummy control is a better solution than the flag. But look at the given example :

#include <MsgBoxConstants.au3>
#include <GUIConstantsEx.au3>
#include <WindowsConstants.au3>

; Whichever method we use, we need to declare the dummy control or the flag as a Global variable
Global $hLeftClick, $fRightClick = False

GUICreate("Click me!")

; Create a dummy control for the handler to action
$hLeftClick = GUICtrlCreateDummy()

GUISetState()

; Register our messages
GUIRegisterMsg($WM_LBUTTONUP, "_WM_LBUTTONUP")
GUIRegisterMsg($WM_RBUTTONUP, "_WM_RBUTTONUP")

While 1
    Switch GUIGetMsg()
        Case $GUI_EVENT_CLOSE
            ExitLoop
        Case $hLeftClick
            ; Our dummy control was actioned so run the required code
            MsgBox($MB_TOPMOST, "Click", "LEFT CLICK!")
    EndSwitch

    ; Look for the flag
    If $fRightClick = True Then
        ; Run the code
        MsgBox($MB_TOPMOST, "Click", "RIGHT CLICK!")
        ; Do not forget to reset the flag!
        $fRightClick = False
    EndIf

WEnd

Func _WM_LBUTTONUP($hWnd, $iMsg, $wParam, $lParam)
    ; Action the dummy control
    GUICtrlSendToDummy($hLeftClick)
EndFunc

Func _WM_RBUTTONUP($hWnd, $iMsg, $wParam, $lParam)
    ; Set the flag
    $fRightClick = True
EndFunc

* 1st test : left click once in the Gui (dummy control) => MsgBox appears on top
Do not close the Msgbox, but left click another couple of times in the Gui, outside the Msgbox.
Now only close the Msgbox, what happens ?
All the pending left clicks you made will now action the dummy control again & again, with several Msgbox appearing.

* 2nd test : right click once in the Gui (flag) => MsgBox appears on top.
Do same as 1st test (with right clicks this time) while the Msgbox is on top
What happens after you close Msgbox ?
Nothing happens (and that's very good), no pending right clicks, no new Msgbox, nothing.

That's the reason why I always preferred the flag option :)

Posted (edited)

@Xandy : glad you liked the tests :)

In fact, there are (at least) 2 ways to solve situations similar to the 1st test above (a dummy control being triggered again & again, due to pending left clicks on the gui while Msgbox isn't closed)

1) 1st way is to disable the Gui until MsgBox is closed, like this :

$hGUI = GUICreate("Click me!")
...
GUISetState(@SW_DISABLE, $hGUI)
MsgBox($MB_TOPMOST, "Click", "LEFT CLICK!")
GUISetState(@SW_ENABLE, $hGUI)

This works fine and left clicks on the gui won't trigger the dummy control after the Gui is enabled.

2) A very interesting 2nd way that I discovered a few weeks ago and now I use it everywhere, for example in all 5 dialogs of my CSV file editor script. These 5 dialogs are :

_ChooseColor()
FileOpenDialog()
FileSaveDialog()
Inputbox()
Msgbox()

All these dialogs have in common their last parameter which is :

hwnd ; a window handle to use as the parent for this dialog.

As soon as you indicate the handle of the GUI in this last parameter, then all clicks on the GUI are "lost" while the dialog box is opened. And that's fantastic because you won't mess the environment mistakenly (for example by clicking another control or another listview row etc...)

I'm not sure many AutoIt scripters use this important functionality, because when you look at AutoIt scripts, this is what you see very often, for example :

MsgBox($MB_TOPMOST, "Click", "LEFT CLICK!")

While in fact, the following syntax is much more interesting in any script... and now we know why :)

MsgBox($MB_TOPMOST, "Click", "LEFT CLICK!", 0, $hGUI)

 

Edited by pixelsearch
  • Moderators
Posted

pixelsearch,

Take a look at the Modal MsgBox Styles tutorial in the Wiki - you are not the first to discover this!

M23

 

Public_Domain.png.2d871819fcb9957cf44f4514551a2935.png Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind

Open spoiler to see my UDFs:

Spoiler

ArrayMultiColSort ---- Sort arrays on multiple columns
ChooseFileFolder ---- Single and multiple selections from specified path treeview listing
Date_Time_Convert -- Easily convert date/time formats, including the language used
ExtMsgBox --------- A highly customisable replacement for MsgBox
GUIExtender -------- Extend and retract multiple sections within a GUI
GUIFrame ---------- Subdivide GUIs into many adjustable frames
GUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView items
GUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeView
Marquee ----------- Scrolling tickertape GUIs
NoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxes
Notify ------------- Small notifications on the edge of the display
Scrollbars ----------Automatically sized scrollbars with a single command
StringSize ---------- Automatically size controls to fit text
Toast -------------- Small GUIs which pop out of the notification area

 

Posted (edited)
1 hour ago, Melba23 said:

you are not the first to discover this!

And certainly not the last... :)
Thanks Melba23 for this interesting link. I truly wish there was a link in the help file (MsgBox topic) leading us immediately to the Wiki page you indicated, where by the way we read this :

"Although the values needed to set these styles are given in the Helpfile, it does not actually explain the difference between them."

This sentence by itself means a lot !

So $MB_TASKMODAL would have done it for me... but well, as I use now this last parameter $hGUI in all others dialogue boxes (list in my precedent post), I guess I'll stick to it (though I'll try not to forget that $MB_TASKMODAL can do it too). Also there is something else I never understood :

Why does everybody use $MB_SYSTEMMODAL, which truncates the Msgbox title (as written in the help file and it's true, you can verify it anytime) :

[...]However, the title could get truncated if the SYSTEMMODAL flag (4096) is used. (help file)

That's the only reason why I preferred $MB_TOPMOST since day #1, it displays much more longer titles than $MB_SYSTEMMODAL, and stays also on top (like $MB_SYSTEMMODAL does)
That's another mystery to me... why should anyone have his titles truncated when it can be so easily avoidable ?

Also, concerning $MB_APPLMODAL (0) that continuously plays hide & seek with you as soon as you click anywhere, thanks, but no thanks... :no:

Edited by pixelsearch

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...