QWidget 的背景应用于其所有 QWidget children
QWidget's background applied to all its QWidget children
我选择使用 Qt 来管理我正在处理的项目的 GUI。
在我的 QWidget
底部找到如何应用图片后,我注意到它对添加到其中的所有组件都有影响。
无论通过 setStyleSheet
方法或什至使用 QPixmap
应用何种样式,这些元素的背景始终是为 QWidget
容器定义的图像。
如何避免这种行为?
这是我的代码:
MainMenu::MainMenu(QWidget* Parent, const QPoint& Position, const QSize& Size) : QWidget(Parent) {
QString qwidgetStyle = "QWidget {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
QString buttonStyle = "color: rgba(73, 123, 176, 1); font-size:30px; background-color: rgba(73, 123, 176, 1);";
move(Position);
resize(Size);
setStyleSheet(qwidgetStyle);
// Menu title
QLabel *title = new QLabel(this);
title->setText("Menu");
title->setStyleSheet(buttonStyle);
title->setAlignment(Qt::AlignCenter);
// Menu buttons
// Play
buttonPlay = new QPushButton("Play");
(*buttonPlay).setEnabled(true);
(*buttonPlay).setStyleSheet(buttonStyle);
connect(buttonPlay, SIGNAL(clicked()), this, SLOT(handleButton()));
// Option
buttonOptions = new QPushButton("Options", this);
(*buttonOptions).setEnabled(true);
(*buttonOptions).setGeometry(250, 175, 100, 50);
(*buttonOptions).setStyleSheet(buttonStyle);
connect(buttonOptions, SIGNAL(clicked()), this, SLOT(handleButton()));
// Quit
buttonQuit = new QPushButton("Quit", this);
(*buttonQuit).setEnabled(true);
(*buttonQuit).setGeometry(250, 275, 100, 50);
(*buttonQuit).setStyleSheet(buttonStyle);
connect(buttonQuit, SIGNAL(clicked()), this, SLOT(handleButton()));
// Layout
QGridLayout *layout = new QGridLayout;
layout->setMargin(50);
layout->addWidget(title, 0, 0, 1, 5);
layout->addWidget(buttonPlay, 3, 1, 2, 3);
layout->addWidget(buttonOptions, 4, 1, 2, 3);
layout->addWidget(buttonQuit, 5, 1, 2, 3);
setLayout(layout);
show();
}
您遇到的行为完全正常,原因如下:
QString qwidgetStyle = "QWidget {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
...
setStyleSheet(qwidgetStyle);
在这里,您刚刚告诉 Qt 使用关键字 QWidget
将 qwidgetstyle
应用于 您应用程序的每个 QWidget。这就是为什么在 Qt 中,如果要将样式应用于此特定对象,最好为对象设置一个名称。
在您的代码中,QLabel
和 QPushButton
都继承自 QWidget
,因此它们将具有您为 QWidget
、 定义的样式除非你给它们命名或为每个指定样式。
如果你想为直接继承自 QWidget
的 MainMenu
设置样式 sheet(这是你首先要做的),你必须设置一个名称,然后应用样式:
setObjectName("MainMenu");
QString qwidgetStyle = "QWidget#MainMenu {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
setStyleSheet(qwidgetStyle); // here, only your MainMenu will have the style "qwidgetstyle"
请注意,例如,您可以为每个 QWidget
设置相同的样式 sheet,并且只为您的 MainMenu
添加特定颜色:
// this is in a CSS, but you can apply it directly from the MainMenu constructor of course
QWidget, QWidget#MainMenu {
background-image: url(background.jpg);
border: 5px solid rgba(3, 5, 28, 1);
} // aplied to all QWidget
QWidget#MainMenu {
color : #9b9b9b; // a nice grey, only applied to MainMenu
}
同样,在使用样式 sheets 时要具体,否则您最终会在应用程序中到处出现奇怪的 colors/alignments :)。希望对您有所帮助!
注意:您还可以感谢@PaulRooney,他在评论中给出了非常好的 link。
我选择使用 Qt 来管理我正在处理的项目的 GUI。
在我的 QWidget
底部找到如何应用图片后,我注意到它对添加到其中的所有组件都有影响。
无论通过 setStyleSheet
方法或什至使用 QPixmap
应用何种样式,这些元素的背景始终是为 QWidget
容器定义的图像。
如何避免这种行为?
这是我的代码:
MainMenu::MainMenu(QWidget* Parent, const QPoint& Position, const QSize& Size) : QWidget(Parent) {
QString qwidgetStyle = "QWidget {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
QString buttonStyle = "color: rgba(73, 123, 176, 1); font-size:30px; background-color: rgba(73, 123, 176, 1);";
move(Position);
resize(Size);
setStyleSheet(qwidgetStyle);
// Menu title
QLabel *title = new QLabel(this);
title->setText("Menu");
title->setStyleSheet(buttonStyle);
title->setAlignment(Qt::AlignCenter);
// Menu buttons
// Play
buttonPlay = new QPushButton("Play");
(*buttonPlay).setEnabled(true);
(*buttonPlay).setStyleSheet(buttonStyle);
connect(buttonPlay, SIGNAL(clicked()), this, SLOT(handleButton()));
// Option
buttonOptions = new QPushButton("Options", this);
(*buttonOptions).setEnabled(true);
(*buttonOptions).setGeometry(250, 175, 100, 50);
(*buttonOptions).setStyleSheet(buttonStyle);
connect(buttonOptions, SIGNAL(clicked()), this, SLOT(handleButton()));
// Quit
buttonQuit = new QPushButton("Quit", this);
(*buttonQuit).setEnabled(true);
(*buttonQuit).setGeometry(250, 275, 100, 50);
(*buttonQuit).setStyleSheet(buttonStyle);
connect(buttonQuit, SIGNAL(clicked()), this, SLOT(handleButton()));
// Layout
QGridLayout *layout = new QGridLayout;
layout->setMargin(50);
layout->addWidget(title, 0, 0, 1, 5);
layout->addWidget(buttonPlay, 3, 1, 2, 3);
layout->addWidget(buttonOptions, 4, 1, 2, 3);
layout->addWidget(buttonQuit, 5, 1, 2, 3);
setLayout(layout);
show();
}
您遇到的行为完全正常,原因如下:
QString qwidgetStyle = "QWidget {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
...
setStyleSheet(qwidgetStyle);
在这里,您刚刚告诉 Qt 使用关键字 QWidget
将 qwidgetstyle
应用于 您应用程序的每个 QWidget。这就是为什么在 Qt 中,如果要将样式应用于此特定对象,最好为对象设置一个名称。
在您的代码中,QLabel
和 QPushButton
都继承自 QWidget
,因此它们将具有您为 QWidget
、 定义的样式除非你给它们命名或为每个指定样式。
如果你想为直接继承自 QWidget
的 MainMenu
设置样式 sheet(这是你首先要做的),你必须设置一个名称,然后应用样式:
setObjectName("MainMenu");
QString qwidgetStyle = "QWidget#MainMenu {background-image: url(background.jpg); border: 5px solid rgba(3, 5, 28, 1);}";
setStyleSheet(qwidgetStyle); // here, only your MainMenu will have the style "qwidgetstyle"
请注意,例如,您可以为每个 QWidget
设置相同的样式 sheet,并且只为您的 MainMenu
添加特定颜色:
// this is in a CSS, but you can apply it directly from the MainMenu constructor of course
QWidget, QWidget#MainMenu {
background-image: url(background.jpg);
border: 5px solid rgba(3, 5, 28, 1);
} // aplied to all QWidget
QWidget#MainMenu {
color : #9b9b9b; // a nice grey, only applied to MainMenu
}
同样,在使用样式 sheets 时要具体,否则您最终会在应用程序中到处出现奇怪的 colors/alignments :)。希望对您有所帮助!
注意:您还可以感谢@PaulRooney,他在评论中给出了非常好的 link。