1、先说说我的后台程序的应用场景:关闭当前程序(隐藏),调用另一个ui,ui的类型是悬浮窗(Qt::Tool),并且在系统通知栏可以见到图标,后台程序逻辑都正常执行;
2、实现后台运行的两种主要方式:
(1)重写closeEvent,并设置event->ignore();
void Dialog::closeEvent(QCloseEvent *event)
{
QMessageBox::information(this, "Tips", "The Program is miniSize,you can see it on the windows bottom");
setVisible(false);
event->ignore();
}
(2)main函数中设置QApplication::setQuitOnLastWindowClosed(false);
#include "dialog.h"
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QApplication::setQuitOnLastWindowClosed(false);
Dialog w;
w.show();
return a.exec();
}
坑来了:
特别特别特别注意:第一种和第二种两者实现效果在用户直观看是一模一样的,但是!!!实体功能就完全两码事!!!
第一种方法是程序在后台挂着的时候,虽然不可见,但是里面的逻辑依旧在后台监听执行中------------>这种方法符合我们的预期,正确;
第二种方法虽然在后台挂着,不可见,但是其实是一个空壳子,就是所有Qt相关的逻辑处理全都不起作用,比方说,你的程序原来是在监听鼠标或者按键,从而响应某些事件,而当你使用这种方法在后台挂起的时候,监听全部失效,我称之为空壳子后台,除非你重新在程序里show(),但这不就是违背我们后台程序运行的设计原则了不是吗?
网上找了很多很多帖子,似乎没有跟这个坑很相似的,于是自己探索出来解决方案就赶紧来发贴了;
如果有哪个地方讲的不对,请及时指出!