Aphotic

Multi "Screen" GUI Management

8 posts in this topic

#1 ·  Posted (edited)

Just wanted to share my functions for managing a GUI with lots of controls and many screens.

I personally feel that it is very efficient and keeps line count to a minimum.

And if it's not, I'll learn a better solution!

Note: There are some conditional veriables such as $changes and $cont that are modified by the main loop in this particular script; they are meant as an example, please don't try too hard to understand why they're used.

*Usage*

This allows you to re-state a handful of buttons in one line when doing slight GUI changes:

ToggleCTRL($GUI_DISABLE, $dALO, $dAAF, $dRLA) (A few buttons on a certain screen)

ToggleCTRL($GUI_DISABLE, $dSAV, $dCAN) (Save/Cancel buttons)

AND

A single line solution to switching a GUI "screen":

GuiMod("MAIN", $GUI_HIDE)

GuiMod("DETAILS", $GUI_SHOW)

GuiMod("PLANS", $GUI_HIDE)

Another way I've used this to my advantage is as follows:

Say a GUI has 3 or 4 main screens, and 3 or 4 "form" screens.

When switching to a form screen, save the main screen that it was on to a variable; then once the user is done with the form, either submitting or cancelling, you can call the variable to revert back to the main screen it was on.

Func _GuiMod($i, $tog, $act = True)
   Switch $i
   Case "MAIN"
      If $tog = $GUI_SHOW And $changes Then
         $changes = False
         ControlClick($GUI, "", $LOGfg)
      Else
      EndIf
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 535, 445)
      _ToggleCTRL($tog, $TAB, $LOGfl, $LOGfc, $LOGfi, $LOGfg, $LOGta, $LOGvd)
      _ToggleCTRL($tog, $LOGtp, $LOGse)
   Case "DETAILS"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 535, 475)
      Local $cont = True
      If $tog = $GUI_SHOW And $act Then
         If Not UpdateDetails() Then
            $cont = False
            _GuiMod("MAIN", $GUI_SHOW)
         EndIf
      EndIf
      If $cont Then
         _ToggleCTRL($tog, $dUID, $dICU, $dACC, $dCOF, $dNAM, $dCO2, $dIPW, $dEMA, $dEDI, $dLOG, $dMOD)
         _ToggleCTRL($tog, $dUPD, $dINP, $dAPL, $dALO, $dAAF, $dPLL, $dLOL, $dAFL, $dSAV, $dCAN, $dRPL)
         _ToggleCTRL($tog, $dRLA, $dACT, $dAC2, $dRET, $dDEL, $dADD, $dMQC)
      EndIf
   Case "ADD-INPUT"
      _ToggleCTRL($tog, $nCOMi, $nCO2i, $nNAMi, $nNAMb, $nEMAi, $nPREc, $nACCc, $nICUi, $nADDi, $nNOTi)
      _ToggleCTRL($tog, $nAPLb, $nALOb, $nAAFb, $nPLAl, $nLOCl, $nAFFl, $nRPLb, $nRLAb, $nADDb, $nCLEb)
   Case "PLANS"
      If $tog <> $GUI_SHOW Or Not $changing Then
         If $act Then _ToggleCTRL($tog, $dMOD, $dLOG, $dUPD, $dDEL)
         _ToggleCTRL($tog, $dINP, $dAPL, $dALO, $dAAF, $dPLL, $dLOL, $dAFL, $dSAV, $dCAN, $dRPL, $dRLA)
      EndIf
   Case "CHANGE"
      _ToggleCTRL($tog, $dITL, $dITC, $dAML, $dAMC, $dSCB, $dCCB, $dEAB)
      If $tog = $GUI_SHOW Then
         GUICtrlSetState($dRET, $GUI_DISABLE)
      Else
         GUICtrlSetState($dRET, $GUI_ENABLE)
      EndIf
   Case "NEW"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 465, 475)
      _ToggleCTRL($tog, $TAB, $nCOMl, $nCOMi, $nCO2l, $nCO2i, $nNAMl, $nNAMi, $nEMAl, $nEMAi, $nPREl, $nPREc)
      _ToggleCTRL($tog, $nACCl, $nACCc, $nPAEb, $nICUl, $nICUi, $nADDi, $nAPLb, $nALOb, $nAAFb, $nPLAl, $nLOCl)
      _ToggleCTRL($tog, $nAFFl, $nRPLb, $nNOTl, $nNOTi, $nADDb, $nCLEb, $nLAST)
   Case "ACCESS"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 465, 330)
      _ToggleCTRL($tog, $ACCd1, $ACCd2, $TYPla, $TYPli, $TYPad, $TYPde, $TYPmu, $TYPmd, $ACCla, $ACCli)
      _ToggleCTRL($tog, $ACCde, $ACCmu, $ACCmd, $ACCdl, $ACCdi, $ACCal, $ACCai, $ACCaa, $taRET)
   Case "TPi"
      _ToggleCTRL($tog, $tpOPEb, $tpCREr, $tpLINr, $tpCO2i, $tpEMAi, $tpEMAl, $tpCREb, $tpCOPb, $tpCOPi, $tpCTOi, $tpCGOb)
      _ToggleCTRL($tog, $tpUFLi, $tpUFLb, $tpICUi, $tpPLAi, $tpLINb, $tpDLIb, $tpUFMi, $tpSCAl, $tpCFAr, $tpCBAr)
   Case "TPC"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpCO2l, $tpCO2i, $tpCOPl, $tpCOPi, $tpCREb, $tpCOPb, $tpSEPl, $tpCTOl, $tpCTOi, $tpCGOb, $tpLAST)
      _ToggleCTRL($tog, $tpIDNl, $tpIDNi, $tpIDNn, $tpSCAl, $tpEMAi, $tpEMAl, $tpCFAr, $tpCBAr)
   Case "TPL"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpUFLl, $tpUFLi, $tpUFLb, $tpICUl, $tpICUi, $tpPLAl, $tpPLAi, $tpLINb, $tpDLIb, $tpUFMl, $tpUFMi, $tpIMAb, $tpIMRb)
   Case "TPH"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpUFLl, $tpUFLi, $tpUFLb, $tpUFMl, $tpUFMi, $tpCOCl, $tpCOCi, $tpCOGb)
   Case "TPD"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpDIDl, $tpDIDi, $tpDIDb)
   EndSwitch
