Jump to content
corz

Help my one-hit-wonder!

Recommended Posts

corz

This is a magnifier-color-picker thing mostly based on some code I found on Stack Overflow, of all places. At least all the clever bits are from there. 

I'd love to use this code inside an app I'm working on. But it has an issue. The first time the mag pops up it works perfectly, but the second and subsequent times, it's a boring grey square. 

One of you smart dudes will probably look at this and go, "Aha!", but I'm stumped.

#include <WindowsConstants.au3>
#include <WinAPI.au3>
#include <StaticConstants.au3>

MagWindow()
MagWindow()

; Magnifier-Color-Picker..
; Props to McBarby for the cross-hairs.
func MagWindow()

    global $iMagZoom = 5
    global $iMagWidth = Ceiling(100/$iMagZoom)
    global $iMagHeight = Ceiling(100/$iMagZoom)

    global $hDCDesk, $hDCZoom, $hPen
    global $hUser32 = DllOpen("user32.dll")
    global $hGDI32 = DllOpen("gdi32.dll")
    global $pixel_color, $mag_open = false
    local  $mX, $mY
    
    global $hCross = GUICreate('', 48, 48, -1, -1, $WS_POPUP, $WS_EX_TOPMOST)
    WinSetTrans($hCross, '', 0)
    GUISetCursor(3, 1, $hCross)

    global $hZoom = GUICreate("MagPicker", $iMagWidth * $iMagZoom, $iMagHeight * $iMagZoom, _
                    MouseGetPos(0), MouseGetPos(1), $WS_POPUP+$WS_BORDER, $WS_EX_TOPMOST)

    global $mag_label = GUICtrlCreateLabel("placehold", (($iMagHeight * $iMagZoom)/2)+2, ($iMagHeight * $iMagZoom) - 13, _
                            (($iMagHeight * $iMagZoom)/2)-3, 12, $SS_RIGHT)
    
    ; put this after the GUICreate()s so that it will not error on startup with mouse already moving. (now trapped! but we will leave them here.)
    global $__hMouseProc = DllCallbackRegister("_MouseProc", "long", "int;wparam;lparam")
    global $__hHook = _WinAPI_SetWindowsHookEx($WH_MOUSE_LL, DllCallbackGetPtr($__hMouseProc), _WinAPI_GetModuleHandle(0))
        
    GUISetState(@SW_SHOW, $hCross)
    GUISetState(@SW_SHOW, $hZoom)
    $mag_open = true
    
    ; once at start, then from the mouse-callback-function..
    _Magnify()
    
    while $mag_open
        Sleep(50)
        $mX = MouseGetPos(0)
        $mY = MouseGetPos(1)        
        $pixel_color = Hex(PixelGetColor($mX, $mY), 6)
        GUICtrlSetData ($mag_label, $pixel_color)
    wend
    
    GUIDelete($hZoom)
    GUIDelete($hCross)
    ReleaseHooks()
    
endfunc

