Jump to content
InunoTaishou

Parent window always above child window

Recommended Posts

InunoTaishou

I'm essentially trying to create a pop-out window from the Parent GUI by using a child gui (So the child always stays aligned with the parent and I don't have to track the position of the parent and update the child myself). I've got it tracking and got the pop-out window working (pretty smoothly) but I need the child to always be below the parent.

I tried using GUISetOnTop and using a variant of different styles and exStyles but none seemed to work as needed. Is this possible?

And here's some code. (Hovering over the right side of the Parent window will slide the child to the right, when the cursor goes out of bounds the child goes back to the start.)

#include <GuiConstantsEx.au3>
#include <WindowsConstants.au3>
#include <WinAPI.au3>
#include <WinAPIGdi.au3>

AutoItSetOption("GuiOnEventMode", 1)

$frmMain = GUICreate("Parent", 400, 400, -1, -1, -1, $WS_EX_TOPMOST)
GUISetBkColor(0x000000, $frmMain)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "MyFunc")
GUISetOnEvent($GUI_EVENT_CLOSE, "Close")

$frmChild = GuiCreate("Child", 200, 395, 195, -1, $WS_POPUP, BITOR($WS_EX_MDICHILD, $WS_EX_DLGMODALFRAME), $frmMain)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "MyFunc")
GUISetOnEvent($GUI_EVENT_CLOSE, "Close")

$btnButton = GUICtrlCreateButton("Test", 50, 10, 140, 20)
GUICtrlSetFont(-1, 10, 300, "", "Segoe UI")
GUICtrlSetOnEvent(-1, "DoStuff")

$lblLabel = GUICtrlCreateLabel("Press the button to do stuff", 50, 35, 140, 40)
GUICtrlSetFont(-1, 10, 300, "", "Segoe UI")

GUISetState(@SW_SHOW, $frmMain)
GUISetState(@SW_SHOW, $frmChild)

While 1
    Sleep(250)
WEnd

Func Close()
    Exit
EndFunc

Func DoStuff()
    GUICtrlSetData($lblLabel, "Stuff happened! :D")
    Sleep(1000)
    GUICtrlSetData($lblLabel, "Press the button to do stuff")
EndFunc

Func MyFunc()
    Local $gui_coords = WinGetPos("Parent")
    Local $mouse_coords = MouseGetPos()
    Local static $displayed = False
    Local Static $x_offset = 0
    
    If ((Not _WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 325, $gui_coords[1] + 10, $gui_coords[0] + 585, $gui_coords[1] + 450)) and $displayed) Then
        While ((Not _WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 350, $gui_coords[1] + 10, $gui_coords[0] + 350 + $x_offset, $gui_coords[1] + 450)) and $x_offset <> 0)
            $gui_coords = WinGetPos("Parent")
            $mouse_coords = MouseGetPos()
            
            WinMove("Child", "", $gui_coords[0] + 194 + $x_offset, $gui_coords[1] + 24)
            $x_offset -= 6
            Sleep(1)
        Wend
        
        If ($x_offset <> 0) Then
            For $i = $x_offset to 0 Step -3
                WinMove("Child", "", $gui_coords[0] + 194 + $i, $gui_coords[1] + 24)
            Next
            $x_offset = 0
        Else
            $displayed = False
        EndIf
    ElseIf (_WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 325, $gui_coords[1] + 24, $gui_coords[0] + 400, $gui_coords[1] + 450) and Not $displayed) Then
        While (_WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 325, $gui_coords[1] + 24, $gui_coords[0] + 400 + $x_offset, $gui_coords[1] + 450) and $x_offset <> 180)
            $gui_coords = WinGetPos("Parent")
            $mouse_coords = MouseGetPos()
            
            WinMove("Child", "", $gui_coords[0] + 194 + $x_offset, $gui_coords[1] + 24)
            $x_offset += 10
            Sleep(1)
        Wend
        
        If ($x_offset <> 180) Then
            For $i = $x_offset to 180 Step 3
                WinMove("Child", "", $gui_coords[0] + 194 + $i, $gui_coords[1] + 24)
            Next
            $x_offset = 180
        Else
            $displayed = True
        EndIf
    EndIf
EndFunc

 

Share this post