EndFunc

Func _ToggleCTRL($tog, $c0 = 0, $c1 = 0, $c2 = 0, $c3 = 0, $c4 = 0, $c5 = 0, $c6 = 0, $c7 = 0, $c8 = 0, $c9 = 0, $c10 = 0, $c11 = 0, $c12 = 0)
   For $i = 0 To @NumParams
      GUICtrlSetState(Eval("c" & $i), $tog)
   Next
EndFunc

 

Edited by Aphotic

Share this post


Link to post
Share on other sites



I see only functions.
Can you post also example to show us how to use it ?

 


Wondering who uses AutoIT and what it can be used for ?


ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button:

Spoiler

Last update: 2017-03-27
Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAPPOP3.au3 UDF *  RTF Printer - UDF * XML.au3 - BETA * ADO.au3 UDF SMTP Mailer UDF * WinSCP UDF *

My contribution to others projects: * _sql.au3 UDF  *

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Best coding practices * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities *

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

 

Share this post


Link to post
Share on other sites

Small question/suggestion for your _ToggleCTRL function.  Why not just provide an array to the function?  That way you don't limit yourself to x (12) manually defined parameters and you eliminate the extra overhead from the Eval function.

Share this post


Link to post
Share on other sites

#4 ·  Posted (edited)

On ‎11‎/‎11‎/‎2016 at 4:30 PM, mLipok said:

I see only functions.
Can you post also example to show us how to use it ?

 

Edited the first post.

On ‎11‎/‎14‎/‎2016 at 2:54 PM, spudw2k said:

Small question/suggestion for your _ToggleCTRL function.  Why not just provide an array to the function?  That way you don't limit yourself to x (12) manually defined parameters and you eliminate the extra overhead from the Eval function.

