diff options
Diffstat (limited to 'drm.ahk')
-rw-r--r-- | drm.ahk | 124 |
1 files changed, 96 insertions, 28 deletions
@@ -2,27 +2,44 @@ #SingleInstance Force #Persistent -; Try to retrieve user-set resolutions +; Retrieve user-set resolutions or fall back on defaults RegRead, ResolutionsString, HKEY_CURRENT_USER\Software\JohnAJ\DRM, Resolutions -if (ErrorLevel != 1) - goto Start +if (ErrorLevel = 1) +{ + ResolutionsString = 1600x1200|1024x768|800x600|640x480 ; 4:3 + if (A_ScreenWidth/A_ScreenHeight = 1.6) + ResolutionsString = 1920x1200|1680x1050|1440x900|1280x800 ; 16:10 + if (Round(A_ScreenWidth/A_ScreenHeight, 2) = 1.77) + ResolutionsString = 1920x1080|1366x768|1280x720|854x480 ; 16:9 + RegWrite, REG_SZ, HKEY_CURRENT_USER\Software\JohnAJ\DRM, Resolutions, %ResolutionsString% +} + +Resolutions := StrSplit(ResolutionsString, "|") -; Fall back on default resolutions +; Retrieve user-set exceptions -ResolutionsString = 1600x1200|1024x768|800x600|640x480 ; 4:3 -if (A_ScreenWidth/A_ScreenHeight = 1.6) - ResolutionsString = 1920x1200|1680x1050|1440x900|1280x800 ; 16:10 -if (Round(A_ScreenWidth/A_ScreenHeight, 2) = 1.77) - ResolutionsString = 1920x1080|1366x768|1280x720|854x480 ; 16:9 +RegRead, IgnoreString, HKEY_CURRENT_USER\Software\JohnAJ\DRM, Ignore +IgnoreString := "|" IgnoreString ; leading pipe for easy string matching -RegWrite, REG_SZ, HKEY_CURRENT_USER\Software\JohnAJ\DRM, Resolutions, %ResolutionsString% +if (ErrorLevel = 1) +{ + IgnoreString = "" + RegWrite, REG_SZ, HKEY_CURRENT_USER\Software\JohnAJ\DRM, Ignore, % "" +} + +RegRead, IgnoreSizeString, HKEY_CURRENT_USER\Software\JohnAJ\DRM, IgnoreSize +IgnoreSizeString := "|" IgnoreSizeString ; leading pipe for easy string matching + +if (ErrorLevel = 1) +{ + IgnoreSizeString = "" + RegWrite, REG_SZ, HKEY_CURRENT_USER\Software\JohnAJ\DRM, IgnoreSize, % "" +} ; Set up tray menu -Start: -Resolutions := StrSplit(ResolutionsString, "|") Menu, Tray, NoStandard Menu, Tray, Tip, Dynamic Resolution Manager for k, res in Resolutions @@ -64,32 +81,56 @@ SwitchToResolutionFrom(WidthNew, HeightNew, WidthOrig, HeightOrig) Restore(Positions) } -; Set screen resolution - -SetResolution(Width, Height, ColorDepth := 32) -{ - VarSetCapacity(DeviceMode, 156, 0) - NumPut(156, DeviceMode, 36) - DllCall("EnumDisplaySettingsA", UInt, 0, UInt, -1, UInt, &DeviceMode) - NumPut(0x5c0000, DeviceMode, 40) - NumPut(ColorDepth, DeviceMode, 104) - NumPut(Width, DeviceMode, 108) - NumPut(Height, DeviceMode, 112) - DllCall("ChangeDisplaySettingsA", UInt, &DeviceMode, UInt, 0) -} - Save(ByRef Positions) { + global IgnoreString + global IgnoreSizeString + Positions := {} WinGet, id, list SysGet, WorkArea, MonitorWorkArea Width := WorkAreaRight - WorkAreaLeft Height := WorkAreaBottom - WorkAreaTop + Loop, %id% { i := id%A_Index% WinReallyGetPos(i, x, y, w, h) - Positions[i] := [x / Width, y / Height, w / Width, h / Height] + WinGet, exe, ProcessName, ahk_id %i% + + ; Ignore position and size (2) + + if (InStr(IgnoreString, "|" exe)) + Positions[i] := [x, y, w, h, 2, 0] + + ; Ignore size, but retain position (1) + + else if (InStr(IgnoreSizeString, "|" exe)) + { + rx := x / Width + ry := y / Height + + ; Calculate position relative to right/bottom if necessary + + Align := 1 ; to align right, this should be divisible by 3; bottom, by 5 + if (x > Width / 2) + { + Align := Align * 3 + rx := (Width - (x + w)) / Width + } + if (y > Height / 2) + { + Align := Align * 5 + ry := (Height - (y + h)) / Height + } + + Positions[i] := [rx, ry, w, h, 1, Align] + } + + ; Retain position and size (0) + + else + Positions[i] := [x / Width, y / Height, w / Width, h / Height, 0, 0] } } @@ -104,10 +145,37 @@ Restore(Positions) y := props[2] w := props[3] h := props[4] - WinReallyMove(i, x * Width, y * Height, w * Width, h * Height) + if (props[5] = 2) ; ignore position and size + WinReallyMove(i, x, y, w, h) + else if (props[5] = 1) ; ignore size, but retain position + { + rx := x * Width + ry := y * Height + if (Mod(props[6], 3) = 0) ; align right + rx := Width - rx - w + if (Mod(props[6], 5) = 0) ; align bottom + ry := Height - ry - h + WinReallyMove(i, rx, ry, w, h) + } + else ; retain position and size + WinReallyMove(i, x * Width, y * Height, w * Width, h * Height) } } +; Set screen resolution + +SetResolution(Width, Height, ColorDepth := 32) +{ + VarSetCapacity(DeviceMode, 156, 0) + NumPut(156, DeviceMode, 36) + DllCall("EnumDisplaySettingsA", UInt, 0, UInt, -1, UInt, &DeviceMode) + NumPut(0x5c0000, DeviceMode, 40) + NumPut(ColorDepth, DeviceMode, 104) + NumPut(Width, DeviceMode, 108) + NumPut(Height, DeviceMode, 112) + DllCall("ChangeDisplaySettingsA", UInt, &DeviceMode, UInt, 0) +} + ; Get position of any window, even a minimized one WinReallyGetPos(hwnd, ByRef x, ByRef y, ByRef w="", ByRef h="") |