func _Magnify($_iX=-1, $_iY=-1)
    local Static $fInit = true
    if $fInit then
        $fInit = False
        $hDCDesk = (DLLCall($hUser32, "int", "GetDC", "hwnd", 0))[0]
        $hDCZoom = (DLLCall($hUser32, "int", "GetDC", "hwnd", $hZoom))[0]
        $hPen = (DLLCall($hGDI32, "int", "CreatePen", "int", 0, "int", 3, "int", 0x008b9094))[0] ; 0=PS_SOLID, dark-blue (0x00BBGGRR)
        DLLCall($hGDI32, "int", "SelectObject", "int", $hDCZoom, "hwnd", $hPen)
        $_iX = MouseGetPos(0)
        $_iY = MouseGetPos(1)
    endif
    local $iW = $iMagWidth * $iMagZoom, $iH = $iMagHeight * $iMagZoom
    if not @error then
        DLLCall($hGDI32, "int", "StretchBlt", "int", $hDCZoom, "int", _
            0, "int", 0, "int", $iW, "int", $iH, "int", $hDCDesk, "int", _
            $_iX - $iMagWidth/2, "int", $_iY - $iMagHeight/2, "int", $iMagWidth ,"int", $iMagHeight, _
            "long", $SRCCOPY)
        ; draw the crosshair    (start x, start y, end x, end y)
        _GDI32_DrawLine($hDCZoom, ($iW/2)-2, $iH/8, ($iW/2)-2, 4*($iH/8)-6, $hGDI32)     ; vertical top
        _GDI32_DrawLine($hDCZoom, ($iW/2)-2, 5*($iH/8)-10, ($iW/2)-2, 7*($iH/8), $hGDI32) ; vertical bottom
        _GDI32_DrawLine($hDCZoom, $iW/8, ($iH/2)-2, (3*($iW/8))+6, ($iH/2)-2, $hGDI32)     ; horizontal left
        _GDI32_DrawLine($hDCZoom, 4*($iW/8)+3, ($iH/2)-2, 7*($iW/8), ($iH/2)-2, $hGDI32) ; horizontal right
    endif
endfunc

func _GDI32_DrawLine(ByRef $_hDC, $_iX0, $i_Y0, $_iX1, $i_Y1, $_hDll=-1)
    If $_hDll = -1 then $_hDll = "gdi32.dll"
    Local $tCurrent = DllStructCreate("struct; long X;long Y; endstruct")
    DllCall($_hDll, "int", "MoveToEx", "int", $_hDC, "int", $_iX0, "int", $i_Y0, "ptr", DllStructGetPtr($tCurrent))
    DllCall($_hDll, "int", "LineTo", "int", $_hDC, "int", $_iX1, "int", $i_Y1)
    return $tCurrent
endfunc

func _MouseProc($_nCode, $_wParam, $_lParam)
    local $tMSLLHOOKSTRUCT = DllStructCreate("struct; long X;long Y; endstruct; " & _
        "DWORD mouseData; DWORD flags; DWORD time; ULONG_PTR dwExtraInfo;endstruct", $_lParam)
    if $_nCode < 0 Then Return _WinAPI_CallNextHookEx($__hHook, $_nCode, $_wParam, $_lParam)
    local $iX = $tMSLLHOOKSTRUCT.X, $iY = $tMSLLHOOKSTRUCT.Y
    switch $_wParam
        case $WM_LBUTTONDOWN
            CloseMag()
        case $WM_MOUSEMOVE
            if not $mag_open then return
            WinMove($hCross, "", $iX -24, $iY -24)
            Local $iXz = ($iX +24 + $iMagWidth*$iMagZoom > @DesktopWidth) ? $iX -(24 + $iMagWidth*$iMagZoom) : $iX +24
            Local $iYz = ($iY +24 + $iMagHeight*$iMagZoom > @DesktopHeight) ? $iY -(24 + $iMagHeight*$iMagZoom) : $iY +24
            WinMove($hZoom, "", $iXz + $iMagWidth/2, $iYz)
            _Magnify($iX, $iY)
    endswitch
    return _WinAPI_CallNextHookEx($__hHook, $_nCode, $_wParam, $_lParam)
endfunc

func ReleaseHooks()
    DLLCall($hUser32, "int", "ReleaseDC", "int", $hDCZoom, "hwnd", $hPen)
    DLLCall($hUser32, "int", "ReleaseDC", "int", $hDCDesk, "hwnd", 0)
    DLLCall($hUser32, "int", "ReleaseDC", "int", $hDCZoom, "hwnd", 0)
    DllClose($hUser32)
    DllClose($hGDI32)
    _WinAPI_UnhookWindowsHookEx($__hHook)
    DllCallbackFree($__hMouseProc)
endfunc

func CloseMag()  ; called by mouse left click
    $mag_open = false