Sometimes, I call the ToggleCTRL function with different groups of control variables, maybe even just two to three.

I like your idea, although I wish I could call it with something like:

ToggleCTRL($GUI_DISABLE, [$nALOb, $nAAFb])

I don't like the idea of having to declare a local variable every time before calling it, unless I'm missing something...

Local $tcArr = [$nALOb, $nAAFb]

ToggleCTRL($GUI_DISABLE, $tcArr)

The idea is to reduce the line count in the main script logic; please advise?

 

Thank you to you both!

 

 

Edited by Aphotic

Share this post


Link to post
Share on other sites

#5 ·  Posted (edited)

Well, you're right...you'd have to define the arrays, but not every time (unless it truly needs to be dynamic).  You could declare arrays for each collection of controls at the beginning of your script.  

edit:
Another idea I thought of to simply the array creation....you could use StringSplit to create an array from a character delimited string with your control IDs.  Really cutting out the Eval overhead is what I was suggesting.  

Edited by spudw2k
1 person likes this

Share this post


Link to post
Share on other sites
21 hours ago, spudw2k said:

Well, you're right...you'd have to define the arrays, but not every time (unless it truly needs to be dynamic).  You could declare arrays for each collection of controls at the beginning of your script.  

edit:
Another idea I thought of to simply the array creation....you could use StringSplit to create an array from a character delimited string with your control IDs.  Really cutting out the Eval overhead is what I was suggesting.  

Yeah, I'd rather not define an array that's going to be used once.

The delimited string idea is perfect, thank you very much; I'll edit the first post with that!

Share this post


Link to post
Share on other sites

I'm not sure if I prefer this method. It may reduce the need for Eval and turn it into a one line solution, although I've never had issues with performance when using Eval and the method I'm currently using is a tad easier to read.

