ken0137 发表于 2011-6-13 10:30:59

触边隐藏的问题

在论坛上找了一些作品套用了一下,发现当点击按钮,跳出input框后,无论选择确定或者取消,当鼠标移到屏幕右侧,主界面都无法自动出现了,要用鼠标按住一下才能出来,求教我的RunButton函数哪里错了?


#include <GDIPlus.au3>
#include <GUIConstantsEx.au3>
#include <Misc.au3>
#include <StaticConstants.au3>

#include <WindowsConstants.au3>
#include <ComboConstants.au3>
#include <SendMessage.au3>
#include <WinAPI.au3>
#include <Timers.au3>
Opt("GUIOnEventMode", 1)

HotKeySet("{ESC}", "_Exit")
If _Singleton(@ScriptName, 1) = 0 Then
        MsgBox(0, "警告", "你只能启动该应用程序一次!")
        Exit (1)
EndIf
Global $IniName = ""
Global $Z
$Z=10
;=========界面参数==================
Dim $LabelArray[$Z + 4]
Dim $Over[$Z + 2]
Dim $Pressed[$Z + 2]
Global Const $AC_SRC_ALPHA = 1
Global Const $Sensitivity = 10
Global Const $GWidth = 167
Global Const $GHeight = 120 + $Z * 41
Global $PosX = @DesktopWidth - 267
Global $PosY = (@DesktopHeight - 120 - $Z * 41)/2
Global $Pause = 0
Global $LastActiveWindow = ""
Global $Offline = 1
Global $LastPassBut=0
$SN=''
;=========自动隐藏参数============
$steps = 10
$dockvalue = 20
$allowdock = 4
$hidevalue = 5
$showdelay = 0
$hidedelay = 10

$dock = 0
$timer = 0
$time = 0
$animationfinished = False
$mousechecktimeron = False
$mouseinwindow = False
$show = True
;=========数据库==========
Global $RS
Global $Conn

GUIRegisterMsg($WM_WINDOWPOSCHANGING, "WM_WINDOWPOSCHANGING")
$Form1 = GUICreate("Main", $GWidth, $GHeight, $PosX, $PosY, $WS_POPUP, BitOR($WS_EX_TOOLWINDOW, $WS_EX_TOPMOST))
;~ $Form1 = GUICreate("Main", $GWidth, $GHeight, $PosX, $PosY)
GUISetState(@SW_SHOW, $Form1)
$NumberTxt=GUICtrlCreateInput("", 12, 9 , 144, 36)
GUICtrlSetFont(-1, 16)
For $i = 1 To $Z
        $LabelArray[$i] = GUICtrlCreateButton("步骤 " & $i, 12, 49 + ($i - 1) * 41, 144, 36)
Next
$LabelArray[$Z + 1] = GUICtrlCreateButton("退出", 96, 49 + $Z * 41, 60, 36);退出标签
$LabelArray[$Z + 2] = GUICtrlCreateLabel("111", 19, 54 + $Z * 41, 87, 13, BitOR($SS_CENTER, $SS_CENTERIMAGE));状态标签
GUICtrlSetFont(-1, 8)
$LabelArray[$Z + 3] = GUICtrlCreateLabel("2222", 19, 66 + $Z * 41, 87, 13, BitOR($SS_CENTER, $SS_CENTERIMAGE));使用标签
GUICtrlSetFont(-1, 8)

GUICtrlSetState($LabelArray,$GUI_FOCUS)

GUISetOnEvent($GUI_EVENT_CLOSE, "_Exit")
GUISetOnEvent($GUI_EVENT_PRIMARYDOWN, "PRIMARYDOWN")
GUISetOnEvent($GUI_EVENT_PRIMARYUP, "SetCheckMouseTimer")

GUICtrlSetOnEvent($LabelArray[$Z + 1], "_Exit")

While 1
        Sleep(1)
WEnd

