Qt设置样式时一个组合控件中的属性

主要是针对在使用Qt提供的控件时,想要使用qss去美化控件时,却不知道控件中的一个子控件的名称以及相关属性如何设置;

1. QComboBox --组合下拉栏
- 设置下拉按钮的样式;QComboBox::drop-down;通过这个选择器可以设置下拉按钮的形状以及一些基本属性设置;

		QComboBox::drop-down {
		subcontrol-origin: padding;
		subcontrol-position: top right;
		width: 30px;							//按钮宽度
		border-left-width: 0px;			//按钮左边框宽度
		border-left-color: gray;			//按钮左边框颜色
		border-left-style: solid;			//左边框线条样式
		border-top-right-radius: 3px;		//设置右上角的旋转弧度
		border-bottom-right-radius: 3px;		//设置右下角的旋转弧度
		}
  • 设置鼠标经过下拉按钮时下拉按钮的样式
		QComboBox::down-arrow:hover {
		image: url(:/images/Login_Ui/drop_down_hover.png);
		}
  • 设置下拉按钮被按下时按钮的样式
		QComboBox::down-arrow:pressed {
		border-image: url(:/images/Login_Ui/drop_down_pressed.png);
		}
  • 设置下拉列表中数据项的样式
		QComboBox QAbstractItemView::item {
		    height: 50px;
		}

            需要注意的是:在设置完成时候,还需要调用接口QComboBox::setView() ,否则刚才创建的样式不生效

		ui->comboBox->setView(new  QListView());
  1. QTabWidget
        1、设置QTabWidget中tab-bar标签样式
QTabWidget::tab-bar
{
	alignment:left;		//设置文字左对齐
}

QTabWidget::pane
{
	border:none;
}

QTabWidget::tab-bar
{
	alignment:left;
}

QTabBar QToolButton::right-arrow {
    image: url(rightarrow.png);  
}

QTabBar QToolButton::left-arrow {
    image: url(rightarrow.png);  
}

QTabBar::tab
{
	margin-bottom:2px;
	font-size:15px;
	font-family:Microsoft YaHei;
	color:rgba(99,122,135,1);
	background:rgba(255,255,255,1);
	min-width:200px;
	min-height:42px;
}

QTabBar::tab::currentTabIcon
{
	min-height:42px;
}

QTabBar::tab:hover
{
	font-size:15px;
	font-family:Microsoft YaHei;
	color:rgba(0,140,255,1);
	background:rgba(227,242,255,1);
}

QTabBar::tab:selected
{
	background:rgba(0,140,255,1);
	font-size:15px;
	font-family:Microsoft YaHei;
	color:rgba(255,255,255,1);
}

QScrollBar::add-page:vertical, QScrollBar::sub-page:vertical
{
	background:rgba(221, 221, 221,1);
}

QScollBar::add-line:vertical, QScrollBar::sub-line:vertical
{
	background:transparent;
}

QScollBar::add-line:vertical, QScrollBar::add-line:vertical
{
	background:transparent;
}
  1. QTableWidget
QHeaderView
{
    background:transparent;
}

QHeaderView::section
{
    font-size:15px;
    font-family:Microsoft YaHei;
	background:rgba(255,255,255,1);
	font-weight:bold;
	color:rgba(77,94,116,1);
	border:1px solid  rgb(209, 209, 209);			//设定表头外边框,有时表头不显示边框,可以通过设置该属性来解决
    min-height:40px;
    max-height:40px;

}
QTableWidget
{
    background:#FFFFFF;
    font-size:12px;
    font-family:Microsoft YaHei;
    color:#666666;
	marging-left:0px;
	border:1px solid  rgb(209, 209, 209);   //如果是用代码去创建表,有时会出现表的边框缺失,可以通过设置这个属性来解决
}
 
QTableWidget::item::selected 			//表格中单元格被选中时的样式
{
    color:red;
    background:#EFF4FF;
}