Func _GuiMod($i, $tog, $act = True)
   Switch $i
   Case "MAIN"
      If $tog = $GUI_SHOW And $changes Then
         $changes = False
         ControlClick($GUI, "", $LOGfg)
      Else
      EndIf
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 535, 445)
      _ToggleCTRL($tog, $TAB &"|"& $LOGfl &"|"& $LOGfc &"|"& $LOGfi &"|"& $LOGfg &"|"& $LOGta &"|"& $LOGvd &"|"& $LOGtp &"|"& $LOGse)
   Case "DETAILS"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 535, 475)
      Local $cont = True
      If $tog = $GUI_SHOW And $act Then
         If Not UpdateDetails() Then
            $cont = False
            _GuiMod("MAIN", $GUI_SHOW)
         EndIf
      EndIf
      If $cont Then
         _ToggleCTRL($tog, $dUID &"|"& $dICU &"|"& $dACC &"|"& $dCOF &"|"& $dNAM &"|"& $dCO2 &"|"& $dIPW &"|"& $dEMA &"|"& $dEDI &"|"& $dLOG &"|"& $dMOD)
         _ToggleCTRL($tog, $dUPD &"|"& $dINP &"|"& $dAPL &"|"& $dALO &"|"& $dAAF &"|"& $dPLL &"|"& $dLOL &"|"& $dAFL &"|"& $dSAV &"|"& $dCAN &"|"& $dRPL)
         _ToggleCTRL($tog, $dRLA &"|"& $dACT &"|"& $dAC2 &"|"& $dRET &"|"& $dDEL &"|"& $dADD &"|"& $dMQC)
      EndIf
   Case "ADD-INPUT"
      _ToggleCTRL($tog, $nCOMi &"|"& $nCO2i &"|"& $nNAMi &"|"& $nNAMb &"|"& $nEMAi &"|"& $nPREc &"|"& $nACCc &"|"& $nICUi &"|"& $nADDi &"|"& $nNOTi)
      _ToggleCTRL($tog, $nAPLb &"|"& $nALOb &"|"& $nAAFb &"|"& $nPLAl &"|"& $nLOCl &"|"& $nAFFl &"|"& $nRPLb &"|"& $nRLAb &"|"& $nADDb &"|"& $nCLEb)
   Case "PLANS"
      If $tog <> $GUI_SHOW Or Not $changing Then
         If $act Then _ToggleCTRL($tog, $dMOD &"|"& $dLOG &"|"& $dUPD &"|"& $dDEL)
         _ToggleCTRL($tog, $dINP &"|"& $dAPL &"|"& $dALO &"|"& $dAAF &"|"& $dPLL &"|"& $dLOL &"|"& $dAFL &"|"& $dSAV &"|"& $dCAN &"|"& $dRPL &"|"& $dRLA)
      EndIf
   Case "CHANGE"
      _ToggleCTRL($tog, $dITL &"|"& $dITC &"|"& $dAML &"|"& $dAMC &"|"& $dSCB &"|"& $dCCB &"|"& $dEAB)
      If $tog = $GUI_SHOW Then
         GUICtrlSetState($dRET, $GUI_DISABLE)
      Else
         GUICtrlSetState($dRET, $GUI_ENABLE)
      EndIf
   Case "NEW"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 465, 475)
      _ToggleCTRL($tog, $TAB &"|"& $nCOMl &"|"& $nCOMi &"|"& $nCO2l &"|"& $nCO2i &"|"& $nNAMl &"|"& $nNAMi &"|"& $nEMAl &"|"& $nEMAi &"|"& $nPREl &"|"& $nPREc &"|"& $nACCl &"|"& $nACCc &"|"& $nPAEb &"|"& $nICUl &"|"& $nICUi &"|"& $nADDi &"|"& $nAPLb &"|"& $nALOb &"|"& $nAAFb &"|"& $nPLAl &"|"& $nLOCl &"|"& $nAFFl &"|"& $nRPLb &"|"& $nNOTl &"|"& $nNOTi &"|"& $nADDb &"|"& $nCLEb &"|"& $nLAST)
   Case "ACCESS"
      If $tog = $GUI_SHOW Then WinMove($GUI, "", Default, Default, 465, 330)
      _ToggleCTRL($tog, $ACCd1 &"|"& $ACCd2 &"|"& $TYPla &"|"& $TYPli &"|"& $TYPad &"|"& $TYPde &"|"& $TYPmu &"|"& $TYPmd &"|"& $ACCla &"|"& $ACCli &"|"& $ACCde &"|"& $ACCmu &"|"& $ACCmd &"|"& $ACCdl &"|"& $ACCdi &"|"& $ACCal &"|"& $ACCai &"|"& $ACCaa &"|"& $taRET)
   Case "TPi"
      _ToggleCTRL($tog, $tpOPEb &"|"& $tpCREr &"|"& $tpLINr &"|"& $tpCO2i &"|"& $tpEMAi &"|"& $tpEMAl &"|"& $tpCREb &"|"& $tpCOPb &"|"& $tpCOPi &"|"& $tpCTOi &"|"& $tpCGOb &"|"& $tpUFLi &"|"& $tpUFLb &"|"& $tpICUi &"|"& $tpPLAi &"|"& $tpLINb &"|"& $tpDLIb &"|"& $tpUFMi &"|"& $tpSCAl &"|"& $tpCFAr &"|"& $tpCBAr)
   Case "TPC"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpCO2l &"|"& $tpCO2i &"|"& $tpCOPl &"|"& $tpCOPi &"|"& $tpCREb &"|"& $tpCOPb &"|"& $tpSEPl &"|"& $tpCTOl &"|"& $tpCTOi &"|"& $tpCGOb &"|"& $tpLAST &"|"& $tpIDNl &"|"& $tpIDNi &"|"& $tpIDNn &"|"& $tpSCAl &"|"& $tpEMAi &"|"& $tpEMAl &"|"& $tpCFAr &"|"& $tpCBAr)
   Case "TPL"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpUFLl &"|"& $tpUFLi &"|"& $tpUFLb &"|"& $tpICUl &"|"& $tpICUi &"|"& $tpPLAl &"|"& $tpPLAi &"|"& $tpLINb &"|"& $tpDLIb &"|"& $tpUFMl &"|"& $tpUFMi &"|"& $tpIMAb &"|"& $tpIMRb)
   Case "TPH"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPD", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpUFLl &"|"& $tpUFLi &"|"& $tpUFLb &"|"& $tpUFMl &"|"& $tpUFMi &"|"& $tpCOCl &"|"& $tpCOCi &"|"& $tpCOGb)
   Case "TPD"
      If $tog = $GUI_SHOW Then
         _GuiMod("TPC", $GUI_HIDE)
         _GuiMod("TPL", $GUI_HIDE)
         _GuiMod("TPH", $GUI_HIDE)
      EndIf
      _ToggleCTRL($tog, $tpDIDl &"|"& $tpDIDi &"|"& $tpDIDb)
   EndSwitch
