This commit is contained in:
2025-10-05 11:49:22 +08:00
parent d54074cb57
commit 1d19b705d3
2 changed files with 43 additions and 37 deletions
+23 -17
View File
@@ -808,27 +808,19 @@ namespace Ink_Canvas.Helpers
return; return;
bool shouldEnableHotkeys = ShouldEnableHotkeysBasedOnContext(); bool shouldEnableHotkeys = ShouldEnableHotkeysBasedOnContext();
bool currentlyHasHotkeys = _registeredHotkeys.Count > 0;
if (shouldEnableHotkeys) if (shouldEnableHotkeys && !currentlyHasHotkeys)
{
// 如果热键未注册,则注册
if (_registeredHotkeys.Count == 0)
{ {
// 需要注册快捷键
LoadHotkeysFromSettings(); LoadHotkeysFromSettings();
} }
} else if (!shouldEnableHotkeys && currentlyHasHotkeys)
else
{
// 如果热键已注册,则注销(与鼠标模式禁用保持一致)
if (_registeredHotkeys.Count > 0)
{ {
// 需要注销快捷键
UnregisterAllHotkeys(); UnregisterAllHotkeys();
// 注意:这里不设置 _hotkeysShouldBeRegistered = false
// 因为我们需要保持热键系统的启用状态,只是暂时注销热键
// 这样当上下文变化时,热键可以重新注册
}
} }
// 如果状态没有变化,则不进行任何操作
} }
catch (Exception ex) catch (Exception ex)
{ {
@@ -871,6 +863,18 @@ namespace Ink_Canvas.Helpers
{ {
try try
{ {
// 检查当前是否处于鼠标模式
bool isMouseMode = IsInSelectMode();
if (isMouseMode)
{
// 鼠标模式下,根据设置决定是否启用快捷键
return MainWindow.Settings.Appearance.EnableHotkeysInMouseMode;
}
else
{
// 非鼠标模式下,需要检查焦点和屏幕位置
// 策略1:鼠标在窗口上时启用热键(最高优先级) // 策略1:鼠标在窗口上时启用热键(最高优先级)
if (_isMouseOverWindow) if (_isMouseOverWindow)
{ {
@@ -878,7 +882,7 @@ namespace Ink_Canvas.Helpers
} }
// 策略2:在多屏幕环境下,检查鼠标是否在当前窗口所在的屏幕上 // 策略2:在多屏幕环境下,检查鼠标是否在当前窗口所在的屏幕上
if (_isMultiScreenMode) if (_isMultiScreenMode && _enableScreenSpecificHotkeys)
{ {
var mousePosition = Control.MousePosition; var mousePosition = Control.MousePosition;
var mouseScreen = Screen.FromPoint(mousePosition); var mouseScreen = Screen.FromPoint(mousePosition);
@@ -899,8 +903,10 @@ namespace Ink_Canvas.Helpers
return true; return true;
} }
// 默认情况:禁用热 // 策略4:如果以上都不满足,但在非鼠标模式下,仍然启用快捷
return false; // 这样可以确保在批注模式下快捷键始终可用
return true;
}
} }
catch (Exception ex) catch (Exception ex)
{ {