endfunc

 

Thanks for any and all insights!

;o) Cor


nothing is foolproof to the sufficiently talented fool..

Share this post


Link to post
Share on other sites
Jos

Nice ...   try this version and find the difference :)

#include <WindowsConstants.au3>
#include <WinAPI.au3>
#include <StaticConstants.au3>

MagWindow()
MagWindow()

; Magnifier-Color-Picker..
; Props to McBarby for the cross-hairs.
Func MagWindow()

    Global $iMagZoom = 5
    Global $iMagWidth = Ceiling(100 / $iMagZoom)
    Global $iMagHeight = Ceiling(100 / $iMagZoom)

    Global $hDCDesk = 0, $hDCZoom = 0, $hPen = 0
    Global $hUser32 = DllOpen("user32.dll")
    Global $hGDI32 = DllOpen("gdi32.dll")
    Global $pixel_color, $mag_open = False
    Local $mX = 0, $mY = 0

    Global $hCross = GUICreate('', 48, 48, -1, -1, $WS_POPUP, $WS_EX_TOPMOST)
    WinSetTrans($hCross, '', 0)
    GUISetCursor(3, 1, $hCross)

    Global $hZoom = GUICreate("MagPicker", $iMagWidth * $iMagZoom, $iMagHeight * $iMagZoom, _
            MouseGetPos(0), MouseGetPos(1), $WS_POPUP + $WS_BORDER, $WS_EX_TOPMOST)

    Global $mag_label = GUICtrlCreateLabel("placehold", (($iMagHeight * $iMagZoom) / 2) + 2, ($iMagHeight * $iMagZoom) - 13, _
            (($iMagHeight * $iMagZoom) / 2) - 3, 12, $SS_RIGHT)

    ; put this after the GUICreate()s so that it will not error on startup with mouse already moving. (now trapped! but we will leave them here.)
    Global $__hMouseProc = DllCallbackRegister("_MouseProc", "long", "int;wparam;lparam")
    Global $__hHook = _WinAPI_SetWindowsHookEx($WH_MOUSE_LL, DllCallbackGetPtr($__hMouseProc), _WinAPI_GetModuleHandle(0))

    GUISetState(@SW_SHOW, $hCross)
    GUISetState(@SW_SHOW, $hZoom)
    $mag_open = True

    ; once at start, then from the mouse-callback-function..
    _Magnify()

    While $mag_open
        Sleep(50)
        $mX = MouseGetPos(0)
        $mY = MouseGetPos(1)
        $pixel_color = Hex(PixelGetColor($mX, $mY), 6)
        GUICtrlSetData($mag_label, $pixel_color)
    WEnd

    GUIDelete($hZoom)
    GUIDelete($hCross)
    ReleaseHooks()

EndFunc   ;==>MagWindow

