// remove question mark from the title bar
setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint);
默认情况下,Qt::WindowContextHelpButtonHint 标志被添加到对话框中。您可以使用对话框构造函数的 WindowFlags 参数来控制它。
例如,您可以通过执行以下操作仅指定 TitleHint 和 SystemMenu 标志:
QDialog *d = new QDialog(0, Qt::WindowSystemMenuHint | Qt::WindowTitleHint);
d->exec();
如果您添加 Qt::WindowContextHelpButtonHint 标志,您将获得帮助按钮。
在 PyQt 中,您可以执行以下操作:
from PyQt4 import QtGui, QtCore
app = QtGui.QApplication([])
d = QtGui.QDialog(None, QtCore.Qt.WindowSystemMenuHint | QtCore.Qt.WindowTitleHint)
d.exec_()
有关窗口标志的更多详细信息,请参见 Qt 文档中的 WindowType enum。
Qt::WindowCloseButtonHint
。
QtCore.Qt.WindowCloseButtonHint
并删除 QtCore.Qt.WindowTitleHint
。我假设设置标志会覆盖默认标志,因此您需要指定您想要的所有标志。
从 Qt 5.10 开始,您可以使用单个 QApplication
属性全局禁用这些按钮!
QApplication::setAttribute(Qt::AA_DisableWindowContextHelpButton);
好的,我找到了一种方法来做到这一点。
它确实处理窗口标志。所以这是我使用的代码:
Qt::WindowFlags flags = windowFlags()
Qt::WindowFlags helpFlag =
Qt::WindowContextHelpButtonHint;
flags = flags & (~helpFlag);
setWindowFlags(flags);
但是这样做有时会重置对话框的图标。因此,要确保对话框的图标不会改变,您可以添加两行。
QIcon icon = windowIcon();
Qt::WindowFlags flags = windowFlags();
Qt::WindowFlags helpFlag =
Qt::WindowContextHelpButtonHint;
flags = flags & (~helpFlag);
setWindowFlags(flags);
setWindowIcon(icon);
setWindowFlags(windowFlags() & ~Qt::WindowContextHelpButtonHint);
我在 Windows 7、Qt 5.2 中遇到了这个问题,最适合我的标志组合是:
Qt::WindowTitleHint | Qt::WindowCloseButtonHint
这给了我一个工作关闭按钮,但没有问号帮助按钮。仅使用 Qt::WindowTitleHint 或 Qt::WindowSystemMenuHint 摆脱了帮助按钮,但它也禁用了关闭按钮。
正如 Michael Bishop 所建议的那样,正是在使用 windowflags 示例导致我进行了这种组合。谢谢!
此处列出的答案会起作用,但要自己回答,我建议您运行示例程序 $QTDIR/examples/widgets/windowflags
。这将允许您测试窗口标志的所有配置及其效果。对于找出 squirrelly windowflags 问题非常有用。
默认情况下,可以使用以下方法为应用程序中的所有对话框删除问号:
将以下事件过滤器附加到程序开始处的 QApplication
:
bool eventFilter (QObject *watched, QEvent *event) override
{
if (event->type () == QEvent::Create)
{
if (watched->isWidgetType ())
{
auto w = static_cast<QWidget *> (watched);
w->setWindowFlags (w->windowFlags () & (~Qt::WindowContextHelpButtonHint));
}
}
return QObject::eventFilter (watched, event);
}
我找不到插槽,但您可以覆盖虚拟 winEvent
函数。
#if defined(Q_WS_WIN)
bool MyWizard::winEvent(MSG * msg, long * result)
{
switch (msg->message)
{
case WM_NCLBUTTONDOWN:
if (msg->wParam == HTHELP)
{
}
break;
default:
break;
}
return QWizard::winEvent(msg, result);
}
#endif
由于来自@amos 的 PyQt4 解决方案对我不起作用并且 PyQt4 的版本已被弃用,这是我关于如何删除“?”的解决方案。在 PyQt5 的对话框中:
class window(QDialog):
def __init__(self):
super(window, self).__init__()
loadUi("window.ui", self)
self.setWindowFlag(QtCore.Qt.WindowContextHelpButtonHint,False) # This removes it
setWindowFlags(windowFlags().setFlag(Qt::WindowContextHelpButtonHint, false))
不过,这两者中哪一个更具可读性是非常主观的。