QScrollBar::vertical 			//社会滚动条的宽和高
{
	width: 15px;
	height:50px;
}
QScrollBar::handle:hover				//设置竖直方向的滚动条的样式
{
	background:rgba(200,209,219,1);
}
QScrollBar::handle:pressed
{
	background:rgba(0,140,255,1);
}
	
  1. QTreeWidget
QTreeWidget{
	background:rgba(255,255,255,1);
    /* set the font properties*/
    font-size:14px;
	font-family:Microsoft YaHei;
	outline:0px;
	show-decoration-selected: 1;
    selection-background-color: rgba(227, 242, 255,1);
	color: black; /*rgba(99,122,135,1);*/
	border:none;
	border-top:1px solid rgb(192,192,192);
    border-bottom:1px solid rgb(192,192,192);
	
}
 
QTreeWidget::item{ 
	height:30px;
    margin:10px;
  	background:rgba(255,255,255,1);  
    background-clip: margin;
}

QTreeWidget::branch{
    background:rgba(255,255,255,1);
	border-image: none;
}

QTreeView::item:hover {
    background: rgba(227, 242, 255,1);
}
 
QTreeView::item:selected:active{
    background: rgba(227, 242, 255,1);
	color:rgba(1,141,255,1);
}
 
QTreeView::item:selected:!active {
    background: rgba(227, 242, 255,1);
	color:rgba(1,141,255,1);
}

QTreeView::item:hover,
QTreeView::branch:hover,
QTreeViewl::item:selected,
QTreeView::branch:selected
{
    background: rgba(227, 242, 255,1);
}

QTreeView::branch:hover
{
    background: rgba(227, 242, 255,1);
}

QTreeWidget::branch:closed:has-children:!has-siblings,
QTreeWidget::branch:closed:has-children:has-siblings {
    border-image: none;
    image: url(:/Resources/image/dm_btn_down_collapse.png);
}
 
 
QTreeWidget::branch:open:has-children:!has-siblings,
QTreeWidget::branch:open:has-children:has-siblings  {
    border-image: none;
    image: url(:/Resources/image/dm_btn_down_exhibition.png);
}

QScrollBar::handle:vertical
{
	background:rgba(200,200,200,1);
    border: 0px solid grey;           
    border-radius:3px;                
    width: 8px;              
}

QScrollBar::vertical 
{
	width: 15px;
	height:30px;
	background:rgba(184,192,1851);
}
QScrollBar::handle:hover
{
	background:rgba(98,184,255,1);
}
QScrollBar::handle:pressed
{
	background:rgba(98,184,255,1);

}

QScrollBar::add-page:vertical, QScrollBar::sub-page:vertical
{
	background:rgba(221, 221, 221,1);
}

QScollBar::add-line:vertical, QScrollBar::sub-line:vertical
{
	background:transparent;
}

QScollBar::add-line:vertical, QScrollBar::add-line:vertical
{
	background:transparent;
}
  1. QCheckBox
QCheckBox{
	font-size:15px;
	font-family:Microsoft YaHei;
	color:rgba(77,94,116,1);
}

/*单选框未选中样式*/
QCheckBox::indicator::unchecked {
    image: url(:/Resources/image/dm_btn_cycle_nochoose.png);
}
/*单选框选中样式*/
QCheckBox::indicator::checked { 
    image: url(:/Resources/image/dm_btn_cycle_choose.png);
}

