QT设置控件颜色

QT子窗口背景色设置
2011-09-02 13:07

有时我们需要在QWidget中再嵌入子QWidget,且要求设置父QWidget的背景色,而子QWidget的背景色不变.于是我们写出了下面的代码

int main ( int argc, char **argv )
{
 QApplication app (argc, argv ) ;
   QWidget *pw = new QWidget ( ) ;
   QPushButton *sw1 = new QPushButton ( "http://www.langisle.com/blog", pw ) ;
   QWidget *sw2 = new QWidget (pw ) ;   pw - >setStyleSheet ( "background-color:blue;" ) ; // 设置背景色
     QVBoxLayout *layout = new QVBoxLayout ( ) ;
 layout - >addWidget (sw1 ) ;
 layout - >addWidget (sw2 ) ;
 pw - >setLayout (layout ) ;
 pw - >resize ( 300, 200 ) ;
 pw - >show ( ) ;
  return app. exec ( ) ;
}

然而运行结果不对,子窗口继承了父窗口的背景颜色,效果如下图

我们修改一下代码,让setStyleSheet只作用于父窗口

int main ( int argc, char **argv )
{
 QApplication app (argc, argv ) ;
   QWidget *pw = new QWidget ( ) ;
   QPushButton *sw1 = new QPushButton ( "http://www.langisle.com/blog", pw ) ;
   QWidget *sw2 = new QWidget (pw ) ;
    pw - >setObjectName ( "pw" ) ; // 设置对象句,相当于css里的id
 pw - >setStyleSheet ( "#pw {background-color:blue;}" ) ; // 设置id对应元素的背景色
     QVBoxLayout *layout = new QVBoxLayout ( ) ;
 layout - >addWidget (sw1 ) ;
 layout - >addWidget (sw2 ) ;
 pw - >setLayout (layout ) ;
 pw - >resize ( 300, 200 ) ;
 pw - >show ( ) ;
  return app. exec ( ) ;
}

再看显示效果,按钮的背景色对了,可sw2还是看不到,这是为什么呢

实际这种结果并不是继承了父窗口背景色,而是由于了窗口的背景色没有刷新,使用setAutoFillBackground让sw2自动刷新背景

int main ( int argc, char **argv )
{
 QApplication app (argc, argv ) ;
   QWidget *pw = new QWidget ( ) ;
   QPushButton *sw1 = new QPushButton ( "http://www.langisle.com/blog", pw ) ;
   QWidget *sw2 = new QWidget (pw ) ;
    sw2 - >setAutoFillBackground ( true ) ; // 自动刷新背景
   pw - >setObjectName ( "pw" ) ; // 设置对象句,相当于css里的id
 pw - >setStyleSheet ( "#pw {background-color:blue;}" ) ; // 设置id对应元素的背景色
     QVBoxLayout *layout = new QVBoxLayout ( ) ;
 layout - >addWidget (sw1 ) ;
 layout - >addWidget (sw2 ) ;
 pw - >setLayout (layout ) ;
 pw - >resize ( 300, 200 ) ;
 pw - >show ( ) ;
   return app. exec ( ) ;
}
最终显示效果如下

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在PyQt5中,QStackedWidget本身没有提供直接设置背景颜色的方法。但是,你可以通过在QStackedWidget中放置一个QFrame,并将其背景颜色设置为所需颜色来实现这个效果。 下面是一个示例代码,演示如何使用QStackedWidget设置背景颜色: ```python import sys from PyQt5.QtWidgets import QApplication, QMainWindow, QWidget, QVBoxLayout, QStackedWidget, QFrame class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle("设置背景颜色示例") # 创建堆叠窗口部件 self.stackedWidget = QStackedWidget() self.setCentralWidget(self.stackedWidget) # 创建和添加子界面 self.page1 = Page1() self.page2 = Page2() self.stackedWidget.addWidget(self.page1) self.stackedWidget.addWidget(self.page2) # 设置堆叠窗口部件的背景颜色 self.stackedWidget.setStyleSheet("background-color: red;") class Page1(QWidget): def __init__(self): super().__init__() layout = QVBoxLayout() self.setLayout(layout) class Page2(QWidget): def __init__(self): super().__init__() layout = QVBoxLayout() self.setLayout(layout) if __name__ == "__main__": app = QApplication(sys.argv) mainWindow = MainWindow() mainWindow.show() sys.exit(app.exec_()) ``` 在这个示例中,我们在MainWindow类中创建了一个QStackedWidget作为主窗口的中央部件。然后,我们创建了两个子界面Page1和Page2,并将它们添加到QStackedWidget中。最后,我们使用`setStyleSheet()`方法将QStackedWidget的背景颜色设置为红。 你可以根据需要修改`setStyleSheet()`方法中的CSS样式来设置不同的背景颜色。希望这能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值