Opened 16 years ago
Closed 16 years ago
#700 closed Bug (Fixed)
_GUICtrlTreeView_ClickItem() function does not always click on Tree View item
Reported by: | Bowmore | Owned by: | Gary |
---|---|---|---|
Milestone: | 3.2.13.12 | Component: | Standard UDFs |
Version: | 3.2.12.1 | Severity: | None |
Keywords: | GuiTreeView.au3 | Cc: |
Description
Enviroment:
Win XP Home SP3
AutoIt 3.2.12.1
AutoIt Beta 3.2.13.11
The coords of the centre of the item are calculated relative to the top left origin of the tree view control, but the click is preformed using whatever MouseCoordMode the user has set. The MouseCoordMode option needs setting to 1 and then resetting back to the original value before exiting the function. The coords of the item and the origin of the Tree View control need to be added to get the coords relative to the screen.
Code to demonstrate existing behaviour of existing function and that of the suggested fix below. GuiControlsItemClickTest.exe is a compiled version of the Sample GUI from the examples folder to give some tabs to click.
Opt("MustDeclareVars", 1) Opt("WinWaitDelay", 100) Opt("WinTitleMatchMode", 4) Opt("WinDetectHiddenText", 1) Opt("MouseCoordMode", 2) Opt("PixelCoordMode", 2) #include <GuiTreeView.au3> Local $hWnd = 0 Local $iCommandID = 0 Local $hItem = 0 Run(@ScriptDir & "\GuiControlsItemClickTest.exe") For $ifunc = 0 To 1 ;Display behaviour when mouse is not moved and then when mouse is moved For $iMove = 0 To 1 ;Use each of the MouseCoordMode in turn For $iCoordMode = 0 To 2 Opt("MouseCoordMode", $iCoordMode) WinActivate("Sample GUI") $hwnd = ControlGetHandle("Sample GUI","","SysTreeView322") If $ifunc = 0 Then ;click on Tree View Item2 without moving mouse ToolTip("Standard UDF Function '_GUICtrlTreeView_ClickItem()' MouseCoordMode = " & $iCoordMode & @CRLF & "Attempting To click on item 'Item2' moving mouse " & ($iMove <> 0), 20, 20) WinActivate("Sample GUI") $hItem = _GUICtrlTreeView_FindItem($hWnd, "Item2") _GUICtrlTreeView_EnsureVisible($hWnd, $hItem) WinActivate("Sample GUI") _GUICtrlTreeView_ClickItem($hWnd, $hItem, "left", ($iMove <> 0), 1, 50) Sleep(3000) ;click on Tree View foo moving mouse ToolTip("Standard UDF Function '_GUICtrlTreeView_ClickItem()' MouseCoordMode = " & $iCoordMode & @CRLF & "Attempting To click on item 'TreeView' moving mouse " & ($iMove <> 0), 20, 20) WinActivate("Sample GUI") $hItem = _GUICtrlTreeView_FindItem($hWnd, "TreeView") _GUICtrlTreeView_EnsureVisible($hWnd, $hItem) WinActivate("Sample GUI") _GUICtrlTreeView_ClickItem($hWnd, $hItem, "left", ($iMove <> 0), 1, 50) Sleep(3000) Else ;click on Tree View Item1 without moving mouse ToolTip("Modified UDF Function '_GUICtrlTreeView_ClickItem()' MouseCoordMode = " & $iCoordMode & @CRLF & "Attempting To click on item 'Foo' moving mouse " & ($iMove <> 0), 20, 20) WinActivate("Sample GUI") $hItem = _GUICtrlTreeView_FindItem($hWnd, "Foo") _GUICtrlTreeView_EnsureVisible($hWnd, $hItem) WinActivate("Sample GUI") MOD_GUICtrlTreeView_ClickItem($hWnd, $hItem, "left", ($iMove <> 0), 1, 50) Sleep(3000) ;click on Tree View TreeView moving mouse ToolTip("Modified UDF Function '_GUICtrlTreeView_ClickItem()' MouseCoordMode = " & $iCoordMode & @CRLF & "Attempting To click on item 'Item1' moving mouse " & ($iMove <> 0), 20, 20) WinActivate("Sample GUI") $hItem = _GUICtrlTreeView_FindItem($hWnd, "Item1") _GUICtrlTreeView_EnsureVisible($hWnd, $hItem) WinActivate("Sample GUI") MOD_GUICtrlTreeView_ClickItem($hWnd, $hItem, "left", ($iMove <> 0), 1, 50) Sleep(3000) EndIf Next Next Next Exit Func MOD_GUICtrlTreeView_ClickItem($hWnd, $hItem, $sButton = "left", $fMove = False, $iClicks = 1, $iSpeed = 0) If $Debug_TV Then _GUICtrlTreeView_ValidateClassName($hWnd) If Not IsHWnd($hWnd) Then $hWnd = GUICtrlGetHandle($hWnd) Local $tPoint, $tRect, $iX, $iY, $iXOrigin, $iYOrigin, $iMode, $aPos ;Get position of TreeView control $tRect = _WinAPI_GetWindowRect($hWnd) ;Get coords of TreeView top left corner $tPoint = _WinAPI_PointFromRect($tRect, False) _WinAPI_GetXYFromPoint($tPoint, $iXOrigin, $iYOrigin) ;Get centre if item relative to TreeView control $tRect = _GUICtrlTreeView_DisplayRectEx($hWnd, $hItem, True) $tPoint = _WinAPI_PointFromRect($tRect) _WinAPI_GetXYFromPoint($tPoint, $iX, $iY) ; Add coords to get screen coords $iX += $iXOrigin $iY += $iYOrigin ;Switch to screen MouseCoordMode $iMode = Opt("MouseCoordMode", 1) If Not $fMove Then $aPos = MouseGetPos() _WinAPI_ShowCursor(False) ;_WinAPI_ShowCursor does not seem to work on XP so set mouse speed it instant MouseClick($sButton, $iX, $iY, $iClicks, 0) MouseMove($aPos[0], $aPos[1], 0) _WinAPI_ShowCursor(True) Else MouseClick($sButton, $iX, $iY, $iClicks, $iSpeed) EndIf ;Switch back to user MouseCoordMode Opt("MouseCoordMode", $iMode) EndFunc ;==>_GUICtrlTreeView_ClickItem
Attachments (0)
Change History (2)
comment:1 Changed 16 years ago by Bowmore
comment:2 Changed 16 years ago by Gary
- Milestone set to 3.2.13.12
- Resolution set to Fixed
- Status changed from new to closed
Fixed in version: 3.2.13.12
Guidelines for posting comments:
- You cannot re-open a ticket but you may still leave a comment if you have additional information to add.
- In-depth discussions should take place on the forum.
For more information see the full version of the ticket guidelines here.
I was going to attach this file GuiControlsItemClickTest.exe but it is a bit to big. It is the SampleControls.au3 from the AutoIt\Examples folder compliled and saved as GuiControlsItemClickTest.exe