EndFunc

Func _ToggleCTRL($tog, $ctrl)
   Local $arr = StringSplit($ctrl, "|")
   For $i = 1 To Ubount($arr)-1
      GUICtrlSetState($arr[$i], $tog)
   Next
EndFunc

 

Share this post


Link to post
Share on other sites

#8 ·  Posted (edited)

Today I realized a good way to further reduce the needed code to process controls like this.

 

Local $mNamLa = GUICtrlCreateLabel("Name:", 8, 9)
Local $mNamIn = GUICtrlCreateInput("", 50, 5, 220, 20)
Local $mTypLa = GUICtrlCreateLabel("Type:", 12, 39)
Local $mTypAD = GUICtrlCreateRadio("Active Directory", 50, 35, 100)
Local $mTypIn = GUICtrlCreateRadio("Input", 160, 35, 50)
Local $mTypSe = GUICtrlCreateRadio("Select", 220, 35, 50)
Local $mADaLa = GUICtrlCreateLabel("Attribute Name:", 10, 71, 79)
Local $mADaIn = GUICtrlCreateInput("", 90, 67, 180)
Local $mSelLa = GUICtrlCreateLabel("Values:", 30, 71, 44)
Local $mSelCo = GUICtrlCreateCombo("", 75, 67, 120, 25, $CBS_DROPDOWNLIST)
Local $mSelAd = GUICtrlCreateButton("", 205, 64, 26, 26, $BS_ICON)
GUICtrlSetImage(-1, @ScriptDir & "\icons\add.ico")
Local $mSelRe = GUICtrlCreateButton("", 240, 64, 26, 26, $BS_ICON)
GUICtrlSetImage(-1, @ScriptDir & "\icons\delete.ico")
Local $mActSa = GUICtrlCreateButton("Save", 30, 105, 100, 25)
Local $mActCa = GUICtrlCreateButton("Cancel", 150, 105, 100, 25)

;Using the function below, you can use the following to toggle gui screens.
_ToggleCTRL($GUI_HIDE, "mNamLa", "mActCa")
;Further, it leaves the option to toggle a list of particular ones that are not in order if you need to
_ToggleCTRL($GUI_HIDE, $mTypLa, $mTypAD, $mTypIn, $mTypSe, $mSelLa, $mSelCo)

Func _ToggleCTRL($tog, $c0 = 0, $c1 = 0, $c2 = 0, $c3 = 0, $c4 = 0, $c5 = 0, $c6 = 0, $c7 = 0, $c8 = 0, $c9 = 0, $c10 = 0, $c11 = 0, $c12 = 0)
   If IsString($c0) Then
      For $i = Eval($c0) To Eval($c1)
         GUICtrlSetState($i, $tog)
      Next
   Else
      For $i = 0 To @NumParams
         GUICtrlSetState(Eval("c" & $i), $tog)
      Next
   EndIf
EndFunc

 

Edited by Aphotic

Share this post


