Moderators Melba23 Posted May 8, 2010 Moderators Posted May 8, 2010 Hi all,GUISwitch returns the handle of the previously "current" window. Is there any way of determining the "current" window without using GUISwitch?Why do I want to know? In order to work, my StringSize UDF requires the creation, and then destruction, of a GUI within the function. This has not posed a problem until yesterday when another member found that he needed to GUISwitch back to his GUI when calling the function AFTER an initial GUICreate command or the controls would not get created in that GUI (or any other). Testing (see below) has shown that this is because in destroying its own GUI, the UDF also seems to empty the "current" GUI location - GUISwitch returns 0x00000000. If you have only the one GUI in your script, AutoIt appears to adopt this by default when asked to create any new controls - the problem only came to light because the script in question had multiple GUIs, and AutoIt (quite reasonably) declined to choose between them when creating new controls.Now it is not onerous for the user to GUISwitch back in the specific circumstances of having multiple GUIs and using the UDF after having used GUICreate, but it would be preferable and neater to save the handle of the "current" GUI as the UDF starts so that it can GUISwitch back to this GUI as it ends. However I cannot find a way to get this information other than as a return from GUISwitch - and within the UDF there is nothing available to GUISwitch to! If I wait the UDF creates its own GUI, then that of course becomes the "current" one and the previous handle is lost.I could ask the user to pass a handle into the UDF, but that means yet another parameter to deal with a single specific set of circumstances. My hope is that the value is not stored in an internal AutoIt register and so can be obtained via the API, but my Googling has so far come up blank.Any ideas - or suggestions of another way to deal with the problem?M23If you would like to see the behaviour described above, here is a short example script:expandcollapse popup#include <GUIConstantsEx.au3> ; Create a GUI so that there are multiple GUIs in the script $hGUI_2 = GUICreate("Test 2", 200, 100, 10, 10) ; <<<<<<<<<<<<<<<<<<<< ConsoleWrite("GUI_2 = " & $hGUI_2 & @CRLF) ; <<<<<<<<<<<<<<<<<<<< GUISetState(@SW_SHOW, $hGUI_2) ; <<<<<<<<<<<<<<<<<<<< ; Create the main GUI $hGUI_1 = GUICreate("Test 1", 200, 100, 300, 10) ConsoleWrite("GUI_1 = " & $hGUI_1 & @CRLF) ; Create first control $hButton_1 = GUICtrlCreateButton("Test 1", 10, 10, 80, 30) ; Simulate the StringSize UDF _Sim_StringSize() ; Switch to the dummy GUI ConsoleWrite("Switch [?] - 2 (last was GUI_3): " & GUISwitch($hGUI_2) & @CRLF) ; xxxxxxxxxxxxxxxxxxx ; Switch back to the main GUI ConsoleWrite("Switch 2 - 1 (should be GUI_2): " & GUISwitch($hGUI_1) & @CRLF) ; xxxxxxxxxxxxxxxxxxx ; Create second control in the main GUI $hButton_2 = GUICtrlCreateButton("Test 2", 10, 50, 80, 30) GUISetState(@SW_SHOW, $hGUI_1) While 1 Switch GUIGetMsg() Case $GUI_EVENT_CLOSE Exit EndSwitch WEnd Func _Sim_StringSize() $hGUI_3 = GUICreate("Test 3", 200, 100, 600, 10) ConsoleWrite("GUI_3 = " & $hGUI_3 & @CRLF) GUISetState(@SW_SHOW, $hGUI_3) GUIDelete($hGUI_3) EndFuncRun it as posted and you should see that you get 0x00000000 returned whan you switch to $hGUI_2.Now, comment out the 2 Switch lines (marked with xxxxxxxxxxx) - and look, no second button! AutoIt cannot decide which of the 2 GUIs is "current".Finally, comment out the 3 lines which create the additional GUI (marked with <<<<<<<<<<<<<<) - and hey presto, the second button reappears! AutoIt has only one GUI in the script and has obviously decided it must be "current". 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 columnsChooseFileFolder ---- Single and multiple selections from specified path treeview listingDate_Time_Convert -- Easily convert date/time formats, including the language usedExtMsgBox --------- A highly customisable replacement for MsgBoxGUIExtender -------- Extend and retract multiple sections within a GUIGUIFrame ---------- Subdivide GUIs into many adjustable framesGUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView itemsGUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeViewMarquee ----------- Scrolling tickertape GUIsNoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxesNotify ------------- Small notifications on the edge of the displayScrollbars ----------Automatically sized scrollbars with a single commandStringSize ---------- Automatically size controls to fit textToast -------------- Small GUIs which pop out of the notification area
Bowmore Posted May 8, 2010 Posted May 8, 2010 Interesting issue Melba23 using WinGetHandle ( "[ACTIVE]" ) returns the the correct handle for the active window, $hGUI_1 when I run it, if inserted as below. However the second button is still not drawn. It seems as thought GUIDelete() destroys AutoIts internal handle to the currently active window and Autoit is not internally picking up the handle of the window that the operating system made active when the active window ($hGUI_3) was destroyed. ; Switch to the dummy GUI ConsoleWrite("Switch [?] - 2 (last was GUI_3): " & WinGetHandle ( "[ACTIVE]" ) & @CRLF) ; xxxxxxxxxxxxxxxxxxx ;~ ConsoleWrite("Switch [?] - 2 (last was GUI_3): " & GUISwitch($hGUI_2) & @CRLF) ; xxxxxxxxxxxxxxxxxxx ; Switch back to the main GUI ;~ ConsoleWrite("Switch 2 - 1 (should be GUI_2): " & GUISwitch($hGUI_1) & @CRLF) ; xxxxxxxxxxxxxxxxxxx "Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to build bigger and better idiots. So far, the universe is winning."- Rick Cook
Moderators Melba23 Posted May 8, 2010 Author Moderators Posted May 8, 2010 Bowmore,Thanks for that suggestion. I have continued experimenting and found that using WinActivate on the newly created GUI (even before you use GUISetState) will allow you to use your WinGetHandle("[ACTIVE]") idea successfully, but that you must do this every time you call the function. Try this script and see what happens if you comment out either of the WinActivate lines (marked with ~~~~~~~~~~~~~):expandcollapse popup#include <GUIConstantsEx.au3> ; Create a GUI so that there are multiple GUIs in the script $hGUI_2 = GUICreate("Test 2", 200, 130, 10, 10) ConsoleWrite("GUI_2 = " & $hGUI_2 & @CRLF) GUISetState(@SW_SHOW, $hGUI_2) ; Create the main GUI $hGUI_1 = GUICreate("Test 1", 200, 130, 300, 10) ConsoleWrite("GUI_1 = " & $hGUI_1 & @CRLF) ;GUISetState(@SW_SHOW, $hGUI_1) ; ############################ ; Create first control $hButton_1 = GUICtrlCreateButton("Test 1", 10, 10, 80, 30) WinActivate($hGUI_1) ; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ; Simulate the StringSize UDF _Sim_StringSize() ; Create second control in the main GUI $hButton_2 = GUICtrlCreateButton("Test 2", 10, 50, 80, 30) WinActivate($hGUI_1) ; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ; Simulate the StringSize UDF _Sim_StringSize() ; Create third control in the main GUI $hButton_3 = GUICtrlCreateButton("Test 3", 10, 90, 80, 30) GUISetState(@SW_SHOW, $hGUI_1) While 1 Switch GUIGetMsg() Case $GUI_EVENT_CLOSE Exit EndSwitch WEnd Func _Sim_StringSize() $hPrev = WinGetHandle("[ACTIVE]") ; +++++++++++++++++++++++++++ $hGUI_3 = GUICreate("Test 3", 200, 100, 600, 10) ConsoleWrite("GUI_3 = " & $hGUI_3 & @CRLF) GUISetState(@SW_SHOW, $hGUI_3) GUIDelete($hGUI_3) GUISwitch($hPrev) ; +++++++++++++++++++++++++++ EndFuncIt looks as if AutoIt picks up the fully formed GUI as the "active" one. So your suggestion still requires the user to add a line to his code - to activate the GUI before the UDF call rather then to switch back to it when the UDF returns.However, when I used GUISetState on $hGUI_1 before calling the simulated UDF, I had more success. Try uncommenting the first GUISetState line (########) and recommenting the WinActivate ones (~~~~~~~~). You now get all controls on $hGUI_1 which is what I would expect as Windows would default to that GUI as the last activated when the UDF GUI is destroyed.Thanks again for the suggestion - activating the GUI might well be the way to do it.M23 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 columnsChooseFileFolder ---- Single and multiple selections from specified path treeview listingDate_Time_Convert -- Easily convert date/time formats, including the language usedExtMsgBox --------- A highly customisable replacement for MsgBoxGUIExtender -------- Extend and retract multiple sections within a GUIGUIFrame ---------- Subdivide GUIs into many adjustable framesGUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView itemsGUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeViewMarquee ----------- Scrolling tickertape GUIsNoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxesNotify ------------- Small notifications on the edge of the displayScrollbars ----------Automatically sized scrollbars with a single commandStringSize ---------- Automatically size controls to fit textToast -------------- Small GUIs which pop out of the notification area
Bowmore Posted May 8, 2010 Posted May 8, 2010 I wasn't really proposing my suggestion as a solution. My intention was to try and help narrow down where the problem was occurring. Like yourself I've been trying different things to try an understand what is happening. The code below offers a sort of workaround by forcing the GUI to be shown. This seems OK on the small test GUI which is drawn quickly, but it may not be acceptable on a larger GUI. expandcollapse popup#include <GUIConstantsEx.au3> ; Create a GUI so that there are multiple GUIs in the script $hGUI_2 = GUICreate("Test 2", 200, 130, 10, 10) ConsoleWrite("GUI_2 = " & $hGUI_2 & @CRLF) GUISetState(@SW_SHOW, $hGUI_2) ; Create the main GUI $hGUI_1 = GUICreate("Test 1", 200, 130, 300, 10) ConsoleWrite("GUI_1 = " & $hGUI_1 & @CRLF) ; Create first control $hButton_1 = GUICtrlCreateButton("Test 1", 10, 10, 80, 30) ; Simulate the StringSize UDF _Sim_StringSize() ; Create second control in the main GUI $hButton_2 = GUICtrlCreateButton("Test 2", 10, 50, 80, 30) ; Simulate the StringSize UDF _Sim_StringSize() ; Create third control in the main GUI $hButton_3 = GUICtrlCreateButton("Test 3", 10, 90, 80, 30) GUISetState(@SW_SHOW, $hGUI_1) While 1 Switch GUIGetMsg() Case $GUI_EVENT_CLOSE Exit EndSwitch WEnd Func _Sim_StringSize() GUISetState(@SW_SHOW) ; ############################ $hPrev = WinGetHandle("[ACTIVE]") ; +++++++++++++++++++++++++++ $hGUI_3 = GUICreate("Test 3", 200, 100, -1000, -1000) ConsoleWrite("GUI_3 = " & $hGUI_3 & @CRLF) GUISetState(@SW_SHOW, $hGUI_3) GUIDelete($hGUI_3) GUISwitch($hPrev) ; +++++++++++++++++++++++++++ EndFunc "Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to build bigger and better idiots. So far, the universe is winning."- Rick Cook
Moderators Melba23 Posted May 8, 2010 Author Moderators Posted May 8, 2010 Bowmore, Thanks for that. An interesting little conundrum which does not seem easy to solve. I am now trying to get the UDF to work without needing to create/destroy a GUI which I hope will make the whole question somewhat moot. trancexx has posted some code which looks promising - fingers crossed! Thanks again for taking the time to try and work out what was going on in the example I posted - I appreciate it. M23 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 columnsChooseFileFolder ---- Single and multiple selections from specified path treeview listingDate_Time_Convert -- Easily convert date/time formats, including the language usedExtMsgBox --------- A highly customisable replacement for MsgBoxGUIExtender -------- Extend and retract multiple sections within a GUIGUIFrame ---------- Subdivide GUIs into many adjustable framesGUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView itemsGUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeViewMarquee ----------- Scrolling tickertape GUIsNoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxesNotify ------------- Small notifications on the edge of the displayScrollbars ----------Automatically sized scrollbars with a single commandStringSize ---------- Automatically size controls to fit textToast -------------- Small GUIs which pop out of the notification area
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now