Qt中设置widget背景颜色/图片的注意事项(使用样式表 setStyleSheet())

 在Qt中设置widget背景颜色或者图片方法很多种:重写paintEvent() , 调色板QPalette , 样式表setStyleSheet等等。

      但是各种方法都有其注意事项,如果不注意则很容易陷入麻烦中。

1:setStyleSheet()

     这个函数我一直很喜欢使用,因为只要写一句就可以实现效果,比其他方法都简单,但是其却有一个很值得注意的地方,也就是这个地方让我大吃苦头。

    亦即:①:该函数只能用于设置有父窗口的子窗口的背景!如果一个窗口没有子窗口,则无法使用该函数来设置背景颜色或图                             片!!

             ②:同时:对于一个父窗口而言:如果我们用setStyleShette设置了其样式,而对于其子窗口:如果没有用同样的函数来设                    置的话, 则其子窗口的样式和其父窗口完全一致,亦即:其集成了自己父窗口的样式!

             ③:延伸:对顶层窗口(没有父窗口),其有若干个子窗口,则当我们用setStyleShette来设置这个顶层窗口的样式后,依据①可知:该父窗口本身没有任何变化,亦即设置没有生效;而其子窗口:只要子窗口本身没有用setStyleShette来设置自己的样式表,则其就是用的自己父窗口的样式表!!

     例如:

     主窗口(没有父类)为MainWin

MainWin::MainWin()

{

this->setStyleSheet("background-image:url(:/bmp/IMG_0345.JPG)");

iButton = new QPushButton(this);

iLabel = new QLabel(iButton);

}

    运行一下,效果如下:

 亦即:虽然我们设置的是顶层的父窗口,但是该样式却是在其子窗口中生效,而顶层父窗口没有任何变化! 这验证了①。

修改一下上例代码:

MainWin::MainWin()

{

this->setStyleSheet("background-image:url(:/bmp/IMG_0345.JPG)");

iButton = new QPushButton(this);

iLabel = new QLabel(iButton);

iLabel->setStyleSheet("background-image:url(:/bmp/1257253475842.jpg)");

}

       则运行效果如下:

 可见:子窗口只有调用setStyleSheet()设置了自己的样式后才可以隔断父窗口的样式,否则其将是用父窗口的样式。

       再修改一下代码:

MainWin::MainWin()

{

iButton = new QPushButton(this);

iButton ->setStyleSheet("background-image:url(:/bmp/IMG_0345.JPG)");

iLabel = new QLabel(iButton);

}

运行一下,效果如下:

可见:设置有父窗口的子窗口时:setStyleSheet()一定生效!!!

  后来我又思考了一个问题,那就是:对于顶层父窗口,如果我setStyleSheet()设置了样式表,而对其子窗口,我用其他方法,比如用QPalette调色板来设置背景图片/颜色,这时子窗口的背景到底是由继承自父窗口的样式表决定呢还是由子窗口本身的QPalette调色板决定呢?

再次修改代码:

MainWin::MainWin()

{

this->setStyleSheet("background-image:url(:/bmp/IMG_0345.JPG)");

iButton = new QPushButton(this);

iLabel = new QLabel(iButton);

QPalette palette;

palette.setBrush(iLabel->backgroundRole(),QBrush(QImage(":/bmp/1257253475842.jpg")));

iLabel->setPalette(palette);

iLabel->setAutoFillBackground(true);

}

此段代码中我用QPalette来设置子窗口的背景图片,看下到底是样式表还是调色板生效,效果如下

 

 

由此可见:一旦顶层窗口设置了样式表,则其子窗口无论用什么方法来设置背景,都会不生效!!!

那如果不是顶层窗口而仅仅是一般窗口设置了样式表呢?再次修改代码:

MainWin::MainWin()

{

iButton = new QPushButton(this);

iButton ->setStyleSheet("background-image:url(:/bmp/IMG_0345.JPG)");

iLabel = new QLabel(iButton);

QPalette palette;

palette.setBrush(iLabel->backgroundRole(),QBrush(QImage(":/bmp/1257253475842.jpg")));

iLabel->setPalette(palette);

iLabel->setAutoFillBackground(true);

}

运行效果同上,这说明:不管是顶层窗口还是一般窗口,只要用setStyleSheet设置了样式表,则其子窗口用其它方式设置背景颜色/图片均不生效,只能用同样方式setStyleSheet来设置更改!!!

为了验证上边的结论,再次修改代码:

MainWin::MainWin()

iButton = new QPushButton(this);

iLabel = new QLabel(iButton);

QPalette palette;

palette.setBrush(iLabel->backgroundRole(),QBrush(QImage(":/bmp/1257253475842.jpg")));

iLabel->setPalette(palette);

iLabel->setAutoFillBackground(true);

}

运行一下:

 

此时调色板才生效,这也间接证明了上述结论。

==========================================================================