Func _Magnify($_iX = -1, $_iY = -1, $reset = False)
    Local Static $fInit = True
    If $fInit Then
        $fInit = False
        $hDCDesk = (DllCall($hUser32, "int", "GetDC", "hwnd", 0))[0]
        $hDCZoom = (DllCall($hUser32, "int", "GetDC", "hwnd", $hZoom))[0]
        $hPen = (DllCall($hGDI32, "int", "CreatePen", "int", 0, "int", 3, "int", 0x008b9094))[0] ; 0=PS_SOLID, dark-blue (0x00BBGGRR)
        DllCall($hGDI32, "int", "SelectObject", "int", $hDCZoom, "hwnd", $hPen)
        $_iX = MouseGetPos(0)
        $_iY = MouseGetPos(1)
    EndIf
    Local $iW = $iMagWidth * $iMagZoom, $iH = $iMagHeight * $iMagZoom
    If Not @error Then
        DllCall($hGDI32, "int", "StretchBlt", "int", $hDCZoom, "int", _
                0, "int", 0, "int", $iW, "int", $iH, "int", $hDCDesk, "int", _
                $_iX - $iMagWidth / 2, "int", $_iY - $iMagHeight / 2, "int", $iMagWidth, "int", $iMagHeight, _
                "long", $SRCCOPY)
        ; draw the crosshair    (start x, start y, end x, end y)
        _GDI32_DrawLine($hDCZoom, ($iW / 2) - 2, $iH / 8, ($iW / 2) - 2, 4 * ($iH / 8) - 6, $hGDI32) ; vertical top
        _GDI32_DrawLine($hDCZoom, ($iW / 2) - 2, 5 * ($iH / 8) - 10, ($iW / 2) - 2, 7 * ($iH / 8), $hGDI32) ; vertical bottom
        _GDI32_DrawLine($hDCZoom, $iW / 8, ($iH / 2) - 2, (3 * ($iW / 8)) + 6, ($iH / 2) - 2, $hGDI32) ; horizontal left
        _GDI32_DrawLine($hDCZoom, 4 * ($iW / 8) + 3, ($iH / 2) - 2, 7 * ($iW / 8), ($iH / 2) - 2, $hGDI32) ; horizontal right
    EndIf
    If $reset Then
        $fInit = True
    EndIf
EndFunc   ;==>_Magnify

Func _GDI32_DrawLine(ByRef $_hDC, $_iX0, $i_Y0, $_iX1, $i_Y1, $_hDll = -1)
    If $_hDll = -1 Then $_hDll = "gdi32.dll"
    Local $tCurrent = DllStructCreate("struct; long X;long Y; endstruct")
    DllCall($_hDll, "int", "MoveToEx", "int", $_hDC, "int", $_iX0, "int", $i_Y0, "ptr", DllStructGetPtr($tCurrent))
    DllCall($_hDll, "int", "LineTo", "int", $_hDC, "int", $_iX1, "int", $i_Y1)
    Return $tCurrent
EndFunc   ;==>_GDI32_DrawLine

Func _MouseProc($_nCode, $_wParam, $_lParam)
    Local $tMSLLHOOKSTRUCT = DllStructCreate("struct; long X;long Y; endstruct; " & _
            "DWORD mouseData; DWORD flags; DWORD time; ULONG_PTR dwExtraInfo;endstruct", $_lParam)
    If $_nCode < 0 Then Return _WinAPI_CallNextHookEx($__hHook, $_nCode, $_wParam, $_lParam)
    Local $iX = $tMSLLHOOKSTRUCT.X, $iY = $tMSLLHOOKSTRUCT.Y
    Switch $_wParam
        Case $WM_LBUTTONDOWN
            CloseMag()
        Case $WM_MOUSEMOVE
            If Not $mag_open Then Return
            WinMove($hCross, "", $iX - 24, $iY - 24)
            Local $iXz = ($iX + 24 + $iMagWidth * $iMagZoom > @DesktopWidth) ? $iX - (24 + $iMagWidth * $iMagZoom) : $iX + 24
            Local $iYz = ($iY + 24 + $iMagHeight * $iMagZoom > @DesktopHeight) ? $iY - (24 + $iMagHeight * $iMagZoom) : $iY + 24
            WinMove($hZoom, "", $iXz + $iMagWidth / 2, $iYz)
            _Magnify($iX, $iY)
    EndSwitch
    Return _WinAPI_CallNextHookEx($__hHook, $_nCode, $_wParam, $_lParam)
EndFunc   ;==>_MouseProc

Func ReleaseHooks()
    _Magnify(Default, Default, True)
    DllCall($hUser32, "int", "ReleaseDC", "int", $hDCZoom, "hwnd", $hPen)
    DllCall($hUser32, "int", "ReleaseDC", "int", $hDCDesk, "hwnd", 0)
    DllCall($hUser32, "int", "ReleaseDC", "int", $hDCZoom, "hwnd", 0)
    DllClose($hUser32)
    DllClose($hGDI32)
    _WinAPI_UnhookWindowsHookEx($__hHook)
    DllCallbackFree($__hMouseProc)