Func RunButton($ButtonNumber)       
        MouseClick('primary',@DesktopWidth/2,@DesktopHeight/2)
        Sleep(1000)
        Switch $ButtonNumber
                Case 1 To $Z
                        If $ButtonNumber = 1 Then
                                $SNTxt = InputBox("信息输入框", "扫入条码", "", "", -1, -1)
                                If (@error = 0) And ($SNTxt <> '') Then
                                        $SN = $SNTxt
                                        $LastPassBut=0                                        
                                        ConsoleWrite($SN)
                                Else
                                        ConsoleWrite(@CRLF&@error&@CRLF)
                                        Return 0
                                EndIf       
                               
                        EndIf
                        If $SN <>'' Then       
               
                                For $J = $ButtonNumber To $Z
                                       
                                        $Flag = MsgBox(4 + 32 + 262144, "信息提示框", "是否继续进行第"&$J&"项的测试")
                                        If $Flag = 7 Then
                                                GUICtrlSetState($LabelArray[$J],$GUI_FOCUS)
                                                Return
                                        EndIf                                       
                                        If $LastPassBut<>$J-1 Then
                                                MsgBox(0+48+262144,"信息提示框", "请上一Pass的测试项加一开始测试")
                                                GUICtrlSetState($LabelArray[$J],$GUI_FOCUS)
                                                Return
                                        EndIf                                       
;~                                         Opterate($J)
                                        $LastPassBut=$J
                                Next
                                If $LastPassBut=$Z Then
