summaryrefslogtreecommitdiffstats
path: root/functions.ahk
diff options
context:
space:
mode:
authorbreadcat2015-04-09 01:21:57 +0100
committerbreadcat2015-04-09 01:21:57 +0100
commit86198de452918af94aec4bd5e0918b494595f125 (patch)
tree5f342d9660db4c2efcf03fd46197662e7b8bad83 /functions.ahk
parent31575a608b5f2bbd0685b1c4f35e712d96f1a2dc (diff)
downloadahka-86198de452918af94aec4bd5e0918b494595f125.tar.gz
ahka-86198de452918af94aec4bd5e0918b494595f125.tar.bz2
ahka-86198de452918af94aec4bd5e0918b494595f125.zip
Large refactor
Clean up code by moving functions to separate file, better organise hotkeys. Lines 132-136 are currently broken, but rarely used. Removed toggle taskbar as it was broken and never used. winSplit() toggle is also currently broken.
Diffstat (limited to 'functions.ahk')
-rw-r--r--functions.ahk263
1 files changed, 263 insertions, 0 deletions
diff --git a/functions.ahk b/functions.ahk
new file mode 100644
index 0000000..e82b71c
--- /dev/null
+++ b/functions.ahk
@@ -0,0 +1,263 @@
+dirWorking() {
+if A_OSVersion in WIN_XP
+ {
+ Run explorer %A_MyDocuments%
+ }
+ Else
+ {
+ Run explorer %A_MyDocuments%\..\Downloads
+ }
+ Return
+ }
+
+dirSync() {
+if A_OSVersion in WIN_XP
+ {
+ Run explorer %A_MyDocuments%\Vault
+ }
+ Else
+ {
+ Run explorer %A_MyDocuments%\..\Vault
+ }
+ Return
+ }
+
+launchTerminal() {
+if A_OSVersion in WIN_XP
+ {
+ Run C:\cygwin\bin\mintty.exe -
+ }
+ Else
+ {
+ Run C:\cygwin64\bin\mintty.exe -
+ }
+ Return
+ }
+
+launchKeepass() {
+if A_OSVersion in WIN_XP
+ {
+ Run "%A_MyDocuments%\Vault\docs\keepass\KeePass.exe"
+ }
+ Else
+ {
+ Run "%A_MyDocuments%\..\Vault\docs\keepass\KeePass.exe"
+ }
+ Return
+ }
+
+insertDate() {
+ FormatTime, CurrentDateTime,, yyyy-MM-dd
+ Send %CurrentDateTime%
+ return
+ }
+insertDateTime() {
+ FormatTime, CurrentDateTime,, yyyy-MM-dd HHmm
+ Send %CurrentDateTime%
+ return
+ }
+
+appendClipboard() {
+ newclipboard = %clipboard%
+ Send, ^c
+ clipboard = %newclipboard%`r`n%clipboard%
+ return
+ }
+
+pasteTelephone() {
+ StringReplace, clipboard, clipboard, +44, 0, All ;translate intl codes
+ StringReplace, clipboard, clipboard, %A_SPACE%,, All ;remove spaces
+ StringReplace, clipboard, clipboard, %A_Tab%, `,, All ;remove tabs
+ StringReplace, clipboard, clipboard, `,,, All ;remove commas
+ StringReplace, clipboard, clipboard, `r,, All ;remove lines
+ StringReplace, clipboard, clipboard, `n,, All ;remove lines
+ StringReplace, clipboard, clipboard, -,, All ;remove hyphens
+ StringReplace, clipboard, clipboard, (,, All ;remove lbracket
+ StringReplace, clipboard, clipboard, ),, All ;remove rbracket
+ StringLeft, 5digits, clipboard, 5
+ StringRight, 6digits, clipboard, 6
+ Send %5digits% %6digits%
+ return
+ }
+
+createYoutubeLink() {
+ send,{end}{shift down}{home}{shift up}{del}
+ send,https://www.youtube.com/watch?v={ctrl down}v{ctrl up}
+ return
+ }
+
+typeSyncDocs() {
+if A_OSVersion in WIN_XP
+ {
+ Send %A_MyDocuments%\Vault\docs\
+ }
+ Else
+ {
+ Send C:\Users\%A_UserName%\Vault\docs\
+ }
+ Return
+ }
+typeDocuments() {
+if A_OSVersion in WIN_XP
+ {
+ Send %A_MyDocuments%
+ }
+ Else
+ {
+ Send C:\Users\%A_UserName%\
+ }
+ Return
+ }
+typeVault() {
+if A_OSVersion in WIN_XP
+ {
+ Send %A_MyDocuments%\Vault\
+ }
+ Else
+ {
+ Send C:\Users\%A_UserName%\Vault\
+ }
+ Return
+ }
+typeCygwin() {
+if A_OSVersion in WIN_XP
+ {
+ Send C:\cygwin\home\%A_UserName%\
+ }
+ Else
+ {
+ Send C:\cygwin64\home\%A_UserName%\
+ }
+ Return
+ }
+
+;toggle between default audio output (http://ml.pe/optimizing/2013/changing-the-default-sound-device-using-autohotkey/)
+toggleAudioDevice() {
+ switch := !switch
+ If (switch)
+ usePlaybackDevice(1)
+ else
+ usePlaybackDevice(3)
+ return
+ }
+ usePlaybackDevice(device) {
+ Run, mmsys.cpl
+ WinWaitActive, Sound ahk_class #32770
+ ControlSend, SysListView321,{Down %device%}, Sound ahk_class #32770
+ ControlClick, Button2, Sound ahk_class #32770
+ WinClose, Sound ahk_class #32770
+}
+
+winSplit() { ;split active and previous window side by side, press again to swap positions
+ splitToggle := !splitToggle
+ If (splitToggle) {
+ Tile("R")
+ Sleep, 15
+ Send {AltDown}{Tab}{AltUp}
+ Sleep, 10
+ Tile("L")
+ Sleep, 15
+ Send {AltDown}{Tab}{AltUp}
+ }
+ else {
+ Tile("L")
+ Sleep, 15
+ Send {AltDown}{Tab}{AltUp}
+ Sleep, 10
+ Tile("R")
+ Sleep, 15
+ Send {AltDown}{Tab}{AltUp}
+ }
+ return
+ }
+
+kdeMove() {
+ MouseGetPos,KDE_X1,KDE_Y1,KDE_id
+ WinGet,KDE_Win,MinMax,ahk_id %KDE_id%
+ If KDE_Win
+ WinRestore, A
+ WinGetPos,KDE_WinX1,KDE_WinY1,,,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)
+ WinMove,ahk_id %KDE_id%,,%KDE_WinX2%,%KDE_WinY2% ; Move the window to the new position.
+ }
+ return
+ }
+
+kdeResize() {
+ MouseGetPos,KDE_X1,KDE_Y1,KDE_id
+ WinGet,KDE_Win,MinMax,ahk_id %KDE_id%
+ If KDE_Win
+ WinRestore, A
+ ; 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
+ 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%
+ KDE_X2 -= KDE_X1 ; Obtain an offset from the initial mouse position.
+ 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 + KDE_X1) ; Reset the initial position for the next iteration.
+ KDE_Y1 := (KDE_Y2 + KDE_Y1)
+ }
+ return
+ }
+
+Tile(Pos)
+{
+ WinGetClass, class, A
+ IfInString , shell_TrayWnd,Progman,Button,DV2ControlHost, %class%
+ Return
+ IfWinExist,ahk_class Shell_TrayWnd
+ SysGet, m, MonitorWorkArea
+ Else SysGet, m, Monitor
+ WinGetPos, MWT_X, MWT_Y, MWT_W, MWT_H, A
+ SendMessage, 0x1F,,,, A
+ WinGet, MWT_active, MinMax, A
+ if (MWT_active = 1)
+ WinRestore, A
+ If (Pos = "T")
+ WinMove, A,, 0, 0, mRight, mBottom/2
+ If (Pos = "B")
+ WinMove, A,, 0, mBottom/2, mRight, mBottom/2
+ If (Pos = "L")
+ WinMove, A,, 0, 0, mRight/2, mBottom
+ If (Pos = "R")
+ WinMove, A,, mRight/2, 0, mRight/2, mBottom
+ If (Pos = "TL")
+ WinMove, A,, 0, 0, mRight/2, mBottom/2
+ If (Pos = "TR")
+ WinMove, A,, mRight/2, 0, mRight/2, mBottom/2
+ If (Pos = "BR")
+ WinMove, A,, mRight/2, mBottom/2, mRight/2, mBottom/2
+ If (Pos = "BL")
+ WinMove, A,, 0, mBottom/2, mRight/2, mBottom/2
+}
+Return