我有两个QGroupBoxes,其中一个是另一个的子级。我想在不更改子标题颜色的情况下更改父标题的颜色。根据qt文档,我尝试了以下操作:https://doc.qt.io/qt-5/stylesheet-examples.html
我的代码:
mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QGroupBox>
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
MainWindow(QWidget *parent = nullptr);
~MainWindow();
private:
Ui::MainWindow *ui;
QGroupBox *r1;
QGroupBox *r2;
};
#endif // MAINWINDOW_H
主窗口.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainWindow)
{
ui->setupUi(this);
r1 = new QGroupBox("test",this);
r1->setGeometry(10,10,100,100);
r1->setStyleSheet("QGroupBox::title#r1{color:red}");
r1->show();
r2 = new QGroupBox("test",r1);
r2->setGeometry(10,10,80,80);
r2->show();
}
MainWindow::~MainWindow()
{
delete ui;
}
这对我不起作用。标题不会变色
如果我只是通过在设计器中创建QGroupBox来执行同样的操作,它就会工作。帮我弄清楚我做错了什么?
QSS与CSS略有不同。Qt只是不知道在你的情况下r1
是什么。为了达到您想要的效果,您可以:
setObjectName()
,然后通过此名称引用。因此,只有一个元素具有不同的颜色
r1 = new QGroupBox("test",this);
r1->setGeometry(10,10,100,100);
r1->setObjectName("r1");
r1->setStyleSheet("QGroupBox#r1 {color: red}");
r1->show();
r2 = new QGroupBox("test",r1);
r2->setGeometry(10,10,80,80);
r2->show();
- 使用
>
选择器匹配父子关系。在这种情况下,作为QMainWindow
的直接子级的所有QGroupBox
将是红色的
r1 = new QGroupBox("test",this);
r1->setGeometry(10,10,100,100);
r1->setStyleSheet("QMainWindow > QGroupBox {color: red}");
r1->show();
r2 = new QGroupBox("test",r1);
r2->setGeometry(10,10,80,80);
r2->show();
- 使用
title
属性值-但是,我强烈不建议使用这种方法
r1 = new QGroupBox("test",this);
r1->setGeometry(10,10,100,100);
r1->setStyleSheet("QGroupBox[title='test'] {color: red}");
r1->show();
r2 = new QGroupBox("test",r1);
r2->setGeometry(10,10,80,80);
r2->show();
有关语法的更多信息,请点击此处:https://doc.qt.io/Qt-5/stylesheet-syntax.html