赞
踩
- class CustomTabStyle : public QProxyStyle//继承QProxyStyle
- {
- public:
- QSize sizeFromContents(ContentsType type, const QStyleOption *option,
- const QSize &size, const QWidget *widget) const
- {
- QSize tabsize = QProxyStyle::sizeFromContents(type, option, size, widget);
- if (type == QStyle::CT_TabBarTab) {
- tabsize.transpose();
- tabsize.rwidth() = 90; // 设置每个tabBar中item的大小
- tabsize.rheight() = 44;//设置高度
- }
- return tabsize;
- }
- //重写函数drawControl,绘图控制
- //ControlElement控制元件,option,QStyle选项,painter绘图,widget对象
- void drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const
- {
- if (element == CE_TabBarTabLabel) {//如果元件是TabBarTabLabel
- if (const QStyleOptionTab *tab = qstyleoption_cast<const QStyleOptionTab *>(option)) {
- QRect allRect = tab->rect;//获取tab矩形框
- if (tab->state & QStyle::State_Selected) {
- painter->save();
- painter->setPen(0x89cfff);//设置颜色
- painter->setBrush(QBrush(0x89cfff));//设置Brush颜色
- painter->drawRect(allRect.adjusted(6, 6, 6, -6));//这里调整高亮
- // painter->restore();//恢复
- }
- QTextOption option;//这里设置文本样式
- option.setAlignment(Qt::AlignCenter);//设置对其方式。居中对齐
- if (tab->state & QStyle::State_Selected) {
- painter->setPen(0xf8fcff);//设置颜色
- }
- else {
- painter->setPen(0x5d5d5d);
- }
- painter->drawText(allRect, tab->text, option);//绘制文本
- return;
- }
- }
- if (element == CE_TabBarTab) {
- QProxyStyle::drawControl(element, option, painter, widget);
- }
- }
- };

下面:使用即可
QTabBar *tab=ui->tabWidget->tabBar();
tab->setStyle(new CustomTabStyle);//设置样式
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。