Tips:
  Qt的样式设置占用时间消耗还是比较大的,如果在实际使用中,是用代码不断的创建某个控件,而有需要不断为这个控件调用setStyleSheet来设置样式,循环创建的数量过多时,会严重影响程序的响应速度,需要注意这点!!!!!!!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用QSS(Qt Style Sheet)来设置QPushButton的颜色。具体方法如下: 1. 在QPushButton所在的窗口或对话框,右键单击选择“添加样式表”。 2. 在弹出的样式表编辑器,输入以下代码: QPushButton { background-color: #FF0000; } 其,#FF0000是十六进制的颜色代码,表示红色。你可以根据需要修改颜色代码。 3. 点击“应用”按钮,即可看到QPushButton的颜色已经改变了。 注意:如果你想对所有QPushButton都设置相同的颜色,可以将上述代码放在应用程序的全局样式。 ### 回答2: qt可以使用QSS(Qt Style Sheets)来设置QPushbutton的颜色。QSS是基于CSS语法的Qt界面风格表,它允许一个程序员通过CSS样式QT界面进行美化。 1.设置按钮颜色 如果要设置QPushbutton的背景颜色和前景颜色,可以使用QSS样式表来实现。例如,以下代码将QPushbutton设置为红色背景、白色前景: ```python QPushButton { background-color: red; color: white; } ``` 您可以将这些代码添加到您的qt应用程序,然后使用样式表将QtObject设置为QPushButton类。或者,如果您要设置QPushbutton特定的ID颜色,那么您可以添加以下代码开头: ```python # myButton: QPushButton { background-color: red; color: white; } ``` 这会将具有myButton ID的所有QPushbutton设置为红色背景、白色前景。 2.悬停更改按钮颜色 有,您可能想更新QPushbutton的背景颜色和前景颜色,以便在悬停进行更改。这可以通过以下代码来实现: ```python QPushButton:hover { background-color: green; color: blue; } ``` 当用户将鼠标悬停在QPushbutton上,此代码将使用绿色背景、蓝色前景更新控件。 3.按下更改按钮颜色 最后,您可能需要通过更改用户按下QPushbutton的背景颜色和前景颜色,使UI更加互动。这可以通过以下代码来实现: ```python QPushButton:pressed { background-color: orange; color: black; } ``` 当用户按下QPushbutton,此代码将使用橙色背景、黑色前景更新控件。 总结: 以上是设置QPushbutton按钮颜色的方法,通过QSS样式表可以在QT方便地进行定制。您可以使用这些方法来创建令人愉悦的用户体验,同使您的UI更加互动。 ### 回答3: 在Qt,QPushButton是最常用的控件之一,它允许用户在界面上进行交互,并触发事件。设置QPushButton的颜色可以使界面更加美观和个性化。下面我们来看一下如何在Qt设置QPushButton的颜色。 在Qt,通常有两种方法可以设置QPushButton的背景颜色:使用CSS和使用QPalette。 使用CSS设置QPushButton的颜色: 1.在Qt Creator,打开界面设计器。从界面构建工具箱将QPushButton拖入界面图形视图。 2.选QPushButton。在属性编辑器的下拉菜单选择StyleSheet,然后单击右侧的小箭头。这将打开CSS编辑器。 3.在CSS编辑器,可以使用CSS语法设置QPushButton的样式。例如,可以使用background-color属性设置背景颜色。以下是设置背景颜色为红色的样例代码: QPushButton { background-color: red } 4.单击“确定”以保存CSS样式并关闭CSS编辑器。此,界面设计器的QPushButton将呈现出红色背景色。 使用QPalette设置QPushButton的颜色: 1.在Qt Creator,打开界面设计器。从界面构建工具箱将QPushButton拖入界面图形视图。 2.选QPushButton。在属性编辑器,展开palette属性组并单击编辑按钮。这将打开QPalette编辑器。 3.在QPalette编辑器,可以设置QPushButton使用的颜色组合。例如,可以设置背景颜色为红色。以下是设置背景色为红色的样例代码: palette.setColor(QPalette::Button, QColor(Qt::red)); 4.单击“确定”以保存QPalette并关闭QPalette编辑器。此,界面设计器的QPushButton将呈现出红色背景色。 总之,无论是使用CSS还是QPalette,都可以轻松地设置QPushButton的颜色,从而使界面更加个性化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值