设置QMainWindow中央窗口小部件的背景



在Windows 7(MSVC 2010)上使用Qt 4.8.4,我的应用程序中有一个带工具栏的标准QMainWindow。我希望工具栏保持灰色,但中央小部件应该有白色背景。起初调用centralWidget->setStyleSheet("background-color: white;")似乎可以完成这项工作,但将其与设计器生成的小部件(Q_OBJECT)一起使用则不行。随后,我尝试了各种其他方法来设置样式表(也使用Designer),但都无济于事。

要查看此效果,请在test.h中添加或删除Q_OBJECT行。当它在那里时,只有标签得到一个白色bg。如果Q_OBJECT被注释掉,那么整个中心小部件都是白色的。当然,我希望整个区域都是白色的,但也需要Q_OBJECT

以下是文件:

main.cpp:

#include "test.h"
class testwin : public QMainWindow {
public:
    QWidget     *centralWidget;
    QToolBar    *mainToolBar;
    testwin(QWidget *parent = 0) : QMainWindow(parent) {
        centralWidget = new test(this);
        setCentralWidget(centralWidget);
        mainToolBar = new QToolBar(this);
        this->addToolBar(Qt::TopToolBarArea, mainToolBar);
    };
    ~testwin() {};
};
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    testwin w;
    w.centralWidget->setStyleSheet("background-color: white;");
    w.show();
    return a.exec();
}

测试.h:

#include <QtGui>
class test : public QWidget
{
    Q_OBJECT    // remove this
public:
    QLabel *label;
    test(QWidget *parent = 0) {
        resize(400, 300);
        label = new QLabel(this);
        label->setText("Test");
    };
};

状态更新:

  • setStyleSheet("QWidget { background-color: white; }")不能解决问题
  • 我成功地将每个Widget(包括弹出对话框)都变成了白色,但这不是我想要的
w.centralWidget->setStyleSheet("QWidget { background-color: white; }");

好的,可以在这里找到正确的答案,或者阅读文档。我需要为我的测试类实现paintEvent:

class test : public QWidget
{
    Q_OBJECT    // remove this
public:
    QLabel *label;
    test(QWidget *parent = 0) {
        resize(400, 300);
        label = new QLabel(this);
        label->setText("Test");
    };
    void paintEvent(QPaintEvent *)
    {
        QStyleOption opt;
        opt.init(this);
        QPainter p(this);
        style()->drawPrimitive(QStyle::PE_Widget, &opt, &p, this);
    }
};

也非常感谢1+1=2,他们在Qt项目论坛上为我阅读了手册。

有更好的方法。

如您所知,每个QMainWindow都有一个中心小部件,默认情况下命名为centralwidget

因此,解决此问题的最佳方法是更改小部件的背景。

当我们使用样式表时,它非常简单。在这种情况下,将是以下情况:

#centralwidget {
    background-color: rgb(0, 0, 0);
}

相关内容

  • 没有找到相关文章

最新更新