這個垂直的tabWidge如何 給文字方向弄水平了呢
通過網上搜集資料,目前瞭解有以下3種解決方案:
1.通過自定義派生一個QTabwidget類,然後在自定義myQTabWidget類中對於文字等 進行重繪。
不過本人爲新手菜鳥,對重繪文本這塊不是很懂,還請大俠指點。
2.對於QT原生的QTabwidget類進行QProxyStyle風格設置,具體看以下的代碼,
該方法能夠實現文字方向水平了,可是給之前通過QSS設置的背景顏色等沖掉了,現在無法設置背景,不知道如何在此基礎上重新設置背景,還請了解的大俠指點迷津。
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控件應用上面的樣式:
1
|
ui.myTabWidget->setStyle( new CustomTabStyle); |