当我打开我的应用程序然后应用程序正在等待与服务器的连接时,我已经通过调用等待来自服务器的确认数据包的插槽run()
来做到这一点,当它接收到它然后它隐藏“等待连接“字符串并加载其他东西。问题是当它等待数据包时系统托盘图标没有响应任何东西,当服务器发送数据包和应用程序加载时,系统托盘图标开始响应(对于右键单击菜单)。
我正在使用ZeroMQ进行IPC。
我有这样的事情:
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show();
//THIS PART
QTimer::singleShot(2000,&w,SLOT(run()));
return a.exec();
}
答案 0 :(得分:3)
您阻止事件循环。这将永远不会奏效。不幸的是,ZMQ不提供任何特定于平台的消息循环集成。因此,您必须在单独的线程中使用它。
这更容易,因为无论如何将网络代码放入窗口小部件类中都是糟糕的设计。
创建一个封装网络的ZMQ
对象,并将其推送到单独的线程。只要您与ZMQ实例的所有通信都通过信号/插槽或QMetaObject::invokeMethod
,您就可以了。
请参阅this answer for code to Thread
。
class ZMQ : public QObject {
Q_OBJECT
Q_SLOT void run() {
...
forever {
socket.send(request,0);
socket.recv(&response);
if(response.compare("login") == 0) {
emit loggedIn();
socket.close();
return;
}
}
}
public:
ZMQ() {}
Q_SIGNAL void loggedIn();
};
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
ZMQ zmq;
Thread thread; // see https://stackoverflow.com/a/25230470/1329652
MainWindow w;
w.connect(&zmq, SIGNAL(loggedIn()), SLOT(loggedIn()));
zmq.moveToThread(&thread);
thread.start();
QMetaObject::invokeMethod(&zmq, "run");
w.show();
return a.exec();
}
答案 1 :(得分:0)
您需要在一个单独的线程中运行当前Mainwindow :: run()中的代码,以便不阻止事件循环。
使用包含相同代码的运行槽创建一个新的QObject,并将其移动到自己的线程。 像这样:
QThread *thread = new QThread;
thread->start();
qobject_with_run_slot->moveToThread(thread);
QTimer::singleShot(2000, qobject_with_run_slot, SLOT(run()));