fixed bug #18650 'Unexpected monitor focus changes'

fixed bug in 'Manager_setWindowMonitor(d) ' and 'Manager_setViewMonitor(d) '
fixed bug in 'Debug_setLogLevel(d)', if 'Debug_logLevel=0'
This commit is contained in:
joten 2012-10-16 18:09:17 +02:00
parent de1b284f14
commit 53b4a83757
2 changed files with 27 additions and 14 deletions

View file

@ -161,7 +161,7 @@ Debug_setLogLevel(d)
{ {
Debug_logLevel := i Debug_logLevel := i
If (i = 0) If (i = 0)
Debug_logMessage("Logging disabled.") Debug_logMessage("Logging disabled.", 0)
Else Else
Debug_logMessage("Log level set to " i ".") Debug_logMessage("Log level set to " i ".")
} }

View file

@ -80,6 +80,7 @@ Manager_activateMonitor(d)
Else Else
wndId := 0 wndId := 0
} }
Debug_logMessage("DEBUG[1] Manager_activateMonitor: Manager_aMonitor: " Manager_aMonitor ", d: " d ", wndId: " wndId, 1)
Manager_winActivate(wndId) Manager_winActivate(wndId)
} }
} }
@ -493,10 +494,13 @@ Manager_onShellMessage(wParam, lParam)
WinGetTitle, aWndTitle, ahk_id %aWndId% WinGetTitle, aWndTitle, ahk_id %aWndId%
If ((wParam = 4 Or wParam = 32772) And lParam = 0 And aWndClass = "Progman" And aWndTitle = "Program Manager") If ((wParam = 4 Or wParam = 32772) And lParam = 0 And aWndClass = "Progman" And aWndTitle = "Program Manager")
{ {
MouseGetPos, x, y If (Manager_monitorCount > 1)
m := Monitor_get(x, y) {
If m MouseGetPos, x, y
Manager_aMonitor := m m := Monitor_get(x, y)
If m
Manager_aMonitor := m
}
Bar_updateTitle() Bar_updateTitle()
} }
@ -528,10 +532,12 @@ Manager_onShellMessage(wParam, lParam)
If (Manager_monitorCount > 1) If (Manager_monitorCount > 1)
{ {
WinGet, aWndId, ID, A
WinGetPos, aWndX, aWndY, aWndWidth, aWndHeight, ahk_id %aWndId% WinGetPos, aWndX, aWndY, aWndWidth, aWndHeight, ahk_id %aWndId%
m := Monitor_get(aWndX + aWndWidth / 2, aWndY + aWndHeight / 2) m := Monitor_get(aWndX + aWndWidth / 2, aWndY + aWndHeight / 2)
If m Debug_logMessage("DEBUG[1] Manager_onShellMessage: Manager_monitorCount: " Manager_monitorCount ", Manager_aMonitor: " Manager_aMonitor ", m: " m ", aWndId: " aWndId, 1)
Manager_aMonitor := m If m And Not (m = Manager_aMonitor)
Manager_activateMonitor(0)
} }
If wndIds If wndIds
@ -613,7 +619,7 @@ Manager_resetWindowBorder()
Manager_setViewMonitor(d) Manager_setViewMonitor(d)
{ {
Local aView, m, v, wndIds Local aView, aWndId, m, v, wndIds
If (Manager_monitorCount > 1) If (Manager_monitorCount > 1)
{ {
@ -644,7 +650,8 @@ Manager_setViewMonitor(d)
Manager_aMonitor := m Manager_aMonitor := m
View_arrange(m, v) View_arrange(m, v)
Bar_updateTitle() WinGet, aWndId, ID, A
Manager_winActivate(aWndId)
Bar_updateView(m, v) Bar_updateView(m, v)
} }
} }
@ -699,7 +706,7 @@ Manager_setWindowMonitor(d)
View_#%Manager_aMonitor%_#%v%_wndIds := aWndId ";" View_#%Manager_aMonitor%_#%v%_wndIds View_#%Manager_aMonitor%_#%v%_wndIds := aWndId ";" View_#%Manager_aMonitor%_#%v%_wndIds
View_#%Manager_aMonitor%_#%v%_aWndId := aWndId View_#%Manager_aMonitor%_#%v%_aWndId := aWndId
View_arrange(Manager_aMonitor, v) View_arrange(Manager_aMonitor, v)
Bar_updateTitle() Manager_winActivate(aWndId)
Bar_updateView(Manager_aMonitor, v) Bar_updateView(Manager_aMonitor, v)
} }
} }
@ -847,7 +854,7 @@ Manager_unmanage(wndId)
Manager_winActivate(wndId) Manager_winActivate(wndId)
{ {
Local newWnd, wndHeight, wndWidth, wndX, wndY Local aWndId, wndHeight, wndWidth, wndX, wndY
If Config_mouseFollowsFocus If Config_mouseFollowsFocus
{ {
@ -859,16 +866,22 @@ Manager_winActivate(wndId)
Else Else
DllCall("SetCursorPos", "Int", Round(Monitor_#%Manager_aMonitor%_x + Monitor_#%Manager_aMonitor%_width / 2), "Int", Round(Monitor_#%Manager_aMonitor%_y + Monitor_#%Manager_aMonitor%_height / 2)) DllCall("SetCursorPos", "Int", Round(Monitor_#%Manager_aMonitor%_x + Monitor_#%Manager_aMonitor%_width / 2), "Int", Round(Monitor_#%Manager_aMonitor%_y + Monitor_#%Manager_aMonitor%_height / 2))
} }
If Manager_isHung(wndId) If wndId And Manager_isHung(wndId)
{ {
Debug_logMessage("DEBUG[2] Manager_winActivate: Potentially hung window " . wndId, 2) Debug_logMessage("DEBUG[2] Manager_winActivate: Potentially hung window " . wndId, 2)
Return 1 Return 1
} }
Else Else
{ {
Debug_logMessage("DEBUG[1] Activating window: " wndId, 1)
If Not wndId
{
WinGet, wndId, ID, Program Manager ahk_class Progman
Debug_logMessage("DEBUG[1] Activating Program Manager: " wndId, 1)
}
WinActivate, ahk_id %wndId% WinActivate, ahk_id %wndId%
WinGet, newWin, ID, A WinGet, aWndId, ID, A
If (wndId != newWin) If (wndId != aWndId)
Return 1 Return 1
} }
Bar_updateTitle() Bar_updateTitle()