Link to post
Share on other sites
InunoTaishou

Realized I didn't need to use child because the child window would have been hidden anyway so the user would never know if it was behind the main GUI or not. Ended up just moving it off the screen. Created a $frmDummy GUI and made the $frmChild a child of that one just so there was no toolbar icon. Once the mouse goes out of bounds the $frmChild starts to go back to hiding behind the $frmMain GUI. Once the $x_offset is at 0 the $frmChild is moved out of the screen. (Also have an extra if statement after each while loop that moves the $frmChild to see if the user maybe moved the mouse back into, or out of, the bounding area, depending on the state of $displayed.)

 

(Hopefully all of that made sense)

 

Came out pretty smooth.

#include <GuiConstantsEx.au3>
#include <WindowsConstants.au3>
#include <WinAPI.au3>
#include <WinAPIGdi.au3>

AutoItSetOption("GuiOnEventMode", 1)

$frmMain = GUICreate("Parent", 400, 400, -1, -1, -1, $WS_EX_TOPMOST)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "MyFunc")
GUISetOnEvent($GUI_EVENT_CLOSE, "Close")

$lblScrollMenu = GUICtrlCreateLabel("", 375, 0, 25, 400)
GUICtrlSetBkColor(-1, 0x000000)

$frmDummy = GUICreate("Dummy", 0, 0)
$frmChild = GuiCreate("Child", 250, 395, @DesktopWidth * 2, -1, $WS_POPUP, -1, $frmDummy)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "MyFunc")

$btnButton = GUICtrlCreateButton("Stuff", 20, 10, 220, 20)
GUICtrlSetFont(-1, 10, 300, "", "Segoe UI")
GUICtrlSetOnEvent(-1, "DoStuff")

$lblLabel = GUICtrlCreateLabel("Press the button to do stuff", 20, 35, 220, 25)
GUICtrlSetFont(-1, 10, 300, "", "Segoe UI")

GUICtrlCreateGroup("Colors", 20, 65, 220, 100)
GUICtrlCreateRadio("Red", 30, 80, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Green", 90, 80, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Blue", 160, 80, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Cyan", 30, 105, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Magenta", 90, 105, 60, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Yellow", 160, 105, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlCreateRadio("Black", 30, 130, 50, 20)
GUICtrlSetOnEvent(-1, "SetColor")
GUICtrlSetState(-1, $GUI_CHECKED)

GUISetState(@SW_SHOW, $frmMain)
GUISetState(@SW_SHOW, $frmChild)

While 1
    Sleep(250)
WEnd

Func DoStuff()
    GUICtrlSetData($lblLabel, "Stuff happened! :D")
    Sleep(500)
    GUICtrlSetData($lblLabel, "Press the button to do stuff")
EndFunc

Func SetColor()
    Local const $color = GUICtrlRead(@GUI_CtrlId, 1)
    
    If ($color = "Red") Then
        GUICtrlSetBkColor($lblScrollMenu, 0xFF0000)
    ElseIf ($color = "Green") Then
        GUICtrlSetBkColor($lblScrollMenu, 0x00FF00)
    ElseIf ($color = "Blue") Then
        GUICtrlSetBkColor($lblScrollMenu, 0x0000FF)
    ElseIf ($color = "Cyan") Then
        GUICtrlSetBkColor($lblScrollMenu, 0x00FFFF)
    ElseIf ($color = "Yellow") Then
        GUICtrlSetBkColor($lblScrollMenu, 0xFFFF00)
    ElseIf ($color = "Magenta") Then
        GUICtrlSetBkColor($lblScrollMenu, 0xFF00FF)
    Else
        GUICtrlSetBkColor($lblScrollMenu, 0x000000)
    EndIf
EndFunc

Func MyFunc()
    Local $gui_coords = WinGetPos("Parent")
    Local $mouse_coords = MouseGetPos()
    Local static $displayed = False
    Local Static $x_offset = 0
    
    If ($displayed) Then
        If (Not _WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 375, $gui_coords[1] + 10, $gui_coords[0] + 675, $gui_coords[1] + 425)) Then
            While ((Not _WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 375, $gui_coords[1] + 10, $gui_coords[0] + 350 + $x_offset, $gui_coords[1] + 425)) and $x_offset <> 0)
                $gui_coords = WinGetPos("Parent")
                $mouse_coords = MouseGetPos()
                
                $x_offset -= 10
                WinMove("Child", "", $gui_coords[0] + 140 + $x_offset, $gui_coords[1] + 28)
                Sleep(1)
            Wend
            
            If ($x_offset <> 0) Then
                For $i = $x_offset to 260 Step 5
                    WinMove("Child", "", $gui_coords[0] + 140 + $i, $gui_coords[1] + 28)
                Next
                $displayed = True
            Else
                WinMove("Child", "", @DesktopWidth * 2, 0)
                $displayed = False
            EndIf
        EndIf
    Else
        If (_WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 375, $gui_coords[1] + 24, $gui_coords[0] + 400, $gui_coords[1] + 425)) Then
            While (_WinAPI_PtInRectEx($mouse_coords[0], $mouse_coords[1], $gui_coords[0] + 375, $gui_coords[1] + 24, $gui_coords[0] + 425 + $x_offset, $gui_coords[1] + 425) and $x_offset <> 260)
                $gui_coords = WinGetPos("Parent")
                $mouse_coords = MouseGetPos()
                
                $x_offset += 10
                WinMove("Child", "", $gui_coords[0] + 140 + $x_offset, $gui_coords[1] + 28)
                Sleep(1)
            Wend
            
            If ($x_offset <> 260) Then
                For $i = $x_offset to 0 Step -5
                    WinMove("Child", "", $gui_coords[0] + 140 + $i, $gui_coords[1] + 28)
                Next
                WinMove("Child", "", @DesktopWidth * 2, 0)
                $displayed = False
            Else
                $displayed = True
            EndIf
        EndIf
    EndIf