总结:

     1:不要在顶层窗口(无父类的窗口)中使用setStyleSheet() ,否则其一父窗口的背景不会改变,其次其子窗口的背景设置方法变得局限唯一,不能再使用其它方法!

     2:如果一个一般窗口(非顶层窗口)还有子窗口,那最好不要使用setStyleSheet()来设置其背景颜色,因为虽然此时该窗口的背景设置是生效的,但是其子窗口的背景设置也变得局限唯一,只能使用setStyleSheet,而不能使用其它方法!  当然:你如果就是只想使用这种方法,那也完全可以!!

     说白了就是:不要再MainWindow中使用setStyleSheet()!

      而上边之所以强调拓宽子窗口设置背景的方法范围,这是因为:如果只能用setStyleSheet样式表来设置背景图片的话,该图片是无法缩放的,如果其大小与widget窗口大小不相符,则我们无法用程序来实现图片的缩放,除非我们直接处理图片使其大小与widget窗口相符; 而如果不局限于用setStyleSheet样式表来设置的话,我们可以选择用QPalette调色版,其内部setBrush()之前,我们完全可以先对图片进行scale缩放再刷到窗口上,这样就避免直接去处理图片,灵活性强一点!

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/NRC_DouNingBo/archive/2010/05/07/5565212.aspx

 

关于使用setStyleShee来设定窗口样式的文章,参看

http://blog.csdn.net/xie376450483/archive/2010/10/07/5925723.aspx




查看源代码示例


查看源代码示例
  • 6
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 在Qt,可以使用setStyleSheet方法为窗口或部件设置样式表setStyleSheet方法接受一个QString类型的参数,该参数包含CSS样式表的规则。 以下是使用setStyleSheet方法设置样式表的示例代码: ```cpp // 创建一个QPushButton QPushButton *button = new QPushButton("Click me!", this); // 设置样式表 button->setStyleSheet("QPushButton {" "background-color: blue;" "color: white;" "border-style: outset;" "border-width: 2px;" "border-radius: 10px;" "border-color: beige;" "font: bold 14px;" "min-width: 10em;" "padding: 6px;" "}"); // 将按钮添加到窗口 button->show(); ``` 在上面的示例代码,我们创建了一个QPushButton并使用setStyleSheet方法设置了一个样式表样式表定义了按钮的背景颜色、文本颜色、边框样式、边框宽度、边框半径、边框颜色、字体、最小宽度和内边距。 ### 回答2: QtsetStyleSheet()是一种强大的方法,它可以帮助用户在Qt应用程序实现自定义的样式效果。 该方法允许用户通过使用CSS语言来设置各种控件的样式。此外,它可以帮助用户更快地进行界面开发,使得设计师能够更快地实现自己的设计想法。 setStyleSheet()方法可以以字符串形式接受CSS样式表,并将其应用于给定的小部件、控件或整个应用程序的所有小部件。它可以让用户自定义控件的背景颜色、字体、边框等,从而创造出独特的UI外观。 使用styleSheet可以使用简单的选择器,甚至可以使用复杂的选择符来针对特定情况提供特定的样式。例如,您可以为按钮设置鼠标悬停时的样式,并使用“:hover”伪类规则实现这一目的。 setStyleSheet()还允许用户使用QPalette类来设置应用程序使用的颜色,并仅在设置背景、文本和其他颜色时使用该类。这样,每个颜色都可以由设计师定制,而不必在代码逐个设置。 总之,setStyleSheet()方法在Qt应用程序的界面开发极其有用,可以使用户更快地实现自己的想法,从而增强了开发人员的生产率和用户的体验。 ### 回答3: Qt是一个非常流行的跨平台应用程序开发框架,提供了非常丰富的GUI组件。Qt允许用户通过其强大的setStyleSheet函数来改变组件的外观。这个函数允许用户使用CSS样式描述来设置组件的外观。这个函数的使用非常简单,只需要将样式描述作为参数传递给函数即可。 使用setStyleSheet函数可以自定义各种不同的组件属性,包括背景颜色、字体颜色、边框宽度、圆角大小等等。使用这个函数的一个好处是,如果需要修改组件的外观,只需要修改一次样式描述即可,而不用修改每个组件的属性。 为了使用setStyleSheet函数,必须熟悉CSS样式描述的基本语法。CSS样式描述使用类似于HTML的语法,但是它包含了一些额外的属性,如背景图片和渐变颜色等。 例如,以下代码将QPushButton的背景颜色设置为红色,边框宽度为1像素,字体颜色为白色: ``` QPushButton { background-color: red; border: 1px solid black; color: white; } ``` 需要注意的是,在使用setStyleSheet函数时,只需要为组件设置自定义样式描述,不需要为每个组件创建一个独立的样式表。 总之,setStyleSheet函数是Qt GUI编程非常重要的函数之一。我们可以使用它来美化组件的外观,并快速实现视觉效果。学好setStyleSheet函数,可以让我们的Qt应用程序更加美观和舒适。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值