我的Qt5.9程序(在X11 Linux上)使用QProcess启动其他应用程序。我希望控制这些应用程序产生的窗口,因此我获得了它们的winId值,并使用QWindow::fromWinId获得了一个QWindow实例。
问题是这些实例是无效的,并且不代表它们应该显示的窗口。
如果我使用xwininfo检查winId值,将返回正确的信息,因此我知道它们是正确的。
我做错了什么?
编辑:一个例子不会有太大帮助,但下面是:
QProcess *process=new QProcess(this);
...
process.open()
... // wait until window appears
WId winId=PidToWid(process->processId()); // this function returns the Window ID in decimal format. I test this with xwininfo, it's always correct
...
QWindow *appWindow=QWindow::fromWinId(winId);..。基本上就是这样。appWindow是一个有效的QWindow实例,但它与实际的窗口没有任何关系。例如,如果我关闭()它,它会返回true,但窗口不会关闭。
即使我故意提供了错误的WId,最终结果也是一样的。
发布于 2018-05-25 19:15:50
这不是正确的解决方案,解释为什么它应该工作,但它可能对某些人有帮助…
当我使用QWindow从Qt4 QX11EmebeddedContainer切换到Qt5实现时,我的应用程序也遇到了同样的问题。我为解决/修复此问题所做的工作如下:
客户端应用程序:
widget->show(); //Widget had to be shown
widget->createWinId();
sendWinId(widget->winId()); //Post window handle to master app where is constructed container主应用程序:
QWindow* window = QWindow::fromWinId(clientWinId);
window->show(); //This show/hide toggle did trick in combination with show in client app
window->hide();
QWidget* container = QWidget::createWindowContainer(window, parentWindowWidget);在此之后,我能够通过QWidget容器正确地控制窗口。
https://stackoverflow.com/questions/45061803
复制相似问题