当前位置:   article > 正文

tabWidget设置文字方向_qt tabwidget样式表设置文字方向

qt tabwidget样式表设置文字方向
  1. class CustomTabStyle : public QProxyStyle//继承QProxyStyle
  2. {
  3. public:
  4. QSize sizeFromContents(ContentsType type, const QStyleOption *option,
  5. const QSize &size, const QWidget *widget) const
  6. {
  7. QSize tabsize = QProxyStyle::sizeFromContents(type, option, size, widget);
  8. if (type == QStyle::CT_TabBarTab) {
  9. tabsize.transpose();
  10. tabsize.rwidth() = 90; // 设置每个tabBar中item的大小
  11. tabsize.rheight() = 44;//设置高度
  12. }
  13. return tabsize;
  14. }
  15. //重写函数drawControl,绘图控制
  16. //ControlElement控制元件,option,QStyle选项,painter绘图,widget对象
  17. void drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const
  18. {
  19. if (element == CE_TabBarTabLabel) {//如果元件是TabBarTabLabel
  20. if (const QStyleOptionTab *tab = qstyleoption_cast<const QStyleOptionTab *>(option)) {
  21. QRect allRect = tab->rect;//获取tab矩形框
  22. if (tab->state & QStyle::State_Selected) {
  23. painter->save();
  24. painter->setPen(0x89cfff);//设置颜色
  25. painter->setBrush(QBrush(0x89cfff));//设置Brush颜色
  26. painter->drawRect(allRect.adjusted(6, 6, 6, -6));//这里调整高亮
  27. // painter->restore();//恢复
  28. }
  29. QTextOption option;//这里设置文本样式
  30. option.setAlignment(Qt::AlignCenter);//设置对其方式。居中对齐
  31. if (tab->state & QStyle::State_Selected) {
  32. painter->setPen(0xf8fcff);//设置颜色
  33. }
  34. else {
  35. painter->setPen(0x5d5d5d);
  36. }
  37. painter->drawText(allRect, tab->text, option);//绘制文本
  38. return;
  39. }
  40. }
  41. if (element == CE_TabBarTab) {
  42. QProxyStyle::drawControl(element, option, painter, widget);
  43. }
  44. }
  45. };

下面:使用即可

QTabBar *tab=ui->tabWidget->tabBar();

    tab->setStyle(new CustomTabStyle);//设置样式




声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/码创造者/article/detail/861876
推荐阅读
相关标签
  

闽ICP备14008679号