Pulled in JoshsAutoHotKey.ahk from old SVN repository

git-svn-id: http://apu.dw.local/svnusers/JoshHoltrop/JoshsAutoHotKey@3 8131a0b2-b21c-1c47-bd6a-f003126495bd
This commit is contained in:
joshholtrop 2009-03-18 16:54:20 +00:00
parent 030dfa02e7
commit b495e63010

205
JoshsAutoHotKey.ahk Normal file
View File

@ -0,0 +1,205 @@
; JoshsAutoHotKey.ahk
; Version 1.2
; 2009-03-18
;
; Original version from
; http://www.autohotkey.com/docs/scripts/EasyWindowDrag_(KDE).htm
;
; The shortcuts:
; Alt + Left Button : Drag to move a window.
; Alt + Right Button : Drag to resize a window.
; Control + Alt + WheelUp : Maximize a window
; Control + Alt + WheelDown : Restore a window
; Super + WheelDown : Minimize a window
; WheelUp : Focus window under cursor, then send wheel up
; WheelDown : Focus window under cursor, then send wheel down
; Super + Middle Button : Send window to background
;
; You can optionally release Alt after the first
; click rather than holding it down the whole time.
; From Mike Zwagerman, 2009-03-18:
; This changes increase the Maximum Number of Hotkeys allowed
; per interval from the default of 70 to 200
#MaxHotkeysPerInterval 200
#SingleInstance force
If (A_AhkVersion < "1.0.39.00")
{
MsgBox,20,,This script may not work properly with your version of AutoHotkey. Continue?
IfMsgBox,No
ExitApp
}
; This is the setting that runs smoothest on my
; system. Depending on your video card and cpu
; power, you may want to raise or lower this value.
SetWinDelay,2
CoordMode,Mouse
return
!LButton::
;If DoubleAlt
;{
; MouseGetPos,,,KDE_id
; ; This message is mostly equivalent to WinMinimize,
; ; but it avoids a bug with PSPad.
; PostMessage,0x112,0xf020,,,ahk_id %KDE_id%
; DoubleAlt := false
; return
;}
; Get the initial mouse position and window id, and
; abort if the window is maximized.
MouseGetPos,KDE_X1,KDE_Y1,KDE_id
WinGet,KDE_Win,MinMax,ahk_id %KDE_id%
If KDE_Win
return
WinActivate,ahk_id %KDE_id%
; Get the initial window position.
WinGetPos,KDE_WinX1,KDE_WinY1,WinWidth,WinHeight,ahk_id %KDE_id%
Loop
{
GetKeyState,KDE_Button,LButton,P ; Break if button has been released.
If KDE_Button = U
break
MouseGetPos,KDE_X2,KDE_Y2 ; Get the current mouse position.
KDE_X2 -= KDE_X1 ; Obtain an offset from the initial mouse position.
KDE_Y2 -= KDE_Y1
KDE_WinX2 := (KDE_WinX1 + KDE_X2) ; Apply this offset to the window position.
KDE_WinY2 := (KDE_WinY1 + KDE_Y2)
; SysGet,Mon1,Monitor,1
; SysGet,Mon2,Monitor,2
; MsgBox, (%Mon1Left%,%Mon1Top%,%Mon1Right%,%Mon1Bottom%), (%Mon2Left%,%Mon2Top%,%Mon2Right%,%Mon2Bottom%)
WinMove,ahk_id %KDE_id%,,%KDE_WinX2%,%KDE_WinY2% ; Move the window to the new position.
}
return
!RButton::
;If DoubleAlt
;{
; MouseGetPos,,,KDE_id
; ; Toggle between maximized and restored state.
; WinGet,KDE_Win,MinMax,ahk_id %KDE_id%
; If KDE_Win
; WinRestore,ahk_id %KDE_id%
; Else
; WinMaximize,ahk_id %KDE_id%
; DoubleAlt := false
; return
;}
; Get the initial mouse position and window id, and
; abort if the window is maximized.
MouseGetPos,KDE_X1,KDE_Y1,KDE_id
WinGet,KDE_Win,MinMax,ahk_id %KDE_id%
If KDE_Win
return
WinActivate,ahk_id %KDE_id%
; Get the initial window position and size.
WinGetPos,KDE_WinX1,KDE_WinY1,KDE_WinW,KDE_WinH,ahk_id %KDE_id%
; Define the window region the mouse is currently in.
; The four regions are Up and Left, Up and Right, Down and Left, Down and Right.
If (KDE_X1 < KDE_WinX1 + KDE_WinW / 2)
KDE_WinLeft := 1
Else
KDE_WinLeft := -1
If (KDE_Y1 < KDE_WinY1 + KDE_WinH / 2)
KDE_WinUp := 1
Else
KDE_WinUp := -1
; left only
If (KDE_X1 < KDE_WinX1 + KDE_WinW / 4 and abs(KDE_Y1 - KDE_WinY1 - KDE_WinH / 2) < KDE_WinH / 4)
KDE_WinUp := 0
If (KDE_X1 > KDE_WinX1 + 3 * KDE_WinW / 4 and abs(KDE_Y1 - KDE_WinY1 - KDE_WinH / 2) < KDE_WinH / 4)
KDE_WinUp := 0
If (KDE_Y1 < KDE_WinY1 + KDE_WinH / 4 and abs(KDE_X1 - KDE_WinX1 - KDE_WinW / 2) < KDE_WinW / 4)
KDE_WinLeft := 0
If (KDE_Y1 > KDE_WinY1 + 3 * KDE_WinH / 4 and abs(KDE_X1 - KDE_WinX1 - KDE_WinW / 2) < KDE_WinW / 4)
KDE_WinLeft := 0
Loop
{
GetKeyState,KDE_Button,RButton,P ; Break if button has been released.
If KDE_Button = U
break
MouseGetPos,KDE_X2,KDE_Y2 ; Get the current mouse position.
; Get the current window position and size.
WinGetPos,KDE_WinX1,KDE_WinY1,KDE_WinW,KDE_WinH,ahk_id %KDE_id%
If KDE_WinLeft = 0
KDE_X2 := 0
Else
KDE_X2 -= KDE_X1 ; Obtain an offset from the initial mouse position.
If KDE_WinUp = 0
KDE_Y2 := 0
Else
KDE_Y2 -= KDE_Y1
; Then, act according to the defined region.
WinMove,ahk_id %KDE_id%,, KDE_WinX1 + (KDE_WinLeft+1)/2*KDE_X2 ; X of resized window
, KDE_WinY1 + (KDE_WinUp+1)/2*KDE_Y2 ; Y of resized window
, KDE_WinW - KDE_WinLeft *KDE_X2 ; W of resized window
, KDE_WinH - KDE_WinUp *KDE_Y2 ; H of resized window
KDE_X1 += KDE_X2 ; Reset the initial position for the next iteration.
KDE_Y1 += KDE_Y2
}
return
; This detects "double-clicks" of the alt key.
;~Alt::
;DoubleAlt := A_PriorHotKey = "~Alt" AND A_TimeSincePriorHotkey < 400
;Sleep 0
;KeyWait Alt ; This prevents the keyboard's auto-repeat feature from interfering.
;return
#WheelDown::
MouseGetPos,,,KDE_id
WinMinimize,ahk_id %KDE_id%
return
^!WheelUp::
MouseGetPos,,,KDE_id
WinMaximize,ahk_id %KDE_id%
return
^!WheelDown::
MouseGetPos,,,KDE_id
WinRestore,ahk_id %KDE_id%
return
; Added by Josh 2008-11-20
; Super + middle-click will lower (send window to back)
#MButton::
MouseGetPos,,,KDE_id
WinSet,Bottom,,ahk_id %KDE_id%
return
; Added by Josh 2008-12-02
; scrolling the mouse wheel anywhere will activate the window
; that is under the cursor at that screen position
; also sends the event along to the application...
$WheelDown::
MouseGetPos,,,KDE_id
WinActivate,ahk_id %KDE_id%
; added 2008-12-03 to send a middle-button click to Windows
; Explorer windows so I can scroll in the "Folders" pane and
; the main pane independently
WinGetClass class,ahk_id %KDE_id%
if (class = "ExploreWClass")
{
Send {MButton}
}
Send {WheelDown}
return
$WheelUp::
MouseGetPos,,,KDE_id
WinActivate,ahk_id %KDE_id%
WinGetClass class,ahk_id %KDE_id%
if (class = "ExploreWClass")
{
Send {MButton}
}
Send {WheelUp}
return