;~                                         $SN=''
;~                                         $LastPassBut=0
;~                                         $add = 'update testinfo set funcresult=''1'' whereserialid='''& $SN&''''
;~                                         $Conn.Execute($add)
                                        ;开始下一个测试
                                        RunButton(1)
                                EndIf
                        Else
                                MsgBox(0+48+262144,"信息提示框", "请从步骤一开始测试")
                                Return
                        EndIf
;~                         MsgBox(0, "", "You Pressed Button " & $ButtonNumber)
                Case $Z + 1
                        Exit
        EndSwitch
EndFunc

Func PRIMARYDOWN()
        $CursorInfo = GUIGetCursorInfo($Form1)
        For $i=1 To $Z+1
                If $CursorInfo = $LabelArray[$i] Then ;光标在按钮
                        RunButton($i)
                EndIf
        Next       
        KillAnimationTimer()
        KillCheckMouseTimer()       
        _SendMessage($Form1, $WM_NCLBUTTONDOWN, $HTCAPTION, 0)
EndFunc

Func CheckMouse()
        If $dock = 0 Then Return
        $winpos = WinGetPos($Form1)
        Dim $mouseinwindow1 = MouseContains($winpos)
        If BitXOR($mouseinwindow1, $mouseinwindow) Then $time = _Timer_Init()
        $mouseinwindow = $mouseinwindow1
        If $mouseinwindow1 Then
                If Not $show And _Timer_Diff($time) > $showdelay Then
                        $show = True
                        SetAnimationTimer()
                EndIf
        Else
                If $show And _Timer_Diff($time) > $hidedelay Then
                        $show = False
                        SetAnimationTimer()
                EndIf
        EndIf
EndFunc   ;==>CheckMouse

Func SetAnimationTimer()
        $animationfinished = False
        If $timer = 0 Then $timer = _Timer_SetTimer($Form1, 5, "DoAnimation")
EndFunc   ;==>SetAnimationTimer

Func KillAnimationTimer()
        If $timer <> 0 Then
                $timer = _Timer_KillTimer($Form1, $timer)
                $timer = 0
        EndIf
        $animationfinished = True
EndFunc   ;==>KillAnimationTimer

Func SetCheckMouseTimer()
        If Not $mousechecktimeron Then AdlibRegister("CheckMouse", 75)
        $mousechecktimeron = True
EndFunc   ;==>SetCheckMouseTimer

Func KillCheckMouseTimer()
        If $mousechecktimeron Then AdlibUnRegister("CheckMouse")
        $mousechecktimeron = False
EndFunc   ;==>KillCheckMouseTimer

Func MouseContains($winpos)
        $pos = MouseGetPos()
        Return $pos >= $winpos And $pos <= $winpos + $winpos And $pos >= $winpos And $pos <= $winpos + $winpos
EndFunc   ;==>MouseContains

Func WM_WINDOWPOSCHANGING($hWnd, $Msg, $wParam, $lParam)
        If $timer <> 0 Then Return
        $rect = DllStructCreate($tagWINDOWPOS, $lParam)
        $x = DllStructGetData($rect, "X")
        $y = DllStructGetData($rect, "Y")
        $width = DllStructGetData($rect, "CX")
        $height = DllStructGetData($rect, "CY")
        Local $move = 0
        $dock = 0
        $workarea = _GetWorkArea()
        $move = 1

        If BitAND($allowdock, 1) And $x <= $dockvalue And $x <> 0 Then
                $x = 0
                $dock = 1
                $move = 1
        EndIf

        If BitAND($allowdock, 4) And @DesktopWidth - $x - $width <= $dockvalue And $x + $width - @DesktopWidth <> 0 Then
                $x = @DesktopWidth - $width
                $dock = 3
                $move = 1
        EndIf

        If BitAND($allowdock, 2) And $y <= $dockvalue And $y <> 0 Then
                $y = 0
                $dock = 2
                $move = 1
        EndIf

        If BitAND($allowdock, 8) And $workarea - $y - $height <= $dockvalue And $y + $height - $workarea <> 0 Then
                $y = $workarea - $height
                $dock = 4
                $move = 1
        EndIf
        If $move = 1 Then

                DllStructSetData($rect, "X", $x)
                DllStructSetData($rect, "Y", $y)
                $hide = False
        EndIf
EndFunc   ;==>WM_WINDOWPOSCHANGING

Func _GetWorkArea()
        Local Const $SPI_GETWORKAREA = 48
        Local $rect
        Local $stRect = DllStructCreate("long left;long top;long right;long bottom")
        Local $iResult = _WinAPI_SystemParametersInfo($SPI_GETWORKAREA, 0, DllStructGetPtr($stRect), 0)
        If $iResult = True Then
                $rect = DllStructGetData($stRect, "left")
                $rect = DllStructGetData($stRect, "top")
                $rect = DllStructGetData($stRect, "right")
                $rect = DllStructGetData($stRect, "bottom")
                Return $rect
        Else
                Return 0
        EndIf
EndFunc   ;==>_GetWorkArea

Func DoAnimation($hWnd, $Msg, $iIDTimer, $dwTime);自动隐藏关键函数
        If $animationfinished Then Return
        Global $show
        $winpos = WinGetPos($Form1)
        $newx = $winpos
        $newy = $winpos
        $width = $winpos
        $height = $winpos
        Switch $dock
                Case 1, 3
                        $step = $winpos / $steps
                Case 2, 4
                        $step = $winpos / $steps
                Case Else
                        Return
        EndSwitch

        Switch $dock
                Case 1
                        If $show Then
                                $newx += $step
                                If $newx > 0 Then
                                        $newx = 0
                                        $animationfinished = True
                                EndIf
                        Else
                                $newx -= $step
                                If $newx + $width < $hidevalue Then
                                        $newx = -$width + $hidevalue
                                        $animationfinished = True
                                EndIf

                        EndIf
                Case 2
                        If $show Then
                                $newy += $step
                                If $newy > 0 Then
                                        $newy = 0
                                        $animationfinished = True
                                EndIf
                        Else
                                $newy -= $step
                                If $newy + $height < $hidevalue Then
                                        $newy = -$height + $hidevalue
                                        $animationfinished = True
                                EndIf

                        EndIf
                Case 3
                        If $show Then
                                $newx -= $step
                                If $newx + $width < @DesktopWidth Then
                                        $newx = @DesktopWidth - $width
                                        $animationfinished = True
                                EndIf
                        Else
                                $newx += $step
                                If $newx > @DesktopWidth - $hidevalue Then
                                        $newx = @DesktopWidth - $hidevalue
                                        $animationfinished = True
                                EndIf

                        EndIf
                Case 4
                        $workarea = _GetWorkArea()
                        $workareaHeight = $workarea
                        If $show Then
                                $newy -= $step
                                If $newy + $height < $workareaHeight Then
                                        $newy = $workareaHeight - $height
                                        $animationfinished = True
                                EndIf
                        Else
                                $newy += $step
                                If $newy > $workareaHeight - $hidevalue Then
                                        $newy = $workareaHeight - $hidevalue
                                        $animationfinished = True
                                EndIf
                        EndIf

        EndSwitch

        WinMove($Form1, "", $newx, $newy)
        If $animationfinished Then KillAnimationTimer()
EndFunc   ;==>DoAnimation

Func _Exit()
        Exit
EndFunc

ken0137 发表于 2011-6-13 13:35:23

谢谢~~~~~~~~~~

Cygerist 发表于 2011-6-13 14:42:52

很奇怪,不知道什么原因……

wsfda 发表于 2011-6-16 12:34:49

有点复杂,.......

wsfda 发表于 2011-6-16 17:01:58

回复 1# ken0137


    刚才没事看了一下,确实如此,个人觉得,这个程序的结构有问题,把自动隐藏的部分放在循环里,就不会受到影响了

auhj887 发表于 2011-6-21 20:38:37

{:face (370):}
页: [1]
查看完整版本: 触边隐藏的问题