当我打开应用程序时,应用程序正在等待到服务器的连接,为此我调用了一个时隙run(),它等待来自服务器的确认包,当它接收到它时,它隐藏“等待连接”字符串并加载其他内容。问题是,当等待数据包时,系统托盘图标没有响应任何内容,当服务器发送数据包和加载应用程序时,系统托盘图标开始响应(右击菜单)。
我正在使用ZeroMQ作为工控机。
我有这样的事情:
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();
}发布于 2014-08-26 17:53:02
阻止事件循环。这是行不通的。不幸的是,ZMQ没有提供任何特定于平台的消息循环集成。因此,您必须在一个单独的线程中使用它。
这要容易得多,因为将网络代码放入小部件类是很糟糕的设计。
创建一个封装网络的ZMQ对象,并将其推送到一个单独的线程。只要您与ZMQ实例的所有通信都是通过信号/时隙或QMetaObject::invokeMethod进行的,您就可以了。
见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();
}发布于 2014-08-26 18:06:26
您需要在单独的线程中运行当前Mainwindow中的代码::run (),以避免阻塞事件循环。
使用包含相同代码的运行槽创建一个新的QObject,并将其移动到自己的线程。就像这样:
QThread *thread = new QThread;
thread->start();
qobject_with_run_slot->moveToThread(thread);
QTimer::singleShot(2000, qobject_with_run_slot, SLOT(run()));https://stackoverflow.com/questions/25512143
复制相似问题