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