1 Star 0 Fork 5

kylinsecos/kiran-screensaver

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
0002-fix-crash-fix-crash-in-some-situation-d001fc82.patch 4.15 KB
一键复制 编辑 原始数据 按行查看 历史
kylinsecos_admin 提交于 2022-01-21 16:41 . First submission of source code
From d001fc82a1a872ae1dd0dadc5ef3d0c80181c1f6 Mon Sep 17 00:00:00 2001
From: liuxinhao <liuxinhao@kylinos.com.cn>
Date: Fri, 31 Dec 2021 15:32:01 +0800
Subject: [PATCH 2/3] fix(crash): fix crash in some situation
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
- 修复屏保后端在某些情况下崩溃的问题
---
src/idle-watcher/idle-watcher-mate.cpp | 3 +++
src/view/screen-manager.cpp | 16 ++++++++++------
src/view/screen-manager.h | 6 +++---
3 files changed, 16 insertions(+), 9 deletions(-)
diff --git a/src/idle-watcher/idle-watcher-mate.cpp b/src/idle-watcher/idle-watcher-mate.cpp
index 0cba668..9d744c3 100644
--- a/src/idle-watcher/idle-watcher-mate.cpp
+++ b/src/idle-watcher/idle-watcher-mate.cpp
@@ -97,11 +97,14 @@ bool IdleWatcherMate::setIdleDetectionActive(bool idleDetectionActive)
m_idle = false;
m_idleNotice = false;
+
//NOTE:由于空闲预告阶段会抓取鼠标键盘到屏幕外,所以空闲预告阶段不会出现设置空闲检测的情况,暂时不需要考虑特殊情况
if(m_idleTimerID != 0)
{
killTimer(m_idleTimerID);
+ m_idleTimerID = 0;
}
+
m_idleDetectionActive = idleDetectionActive;
return true;
}
diff --git a/src/view/screen-manager.cpp b/src/view/screen-manager.cpp
index f8d7803..d7fc124 100644
--- a/src/view/screen-manager.cpp
+++ b/src/view/screen-manager.cpp
@@ -42,10 +42,10 @@ ScreenManager::ScreenManager(Fade *fade,
if (m_prefs != nullptr)
{
m_enableAnimation = m_prefs->getEnableAnimation();
- m_idleActivationLock = m_prefs->getIdleActivationLock();
+ //m_idleActivationLock = m_prefs->getIdleActivationLock();
}
- QCoreApplication::instance()->installEventFilter(this);
+ QApplication::instance()->installEventFilter(this);
}
ScreenManager::~ScreenManager()
@@ -260,14 +260,15 @@ bool ScreenManager::activate()
// 创建解锁框,屏保框
m_screensaver = new Screensaver(m_enableAnimation, nullptr);
- if (m_idleActivationLock)
- {
+ //NOTE:空闲是否锁定屏幕控制权交由IdleWatcher决定,若IdleWatcher发出空闲信号,则锁定屏幕
+// if (m_idleActivationLock) // 若开启空闲时锁定屏幕,创建解锁框
+// {
if (!setLockActive(true))
{
delete m_screensaver;
return false;
}
- }
+// }
// 获取桌面壁纸路径
QString backgroundPath;
@@ -371,9 +372,10 @@ bool ScreenManager::eventFilter(QObject *watched, QEvent *event)
return QObject::eventFilter(watched, event);
}
+//NOTE:在事件过滤之中删除某些控件并且该控件同时是事件的接收者需要过滤该事件,避免崩溃
bool ScreenManager::eventFilterActivate(QObject *watched, QEvent *event)
{
- if (!m_active)
+ if ( !m_active || (event->type()!=QEvent::MouseButtonPress && event->type()!=QEvent::KeyPress) )
return false;
// 若解锁框已被激活 按键和鼠标事件触发解锁框显示
@@ -388,6 +390,7 @@ bool ScreenManager::eventFilterActivate(QObject *watched, QEvent *event)
else if (!getLockActive())
{
emit sigReqDeactivated();
+ return true;
}
}
else if (event->type() == QEvent::KeyPress)
@@ -396,6 +399,7 @@ bool ScreenManager::eventFilterActivate(QObject *watched, QEvent *event)
if (!getLockActive())
{
emit sigReqDeactivated();
+ return true;
}
else
{
diff --git a/src/view/screen-manager.h b/src/view/screen-manager.h
index b5253a0..9fa14c9 100644
--- a/src/view/screen-manager.h
+++ b/src/view/screen-manager.h
@@ -121,10 +121,10 @@ private:
// 当前显示内容的背景窗口
Window* m_currentWindow = nullptr;
// 屏保界面
- Screensaver* m_screensaver;
+ Screensaver* m_screensaver = nullptr;
// 解锁框界面
- PluginInterface* m_lockerPluginInterface;
- LockerInterface* m_lockerInterface;
+ PluginInterface* m_lockerPluginInterface = nullptr;
+ LockerInterface* m_lockerInterface = nullptr;
};
} // namespace ScreenSaver
} // namespace Kiran
--
2.27.0
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/kylinsecos_admin/kiran-screensaver.git
git@gitee.com:kylinsecos_admin/kiran-screensaver.git
kylinsecos_admin
kiran-screensaver
kiran-screensaver
master

搜索帮助