Qt用.css设置样式代理内不起作用解决方法

参考:https://blog.csdn.net/liang19890820/article/details/50974059#comments
因为代理模型样式默认用原始样式覆盖。
首先主函数使用.css文件覆盖所有样式代码:

int main()
{
	QApplication application(argc,argv);
	QString	qss_file = ":/style/style.css";
	QFile file(qss_file);
	if(file.open(QFile::ReadOnly))
	{
		QString styleSheet = file.readAll();
		application.setStyleSheet(styleSheet);
	}
}

解决方法:
new一个使用代理的所需控件,获取该控件样式,覆盖到代理控件上。
以进度条代理为例:
头文件:

class QProgressBarDelegate : public QStyledItemDelegate
{
	Q_OBJECT
public:
	QProgressBarDelegate (QObject *parent = nullptr);
	~QProgressBarDelegate();

	virtual void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const override;
	virtual bool editorEvent(QEvent *event,QAbstractItemModel *model,const QStyleOptionViewItem &option, const QModelIndex &index) override;

private:
	QScopedPointer<QProgressBar> style_progressBar;	//用来获取原有设定的css样式
};

源文件(需要在构造函数new一下,然后写在paint函数里剩下的略):

QProgressBarDelegate::QProgressBarDelegate (QObject *parent)
	:QStyledItemDelegate(parent)
	,style_progressBar(new QProgressBar())
{
 	// 可以在这里设置样式
 	// 如果用css文件设置了样式就不用在这设置了
    //style_progressBar->setStyleSheet("QProgressBar{border: none; background-color: transparent;} \
    //                             QPushButton:chunk {background-color:rgb(0,255,180);} ");
}
QProgressBarDelegate::~QProgressBarDelegate(){}
void QProgressBarDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
	QStyleOptionProgressBar cpu_bar;
	QWidget * style_widget = style_progressBar.data();
	QApplication::style()->drawControl(QStyle::CE_ProgressBar, &cpu_bar,painter,style_widget);
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奇树谦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值