Link to post
Share on other sites

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

  • Similar Content

    • Fenzik
      By Fenzik
      Hello,
      my question is based on topic about Nvda Screen reader development atThis Link
      Autoit GUI is totaly nice for blind users, because it's controls are mostly standart.
      But in cooperation with Screen Readers this guis are much slower than other guis.
      Do you have any idea about reason of this behaviour?
      Thanks a lot for any answer.
      Fenzik
    • Phoenixx177
      By Phoenixx177
      I've tried to wrap my head around it but just can't imagine how to embed 2 IE browsers in the same GUI.
      Here's what I'm doing so far.
       
      #include <GuiConstantsEx.au3> #include <windowsconstants.au3> #include <IE.au3> Global $oIE = _IECreateEmbedded() ; Create a simple GUI for our output Global $hGUI = GUICreate("Embedded Web control Test", 1280, 580, (@DesktopWidth - 1280) / 2, (@DesktopHeight - 580) / 2, BitOR($WS_OVERLAPPEDWINDOW, $WS_CLIPSIBLINGS, $WS_CLIPCHILDREN, $WS_MAXIMIZEBOX)) Global $GUIActiveX = GUICtrlCreateObj($oIE, 10, 40, 1100, 500) _IENavigate($oIE, "http://xxxxxxxxxx.com") Global $o_doc = _IEDocGetObj($oIE) $o_doc.DocumentElement.ScrollTop = 140 $o_doc.DocumentElement.ScrollLeft = 170 GUISetState() While GUIGetMsg() <> -3 WEnd  
    • mpower
      By mpower
      Hi guys,
      So I am facing an issue with my Listview control flickering like crazy when using the Modern GUI UDF.
      I understand that the reson is because Listviews do not play nice with the $WS_EX_COMPOSITED extended style which is necessary to prevent the rest of the GUI components flickering on resizing.
      I am looking for suggestions on how I can overcome the flickering issue without having to remove the Listview header (as I need the header to allow column resizing and sorting).
      The reproducer is here and the lightly modified Modern GUI UDF is attached as a zip (I added $WS_CLIPCHILDREN and $WS_EX_COMPOSITED to the _Metro_CreateGUI() function in order to stop flickering of other controls like buttons/labels/toggles etc).
      ;!Highly recommended for improved overall performance and responsiveness of the GUI effects etc.! (after compiling): #AutoIt3Wrapper_Run_Au3Stripper=y #Au3Stripper_Parameters=/so /rm /pe ;Required if you want High DPI scaling enabled. (Also requries _Metro_EnableHighDPIScaling()) #AutoIt3Wrapper_Res_HiDpi=y #include-once #NoTrayIcon #include "MetroGUI-UDF\MetroGUI_UDF.au3" #include <GuiListView.au3> $gui = _Metro_CreateGUI("example", 800, 600, -1, -1, True) ;Add/create control buttons to the GUI $Control_Buttons = _Metro_AddControlButtons(True, True, True, True, False) ;CloseBtn = True, MaximizeBtn = True, MinimizeBtn = True, FullscreenBtn = True, MenuBtn = True ;Set variables for the handles of the GUI-Control buttons. (Above function always returns an array this size and in this order, no matter which buttons are selected. $GUI_CLOSE_BUTTON = $Control_Buttons[0] $GUI_MAXIMIZE_BUTTON = $Control_Buttons[1] $GUI_RESTORE_BUTTON = $Control_Buttons[2] $GUI_MINIMIZE_BUTTON = $Control_Buttons[3] $GUI_FULLSCREEN_BUTTON = $Control_Buttons[4] $GUI_FSRestore_BUTTON = $Control_Buttons[5] ;====================================================================================================================================================================== $Button1 = _Metro_CreateButtonEx("Add new item(s)", 20, 20, 130, 50) $Button2 = _Metro_CreateButtonEx("Edit item(s)", 170, 20, 130, 50) $ListView2 = GUICtrlCreateListView("", 0, 86, 800, 400, BitOR($LVS_REPORT, $LVS_SHOWSELALWAYS), $WS_EX_CLIENTEDGE) _GUICtrlListView_SetExtendedListViewStyle($ListView2, BitOR($LVS_EX_DOUBLEBUFFER, $LVS_EX_GRIDLINES, $LVS_EX_SUBITEMIMAGES, $LVS_EX_FLATSB)) For $i = 0 to 8 _GUICtrlListView_AddColumn($ListView2, "col " &$i) Next _GUICtrlListView_SetBkColor($ListView2, 0xF3F3F3) _GUICtrlListView_SetTextBkColor($ListView2, 0xF3F3F3) ;Set resizing options for the controls so they don't change in size or position. This can be customized to match your gui perfectly for resizing. See AutoIt Help file. GUICtrlSetResizing($Button1, 768 + 2 + 32) GUICtrlSetResizing($Button2, 768 + 2 + 32) GUICtrlSetResizing($ListView2, 102) GUISetState(@SW_SHOW) While 1 _Metro_HoverCheck_Loop($gui) ;This hover check has to be added to the main While loop, otherwise the hover effects won't work. $nMsg = GUIGetMsg() Switch $nMsg ;=========================================Control-Buttons=========================================== Case $GUI_EVENT_CLOSE, $GUI_CLOSE_BUTTON _Metro_GUIDelete($gui) ;Delete GUI/release resources, make sure you use this when working with multiple GUIs! Exit Case $GUI_MAXIMIZE_BUTTON GUISetState(@SW_MAXIMIZE) Case $GUI_RESTORE_BUTTON GUISetState(@SW_RESTORE) Case $GUI_MINIMIZE_BUTTON GUISetState(@SW_MINIMIZE) Case $GUI_FULLSCREEN_BUTTON, $GUI_FSRestore_BUTTON _Metro_FullscreenToggle($gui, $Control_Buttons) EndSwitch WEnd Any suggestions would be greately appreciated.
      Cheers!
      MetroGUI-UDF.zip
    • rootx
      By rootx
      someone made a modern Gui like windows 10 style. thx
    • FrancescoDiMuro
      By FrancescoDiMuro
      Good morning community!
      I was working on a script which read the content of a .ini file to retrieve the file that has to open, and, based on the value of a second key stored in the .ini file, set the window on top, minimized or maximized...
      I did something like this, but seems to not work properly...
      Could anyone please tell me what I'm doing wrong?
      Thank you  
       
      #Region ;**** Directives created by AutoIt3Wrapper_GUI **** #AutoIt3Wrapper_Outfile_x64=prova.exe #EndRegion ;**** Directives created by AutoIt3Wrapper_GUI **** #include <ButtonConstants.au3> #include <GUIConstantsEx.au3> #include <StaticConstants.au3> #include <WindowsConstants.au3> #include <MsgBoxConstants.au3> #include <AutoItConstants.au3> ;#include <WinAPIEx.au3> #include <Array.au3> Local $sFileConfigurazione = @ScriptDir & "\configurazione_exe.ini" If(FileExists($sFileConfigurazione)) Then Local $aSezioneIni = IniReadSection($sFileConfigurazione, "CONFIGURAZIONE_EXE") If @error Then MsgBox($MB_ICONERROR, "Errore!", "Errore durante l'apertura del file: " & @CRLF & $sFileConfigurazione & @CRLF & "Errore: " & @error) Else ; Lancio dell'applicativo indicato nel file di configurazione Local $iPID = ShellExecute($aSezioneIni[1][1]) Local $hWnd If($iPID <> 0) Then Local $aWinList = WinList() For $i = 1 To $aWinList[0][0] If(WinGetProcess($aWinList[$i][1] = $iPID)) Then $hWnd = $aWinList[$i][1] EndIf Next Switch($aSezioneIni[2][1]) Case $aSezioneIni[2][1] = "MIN" ToolTip("MIN", 0, 0) WinSetState($hWnd, WinGetTitle($hWnd), @SW_MINIMIZE) Case $aSezioneIni[2][1] = "MAX" ToolTip("MAX", 0, 0) WinSetState($hWnd, WinGetTitle($hWnd), @SW_MAXIMIZE) Case $aSezioneIni[2][1] = "TOP" ToolTip("TOP", 0, 0) WinSetOnTop($hWnd, WinGetTitle($hWnd), $WINDOWS_ONTOP) EndSwitch EndIf EndIf EndIf And the .ini file is like this:
       
      [CONFIGURAZIONE_EXE] PercorsoExe=Here goes the path and the .exe to execute ModalitaAperturaExe=Here goes one of the value below /* TOP Shows the windows on top */ /* MIN Shows the window minimized */ /* MAX Shows the window maximized */