EndFunc   ;==>ReleaseHooks

Func CloseMag() ; called by mouse left click
    $mag_open = False
EndFunc   ;==>CloseMag

Jos

  • Like 1

Visit the SciTE4AutoIt3 Download page for the latest versions  - Beta files                                How to post scriptsource        Forum Rules
 
Live for the present,
Dream of the future,
Learn from the past.
  :)

Share this post


Link to post
Share on other sites
corz

Jos! As ever, you are a star!

Reset. Very clever! Ta, mate!

;o) Cor


nothing is foolproof to the sufficiently talented fool..

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

    • Reziskonh
      By Reziskonh
      Hi, everybody
      I look for GUI whose behavior similar to the message of an email client or antivirus
      In other words:
          Any PC screen able to calculate the size
          To consider the Task bar size
          To find the lower corner on the right/below and to nestle on it

      Notes:
      In GUI the GUICtrlCreateEdit field (as option) - that can be received and displayed through variable information
      Thanks a lot
      PS
      I use the translator, excuse if something is not clear
       

    • VollachR
      By VollachR
      Hi,
      I'd like to show a progress bar for an operation performed by an external program my script is running silently, I want to show it in a GUI I created using the GUICtrlCreateProgress but I have no idea how to do it.
      The important thing to point out is that there's no way of knowing how long the external program will run, as it is a file splitter and it depends on the size of file it splits and the split parts size.
      Can someone point me in the right direction or give me an example how to do so?
      This is my RunWait command:
      RunWait($MYFILES1 & '\fsplit.exe -split ' & $Size & ' mb ' & $File & " -f " & $File & "." & $extension) It uses multiple variables declared and set earlier in the script, how will I got about having the progress of that command shown using GUICtrlCreateProgress ? Is it possible?
      Thank you.
    • nacerbaaziz
      By nacerbaaziz
      Hello my friends
      I have an inquiry and I hope to find the answer here
      I want to create a graphical user interface
      but I want to hide the system menu
      I mean the window menu
      Is this possible?
      If is possible please give me how to do that
      Thanks in advance
    • helmar
      By helmar
      I was playing around with simple GUI creation.  I tend to like parameter driven coding (in prior life (years ago) as Clipper/FoxPro/dBase coder).  Just wanted to see what I could do with a GUI.
      #Region options, includes Opt('MustDeclareVars', 1) Opt("GUIOnEventMode", 1) ; Change to OnEvent mode #include <GUIConstantsEx.au3> #EndRegion options, includes Global Const $nCols = 2, $nRows = 6, $nSpacer = 10, $nBtnWidth = 150, $nBtnHeight = 30 Global $xName = 0, $xID = 0 Global $nGUIWidth = ($nCols * $nBtnWidth) + (($nCols + 1) * $nSpacer) Global $nGUIHeight = ($nRows * $nBtnHeight) + (($nRows + 1) * $nSpacer) Global $hMainGUI = GUICreate("Calculated GUI", $nGUIWidth, $nGUIHeight, -1, -1) For $xRows = 1 to $nRows ;in this arrangement, tabbing is left to right, then next row For $xCols = 1 to $nCols ;reverse the order of this line with the prior line for top to bottom tabbing, then next col $xName += 1 $xID += 1 Global $Dummy = GUICtrlCreateButton("Button" & $xName, _ ($nBtnWidth * ($xCols - 1)) + (($xCols - 1) * $nSpacer) + $nSpacer, _ ($nBtnHeight* ($xRows - 1)) + (($xRows - 1) * $nSpacer) + $nSpacer, _ $nBtnWidth, _ $nBtnHeight) GUICtrlSetOnEvent($xID+2, "Handler") Next Next GUISetOnEvent($GUI_EVENT_CLOSE, "CloseApp") GUISetState(@SW_SHOW) While 1 Sleep(10) WEnd Func CloseApp() Exit EndFunc Func Handler() MsgBox(0,0,"Button " & @GUI_CtrlId - 2) EndFunc  
    • XinYoung
      By XinYoung
      For fun, I'm building an app that opens a webpage and refreshes it every 30 seconds.
      But once the script performs _IEAction($oIE, "refresh"), the GUI closes.
      Any help is appreciated.
       

      #include <ButtonConstants.au3>
      #include <EditConstants.au3>
      #include <GUIConstantsEx.au3>
      #include <StaticConstants.au3>
      #include <WindowsConstants.au3>
      #include <WinAPIFiles.au3>
      #include <Array.au3>
      #include <File.au3>
      #include <Excel.au3>
      #include <DateTimeConstants.au3>
      #include <MsgBoxConstants.au3>
      #include <WinAPIShellEx.au3>
      #include <MsgBoxConstants.au3>
      #include <Date.au3>
      #include <ComboConstants.au3>
      #include <guimenu.au3>
      #include <IE.au3>
      HotKeySet("{F4}", "_Exit")
      ;Open the file(s) in the selected folder
      $extension = ".txt"
      $app2openWith = @SystemDir & "\notepad.exe"
      Func Begin()
          Global $loopTrick = 0
          #Region ### START Koda GUI section ### Form=c:\users\mchu\downloads\autoit\my code\form1.kxf
          Global $UI = GUICreate("Hit Em Up!", 256, 113, -1, -1)
          GUISetBkColor(0x000000)
          $menu = _GUICtrlMenu_GetSystemMenu($UI)
          _GUICtrlMenu_EnableMenuItem($menu, $SC_CLOSE, 1, False)
          Global $url = GUICtrlCreateInput("https://www.youtube.com/watch?v=dQw4w9WgXcQ", 81, 8, 160, 21)
          $Label1 = GUICtrlCreateLabel("Target:", 16, 8, 55, 17)
          GUICtrlSetFont(-1, 12, 800, 0, "MS Sans Serif")
          GUICtrlSetColor(-1, 0x00FF00)
          Global $StartBut = GUICtrlCreateButton("Start", 16, 40, 67, 25)
          GUICtrlSetFont(-1, 13, 800, 0, "MS Sans Serif")
          GUICtrlSetBkColor(-1, 0x008000)
          $Label2 = GUICtrlCreateLabel("(Press F4 to Exit)", 96, 40, 8000, 17)
          GUICtrlSetFont(-1, 12, 800, 0, "MS Sans Serif")
          GUICtrlSetColor(-1, 0x00FF00)
          GUISetState(@SW_SHOW)
          #EndRegion ### END Koda GUI section ###
          While 1
              $UIfunc = GUIGetMsg()
              Select
                  Case $UIfunc = $GUI_EVENT_CLOSE
                      _Exit()
                  Case $UIfunc = $StartBut
                      If GUICtrlRead($url) = "" Then
                          MsgBox(48, "Um...", "Give me a target you idiot.")
                      Else
                          GUICtrlSetState($url, $GUI_DISABLE)
                          GUICtrlSetState($StartBut, $GUI_DISABLE)
                          Start()
                      EndIf
              EndSelect
          WEnd
      EndFunc   ;==>Begin
      Func Start()
          If $loopTrick = 0 Then
              Global $oIE = _IECreate(GUICtrlRead($url))
              _IELoadWait($oIE)
              Again()
          ElseIf $loopTrick = 1 Then
              Sleep(3000)
              _IEAction($oIE, "refresh")
              Sleep(3000)
              Start()
          EndIf
      EndFunc   ;==>Start
      Func Again()
          $loopTrick = 1
          Start()
      EndFunc   ;==>Again
      Func _Exit()
          Exit
      EndFunc   ;==>_Exit
×