当前位置:   article > 正文

QTabWidget设置为垂直方向时 文本如何设置为水平方向_qt tabwidget文字垂直显示

qt tabwidget文字垂直显示

这个垂直的tabWidge如何 给文字方向弄水平了呢 
通过网上搜集资料,目前了解有以下3种解决方案:
1.通过自定义派生一个QTabwidget类,然后在自定义myQTabWidget类中对于文字等 进行重绘。
   不过本人为新手菜鸟,对重绘文本这块不是很懂,还请大侠指点。

2.对于QT原生的QTabwidget类进行QProxyStyle风格设置,具体看以下的代码,
  该方法能够实现文字方向水平了,可是给之前通过QSS设置的背景颜色等冲掉了,现在无法设置背景,不知道如何在此基础上重新设置背景,还请了解的大侠指点迷津。

C/C++ code ?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#include <QtGui>
 
class  CustomTabStyle :  public  QProxyStyle
{
public :
     QSize sizeFromContents(ContentsType type,  const  QStyleOption *option,
         const  QSize &size,  const  QWidget *widget)  const
     {
         QSize s = QProxyStyle::sizeFromContents(type, option, size, widget);
         if  (type == QStyle::CT_TabBarTab)
         {    s.transpose();
         s.rwidth()=70;
         s.rheight()=70;
         }
         return  s;
     }
 
     void  drawControl(ControlElement element,  const  QStyleOption *option, QPainter *painter,  const  QWidget *widget)  const
     {
         if  (element == CE_TabBarTabLabel)
         {
             if  ( const  QStyleOptionTab *tab = qstyleoption_cast< const  QStyleOptionTab *>(option))
             {
                 QStyleOptionTab opt(*tab);
                 //opt.shape = QTabBar::RoundedNorth;
                 opt.text = tr( "Hello" );
                 //QIcon icon(":/Resources/icon2.ico");
                 //opt.icon = icon; 
                     opt.palette.setCurrentColorGroup(QPalette::Disabled);
                  opt.state |= QStyle::State_Sunken;
                 QProxyStyle::drawControl(element, &opt, painter, widget);
 
 
                 return ;
             }
         }
         if  (element == CE_TabBarTab)
         {
             painter->drawText(5,8, "1123" );
             //painter->setBackground(QBrush(Qt::red, Qt::SolidPattern));
 
         }
 
         QProxyStyle::drawControl(element, option, painter, widget);
     }
};



然后再给需要设置的QTabWidget控件应用上面的样式:

C/C++ code ?
1
ui.myTabWidget->setStyle( new  CustomTabStyle);

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

闽ICP备14008679号