EndFunc

Func Close()
    Exit
EndFunc

 

Share this post


Link to post
Share on other sites
InunoTaishou

Not quite, that just resizes the GUI, I was trying to create kind of a sliding GUI that pops out behind the main GUI.

This is what mine loos like.

 

http://i.imgur.com/zoIgTRH.gifv

Edited by InunoTaishou

Share this post


Link to post
Share on other sites
Melba23

InunoTaishou,

that just resizes the GUI

I would like to point out that the UDF does a bit more than that - but it certainly does not slide as you require.

Have you looked into animating the GUI? Take a look at my Toast or Notify UDFs to see how you can do it. If I find time later (I am about to go out) I will see if I can produce an example based on your code above.

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

 

Share this post


Link to post
Share on other sites
Melba23

InunoTaishou,

How about this?

#include <GUIConstantsEx.au3>
#include <WindowsConstants.au3>
#include <AutoItConstants.au3>
#include <WinAPISys.au3>

AutoItSetOption("GuiOnEventMode", 1)

Global $iBorder = 50, $bOpen = False

$hGUI = GUICreate("Test", 500, 500, 200, 200)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "_MouseMove")
GUISetOnEvent($GUI_EVENT_CLOSE, "_Close")

$cScrollLabel = GUICtrlCreateLabel("", 500 - $iBorder, 0, $iBorder, 500)
GUICtrlSetBkColor($cScrollLabel, 0x000000)

GUISetState()

$aWinPos = WinGetPos($hGUI)

$hChild = GUICreate("Child", 250, $aWinPos[3] - 20, $aWinPos[0] + 506, $aWinPos[1] + 10, $WS_POPUP)
GUISetOnEvent($GUI_EVENT_MOUSEMOVE, "_MouseMove")

$cButton = GUICtrlCreateButton("Stuff", 20, 10, 220, 20)
GUICtrlSetFont($cButton, 10, 300, "", "Segoe UI")
GUICtrlSetOnEvent($cButton, "_DoStuff")

$cLabel = GUICtrlCreateLabel("Press the button to do stuff", 20, 35, 220, 25)
GUICtrlSetFont($cLabel, 10, 300, "", "Segoe UI")

