fix:退出软件实现

This commit is contained in:
2026-04-30 16:55:38 +08:00
parent 21c93d38c7
commit c1e599971e
2 changed files with 10 additions and 2 deletions
+8 -2
View File
@@ -1519,6 +1519,7 @@ namespace Ink_Canvas
private bool _allowCloseAfterExitVerification; private bool _allowCloseAfterExitVerification;
private bool _isExitVerificationInProgress; private bool _isExitVerificationInProgress;
private bool _forceCloseFromExitOrRestartButton;
/// <summary> /// <summary>
/// 处理主窗口的关闭流程:记录关闭事件,按需进行退出密码验证或多次确认并据此取消或允许关闭。 /// 处理主窗口的关闭流程:记录关闭事件,按需进行退出密码验证或多次确认并据此取消或允许关闭。
@@ -1541,14 +1542,15 @@ namespace Ink_Canvas
return; return;
} }
if (BtnPPTSlideShowEnd != null && BtnPPTSlideShowEnd.Visibility == Visibility.Visible) if (!_forceCloseFromExitOrRestartButton &&
BtnPPTSlideShowEnd != null && BtnPPTSlideShowEnd.Visibility == Visibility.Visible)
{ {
e.Cancel = true; e.Cancel = true;
BtnPPTSlideShowEnd_Click(BtnPPTSlideShowEnd, null); BtnPPTSlideShowEnd_Click(BtnPPTSlideShowEnd, null);
LogHelper.WriteLogToFile("Ink Canvas closing converted to exit PPT", LogHelper.LogType.Event); LogHelper.WriteLogToFile("Ink Canvas closing converted to exit PPT", LogHelper.LogType.Event);
return; return;
} }
if (currentMode != 0) if (!_forceCloseFromExitOrRestartButton && currentMode != 0)
{ {
e.Cancel = true; e.Cancel = true;
CloseWhiteboardImmediately(); CloseWhiteboardImmediately();
@@ -1580,6 +1582,7 @@ namespace Ink_Canvas
bool ok = await SecurityManager.PromptAndVerifyAsync(Settings, this, "退出验证", "请输入安全密码以退出软件。"); bool ok = await SecurityManager.PromptAndVerifyAsync(Settings, this, "退出验证", "请输入安全密码以退出软件。");
if (!ok) if (!ok)
{ {
_forceCloseFromExitOrRestartButton = false;
LogHelper.WriteLogToFile("Ink Canvas closing cancelled by security password", LogHelper.LogType.Event); LogHelper.WriteLogToFile("Ink Canvas closing cancelled by security password", LogHelper.LogType.Event);
return; return;
} }
@@ -1610,6 +1613,7 @@ namespace Ink_Canvas
if (result1 == MessageBoxResult.Cancel) if (result1 == MessageBoxResult.Cancel)
{ {
_forceCloseFromExitOrRestartButton = false;
e.Cancel = true; e.Cancel = true;
LogHelper.WriteLogToFile("Ink Canvas closing cancelled at first confirmation", LogHelper.LogType.Event); LogHelper.WriteLogToFile("Ink Canvas closing cancelled at first confirmation", LogHelper.LogType.Event);
return; return;
@@ -1621,6 +1625,7 @@ namespace Ink_Canvas
if (result2 == MessageBoxResult.Cancel) if (result2 == MessageBoxResult.Cancel)
{ {
_forceCloseFromExitOrRestartButton = false;
e.Cancel = true; e.Cancel = true;
LogHelper.WriteLogToFile("Ink Canvas closing cancelled at second confirmation", LogHelper.LogType.Event); LogHelper.WriteLogToFile("Ink Canvas closing cancelled at second confirmation", LogHelper.LogType.Event);
return; return;
@@ -1632,6 +1637,7 @@ namespace Ink_Canvas
if (result3 == MessageBoxResult.Cancel) if (result3 == MessageBoxResult.Cancel)
{ {
_forceCloseFromExitOrRestartButton = false;
e.Cancel = true; e.Cancel = true;
LogHelper.WriteLogToFile("Ink Canvas closing cancelled at final confirmation", LogHelper.LogType.Event); LogHelper.WriteLogToFile("Ink Canvas closing cancelled at final confirmation", LogHelper.LogType.Event);
return; return;
@@ -3059,6 +3059,7 @@ namespace Ink_Canvas
LogHelper.WriteLogToFile($"停止PPT监控时出错: {ex.Message}", LogHelper.LogType.Error); LogHelper.WriteLogToFile($"停止PPT监控时出错: {ex.Message}", LogHelper.LogType.Error);
} }
_forceCloseFromExitOrRestartButton = true;
App.IsAppExitByUser = true; App.IsAppExitByUser = true;
// 不设置 CloseIsFromButton = true,让它也经过确认流程 // 不设置 CloseIsFromButton = true,让它也经过确认流程
Close(); Close();
@@ -3072,6 +3073,7 @@ namespace Ink_Canvas
public void BtnRestart_Click(object sender, RoutedEventArgs e) public void BtnRestart_Click(object sender, RoutedEventArgs e)
{ {
Process.Start(System.Windows.Forms.Application.ExecutablePath, "-m"); Process.Start(System.Windows.Forms.Application.ExecutablePath, "-m");
_forceCloseFromExitOrRestartButton = true;
App.IsAppExitByUser = true; App.IsAppExitByUser = true;
// 不设置 CloseIsFromButton = true,让它也经过确认流程 // 不设置 CloseIsFromButton = true,让它也经过确认流程
Close(); Close();