GUICtrlCreateGroup("Colors", 20, 65, 220, 100)
GUICtrlCreateRadio("Red", 30, 80, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Green", 90, 80, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Blue", 160, 80, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Cyan", 30, 105, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Magenta", 90, 105, 60, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Yellow", 160, 105, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlCreateRadio("Black", 30, 130, 50, 20)
GUICtrlSetOnEvent(-1, "_SetColor")
GUICtrlSetState(-1, $GUI_CHECKED)

WinSetTrans($hChild, "", 0)
GUISetState()
_WinAPI_SetWindowPos($hChild, $hGUI, 706, 230, 250, 490, $SWP_HIDEWINDOW)
WinSetTrans($hChild, "", 255)

GUIRegisterMsg($WM_MOVE, "_WM_MOVE")

While 1
    Sleep(10)
WEnd



Func _MouseMove()
    If Not $bOpen Then
        $aWinPos = WinGetPos($hGUI)
        $aCInfo = GUIGetCursorInfo($hGUI)
        Switch $aCInfo[1]
            Case 20 To $aWinPos[3] ; Allow space at the top so that moving to the buttons does not opene the child
                Switch $aCInfo[0]
                    Case $aWinPos[2] - $iBorder To $aWinPos[2]
                        If Not $bOpen Then
                            _WinAPI_AnimateWindow($hChild, BitOR($AW_ACTIVATE, $AW_HOR_POSITIVE))
                            $bOpen = True
                            WinActivate($hChild)
                        EndIf



                EndSwitch

        EndSwitch

    Else
        $aWinPos = WinGetPos($hChild)
        $aCInfo = GUIGetCursorInfo($hChild)
        Switch $aCInfo[1]
            Case 0 To $aWinPos[3]
                If $aCInfo[0] < -$iBorder Then
                    If $bOpen Then
                        _WinAPI_AnimateWindow($hChild, BitOR($AW_HIDE, $AW_HOR_NEGATIVE))
                        $bOpen = False
                        WinActivate($hGUI)
                    EndIf

                EndIf

        EndSwitch

    EndIf

EndFunc   ;==>_MouseMove



Func _DoStuff()
    GUICtrlSetData($cLabel, "Stuff happened! :D")
    Sleep(500)
    GUICtrlSetData($cLabel, "Press the button to do stuff")
EndFunc   ;==>_DoStuff



Func _SetColor()
    Switch GUICtrlRead(@GUI_CtrlId, 1)
        Case "Red"
            GUICtrlSetBkColor($cScrollLabel, 0xFF0000)
        Case "Green"
            GUICtrlSetBkColor($cScrollLabel, 0x00FF00)
        Case "Blue"
            GUICtrlSetBkColor($cScrollLabel, 0x0000FF)
        Case "Cyan"
            GUICtrlSetBkColor($cScrollLabel, 0x00FFFF)
        Case "Yellow"
            GUICtrlSetBkColor($cScrollLabel, 0xFFFF00)
        Case "Magenta"
            GUICtrlSetBkColor($cScrollLabel, 0xFF00FF)
        Case Else
            GUICtrlSetBkColor($cScrollLabel, 0x000000)
    EndSwitch

EndFunc   ;==>_SetColor



Func _Close()
    Exit
EndFunc   ;==>_Close

Func _WM_MOVE($hWnd, $iMsg, $wParam, $lParam)
    #forceref $iMsg, $wParam, $lParam

    If $hWnd = $hGUI Then
        Local $aWinPos = WinGetPos($hGUI)
        WinMove($hChild, "", $aWinPos[0] + 506, $aWinPos[1] + 30)
    EndIf

EndFunc   ;==>_WM_MOVE

Please ask if you have any questions.

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

 

Share this post


Link to post
Share on other sites
InunoTaishou

My god, I didn't realize there was a WinAPI function that could do what I needed!

Yours is pretty nice, looks like a rolling window, I was looking for a sliding window and $AW_SLIDE does exactly that. Thank you very much!

It looks like the GUI becomes disabled while the API function is moving the child though. It does what I need in less code but it doesn't work as well as what I was wanting it for, still really nice function to make some pretty GUIs.

 

And by what I was wanting I mean that if the use moves away from the area that causes the window to move out, it starts to go back into retracted. If the user goes back into the area that causes the window to move out again it starts to move the window out again. The _WinAPI_AnimateWindow looks extremely useful though.

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

    • Sven-Seyfert
      By Sven-Seyfert
      Hi Community,

      I use a UDF by @smashly to play a video in a GUI. That works fine for my main monitor.
      But when I change the X and Y positions of the GUI (also for the video) to my second or third monitor, the video plays, I can hear the sound of it, but I don't see the video.

      I debugged the UDF and checked the Microsoft description for MCI Command Strings which are used in the UDF (docs.microsoft...) - everything is fine, so I got no clue why the video isn't displayed.

      PlayVideoTest.au3:
       
      VideoInGui_by_Smashky.au3 (UDF):
       
      The example video:
       
      It would be great when anyone can help .
      Is there maybe a other way to play (display videos in GUI)?

      Thanks for any suggestion - I'm grateful!
      Sven
    • UEZ
      By UEZ
      Following script shows a parent GUI with a child GUI initialized as MDICHILD.
      #include <Constants.au3> #include <GUIConstantsEx.au3> #include <GuiReBar.au3> #include <GuiScrollBars.au3> #include <GuiToolbar.au3> #include <ScreenCapture.au3> #include <ScrollBarConstants.au3> #include <WindowsConstants.au3> _GDIPlus_Startup() Global Enum $idNew = 1000, $idOpen, $idSave, $idHelper Global Const $iImageW = @DesktopWidth, $iImageH = @DesktopHeight Global Const $hBMP_ScreenCapture = _ScreenCapture_Capture("", 0, 0, $iImageW, $iImageH, False) Global Const $hBitmap = _GDIPlus_BitmapCreateFromHBITMAP($hBMP_ScreenCapture) Sleep(50) Global Const $iW = 1500, $iH = 700, $SC_DRAGMOVE = 0xF012 Global Const $hGUI = GUICreate("Move child GUI within GUI", $iW, $iH) Global Const $hToolbar = _GUICtrlToolbar_Create($hGUI) Global Const $hReBar = _GUICtrlRebar_Create($hGUI, BitOR($CCS_TOP, $RBS_VARHEIGHT, $RBS_AUTOSIZE, $RBS_BANDBORDERS)) Global Const $height_delta = 37 Global Const $idPic = GUICtrlCreatePic("", 0, $height_delta + 2, $iW, $iH) Global $hBitmap_tmp, $hHBitmap_tmp $hBitmap_tmp = _GDIPlus_BitmapCreateFromScan0($iW, $iH) Global $hGfx_Context = _GDIPlus_ImageGetGraphicsContext($hBitmap_tmp) _GUICtrlToolbar_AddBitmap($hToolbar, 1, -1, $IDB_STD_LARGE_COLOR) _GUICtrlToolbar_AddButton($hToolbar, $idNew, $STD_FILENEW) _GUICtrlToolbar_AddButton($hToolbar, $idOpen, $STD_FILEOPEN) _GUICtrlToolbar_AddButton($hToolbar, $idSave, $STD_FILESAVE) _GUICtrlToolbar_AddButtonSep($hToolbar) _GUICtrlToolbar_AddButton($hToolbar, $idHelper, $STD_HELP) _GUICtrlRebar_AddToolBarBand($hReBar, $hToolbar, "", 0) Global Const $iVSscroll = _WinAPI_GetSystemMetrics(2) Global Const $iHSscroll = _WinAPI_GetSystemMetrics(3) Global Const $iYCaption = _WinAPI_GetSystemMetrics(4) Global Const $iYFixedFrame = _WinAPI_GetSystemMetrics(8) Global Const $iXFixedFrame = _WinAPI_GetSystemMetrics(7) Global Const $iMetricsSumX = $iVSscroll + $iXFixedFrame * 2 Global Const $iMetricsSumY = $iHSscroll + $iYCaption + $iYFixedFrame _GUIScrollBars_Init($hGUI) _GUIScrollBars_SetScrollInfoMin($hGUI, $SB_HORZ, 0) _GUIScrollBars_SetScrollInfoMax($hGUI, $SB_HORZ, $iImageW - $iW + 61 + $iMetricsSumX) _GUIScrollBars_SetScrollInfoMin($hGUI, $SB_VERT, 0) _GUIScrollBars_SetScrollInfoMax($hGUI, $SB_VERT, $iImageH - $iH + $iMetricsSumY + $height_delta - 1) GUISetState(@SW_SHOW, $hGUI) Global Const $STM_SETIMAGE = 0x0172 _WinAPI_DeleteObject(GUICtrlSendMsg($idPic, $STM_SETIMAGE, $IMAGE_BITMAP, $hBMP_ScreenCapture)) Global $IE_offset_x = 0, $IE_offset_y = 0 DrawImage($hGfx_Context, $hBitmap, $IE_offset_x, $IE_offset_y, $iW, $iH) GUIRegisterMsg($WM_HSCROLL, "WM_HSCROLL_IE") GUIRegisterMsg($WM_VSCROLL, "WM_VSCROLL_IE") Global $iPosX_Crop = 0, $iPosY_Crop = 0, $iW_crop = 200, $iH_crop = 200, $bMove_Crop = True Global $hGUI_IE_Crop = GUICreate("", $iW_crop, $iH_crop, $iPosX_Crop, $iPosY_Crop) GUISetStyle(BitOR($WS_BORDER, $WS_POPUP), $WS_EX_MDICHILD) _WinAPI_SetParent($hGUI_IE_Crop, $hGUI) WinSetTrans($hGUI_IE_Crop, "", 0xA0) Global $iLable_CropMove = GUICtrlCreateLabel("", 0, 0, $iW_crop, $iH_crop, -1, $GUI_WS_EX_PARENTDRAG) GUISetState(@SW_SHOW, $hGUI_IE_Crop) GUIRegisterMsg($WM_MOVE, "WM_MOVE_IE_GUI_Crop") ;~ GUIRegisterMsg($WM_LBUTTONDOWN, "_WM_LBUTTONDOWN") Do Switch GUIGetMsg() Case $GUI_EVENT_CLOSE ExitLoop EndSwitch Until False GUIRegisterMsg($WM_HSCROLL, "") GUIRegisterMsg($WM_VSCROLL, "") GUIRegisterMsg($WM_MOVE, "") GUIRegisterMsg($WM_LBUTTONDOWN, "") _WinAPI_DeleteObject($hBMP_ScreenCapture) _GDIPlus_BitmapDispose($hBitmap_tmp) _GDIPlus_BitmapDispose($hBitmap) _GDIPlus_GraphicsDispose($hGfx_Context) _GDIPlus_Shutdown() Exit Func WM_HSCROLL_IE($hWnd, $iMsg, $wParam, $lParam) #forceref $iMsg, $lParam Local $Min, $Max, $Page, $TrackPos ; Get all the horizontal scroll bar information Local $tSCROLLINFO_X = _GUIScrollBars_GetScrollInfoEx($hWnd, $SB_HORZ) $Min = DllStructGetData($tSCROLLINFO_X, "nMin") $Max = DllStructGetData($tSCROLLINFO_X, "nMax") $Page = DllStructGetData($tSCROLLINFO_X, "nPage") ; Save the position for comparison later on $IE_offset_x = DllStructGetData($tSCROLLINFO_X, "nPos") $TrackPos = DllStructGetData($tSCROLLINFO_X, "nTrackPos") #forceref $Min, $Max Local $nScrollCode = BitAND($wParam, 0x0000FFFF) Switch $nScrollCode Case $SB_LINELEFT ; user clicked left arrow DllStructSetData($tSCROLLINFO_X, "nPos", $IE_offset_x - 1) Case $SB_LINERIGHT ; user clicked right arrow DllStructSetData($tSCROLLINFO_X, "nPos", $IE_offset_x + 1) Case $SB_PAGELEFT ; user clicked the scroll bar shaft left of the scroll box DllStructSetData($tSCROLLINFO_X, "nPos", $IE_offset_x - $Page) Case $SB_PAGERIGHT ; user clicked the scroll bar shaft right of the scroll box DllStructSetData($tSCROLLINFO_X, "nPos", $IE_offset_x + $Page) Case $SB_THUMBTRACK ; user dragged the scroll box DllStructSetData($tSCROLLINFO_X, "nPos", $TrackPos) EndSwitch DllStructSetData($tSCROLLINFO_X, "fMask", $SIF_POS) _GUIScrollBars_SetScrollInfo($hWnd, $SB_HORZ, $tSCROLLINFO_X) $IE_offset_x = DllStructGetData($tSCROLLINFO_X, "nPos") DrawImage($hGfx_Context, $hBitmap, $IE_offset_x, $IE_offset_y, $iW, $iH) $hHBitmap_tmp = _GDIPlus_BitmapCreateHBITMAPFromBitmap($hBitmap_tmp) _WinAPI_DeleteObject(GUICtrlSendMsg($idPic, $STM_SETIMAGE, $IMAGE_BITMAP, $hHBitmap_tmp)) _WinAPI_DeleteObject($hHBitmap_tmp) $bMove_Crop = False ConsoleWrite($iPosX_Crop & ", " & $iPosY_Crop & " / " & $IE_offset_x & ", " & $IE_offset_y & @CRLF) WinMove($hGUI_IE_Crop, "", -$IE_offset_x + $iPosX_Crop, -$IE_offset_y + $iPosY_Crop) ;~ DllCall("user32.dll", "bool", "MoveWindow", "hwnd", $hGUI_IE_Crop, "int", -$IE_offset_x + $iPosX_Crop, "int", -$IE_offset_y + $iPosY_Crop, "int", $iW_crop, "int", $iH_crop, "bool", True) $bMove_Crop = True Return "GUI_RUNDEFMSG" EndFunc ;==>WM_HSCROLL_IE Func WM_VSCROLL_IE($hWnd, $iMsg, $wParam, $lParam) #forceref $iMsg, $lParam Local $Min, $Max, $Page, $TrackPos ;~ ; Get all the horizontal scroll bar information Local $tSCROLLINFO_Y = _GUIScrollBars_GetScrollInfoEx($hWnd, $SB_VERT) $Min = DllStructGetData($tSCROLLINFO_Y, "nMin") $Max = DllStructGetData($tSCROLLINFO_Y, "nMax") $Page = DllStructGetData($tSCROLLINFO_Y, "nPage") ; Save the position for comparison later on $IE_offset_y = DllStructGetData($tSCROLLINFO_Y, "nPos") $TrackPos = DllStructGetData($tSCROLLINFO_Y, "nTrackPos") #forceref $Min, $Max Local $nScrollCode = BitAND($wParam, 0x0000FFFF) Switch $nScrollCode Case $SB_LINELEFT ; user clicked left arrow DllStructSetData($tSCROLLINFO_Y, "nPos", $IE_offset_y - 1) Case $SB_LINERIGHT ; user clicked right arrow DllStructSetData($tSCROLLINFO_Y, "nPos", $IE_offset_y + 1) Case $SB_PAGELEFT ; user clicked the scroll bar shaft left of the scroll box DllStructSetData($tSCROLLINFO_Y, "nPos", $IE_offset_y - $Page) Case $SB_PAGERIGHT ; user clicked the scroll bar shaft right of the scroll box DllStructSetData($tSCROLLINFO_Y, "nPos", $IE_offset_y + $Page) Case $SB_THUMBTRACK ; user dragged the scroll box DllStructSetData($tSCROLLINFO_Y, "nPos", $TrackPos) EndSwitch DllStructSetData($tSCROLLINFO_Y, "fMask", $SIF_POS) _GUIScrollBars_SetScrollInfo($hWnd, $SB_VERT, $tSCROLLINFO_Y) $IE_offset_y = DllStructGetData($tSCROLLINFO_Y, "nPos") DrawImage($hGfx_Context, $hBitmap, $IE_offset_x, $IE_offset_y, $iW, $iH) $bMove_Crop = False ConsoleWrite($iPosX_Crop & ", " & $iPosY_Crop & " / " & $IE_offset_x & ", " & $IE_offset_y & @CRLF) WinMove($hGUI_IE_Crop, "", -$IE_offset_x + $iPosX_Crop, -$IE_offset_y + $iPosY_Crop) ;~ DllCall("user32.dll", "bool", "MoveWindow", "hwnd", $hGUI_IE_Crop, "int", -$IE_offset_x + $iPosX_Crop, "int", -$IE_offset_y + $iPosY_Crop, "int", $iW_crop, "int", $iH_crop, "bool", True) $bMove_Crop = True Return "GUI_RUNDEFMSG" EndFunc ;==>WM_VSCROLL_IE Func _WM_LBUTTONDOWN($hWnd, $iMsg, $wParam, $lParam) _SendMessage($hGUI_IE_Crop, $WM_SYSCOMMAND, $SC_DRAGMOVE, 0) EndFunc ;==>_WM_LBUTTONDOWN Func WM_MOVE_IE_GUI_Crop($hWnd, $iMsg, $wParam, $lParam) #forceref $iMsg, $wParam If $hWnd = $hGUI_IE_Crop And $bMove_Crop Then $iPosX_Crop = _WinAPI_LoWord($lParam) $iPosY_Crop = _WinAPI_HiWord($lParam) EndIf Return "GUI_RUNDEFMSG" EndFunc ;==>WM_MOVE_IE_GUI_Crop Func WM_SIZE_IE_GUI_Crop($hWnd, $iMsg, $wParam, $lParam) Return $GUI_RUNDEFMSG EndFunc ;==>WM_SIZE_IE_GUI_Crop Func DrawImage($hGfx_Context, $hBitmap, $IE_offset_x, $IE_offset_y, $iW, $iH) _GDIPlus_GraphicsDrawImageRectRect($hGfx_Context, $hBitmap, $IE_offset_x, $IE_offset_y, $iW, $iH, 0, 0, $iW, $iH) $hHBitmap_tmp = _GDIPlus_BitmapCreateHBITMAPFromBitmap($hBitmap_tmp) _WinAPI_DeleteObject(GUICtrlSendMsg($idPic, $STM_SETIMAGE, $IMAGE_BITMAP, $hHBitmap_tmp)) _WinAPI_DeleteObject($hHBitmap_tmp) EndFunc  
      My problem: if you move the child window at left upper corner to another place and move either H or V scrollbar the child GUI will be moved properly. BUT if you have scrolled the scrollbars to the right bottom of the image and move the child GUI to that corner, too then the child GUI jumps if you click on one of the scrollbars.
      Is there something that I didn't consider?
    • Emmhor1
      By Emmhor1
      Hi All,

      MAIN QUESTION:
      Is it possible to Call specific function within a GUI

      So I have a script with multiple functions although I don't want to use every function every time.
      My Idea is to create a simple GUI which allows me to select what functions I want to use then run the funtions by clicking a button.
      I have already made a GUI which allows me to select specific .exe's I would like to run after selection it runs the .exe one by one.
      This script is on my work laptops and cannot access it right now.
       
      Who can help me with this?
      GUIcreate
      Func1 
      Func2
      Func3
      Then have a boxes which allows me to select the specif Func.(I used GUIChecked and Unchecked in my other script)
      Then a button which executes/calls the selected functions
    • Blois
      By Blois
      Hi Guis,
       
      I need to create keyboard shortcut to navigate the tabs and activate them, but I could not use the code below:
      #include <TabConstants.au3> #include <WindowsConstants.au3> #include <GuiTab.au3> #include <GUIConstantsEx.au3> HotKeySet("^{TAB}", "_TabRight") HotKeySet("^+{TAB}", "_TabLeft") $gui = GUICreate("test",450, 300) $Tab1 = GUICtrlCreateTab(20, 24, 425, 201) $TabSheet1 = GUICtrlCreateTabItem("Tabsheet 1") $lbContagemGrupos2 = GUICtrlCreateLabel("aaaa", 50, 50) GUICtrlSetColor(-1, 0x0000FF) GUICtrlCreateTabItem("") $TabSheet2 = GUICtrlCreateTabItem(" ") $TabSheet3 = GUICtrlCreateTabItem(" ") GUISetState() While 1 Switch GUIGetMsg() Case $GUI_EVENT_CLOSE ExitLoop EndSwitch WEnd Func _TabRight() $CurPos = _GUICtrlTab_GetCurSel($Tab1) _GUICtrlTab_SetCurSel($Tab1, $CurPos + 1) $tab = "$TabSheet" & $CurPos GUICtrlSetState($TabSheet1 + $CurPos, $GUI_SHOW) Return EndFunc Func _TabLeft() $CurPos = _GUICtrlTab_GetCurSel($Tab1) _GUICtrlTab_SetCurSel($Tab1, $CurPos - 1) $tab = "$TabSheet" & $CurPos GUICtrlSetState($TabSheet1 + $CurPos, $GUI_SHOW) Return EndFunc Exit  
      can you help me?
×