1 /****************************************************************************
2 **
3 ** Copyright (C) 2015 The Qt Company Ltd.
4 ** Contact: http://www.qt.io/licensing/
5 **
6 ** This file is part of the QtGui module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see http://www.qt.io/terms-conditions. For further
15 ** information use the contact form at http://www.qt.io/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 2.1 or version 3 as published by the Free
20 ** Software Foundation and appearing in the file LICENSE.LGPLv21 and
21 ** LICENSE.LGPLv3 included in the packaging of this file. Please review the
22 ** following information to ensure the GNU Lesser General Public License
23 ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
24 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
25 **
26 ** As a special exception, The Qt Company gives you certain additional
27 ** rights. These rights are described in The Qt Company LGPL Exception
28 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
29 **
30 ** GNU General Public License Usage
31 ** Alternatively, this file may be used under the terms of the GNU
32 ** General Public License version 3.0 as published by the Free Software
33 ** Foundation and appearing in the file LICENSE.GPL included in the
34 ** packaging of this file.  Please review the following information to
35 ** ensure the GNU General Public License version 3.0 requirements will be
36 ** met: http://www.gnu.org/copyleft/gpl.html.
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41 
42 #include "qwindowscestyle.h"
43 
44 #if !defined(QT_NO_STYLE_WINDOWSCE) || defined(QT_PLUGIN)
45 
46 #include "qpainterpath.h"
47 #include "qapplication.h"
48 #include "qdockwidget.h"
49 #include "qtoolbar.h"
50 #include "qpaintengine.h"
51 #include "qpainter.h"
52 #include "qstyleoption.h"
53 #include "qwindowscestyle_p.h"
54 #include "qdebug.h"
55 
56 QT_BEGIN_NAMESPACE
57 
58 static const int windowsItemFrame        =  2; // menu item frame width
59 static const int windowsItemHMargin      =  3; // menu item hor text margin
60 static const int windowsItemVMargin      =  2; // menu item ver text margin
61 static const int windowsArrowHMargin	 =  6; // arrow horizontal margin
62 static const int windowsRightBorder      = 15; // right border on windows
63 static const int windowsCheckMarkWidth   = 14; // checkmarks width on windows
64 
65 static const int windowsCEitemViewCheckBoxSize   = 14;
66 static const int windowsCEFrameGroupBoxOffset    = 9;
67 static const int windowsCEIndicatorSize          = 14;
68 static const int windowsCEExclusiveIndicatorSize = 14;
69 static const int windowsCESliderThickness        = 24;
70 static const int windowsCEIconSize               = 16;
71 
72 static const QColor windowsCECheckBoxGradientColorBegin = QColor(222, 224, 214);
73 static const QColor windowsCECheckBoxGradientColorEnd   =  QColor(255, 255, 255);
74 
75 enum QSliderDirection { SlUp, SlDown, SlLeft, SlRight };
76 
QWindowsCEStyle()77 QWindowsCEStyle::QWindowsCEStyle() : QWindowsStyle() {
78     qApp->setEffectEnabled(Qt::UI_FadeMenu, false);
79     qApp->setEffectEnabled(Qt::UI_AnimateMenu, false);
80 }
81 
drawPrimitive(PrimitiveElement element,const QStyleOption * option,QPainter * painter,const QWidget * widget) const82 void QWindowsCEStyle::drawPrimitive(PrimitiveElement element, const QStyleOption *option,
83                                     QPainter *painter, const QWidget *widget) const {
84 
85     bool doRestore = false;
86     QRect rect = option->rect;
87 
88     switch (element) {
89     case PE_PanelButtonTool: {
90         if (
91 #ifndef QT_NO_TOOLBAR
92              (widget && qobject_cast<QToolBar*>(widget->parentWidget())) ||
93 #endif
94 #ifndef QT_NO_DOCKWIDGET
95              (widget && widget->inherits("QDockWidgetTitleButton")) ||
96 #endif
97             (option->state & (State_Sunken | State_On)))
98                QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect.adjusted(0, 0, 0, 0),
99                   option->palette, option->state & (State_Sunken | State_On),
100                   &option->palette.button());
101         if (option->state & (State_On)){
102             QBrush fill = QBrush(option->palette.midlight().color(), Qt::Dense4Pattern);
103             painter->fillRect(option->rect.adjusted(windowsItemFrame , windowsItemFrame ,
104                               -windowsItemFrame , -windowsItemFrame ), fill);
105         }
106         break; }
107     case PE_IndicatorButtonDropDown:
108         QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect, option->palette,
109             option->state & (State_Sunken | State_On),
110             &option->palette.brush(QPalette::Button));
111         break;
112 #ifndef QT_NO_TABBAR
113         case PE_IndicatorTabTear:
114         if (const QStyleOptionTab *tab = qstyleoption_cast<const QStyleOptionTab *>(option)) {
115             bool rtl = tab->direction == Qt::RightToLeft;
116             QRect rect = tab->rect;
117             QPainterPath path;
118             rect.setTop(rect.top() + ((tab->state & State_Selected) ? 1 : 3));
119             rect.setBottom(rect.bottom() - ((tab->state & State_Selected) ? 0 : 2));
120             path.moveTo(QPoint(rtl ? rect.right() : rect.left(), rect.top()));
121             int count = 3;
122             for(int jags = 1; jags <= count; ++jags, rtl = !rtl)
123                 path.lineTo(QPoint(rtl ? rect.left() : rect.right(), rect.top() + jags * rect.height()/count));
124 
125             painter->setPen(QPen(tab->palette.light(), qreal(.8)));
126             painter->setBrush(tab->palette.background());
127             painter->setRenderHint(QPainter::Antialiasing);
128             painter->drawPath(path);
129         }
130         break;
131 #endif //QT_NO_TABBAR
132 #ifndef QT_NO_TOOLBAR
133         case PE_IndicatorToolBarSeparator:
134             //nothing to draw on WindowsCE
135             break;
136         case PE_IndicatorToolBarHandle:
137             painter->save();
138             painter->translate(option->rect.x(), option->rect.y());
139             if (option->state & State_Horizontal) {
140                 int x = option->rect.width() / 2 - 4;
141                 if (QApplication::layoutDirection() == Qt::RightToLeft)
142                     x -= 2;
143                 if (option->rect.height() > 4) {
144                     QWindowsCEStylePrivate::drawWinCEButton(painter,x - 1, 0, 7, option->rect.height(),
145                         option->palette, false,  0);
146                     QWindowsCEStylePrivate::drawWinCEPanel(painter, x, 1, 3, option->rect.height() - 1,
147                         option->palette, false, 0);
148                     QWindowsCEStylePrivate::drawWinCEPanel(painter, x + 3, 1, 3, option->rect.height() - 1,
149                         option->palette, false, 0);
150                     painter->setPen(option->palette.button().color());
151                     painter->drawLine(x + 4, 2, x + 4,option->rect.height() - 2);
152                 }
153             } else {
154                 if (option->rect.width() > 4) {
155                     int y = option->rect.height() / 2 - 4;
156                     QWindowsCEStylePrivate::drawWinCEPanel(painter, 2, y, option->rect.width() - 2, 3,
157                         option->palette, false,  0);
158                     QWindowsCEStylePrivate::drawWinCEPanel(painter, 2, y + 3, option->rect.width() - 2, 3,
159                         option->palette, false,  0);
160                 }
161             }
162             painter->restore();
163             break;
164 
165 #endif // QT_NO_TOOLBAR
166         case PE_FrameButtonTool: {
167 #ifndef QT_NO_DOCKWIDGET
168             if (widget && widget->inherits("QDockWidgetTitleButton")) {
169                 if (const QDockWidget *dw = qobject_cast<const QDockWidget *>(widget->parent()))
170                     if (dw->isFloating()){
171                         QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect.adjusted(1, 1, 0, 0),
172                                                                 option->palette, option->state & (State_Sunken | State_On),
173                             &option->palette.button());
174                         return;
175                     }
176             }
177 #endif // QT_NO_DOCKWIDGET
178         QBrush fill;
179         bool stippled;
180         bool panel = (element == PE_PanelButtonTool);
181         if ((!(option->state & State_Sunken ))
182             && (!(option->state & State_Enabled)
183             || ((option->state & State_Enabled ) && !(option->state & State_MouseOver)))
184             && (option->state & State_On)) {
185                 fill = QBrush(option->palette.light().color(), Qt::Dense4Pattern);
186                 stippled = true;
187         } else {
188             fill = option->palette.brush(QPalette::Button);
189             stippled = false;
190         }
191         if (option->state & (State_Raised | State_Sunken | State_On)) {
192             if (option->state & State_AutoRaise) {
193                 if(option->state & (State_Enabled | State_Sunken | State_On)){
194                     if (panel)
195                         QWindowsCEStylePrivate::drawWinCEPanel(painter, option->rect, option->palette,
196                         option->state & (State_Sunken | State_On), &fill);
197                     else
198                         qDrawShadeRect(painter, option->rect, option->palette,
199                         option->state & (State_Sunken | State_On), 1);
200                 }
201                 if (stippled) {
202                     painter->setPen(option->palette.button().color());
203                     painter->drawRect(option->rect.adjusted(1, 1, -2, -2));
204                 }
205             } else {
206                 QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect, option->palette,
207                     option->state & (State_Sunken | State_On), panel ? &fill : 0);
208             }
209         } else {
210             painter->fillRect(option->rect, fill);
211         }
212         break; }
213 
214     case PE_PanelButtonBevel: {
215         QBrush fill;
216         bool panel = element != PE_FrameButtonBevel;
217         painter->setBrushOrigin(option->rect.topLeft());
218         if (!(option->state & State_Sunken) && (option->state & State_On))
219             fill = QBrush(option->palette.light().color(), Qt::Dense4Pattern);
220         else
221             fill = option->palette.brush(QPalette::Button);
222 
223         if (option->state & (State_Raised | State_On | State_Sunken)) {
224             QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect, option->palette,
225                                                     option->state & (State_Sunken | State_On),
226                 panel ? &fill : 0); ;
227         } else {
228             if (panel)
229                 painter->fillRect(option->rect, fill);
230             else
231                 painter->drawRect(option->rect);
232         }
233         break; }
234 
235     case PE_FrameGroupBox:
236         if (const QStyleOptionFrame *frame = qstyleoption_cast<const QStyleOptionFrame *>(option)) {
237             QRect fr = frame->rect;
238             painter->setPen(frame->palette.shadow().color());
239             painter->drawRect(fr.x(), fr.y(), fr.x() + fr.width() - 1,
240                               fr.y() + fr.height() - windowsCEFrameGroupBoxOffset);
241         }
242         break;
243 
244    case PE_IndicatorCheckBox: {
245         QBrush fill;
246         if (option->state & State_NoChange)
247             fill = QBrush(option->palette.base().color(), Qt::Dense4Pattern);
248         else if (option->state & State_Sunken)
249             fill = option->palette.button();
250         else if (option->state & State_Enabled)
251             fill = option->palette.base();
252         else
253             fill = option->palette.background();
254         painter->save();
255         doRestore = true;
256         painter->fillRect(option->rect,fill);
257         painter->setPen(option->palette.dark().color());
258         painter->drawRect(option->rect);
259         painter->setPen(option->palette.shadow().color());
260         painter->drawLine(option->rect.x() + 1,option->rect.y() + 1,
261                           option->rect.x() + option->rect.width() - 1, option->rect.y() + 1);
262         painter->drawLine(option->rect.x() + 1,option->rect.y() + 1,
263                           option->rect.x() + 1, option->rect.y() + option->rect.height() - 1);
264         //fall through...
265     }
266     case PE_IndicatorViewItemCheck:
267     case PE_Q3CheckListIndicator: {
268         if (!doRestore) {
269             painter->save();
270             doRestore = true;
271         }
272         int arrowSize= 2;
273         if (element == PE_Q3CheckListIndicator || element == PE_IndicatorViewItemCheck) {
274             QLinearGradient linearGradient(QPoint(option->rect.x(),option->rect.y()), QPoint(option->rect.x()+option->rect.width(),
275                                            option->rect.y()+option->rect.height()));
276             linearGradient.setColorAt(0, windowsCECheckBoxGradientColorBegin);
277             linearGradient.setColorAt(1, windowsCECheckBoxGradientColorEnd);
278             painter->setBrush(linearGradient);
279             painter->setPen(Qt::NoPen);
280             if (option->state & State_NoChange)
281                 painter->setBrush(option->palette.brush(QPalette::Button));
282             painter->setPen(option->palette.link().color());
283             painter->drawRect(option->rect.x(), option->rect.y(), windowsCEitemViewCheckBoxSize, windowsCEitemViewCheckBoxSize);
284             painter->setPen(option->palette.brightText().color());
285             arrowSize= 3;
286         }
287         if (!(option->state & State_Off)) {
288             QLineF lines[9];
289             int i, xx, yy;
290             xx = option->rect.x() + 4;
291             yy = option->rect.y() + 6;
292             for (i = 0; i < 4; ++i) {
293                 lines[i] = QLineF(xx, yy, xx, yy + arrowSize);
294                 ++xx;
295                 ++yy;
296             }
297             yy -= 2;
298             for (i = 4; i < 9; ++i) {
299                 lines[i] = QLineF(xx, yy, xx, yy + arrowSize);
300                 ++xx;
301                 --yy;
302             }
303             painter->drawLines(lines, 9);
304         }
305         if (doRestore)
306             painter->restore();
307 
308         break; }
309     case PE_IndicatorRadioButton: {
310         QRect ir = option->rect;
311         painter->save();
312         painter->setPen(Qt::NoPen);
313         painter->setBrush(option->palette.light());
314         painter->drawEllipse(option->rect);
315         painter->setPen(option->palette.shadow().color());
316         painter->setBrush(option->palette.shadow().color());
317         painter->drawArc(option->rect, 0, 360 * 16);
318         painter->drawArc(option->rect.x() + 1, option->rect.y() + 1, option->rect.width() - 2,
319                          option->rect.height() - 2, 40 * 16, 180 * 16);
320         painter->setPen(option->palette.light().color());
321         painter->drawPoint(option->rect.x() + 11, option->rect.y() + 3);
322         painter->drawPoint(option->rect.x() + 3,option->rect.y() + 3);
323         painter->setPen(option->palette.shadow().color());
324         painter->drawPoint(option->rect.x() +3,option->rect.y() + 12);
325         if (option->state & (State_Sunken | State_On)) {
326             painter->setPen(Qt::NoPen);
327             painter->setBrush(option->palette.text());
328             painter->drawEllipse(option->rect.x() +3,option->rect.y()+ 2,9,10);
329         }
330         painter->restore();
331         break; }
332    case PE_PanelMenuBar:
333        painter->save();
334        painter->setPen(option->palette.shadow().color());
335        painter->drawRect(option->rect);
336        painter->restore();
337        break;
338    case PE_PanelButtonCommand:
339        if (const QStyleOptionButton *btn = qstyleoption_cast<const QStyleOptionButton *>(option)) {
340            QBrush fill;
341            State flags = option->state;
342            QPalette pal = option->palette;
343            QRect r = option->rect;
344            if (! (flags & State_Sunken) && (flags & State_On))
345                fill = QBrush(pal.light().color(), Qt::Dense4Pattern);
346            else
347                fill = pal.brush(QPalette::Button);
348            if (btn->features & QStyleOptionButton::DefaultButton && flags & State_Sunken) {
349                painter->setPen(pal.dark().color());
350                painter->setBrush(fill);
351                painter->drawRect(r.adjusted(0, 0, -1, -1));
352            } else if (flags & (State_Raised | State_Sunken | State_On | State_Sunken)) {
353                QWindowsCEStylePrivate::drawWinCEButton(painter, r, pal, flags & (State_Sunken | State_On),
354                    &fill);
355            } else {
356                painter->fillRect(r, fill);
357            }
358 
359        }
360        break;
361    case PE_FrameDefaultButton: {
362        painter->setPen(option->palette.shadow().color());
363        QRect rect = option->rect;
364        rect.adjust(0, 0, -1, -1);
365        painter->drawRect(rect);
366        break; }
367    case PE_IndicatorSpinPlus:
368    case PE_IndicatorSpinMinus: {
369        QRect r = option->rect;
370        int fw = pixelMetric(PM_DefaultFrameWidth, option, widget)+2;
371        QRect br = r.adjusted(fw, fw, -fw, -fw);
372        int offset = (option->state & State_Sunken) ? 1 : 0;
373        int step = (br.width() + 4) / 5;
374        painter->fillRect(br.x() + offset, br.y() + offset +br.height() / 2 - step / 2,
375            br.width(), step,
376            option->palette.buttonText());
377        if (element == PE_IndicatorSpinPlus)
378            painter->fillRect(br.x() + br.width() / 2 - step / 2 + offset, br.y() + offset+4,
379            step, br.height()-7,
380            option->palette.buttonText());
381        break; }
382     case PE_IndicatorSpinUp:
383     case PE_IndicatorSpinDown: {
384         painter->save();
385             QPoint points[7];
386             switch (element) {
387                 case PE_IndicatorSpinUp:
388                     points[0] = QPoint(-2, -4);
389                     points[1] = QPoint(-2, 2);
390                     points[2] = QPoint(-1, -3);
391                     points[3] = QPoint(-1, 1);
392                     points[4] = QPoint(0, -2);
393                     points[5] = QPoint(0, 0);
394                     points[6] = QPoint(1, -1);
395                 break;
396                 case PE_IndicatorSpinDown:
397                     points[0] = QPoint(0, -4);
398                     points[1] = QPoint(0, 2);
399                     points[2] = QPoint(-1, -3);
400                     points[3] = QPoint(-1, 1);
401                     points[4] = QPoint(-2, -2);
402                     points[5] = QPoint(-2, 0);
403                     points[6] = QPoint(-3, -1);
404                 break;
405                 default:
406                 break;
407             }
408             if (option->state & State_Sunken)
409                 painter->translate(pixelMetric(PM_ButtonShiftHorizontal),
410                 pixelMetric(PM_ButtonShiftVertical));
411             if (option->state & State_Enabled) {
412                 painter->translate(option->rect.x() + option->rect.width() / 2,
413                                    option->rect.y() + option->rect.height() / 2);
414                 painter->setPen(option->palette.buttonText().color());
415                 painter->drawLine(points[0], points[1]);
416                 painter->drawLine(points[2], points[3]);
417                 painter->drawLine(points[4], points[5]);
418                 painter->drawPoint(points[6]);
419             } else {
420                 painter->translate(option->rect.x() + option->rect.width() / 2 + 1,
421                                    option->rect.y() + option->rect.height() / 2 + 1);
422                 painter->setPen(option->palette.light().color());
423                 painter->drawLine(points[0], points[1]);
424                 painter->drawLine(points[2], points[3]);
425                 painter->drawLine(points[4], points[5]);
426                 painter->drawPoint(points[6]);
427                 painter->translate(-1, -1);
428                 painter->setPen(option->palette.mid().color());
429                 painter->drawLine(points[0], points[1]);
430                 painter->drawLine(points[2], points[3]);
431                 painter->drawLine(points[4], points[5]);
432                 painter->drawPoint(points[6]);
433             }
434 
435         painter->restore();
436         break; }
437     case PE_IndicatorArrowUp:
438     case PE_IndicatorArrowDown:
439     case PE_IndicatorArrowRight:
440     case PE_IndicatorArrowLeft: {
441             painter->save();
442             QPoint points[9];
443             switch (element) {
444                 case PE_IndicatorArrowUp:
445 
446                     points[0] = QPoint(-4, 2);
447                     points[1] = QPoint(4, 2);
448                     points[2] = QPoint(-3, 1);
449                     points[3] = QPoint(3, 1);
450                     points[4] = QPoint(-2, 0);
451                     points[5] = QPoint(2, 0);
452                     points[6] = QPoint(-1, -1);
453                     points[7] = QPoint(1, -1);
454                     points[8] = QPoint(0, -2);
455                 break;
456                 case PE_IndicatorArrowDown:
457 
458                     points[0] = QPoint(-4, -2);
459                     points[1] = QPoint(4, -2);
460                     points[2] = QPoint(-3, -1);
461                     points[3] = QPoint(3, -1);
462                     points[4] = QPoint(-2, 0);
463                     points[5] = QPoint(2, 0);
464                     points[6] = QPoint(-1, 1);
465                     points[7] = QPoint(1, 1);
466                     points[8] = QPoint(0, 2);
467                 break;
468                 case PE_IndicatorArrowRight:
469                     points[0] = QPoint(-3, -4);
470                     points[1] = QPoint(-3, 4);
471                     points[2] = QPoint(-2, -3);
472                     points[3] = QPoint(-2, 3);
473                     points[4] = QPoint(-1, -2);
474                     points[5] = QPoint(-1, 2);
475                     points[6] = QPoint(0, -1);
476                     points[7] = QPoint(0, 1);
477                     points[8] = QPoint(1, 0);
478                 break;
479                 case PE_IndicatorArrowLeft:
480                     points[0] = QPoint(1, -4);
481                     points[1] = QPoint(1, 4);
482                     points[2] = QPoint(0, -3);
483                     points[3] = QPoint(0, 3);
484                     points[4] = QPoint(-1, -2);
485                     points[5] = QPoint(-1, 2);
486                     points[6] = QPoint(-2, -1);
487                     points[7] = QPoint(-2, 1);
488                     points[8] = QPoint(-3, 0);
489                 break;
490                 default:
491                 break;
492             }
493             if (option->state & State_Sunken)
494                 painter->translate(pixelMetric(PM_ButtonShiftHorizontal),
495                 pixelMetric(PM_ButtonShiftVertical));
496             if (option->state & State_Enabled) {
497                 painter->translate(option->rect.x() + option->rect.width() / 2,
498                     option->rect.y() + option->rect.height() / 2);
499                 painter->setPen(option->palette.buttonText().color());
500                 painter->drawLine(points[0], points[1]);
501                 painter->drawLine(points[2], points[3]);
502                 painter->drawLine(points[4], points[5]);
503                 painter->drawLine(points[6], points[7]);
504                 painter->drawPoint(points[8]);
505             } else {
506                 painter->translate(option->rect.x() + option->rect.width() / 2 + 1,
507                     option->rect.y() + option->rect.height() / 2 + 1);
508                 painter->setPen(option->palette.light().color());
509                 painter->drawLine(points[0], points[1]);
510                 painter->drawLine(points[2], points[3]);
511                 painter->drawLine(points[4], points[5]);
512                 painter->drawLine(points[6], points[7]);
513                 painter->drawPoint(points[8]);
514                 painter->translate(-1, -1);
515                 painter->setPen(option->palette.mid().color());
516                 painter->drawLine(points[0], points[1]);
517                 painter->drawLine(points[2], points[3]);
518                 painter->drawLine(points[4], points[5]);
519                 painter->drawLine(points[6], points[7]);
520                 painter->drawPoint(points[8]);
521             }
522         painter->restore();
523         break; }
524 
525     case PE_FrameWindow: {
526         QPalette popupPal = option->palette;
527         popupPal.setColor(QPalette::Light, option->palette.background().color());
528         popupPal.setColor(QPalette::Midlight, option->palette.light().color());
529         QWindowsCEStylePrivate::drawWinCEPanel(painter, option->rect, popupPal, option->state & State_Sunken);
530         break; }
531 
532     case PE_Frame:
533     case PE_FrameMenu:
534         if (const QStyleOptionFrame *frame = qstyleoption_cast<const QStyleOptionFrame *>(option)) {
535             QPalette popupPal = frame->palette;
536             QRect r = frame->rect;
537             qDrawPlainRect(painter, r, frame->palette.shadow().color(),1);
538         }
539         break;
540     case PE_FrameStatusBar:
541         QWindowsCEStylePrivate::drawWinCEPanel(painter, option->rect, option->palette, true, 0);
542         break;
543 
544     case PE_FrameTabWidget: {
545         QRect rect = option->rect;
546         QPalette pal = option->palette;
547         QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect, option->palette, false, 0);
548         break; }
549     default:
550         QWindowsStyle::drawPrimitive(element, option, painter, widget);
551         break;
552     }
553 }
554 
drawControl(ControlElement element,const QStyleOption * option,QPainter * painter,const QWidget * widget) const555 void QWindowsCEStyle::drawControl(ControlElement element, const QStyleOption *option,
556                                   QPainter *painter, const QWidget *widget) const {
557    switch (element) {
558    #ifndef QT_NO_MENU
559    case CE_MenuTearoff: {
560         if(option->state & State_Selected) {
561             if(pixelMetric(PM_MenuPanelWidth, option, widget) > 1)
562                 qDrawShadePanel(painter, option->rect.x(), option->rect.y(), option->rect.width(),
563                                 option->rect.height(), option->palette, false, 2,
564                                 &option->palette.brush(QPalette::Button));
565             else
566                 qDrawShadePanel(painter, option->rect.x() + 1, option->rect.y() + 1, option->rect.width() - 2,
567                                 option->rect.height() - 2, option->palette, true, 1, &option->palette.brush(QPalette::Button));
568         } else {
569             painter->fillRect(option->rect, option->palette.brush(QPalette::Button));
570         }
571         painter->setPen(QPen(option->palette.dark().color(), 1, Qt::DashLine));
572         painter->drawLine(option->rect.x()+2, option->rect.y()+option->rect.height()/2-1, option->rect.x()+option->rect.width()-4,
573                     option->rect.y()+option->rect.height()/2-1);
574         painter->setPen(QPen(option->palette.light().color(), 1, Qt::DashLine));
575         painter->drawLine(option->rect.x()+2, option->rect.y()+option->rect.height()/2, option->rect.x()+option->rect.width()-4,
576                     option->rect.y()+option->rect.height()/2);
577         break; }
578 
579 
580    case CE_MenuBarItem:
581         if (const QStyleOptionMenuItem *mbi = qstyleoption_cast<const QStyleOptionMenuItem *>(option)) {
582             bool active = mbi->state & State_Selected;
583             bool hasFocus = mbi->state & State_HasFocus;
584             bool down = mbi->state & State_Sunken;
585             QStyleOptionMenuItem newMbi = *mbi;
586             if (active || hasFocus) {
587                 QBrush b = mbi->palette.brush(QPalette::Highlight);
588                 if (active && down) {
589                     painter->fillRect(mbi->rect.adjusted(0, 1, 0, -1), b);
590                 }
591             }
592             uint alignment = Qt::AlignCenter | Qt::TextShowMnemonic | Qt::TextDontClip
593                             | Qt::TextSingleLine;
594             if (!styleHint(SH_UnderlineShortcut, mbi, widget))
595                 alignment |= Qt::TextHideMnemonic;
596 
597             painter->save();
598             QFont f = painter->font();
599             f.setBold(true);
600             painter->setFont(f);
601             QPixmap pix = mbi->icon.pixmap(pixelMetric(PM_SmallIconSize),
602                                           (mbi->state & State_Enabled) ? QIcon::Normal : QIcon::Disabled);
603             if (!pix.isNull())
604                 drawItemPixmap(painter,mbi->rect, alignment, pix);
605             else
606                 if (active && down)
607                   drawItemText(painter, mbi->rect, alignment, mbi->palette, mbi->state & State_Enabled,
608                              mbi->text, QPalette::Light);
609                 else
610                   drawItemText(painter, mbi->rect, alignment, mbi->palette, mbi->state & State_Enabled,
611                              mbi->text, QPalette::ButtonText);
612             painter->restore();
613         }
614         break;
615 
616    case CE_MenuBarEmptyArea:
617         painter->save();
618         painter->setPen(option->palette.shadow().color());
619         if (widget && !widget->testAttribute(Qt::WA_NoSystemBackground)) {
620             painter->eraseRect(option->rect);
621             QRect r = option->rect;
622             painter->drawLine(r.x() + 1, r.y() + 1, r.x()+ 1, r.y()+ r.height() - 2);
623             painter->drawLine(r.x() - 2 + r.width(), r.y()  + 1, r.x() - 2 + r.width(), r.y() + r.height() - 2);
624             painter->drawLine(r.x() + 1, r.y() +1, r.x() - 1 + r.width(), r.y() + 1);
625             painter->drawLine(r.x() + 1, r.y() + r.height()-2 , r.x() - 2 + r.width(), r.y() + r.height() - 2);
626         }
627         painter->restore();
628         break;
629 
630     case CE_MenuItem:
631           if (const QStyleOptionMenuItem *menuitem = qstyleoption_cast<const QStyleOptionMenuItem *>(option)) {
632             int x, y, w, h;
633             menuitem->rect.getRect(&x, &y, &w, &h);
634             int tab = menuitem->tabWidth;
635             bool dis = !(menuitem->state & State_Enabled);
636             bool checked = menuitem->checkType != QStyleOptionMenuItem::NotCheckable
637                             ? menuitem->checked : false;
638             bool act = menuitem->state & State_Selected;
639 
640             // windows always has a check column, regardless whether we have an icon or not
641             int checkcol = qMax(menuitem->maxIconWidth, windowsCheckMarkWidth);
642             QBrush fill = menuitem->palette.brush(act ? QPalette::Highlight : QPalette::Button);
643             painter->fillRect(menuitem->rect.adjusted(1, 1, 0, 0), fill);
644 
645             if (menuitem->menuItemType == QStyleOptionMenuItem::Separator) {
646                 int yoff = y-1 + h / 2;
647                 painter->setPen(menuitem->palette.shadow().color());
648                 painter->drawLine(x + 4, yoff + 1, x + w - 8, yoff + 1);
649                 return;
650             }
651 
652             QRect vCheckRect = visualRect(option->direction, menuitem->rect, QRect(menuitem->rect.x(),
653                                           menuitem->rect.y(), checkcol, menuitem->rect.height()));
654             if (checked) {
655                 if (act && !dis) {
656                     qDrawPlainRect(painter, vCheckRect,
657                         menuitem->palette.button().color(), 1,
658                                     &menuitem->palette.brush(QPalette::Button));
659                 } else {
660                     QBrush fill(menuitem->palette.button().color(), Qt::Dense4Pattern);
661                     qDrawPlainRect(painter, vCheckRect,menuitem->palette.button().color(), 1, &fill);
662                 }
663             } else if (!act) {
664                 painter->fillRect(vCheckRect, menuitem->palette.brush(QPalette::Button));
665             }
666             // On Windows Style, if we have a checkable item and an icon we
667             // draw the icon recessed to indicate an item is checked. If we
668             // have no icon, we draw a checkmark instead.
669             if (!menuitem->icon.isNull()) {
670                 QIcon::Mode mode = dis ? QIcon::Disabled : QIcon::Normal;
671                 if (act && !dis)
672                     mode = QIcon::Active;
673                 QPixmap pixmap;
674                 if (checked)
675                     pixmap = menuitem->icon.pixmap(pixelMetric(PM_SmallIconSize), mode, QIcon::On);
676                 else
677                     pixmap = menuitem->icon.pixmap(pixelMetric(PM_SmallIconSize), mode);
678                 int pixw = pixmap.width();
679                 int pixh = pixmap.height();
680                 if (act && !dis && !checked)
681                     qDrawPlainRect(painter, vCheckRect,  menuitem->palette.button().color(), 1,
682                                     &menuitem->palette.brush(QPalette::Button));
683                 QRect pmr(0, 0, pixw, pixh);
684                 pmr.moveCenter(vCheckRect.center());
685                 painter->setPen(menuitem->palette.text().color());
686                 painter->drawPixmap(pmr.topLeft(), pixmap);
687             } else if (checked) {
688                 QStyleOptionMenuItem newMi = *menuitem;
689                 newMi.state = State_None;
690                 if (!dis)
691                     newMi.state |= State_Enabled;
692                 if (act)
693                     newMi.state |= State_On;
694                 newMi.rect = visualRect(option->direction, menuitem->rect, QRect(menuitem->rect.x()
695                            + windowsItemFrame, menuitem->rect.y() + windowsItemFrame,
696                              checkcol - 2 * windowsItemFrame, menuitem->rect.height() - 2*windowsItemFrame));
697                 drawPrimitive(PE_IndicatorMenuCheckMark, &newMi, painter, widget);
698             }
699             painter->setPen(act ? menuitem->palette.highlightedText().color() : menuitem->palette.buttonText().color());
700 
701             QColor discol;
702             if (dis) {
703                 discol = menuitem->palette.text().color();
704                 painter->setPen(discol);
705             }
706             int xm = windowsItemFrame + checkcol + windowsItemHMargin;
707             int xpos = menuitem->rect.x() + xm;
708             QRect textRect(xpos, y + windowsItemVMargin, w - xm - windowsRightBorder - tab + 1, h - 2 * windowsItemVMargin);
709             QRect vTextRect = visualRect(option->direction, menuitem->rect, textRect);
710             QString s = menuitem->text;
711             if (!s.isEmpty()) {                     // draw text
712                 painter->save();
713                 int t = s.indexOf(QLatin1Char('\t'));
714                 int text_flags = Qt::AlignVCenter | Qt::TextShowMnemonic | Qt::TextDontClip | Qt::TextSingleLine;
715                 if (!styleHint(SH_UnderlineShortcut, menuitem, widget))
716                     text_flags |= Qt::TextHideMnemonic;
717                 text_flags |= Qt::AlignLeft;
718                 if (t >= 0) {
719                     QRect vShortcutRect = visualRect(option->direction, menuitem->rect,
720                         QRect(textRect.topRight(), QPoint(menuitem->rect.right(), textRect.bottom())));
721                     if (dis && !act)
722                         painter->setPen(discol);
723                     painter->drawText(vShortcutRect, text_flags, s.mid(t + 1));
724                     s = s.left(t);
725                 }
726                 QFont font = menuitem->font;
727                 if (menuitem->menuItemType == QStyleOptionMenuItem::DefaultItem)
728                     font.setBold(true);
729                 painter->setFont(font);
730                 if (dis && !act)
731                     painter->setPen(discol);
732                 painter->drawText(vTextRect, text_flags, s.left(t));
733                 painter->restore();
734             }
735             if (menuitem->menuItemType == QStyleOptionMenuItem::SubMenu) {// draw sub menu arrow
736                 int dim = (h - 2 * windowsItemFrame) / 2;
737                 PrimitiveElement arrow;
738                 arrow = (option->direction == Qt::RightToLeft) ? PE_IndicatorSpinDown : PE_IndicatorSpinUp;
739                 xpos = x + w - windowsArrowHMargin - windowsItemFrame - dim;
740                 QRect  vSubMenuRect = visualRect(option->direction, menuitem->rect, QRect(xpos, y + h / 2 - dim / 2, dim, dim));
741                 QStyleOptionMenuItem newMI = *menuitem;
742                 newMI.rect = vSubMenuRect;
743                 newMI.state = dis ? State_None : State_Enabled;
744                 if (act)
745                     newMI.palette.setColor(QPalette::ButtonText,
746                                            newMI.palette.highlightedText().color());
747                 drawPrimitive(arrow, &newMI, painter, widget);
748             }
749         }
750         break;
751 #endif // QT_NO_MENU
752     case CE_MenuVMargin:
753         painter->fillRect(option->rect, Qt::white);
754         break;
755     case CE_MenuEmptyArea:
756         QWindowsStyle::drawControl(element,option, painter, widget);
757         break;
758 
759 #ifndef QT_NO_TABBAR
760         case CE_TabBarTab:
761             if (const QStyleOptionTab *tab = qstyleoption_cast<const QStyleOptionTab *>(option)) {
762                 drawControl(CE_TabBarTabShape, tab, painter, widget);
763                 drawControl(CE_TabBarTabLabel, tab, painter, widget);
764             }
765             break;
766     case CE_TabBarTabShape:
767         if (const QStyleOptionTab *tab = qstyleoption_cast<const QStyleOptionTab *>(option)) {
768             bool rtlHorTabs = (tab->direction == Qt::RightToLeft
769                                && (tab->shape == QTabBar::RoundedNorth
770                                    || tab->shape == QTabBar::RoundedSouth));
771             bool selected = tab->state & State_Selected;
772             bool lastTab = ((!rtlHorTabs && tab->position == QStyleOptionTab::End)
773                             || (rtlHorTabs
774                                 && tab->position == QStyleOptionTab::Beginning));
775             bool firstTab = ((!rtlHorTabs
776                                && tab->position == QStyleOptionTab::Beginning)
777                              || (rtlHorTabs
778                                  && tab->position == QStyleOptionTab::End));
779             bool onlyOne = tab->position == QStyleOptionTab::OnlyOneTab;
780             bool previousSelected =
781                 ((!rtlHorTabs
782                   && tab->selectedPosition == QStyleOptionTab::PreviousIsSelected)
783                 || (rtlHorTabs
784                     && tab->selectedPosition == QStyleOptionTab::NextIsSelected));
785             bool nextSelected =
786                 ((!rtlHorTabs
787                   && tab->selectedPosition == QStyleOptionTab::NextIsSelected)
788                  || (rtlHorTabs
789                      && tab->selectedPosition
790                             == QStyleOptionTab::PreviousIsSelected));
791             int tabBarAlignment = styleHint(SH_TabBar_Alignment, tab, widget);
792             bool leftAligned = (!rtlHorTabs && tabBarAlignment == Qt::AlignLeft)
793                                 || (rtlHorTabs
794                                     && tabBarAlignment == Qt::AlignRight);
795 
796             bool rightAligned = (!rtlHorTabs && tabBarAlignment == Qt::AlignRight)
797                                  || (rtlHorTabs
798                                          && tabBarAlignment == Qt::AlignLeft);
799             QColor light = tab->palette.light().color();
800             QColor midlight = tab->palette.midlight().color();
801             QColor dark = tab->palette.dark().color();
802             QColor shadow = tab->palette.shadow().color();
803             QColor background = tab->palette.background().color();
804             int borderThinkness = pixelMetric(PM_TabBarBaseOverlap, tab, widget);
805             if (selected)
806                 borderThinkness /= 2;
807             QRect r2(option->rect);
808             int x1 = r2.left();
809             int x2 = r2.right();
810             int y1 = r2.top();
811             int y2 = r2.bottom();
812             switch (tab->shape) {
813             default:
814                 QCommonStyle::drawControl(element, tab, painter, widget);
815                 break;
816             case QTabBar::RoundedNorth: {
817                 if (!selected) {
818                     y1 += 2;
819                     x1 += firstTab ? borderThinkness : 0;
820                     x2 -= lastTab ? borderThinkness : 0;
821                 }
822 
823                 painter->fillRect(QRect(x1 + 1, y1 + 1, (x2 - x1) - 1, (y2 - y1) - 2), tab->palette.background());
824 
825                 // Delete border
826                 if (selected) {
827                     painter->setPen(background);
828                     painter->drawLine(x1, y2 - 1, x2, y2 - 1);
829                     painter->drawLine(x1, y2 + 1, x2, y2 + 1);
830                     painter->drawLine(x1, y2, x2, y2);
831                 }
832                 // Left
833                 if (firstTab || selected || onlyOne || !previousSelected) {
834                     painter->setPen(dark);
835                     painter->drawLine(x1, y1 + 2, x1, y2 - ((onlyOne || firstTab) && selected && leftAligned ? 0 : borderThinkness));
836                     painter->drawPoint(x1 + 1, y1 + 1);
837                         painter->setPen(midlight);
838                         painter->drawLine(x1 + 1, y1 + 2, x1 + 1, y2 -
839                                          ((onlyOne || firstTab) && selected && leftAligned ? 0 : borderThinkness));
840 
841                 }
842                 // Top
843                 {
844                     int beg = x1 + (previousSelected ? 0 : 2);
845                     int end = x2 - (nextSelected ? 0 : 2);
846                     painter->setPen(dark);
847                     painter->drawLine(beg, y1, end, y1);
848 
849                     painter->setPen(midlight);
850                     painter->drawLine(beg, y1 + 1, end, y1 + 1);
851 
852                 }
853                 // Right
854                 if (lastTab || selected || onlyOne || !nextSelected) {
855                     painter->setPen(shadow);
856                     painter->drawLine(x2, y1 + 2, x2, y2 - ((onlyOne || lastTab) && selected && rightAligned ? 0 : borderThinkness));
857                     painter->drawPoint(x2 - 1, y1 + 1);
858                     painter->setPen(dark);
859                     painter->drawLine(x2 - 1, y1 + 2, x2 - 1, y2 - ((onlyOne || lastTab) && selected && rightAligned ? 0 : borderThinkness));
860                 }
861                 break; }
862             case QTabBar::RoundedSouth: {
863                 if (!selected) {
864                     y2 -= 2;
865                     x1 += firstTab ? borderThinkness : 0;
866                     x2 -= lastTab ? borderThinkness : 0;
867                 }
868 
869                 painter->fillRect(QRect(x1 + 1, y1 + 2, (x2 - x1) - 1, (y2 - y1) - 1), tab->palette.background());
870 
871                 // Delete border
872                 if (selected) {
873                     painter->setPen(background);
874                     painter->drawLine(x1, y1 + 1, x2 - 1, y1 + 1);
875                     painter->drawLine(x1, y1 - 1, x2 - 1, y1 - 1);
876                     painter->drawLine(x1, y1, x2 - 1, y1);
877                 }
878                 // Left
879                 if (firstTab || selected || onlyOne || !previousSelected) {
880                     painter->setPen(dark);
881                     painter->drawLine(x1, y2 - 2, x1, y1 + ((onlyOne || firstTab) && selected && leftAligned ? 0 : borderThinkness));
882                     painter->drawPoint(x1 + 1, y2 - 1);
883                     painter->setPen(midlight);
884                     painter->drawLine(x1 + 1, y2 - 2, x1 + 1, y1 + ((onlyOne || firstTab) && selected && leftAligned ? 0 : borderThinkness));
885                 }
886                 // Bottom
887                 {
888                     int beg = x1 + (previousSelected ? 0 : 2);
889                     int end = x2 - (nextSelected ? 0 : 2);
890                     painter->setPen(shadow);
891                     painter->drawLine(beg, y2, end, y2);
892                     painter->setPen(dark);
893                     painter->drawLine(beg, y2 - 1, end, y2 - 1);
894                 }
895                 // Right
896                 if (lastTab || selected || onlyOne || !nextSelected) {
897                     painter->setPen(shadow);
898                     painter->drawLine(x2, y2 - 2, x2, y1 + ((onlyOne || lastTab) && selected &&
899                                       rightAligned ? 0 : borderThinkness));
900                     painter->drawPoint(x2 - 1, y2 - 1);
901                     painter->setPen(dark);
902                     painter->drawLine(x2 - 1, y2 - 2, x2 - 1, y1 + ((onlyOne || lastTab) && selected &&
903                                       rightAligned ? 0 : borderThinkness));
904                 }
905                 break; }
906             case QTabBar::RoundedWest: {
907                 if (!selected) {
908                     x1 += 2;
909                     y1 += firstTab ? borderThinkness : 0;
910                     y2 -= lastTab ? borderThinkness : 0;
911                 }
912 
913                 painter->fillRect(QRect(x1 + 1, y1 + 1, (x2 - x1) - 2, (y2 - y1) - 1), tab->palette.background());
914 
915                 // Delete border
916                 if (selected) {
917                     painter->setPen(background);
918                     painter->drawLine(x2 - 1, y1, x2 - 1, y2);
919                     painter->drawLine(x2, y1, x2, y2);
920                 }
921                 // Top
922                 if (firstTab || selected || onlyOne || !previousSelected) {
923                     painter->setPen(dark);
924                     painter->drawLine(x1 + 2, y1, x2 - ((onlyOne || firstTab) && selected &&
925                                       leftAligned ? 0 : borderThinkness), y1);
926                     painter->drawPoint(x1 + 1, y1 + 1);
927                     painter->setPen(midlight);
928                     painter->drawLine(x1 + 2, y1 + 1, x2 - ((onlyOne || firstTab) && selected &&
929                                       leftAligned ? 0 : borderThinkness), y1 + 1);
930                 }
931                 // Left
932                 {
933                     int beg = y1 + (previousSelected ? 0 : 2);
934                     int end = y2 - (nextSelected ? 0 : 2);
935                     painter->setPen(dark);
936                     painter->drawLine(x1, beg, x1, end);
937                     painter->setPen(midlight);
938                     painter->drawLine(x1 + 1, beg, x1 + 1, end);
939                 }
940                 // Bottom
941                 if (lastTab || selected || onlyOne || !nextSelected) {
942                     painter->setPen(shadow);
943                     painter->drawLine(x1 + 3, y2, x2 - ((onlyOne || lastTab) && selected &&
944                                       rightAligned ? 0 : borderThinkness), y2);
945                     painter->drawPoint(x1 + 2, y2 - 1);
946                     painter->setPen(dark);
947                     painter->drawLine(x1 + 3, y2 - 1, x2 - ((onlyOne || lastTab) && selected &&
948                                       rightAligned ? 0 : borderThinkness), y2 - 1);
949                     painter->drawPoint(x1 + 1, y2 - 1);
950                     painter->drawPoint(x1 + 2, y2);
951                 }
952                 break; }
953             case QTabBar::RoundedEast: {
954                 if (!selected) {
955                     x2 -= 2;
956                     y1 += firstTab ? borderThinkness : 0;
957                     y2 -= lastTab ? borderThinkness : 0;
958                 }
959 
960                 painter->fillRect(QRect(x1 + 2, y1 + 1, (x2 - x1) - 1, (y2 - y1) - 1), tab->palette.background());
961 
962                 // Delete border
963                 if (selected) {
964                     painter->setPen(background);
965                     painter->drawLine(x1 + 1, y1, x1 + 1, y2 - 1);
966                     painter->drawLine(x1, y1, x1, y2 - 1);
967                 }
968                 // Top
969                 if (firstTab || selected || onlyOne || !previousSelected) {
970                     painter->setPen(dark);
971                     painter->drawLine(x2 - 2, y1, x1 + ((onlyOne || firstTab) && selected &&
972                                       leftAligned ? 0 : borderThinkness), y1);
973                     painter->drawPoint(x2 - 1, y1 + 1);
974                     painter->setPen(midlight);
975                     painter->drawLine(x2 - 3, y1 + 1, x1 + ((onlyOne || firstTab) &&
976                                       selected && leftAligned ? 0 : borderThinkness), y1 + 1);
977                     painter->drawPoint(x2 - 1, y1);
978 
979                 }
980                 // Right
981                 {
982                     int beg = y1 + (previousSelected ? 0 : 2);
983                     int end = y2 - (nextSelected ? 0 : 2);
984                     painter->setPen(shadow);
985                     painter->drawLine(x2, beg, x2, end);
986                     painter->setPen(dark);
987                     painter->drawLine(x2 - 1, beg, x2 - 1, end);
988                 }
989                 // Bottom
990                 if (lastTab || selected || onlyOne || !nextSelected) {
991                     painter->setPen(shadow);
992                     painter->drawLine(x2 - 2, y2, x1 + ((onlyOne || lastTab) &&
993                                       selected && rightAligned ? 0 : borderThinkness), y2);
994                     painter->drawPoint(x2 - 1, y2 - 1);
995                     painter->setPen(dark);
996                     painter->drawLine(x2 - 2, y2 - 1, x1 + ((onlyOne || lastTab) &&
997                                       selected && rightAligned ? 0 : borderThinkness), y2 - 1);
998                 }
999                 break; }
1000             }
1001         }
1002         break;
1003 #endif // QT_NO_TABBAR
1004 
1005     case CE_ToolBar: {
1006         QRect rect = option->rect;
1007         painter->setPen(QPen(option->palette.dark().color()));
1008         painter->drawLine(rect.topRight().x()-1,
1009             rect.topRight().y(),
1010             rect.bottomRight().x()-1,
1011             rect.bottomRight().y());
1012         painter->drawLine(rect.bottomLeft().x(),
1013             rect.bottomLeft().y(),
1014             rect.bottomRight().x(),
1015             rect.bottomRight().y());
1016         painter->setPen(QPen(option->palette.light().color()));
1017         painter->drawLine(rect.topRight().x(),
1018             rect.topRight().y(),
1019             rect.bottomRight().x(),
1020             rect.bottomRight().y());
1021         painter->drawLine(rect.topLeft().x(),
1022             rect.topLeft().y(),
1023             rect.topRight().x(),
1024             rect.topRight().y());
1025 
1026         break; }
1027 #ifndef QT_NO_SCROLLBAR
1028     case CE_ScrollBarSubLine:
1029     case CE_ScrollBarAddLine: {
1030         if (option->state & State_Sunken) {
1031             QStyleOption buttonOpt = *option;
1032 
1033             drawPrimitive(PE_PanelButtonBevel, &buttonOpt, painter, widget);
1034         } else {
1035             QStyleOption buttonOpt = *option;
1036             if (!(buttonOpt.state & State_Sunken))
1037                 buttonOpt.state |= State_Raised;
1038             drawPrimitive(PE_PanelButtonBevel, &buttonOpt, painter, widget);
1039         }
1040         PrimitiveElement arrow;
1041         if (option->state & State_Horizontal) {
1042             if (element == CE_ScrollBarAddLine)
1043                 arrow = option->direction == Qt::LeftToRight ? PE_IndicatorArrowRight : PE_IndicatorArrowLeft;
1044             else
1045                 arrow = option->direction == Qt::LeftToRight ? PE_IndicatorArrowLeft : PE_IndicatorArrowRight;
1046         } else {
1047             if (element == CE_ScrollBarAddLine)
1048                 arrow = PE_IndicatorArrowDown;
1049             else
1050                 arrow = PE_IndicatorArrowUp;
1051         }
1052         drawPrimitive(arrow, option, painter, widget);
1053         break; }
1054     case CE_ScrollBarAddPage:
1055     case CE_ScrollBarSubPage: {
1056             QBrush br;
1057             QBrush bg = painter->background();
1058             Qt::BGMode bg_mode = painter->backgroundMode();
1059             painter->setPen(Qt::NoPen);
1060             painter->setBackgroundMode(Qt::OpaqueMode);
1061 
1062             if (option->state & State_Sunken) {
1063                 br = QBrush(option->palette.shadow().color(), Qt::Dense4Pattern);
1064                 painter->setBackground(option->palette.dark().color());
1065                 painter->setBrush(br);
1066             } else {
1067                 QPixmap pm = option->palette.brush(QPalette::Light).texture();
1068                 if (option->state & State_Enabled)
1069                     br = !pm.isNull() ? QBrush(pm) : QBrush(option->palette.button().color(), Qt::Dense4Pattern);
1070                 else
1071                     br = !pm.isNull() ? QBrush(pm) : QBrush(option->palette.light().color(), Qt::Dense4Pattern);
1072                 painter->setBackground(option->palette.base().color());
1073                 painter->setBrush(br);
1074             }
1075             painter->drawRect(option->rect);
1076             painter->setBackground(bg);
1077             painter->setBackgroundMode(bg_mode);
1078             break; }
1079     case CE_ScrollBarSlider:
1080         if (!(option->state & State_Enabled)) {
1081             QStyleOptionButton buttonOpt;
1082             buttonOpt.QStyleOption::operator=(*option);
1083             buttonOpt.state = State_Enabled | State_Raised;
1084             drawPrimitive(PE_PanelButtonBevel, &buttonOpt, painter, widget);
1085             QPixmap pm = option->palette.brush(QPalette::Light).texture();
1086             QBrush br = !pm.isNull() ? QBrush(pm) : QBrush(option->palette.light().color(), Qt::Dense4Pattern);
1087             painter->setPen(Qt::NoPen);
1088             painter->setBrush(br);
1089             painter->setBackgroundMode(Qt::OpaqueMode);
1090             painter->drawRect(option->rect.adjusted(2, 2, -2, -2));
1091         } else {
1092             QStyleOptionButton buttonOpt;
1093             buttonOpt.QStyleOption::operator=(*option);
1094             buttonOpt.state = State_Enabled | State_Raised;
1095             drawPrimitive(PE_PanelButtonBevel, &buttonOpt, painter, widget);
1096         }
1097         break;
1098 #endif // QT_NO_SCROLLBAR
1099     case CE_HeaderSection: {
1100         QBrush fill;
1101         if (option->state & State_On)
1102             fill = QBrush(option->palette.light().color(), Qt::Dense4Pattern);
1103         else
1104             fill = option->palette.brush(QPalette::Button);
1105 
1106         if (option->state & (State_Raised | State_Sunken)) {
1107             QWindowsCEStylePrivate::drawWinCEButton(painter, option->rect, option->palette,
1108                                                     option->state & State_Sunken, &fill);
1109         } else {
1110             painter->fillRect(option->rect, fill);
1111         }
1112         break; }
1113 
1114     case CE_DockWidgetTitle:
1115         QWindowsStyle::drawControl(element,option, painter, widget);
1116         break;
1117 
1118         case CE_PushButtonLabel:
1119         if (const QStyleOptionButton *btn = qstyleoption_cast<const QStyleOptionButton *>(option)) {
1120             painter->save();
1121             QFont f = painter->font();
1122             f.setBold(true);
1123             painter->setFont(f);
1124             QRect ir = btn->rect;
1125             uint tf = Qt::AlignVCenter | Qt::TextShowMnemonic;
1126             if (!styleHint(SH_UnderlineShortcut, btn, widget))
1127                 tf |= Qt::TextHideMnemonic;
1128 
1129             if (btn->state & (State_On | State_Sunken))
1130                 ir.translate(pixelMetric(PM_ButtonShiftHorizontal, option, widget),
1131                              pixelMetric(PM_ButtonShiftVertical, option, widget));
1132             if (!btn->icon.isNull()) {
1133                 QIcon::Mode mode = btn->state & State_Enabled ? QIcon::Normal
1134                                                               : QIcon::Disabled;
1135                 if (mode == QIcon::Normal && btn->state & State_HasFocus)
1136                     mode = QIcon::Active;
1137                 QIcon::State state = QIcon::Off;
1138                 if (btn->state & State_On)
1139                     state = QIcon::On;
1140                 QPixmap pixmap = btn->icon.pixmap(btn->iconSize, mode, state);
1141                 int pixw = pixmap.width();
1142                 int pixh = pixmap.height();
1143                 //Center the icon if there is no text
1144 
1145                 QPoint point;
1146                 if (btn->text.isEmpty()) {
1147                     point = QPoint(ir.x() + ir.width() / 2 - pixw / 2,
1148                                    ir.y() + ir.height() / 2 - pixh / 2);
1149                 } else {
1150                     point = QPoint(ir.x() + 2, ir.y() + ir.height() / 2 - pixh / 2);
1151                 }
1152                 if (btn->direction == Qt::RightToLeft)
1153                     point.rx() += pixw;
1154 
1155                 if ((btn->state & (State_On | State_Sunken)) && btn->direction == Qt::RightToLeft)
1156                     point.rx() -= pixelMetric(PM_ButtonShiftHorizontal, option, widget) * 2;
1157 
1158                 painter->drawPixmap(visualPos(btn->direction, btn->rect, point), pixmap);
1159 
1160                 if (btn->direction == Qt::RightToLeft)
1161                     ir.translate(-4, 0);
1162                 else
1163                     ir.translate(pixw + 4, 0);
1164                 ir.setWidth(ir.width() - (pixw + 4));
1165                 // left-align text if there is
1166                 if (!btn->text.isEmpty())
1167                     tf |= Qt::AlignLeft;
1168             } else {
1169                 tf |= Qt::AlignHCenter;
1170             }
1171             drawItemText(painter, ir, tf, btn->palette, (btn->state & State_Enabled),
1172                          btn->text, QPalette::ButtonText);
1173             painter->restore();
1174         }
1175         break;
1176         default:
1177             QWindowsStyle::drawControl(element, option, painter, widget);
1178             break;
1179     }
1180 }
1181 
drawComplexControl(ComplexControl control,const QStyleOptionComplex * option,QPainter * painter,const QWidget * widget) const1182 void QWindowsCEStyle::drawComplexControl(ComplexControl control, const QStyleOptionComplex *option,
1183                                          QPainter *painter, const QWidget *widget) const {
1184     switch (control) {
1185         #ifndef QT_NO_SLIDER
1186     case CC_Slider:
1187         if (const QStyleOptionSlider *slider = qstyleoption_cast<const QStyleOptionSlider *>(option)) {
1188             int thickness  = pixelMetric(PM_SliderControlThickness, slider, widget);
1189             int len        = pixelMetric(PM_SliderLength, slider, widget);
1190             int ticks = slider->tickPosition;
1191             QRect groove = subControlRect(CC_Slider, slider, SC_SliderGroove, widget);
1192             QRect handle = subControlRect(CC_Slider, slider, SC_SliderHandle, widget);
1193 
1194             if ((slider->subControls & SC_SliderGroove) && groove.isValid()) {
1195                 int mid = thickness / 2;
1196                 if (ticks & QSlider::TicksAbove)
1197                     mid += len / 8;
1198                 if (ticks & QSlider::TicksBelow)
1199                     mid -= len / 8;
1200 
1201                 painter->setPen(slider->palette.shadow().color());
1202                 if (slider->orientation == Qt::Horizontal) {
1203                     QWindowsCEStylePrivate::drawWinCEPanel(painter, groove.x(), groove.y() + mid - 2,
1204                                    groove.width(), 4, option->palette, true);
1205                     painter->drawLine(groove.x() + 1, groove.y() + mid - 1,
1206                                 groove.x() + groove.width() - 3, groove.y() + mid - 1);
1207                 } else {
1208                     QWindowsCEStylePrivate::drawWinCEPanel(painter, groove.x() + mid - 2, groove.y(),
1209                                   4, groove.height(), option->palette, true);
1210                     painter->drawLine(groove.x() + mid - 1, groove.y() + 1,
1211                                 groove.x() + mid - 1, groove.y() + groove.height() - 3);
1212                 }
1213             }
1214             if (slider->subControls & SC_SliderTickmarks) {
1215                 QStyleOptionSlider tmpSlider = *slider;
1216                 tmpSlider.subControls = SC_SliderTickmarks;
1217                 QCommonStyle::drawComplexControl(control, &tmpSlider, painter, widget);
1218             }
1219 
1220             if (slider->subControls & SC_SliderHandle) {
1221                 // 4444440
1222                 // 4333310
1223                 // 4322210
1224                 // 4322210
1225                 // 4322210
1226                 // 4322210
1227                 // *43210*
1228                 // **440**
1229                 // ***0***
1230                 const QColor c0 = slider->palette.shadow().color();
1231                 const QColor c1 = slider->palette.dark().color();
1232                 // const QColor c2 = g.button();
1233                 const QColor c3 = slider->palette.midlight().color();
1234                 const QColor c4 = slider->palette.dark().color();
1235                 QBrush handleBrush;
1236 
1237                 if (slider->state & State_Enabled) {
1238                     handleBrush = slider->palette.color(QPalette::Button);
1239                 } else {
1240                     handleBrush = QBrush(slider->palette.color(QPalette::Button),
1241                                          Qt::Dense4Pattern);
1242                 }
1243 
1244                 int x = handle.x(), y = handle.y(),
1245                    wi = handle.width(), he = handle.height();
1246 
1247                 int x1 = x;
1248                 int x2 = x + wi - 1;
1249                 int y1 = y;
1250                 int y2 = y + he - 1;
1251 
1252                 Qt::Orientation orient = slider->orientation;
1253                 bool tickAbove = slider->tickPosition == QSlider::TicksAbove;
1254                 bool tickBelow = slider->tickPosition == QSlider::TicksBelow;
1255 
1256                 if (slider->state & State_HasFocus) {
1257                     QStyleOptionFocusRect fropt;
1258                     fropt.QStyleOption::operator=(*slider);
1259                     fropt.rect = subElementRect(SE_SliderFocusRect, slider, widget);
1260                     drawPrimitive(PE_FrameFocusRect, &fropt, painter, widget);
1261                 }
1262                 if ((tickAbove && tickBelow) || (!tickAbove && !tickBelow)) {
1263                     Qt::BGMode oldMode = painter->backgroundMode();
1264                     painter->setBackgroundMode(Qt::OpaqueMode);
1265                     QWindowsCEStylePrivate::drawWinCEButton(painter, QRect(x, y, wi, he), slider->palette, false,
1266                                                             &handleBrush);
1267                     painter->setBackgroundMode(oldMode);
1268                     QBrush fill = QBrush(option->palette.light().color(), Qt::Dense4Pattern);
1269                     if (slider->state & State_Sunken)
1270                       painter->fillRect(QRectF(x1 + 2, y1 + 2, x2 - x1 - 3, y2 - y1 - 3),fill);
1271                     return;
1272                 }
1273                 QSliderDirection dir;
1274                 if (orient == Qt::Horizontal)
1275                     if (tickAbove)
1276                         dir = SlUp;
1277                     else
1278                         dir = SlDown;
1279                 else
1280                     if (tickAbove)
1281                         dir = SlLeft;
1282                     else
1283                         dir = SlRight;
1284                 QPolygon a;
1285                 int d = 0;
1286                 switch (dir) {
1287                 case SlUp:
1288                     x2++;
1289                     y1 = y1 + wi / 2;
1290                     d =  (wi + 1) / 2 - 1;
1291                     a.setPoints(5, x1, y1, x1, y2, x2, y2, x2, y1, x1 + d, y1 - d);
1292                     break;
1293                 case SlDown:
1294                     x2++;
1295                     y2 = y2 - wi / 2;
1296                     d =  (wi + 1) / 2 - 1;
1297                     a.setPoints(5, x1, y1, x1, y2, x1 + d, y2+d, x2, y2, x2, y1);
1298                     break;
1299                 case SlLeft:
1300                     d =  (he + 1) / 2 - 1;
1301                     x1 = x1 + he / 2;
1302                     a.setPoints(5, x1, y1, x1 - d, y1 + d, x1, y2, x2, y2, x2, y1);
1303                     y1--;
1304                     break;
1305                 case SlRight:
1306                     d =  (he + 1) / 2 - 1;
1307                     x2 = x2 - he / 2;
1308                     a.setPoints(5, x1, y1, x1, y2, x2, y2, x2 + d, y1 + d, x2, y1);
1309                     y1--;
1310                     break;
1311                 }
1312                 QBrush oldBrush = painter->brush();
1313                 painter->setPen(Qt::NoPen);
1314                 painter->setBrush(handleBrush);
1315                 Qt::BGMode oldMode = painter->backgroundMode();
1316                 painter->setBackgroundMode(Qt::OpaqueMode);
1317                 painter->drawRect(x1, y1, x2 - x1 + 1, y2 - y1 + 1);
1318                 painter->drawPolygon(a);
1319                 QBrush fill = QBrush(option->palette.light().color(), Qt::Dense4Pattern);
1320                 if (slider->state & State_Sunken)
1321                   painter->fillRect(QRectF(x1, y1, x2 - x1 + 1, y2 - y1 + 1),fill);
1322                 painter->setBrush(oldBrush);
1323                 painter->setBackgroundMode(oldMode);
1324 
1325                 if (dir != SlUp) {
1326                     painter->setPen(c4);
1327                     painter->drawLine(x1, y1, x2, y1);
1328                     painter->setPen(c3);
1329                     painter->drawLine(x1, y1 + 1, x2, y1 + 1);
1330                 }
1331                 if (dir != SlLeft) {
1332                     painter->setPen(c3);
1333                     painter->drawLine(x1 + 1, y1 + 1, x1 + 1, y2);
1334                     painter->setPen(c4);
1335                     painter->drawLine(x1, y1, x1, y2);
1336                 }
1337                 if (dir != SlRight) {
1338                     painter->setPen(c0);
1339                     painter->drawLine(x2, y1, x2, y2);
1340                     painter->setPen(c1);
1341                     painter->drawLine(x2 - 1, y1 + 1, x2 - 1, y2 - 1);
1342                 }
1343                 if (dir != SlDown) {
1344                     painter->setPen(c0);
1345                     painter->drawLine(x1, y2, x2, y2);
1346                     painter->setPen(c1);
1347                     painter->drawLine(x1+1, y2 - 1, x2 - 1, y2 - 1);
1348                 }
1349 
1350                switch (dir) {
1351                 case SlUp:
1352                     if (slider->state & State_Sunken)
1353                       painter->fillRect(QRectF(x1 + 3, y1 - d + 2, x2 - x1 - 4,y1), fill);
1354                     painter->setPen(c4);
1355                     painter->drawLine(x1, y1, x1 + d, y1 - d);
1356                     painter->setPen(c0);
1357                     d = wi - d - 1;
1358                     painter->drawLine(x2, y1, x2 - d, y1 - d);
1359                     d--;
1360                     painter->setPen(c3);
1361                     painter->drawLine(x1 + 1, y1, x1 + 1 + d-1, y1 - d + 1);
1362                     painter->setPen(c1);
1363                     painter->drawLine(x2 - 1, y1, x2-1 - d, y1 - d);
1364                     break;
1365                 case SlDown:
1366                     if (slider->state & State_Sunken)
1367                       painter->fillRect(QRectF(x1 + 3, y2 - d, x2 - x1 - 4,y2 - 8), fill);
1368                     painter->setPen(c4);
1369                     painter->drawLine(x1, y2, x1 + d, y2 + d);
1370                     painter->setPen(c0);
1371                     d = wi - d - 1;
1372                     painter->drawLine(x2, y2, x2 - d, y2 + d);
1373                     d--;
1374                     painter->setPen(c3);
1375                     painter->drawLine(x1 + 1, y2, x1 + 1 + d - 1, y2 + d - 1);
1376                     painter->setPen(c1);
1377                     painter->drawLine(x2 - 1, y2, x2 - 1 - d, y2 + d);
1378                     break;
1379                 case SlLeft:
1380                     if (slider->state & State_Sunken)
1381                       painter->fillRect(QRectF(x1 - d + 2, y1 + 2, x1,y2 - y1 - 3), fill);
1382                     painter->setPen(c4);
1383                     painter->drawLine(x1, y1, x1 - d, y1 + d);
1384                     painter->setPen(c0);
1385                     d = he - d - 1;
1386                     painter->drawLine(x1, y2, x1 - d, y2 - d);
1387                     d--;
1388                     painter->setPen(c3);
1389                     painter->drawLine(x1, y1 + 1, x1 - d + 1, y1 + 1 + d - 1);
1390                     painter->setPen(c1);
1391                     painter->drawLine(x1, y2 - 1, x1 - d, y2 - 1 - d);
1392                     break;
1393                 case SlRight:
1394                     if (slider->state & State_Sunken)
1395                       painter->fillRect(QRectF(x2 - d - 4, y1 + 2, x2 - 4, y2 - y1 - 3), fill);
1396                     painter->setPen(c4);
1397                     painter->drawLine(x2, y1, x2 + d, y1 + d);
1398                     painter->setPen(c0);
1399                     d = he - d - 1;
1400                     painter->drawLine(x2, y2, x2 + d, y2 - d);
1401                     d--;
1402                     painter->setPen(c3);
1403                     painter->drawLine(x2, y1 + 1, x2 + d - 1, y1 + 1 + d - 1);
1404                     painter->setPen(c1);
1405                     painter->drawLine(x2, y2 - 1, x2 + d, y2 - 1 - d);
1406                     break;
1407                 }
1408             }
1409         }
1410         break;
1411 #endif // QT_NO_SLIDER
1412     case CC_ToolButton:
1413         if (const QStyleOptionToolButton *toolbutton
1414                 = qstyleoption_cast<const QStyleOptionToolButton *>(option)) {
1415             QRect button, menuarea;
1416 
1417 #ifndef QT_NO_TOOLBAR
1418             bool flat = !(widget ? qobject_cast<QToolBar*>(widget->parentWidget()) : 0);
1419 #else
1420             bool flat = true;
1421 #endif
1422 
1423             button = subControlRect(control, toolbutton, SC_ToolButton, widget);
1424             menuarea = subControlRect(control, toolbutton, SC_ToolButtonMenu, widget);
1425 
1426             if (flat && (toolbutton->subControls & SC_ToolButtonMenu)) {
1427                 menuarea.setLeft(menuarea.left() - 4);
1428                 button.setRight(button.right() - 4);
1429             }
1430 
1431             State bflags = toolbutton->state;
1432 
1433             if (bflags & State_AutoRaise)
1434                 if (!(bflags & State_MouseOver)) {
1435                     bflags &= ~State_Raised;
1436                 }
1437             State mflags = bflags;
1438 
1439             if (toolbutton->activeSubControls & SC_ToolButton)
1440                 bflags |= State_Sunken;
1441             if (toolbutton->activeSubControls & SC_ToolButtonMenu)
1442                 mflags |= State_Sunken;
1443 
1444             QStyleOption tool(0);
1445             tool.palette = toolbutton->palette;
1446             if (toolbutton->subControls & SC_ToolButton) {
1447                     tool.rect = button;
1448                     tool.state = bflags;
1449                     drawPrimitive(PE_PanelButtonTool, &tool, painter, widget);
1450                 }
1451 
1452             if (toolbutton->subControls & SC_ToolButtonMenu) {
1453                 tool.rect = menuarea;
1454                 tool.state = mflags;
1455                 tool.state = bflags;
1456                 drawPrimitive(PE_IndicatorButtonDropDown, &tool, painter, widget);
1457 
1458                 if (!flat) {
1459 
1460                     //connect buttons
1461                     painter->save();
1462                     painter->setPen(tool.palette.button().color());
1463                     painter->drawLine(tool.rect.x() - 2, tool.rect.y(), tool.rect.x() - 2, tool.rect.y() + tool.rect.height());
1464                     painter->drawLine(tool.rect.x() - 1, tool.rect.y(), tool.rect.x() - 1, tool.rect.y() + tool.rect.height());
1465                     painter->drawLine(tool.rect.x(), tool.rect.y(), tool.rect.x(), tool.rect.y() + tool.rect.height());
1466                     painter->drawLine(tool.rect.x() + 1, tool.rect.y(), tool.rect.x() + 1, tool.rect.y() + tool.rect.height());
1467 
1468                     if (tool.state & State_Sunken)
1469                     {
1470                         painter->setPen(tool.palette.midlight().color());
1471                         painter->drawLine(tool.rect.x() - 2, tool.rect.y() + tool.rect.height() - 2,
1472                             tool.rect.x() + 1, tool.rect.y() + tool.rect.height() -2 );
1473                         painter->setPen(tool.palette.shadow().color());
1474                         painter->drawLine(tool.rect.x() - 2, tool.rect.y() + 1,tool.rect.x() + 1, tool.rect.y() + 1);
1475                         painter->drawLine(tool.rect.x() - 2, tool.rect.y(), tool.rect.x() + 1, tool.rect.y());
1476                         painter->setPen(tool.palette.light().color());
1477                         painter->drawLine(tool.rect.x() - 2, tool.rect.y() + tool.rect.height() - 1,
1478                             tool.rect.x() + 1, tool.rect.y() + tool.rect.height() - 1);
1479                     }
1480                     else
1481                     {
1482                         painter->setPen(tool.palette.dark().color());
1483                         painter->drawLine(tool.rect.x() - 2, tool.rect.y(),tool.rect.x() + 1, tool.rect.y());
1484                         painter->drawLine(tool.rect.x() - 2, tool.rect.y()+tool.rect.height() - 2,tool.rect.x() + 1,
1485                             tool.rect.y() + tool.rect.height() - 2);
1486                         painter->setPen(tool.palette.midlight().color());
1487                         painter->drawLine(tool.rect.x() - 2, tool.rect.y() + 1,tool.rect.x() + 1, tool.rect.y() + 1);
1488                         painter->setPen(tool.palette.shadow().color());
1489                         painter->drawLine(tool.rect.x() - 2, tool.rect.y() + tool.rect.height() - 1,
1490                             tool.rect.x() + 1, tool.rect.y() + tool.rect.height() - 1);
1491                     }
1492                     painter->restore();
1493                 }
1494 
1495 
1496                 if (!flat) {
1497                     tool.rect.adjust(-3,0,-3,0);
1498                     painter->save();
1499                     painter->setPen(tool.palette.button().color());
1500                     if (tool.state & State_Sunken)
1501                         painter->drawLine(tool.rect.x() + 2, tool.rect.y() + 10,
1502                         tool.rect.x() + tool.rect.width(), tool.rect.y() + 10);
1503                     else
1504                         painter->drawLine(tool.rect.x() + 1, tool.rect.y() + 9, tool.rect.x() +
1505                         tool.rect.width() - 1, tool.rect.y() + 9);
1506                     painter->restore();
1507                 } else {
1508                     tool.rect.adjust(-1,0,-1,0);
1509                 }
1510 
1511                 drawPrimitive(PE_IndicatorArrowDown, &tool, painter, widget);
1512             }
1513 
1514             if (toolbutton->state & State_HasFocus) {
1515                 QStyleOptionFocusRect fr;
1516                 fr.QStyleOption::operator=(*toolbutton);
1517                 fr.rect.adjust(3, 3, -3, -3);
1518                 if (toolbutton->features & QStyleOptionToolButton::Menu)
1519                     fr.rect.adjust(0, 0, -pixelMetric(QStyle::PM_MenuButtonIndicator,
1520                                                          toolbutton, widget), 0);
1521                 drawPrimitive(PE_FrameFocusRect, &fr, painter, widget);
1522             }
1523             QStyleOptionToolButton label = *toolbutton;
1524             int fw = pixelMetric(PM_DefaultFrameWidth, option, widget);
1525             label.rect = button.adjusted(fw, fw, -fw, -fw);
1526             drawControl(CE_ToolButtonLabel, &label, painter, widget);
1527         }
1528         break;
1529 
1530 #ifndef QT_NO_GROUPBOX
1531     case CC_GroupBox:
1532         if (const QStyleOptionGroupBox *groupBox = qstyleoption_cast<const QStyleOptionGroupBox *>(option)) {
1533             // Draw frame
1534             painter->save();
1535             QFont f = painter->font();
1536             f.setBold(true);
1537             painter->setFont(f);
1538             QStyleOptionGroupBox groupBoxFont = *groupBox;
1539             groupBoxFont.fontMetrics = QFontMetrics(f);
1540             QRect textRect = subControlRect(CC_GroupBox, &groupBoxFont, SC_GroupBoxLabel, widget);
1541             QRect checkBoxRect = subControlRect(CC_GroupBox, option, SC_GroupBoxCheckBox, widget);
1542             if (groupBox->subControls & QStyle::SC_GroupBoxFrame) {
1543                 QStyleOptionFrameV2 frame;
1544                 frame.QStyleOption::operator=(*groupBox);
1545                 frame.features = groupBox->features;
1546                 frame.lineWidth = groupBox->lineWidth;
1547                 frame.midLineWidth = groupBox->midLineWidth;
1548                 frame.rect = subControlRect(CC_GroupBox, option, SC_GroupBoxFrame, widget);
1549                 painter->save();
1550 
1551                 QRegion region(groupBox->rect);
1552                 if (!groupBox->text.isEmpty()) {
1553                     bool ltr = groupBox->direction == Qt::LeftToRight;
1554                     QRect finalRect = checkBoxRect.united(textRect);
1555                     if (groupBox->subControls & QStyle::SC_GroupBoxCheckBox)
1556                         finalRect.adjust(ltr ? -4 : 0, 0, ltr ? 0 : 4, 0);
1557                     region -= finalRect;
1558                 }
1559                 painter->setClipRegion(region);
1560                 drawPrimitive(PE_FrameGroupBox, &frame, painter, widget);
1561                 painter->restore();
1562             }
1563 
1564             // Draw title
1565             if ((groupBox->subControls & QStyle::SC_GroupBoxLabel) && !groupBox->text.isEmpty()) {
1566                 QColor textColor = groupBox->textColor;
1567                 if (textColor.isValid())
1568                     painter->setPen(textColor);
1569                 int alignment = int(groupBox->textAlignment);
1570                 if (!styleHint(QStyle::SH_UnderlineShortcut, option, widget))
1571                     alignment |= Qt::TextHideMnemonic;
1572 
1573                 drawItemText(painter, textRect,  Qt::TextShowMnemonic | Qt::AlignHCenter | alignment,
1574                              groupBox->palette, groupBox->state & State_Enabled, groupBox->text,
1575                              textColor.isValid() ? QPalette::NoRole : QPalette::WindowText);
1576 
1577                 if (groupBox->state & State_HasFocus) {
1578                     QStyleOptionFocusRect fropt;
1579                     fropt.QStyleOption::operator=(*groupBox);
1580                     fropt.rect = textRect;
1581                     drawPrimitive(PE_FrameFocusRect, &fropt, painter, widget);
1582                 }
1583             }
1584             // Draw checkbox
1585             if (groupBox->subControls & SC_GroupBoxCheckBox) {
1586                 QStyleOptionButton box;
1587                 box.QStyleOption::operator=(*groupBox);
1588                 box.rect = checkBoxRect;
1589                 drawPrimitive(PE_IndicatorCheckBox, &box, painter, widget);
1590             }
1591             painter->restore();
1592         }
1593         break;
1594 #endif //QT_NO_GROUPBOX
1595 #ifndef QT_NO_COMBOBOX
1596     case CC_ComboBox:
1597         if (const QStyleOptionComboBox *cmb = qstyleoption_cast<const QStyleOptionComboBox *>(option)) {
1598             QBrush editBrush = cmb->palette.brush(QPalette::Base);
1599             if ((cmb->subControls & SC_ComboBoxFrame) && cmb->frame)
1600                 QWindowsCEStylePrivate::drawWinCEPanel(painter, option->rect, option->palette, true, &editBrush);
1601             else
1602                 painter->fillRect(option->rect, editBrush);
1603 
1604             if (cmb->subControls & SC_ComboBoxArrow) {
1605                 State flags = State_None;
1606 
1607                 QRect ar = subControlRect(CC_ComboBox, cmb, SC_ComboBoxArrow, widget);
1608                 if (cmb->activeSubControls == SC_ComboBoxArrow) {
1609                     painter->setPen(cmb->palette.dark().color());
1610                     painter->setBrush(cmb->palette.brush(QPalette::Button));
1611                     painter->drawRect(ar.adjusted(0, 0, -1, -1));
1612                     QWindowsCEStylePrivate::drawWinCEButton(painter, ar.adjusted(0, 0, -1, -1), option->palette, true,
1613                     &cmb->palette.brush(QPalette::Button));
1614                 } else {
1615                     // Make qDrawWinButton use the right colors for drawing the shade of the button
1616 
1617                     QWindowsCEStylePrivate::drawWinCEButton(painter, ar, option->palette, false,
1618                                    &cmb->palette.brush(QPalette::Button));
1619                 }
1620 
1621                 ar.adjust(2, 2, -2, -2);
1622                 if (option->state & State_Enabled)
1623                     flags |= State_Enabled;
1624 
1625                 if (cmb->activeSubControls == SC_ComboBoxArrow)
1626                     flags |= State_Sunken;
1627                 QStyleOption arrowOpt(0);
1628                 arrowOpt.rect = ar;
1629                 arrowOpt.palette = cmb->palette;
1630                 arrowOpt.state = flags;
1631                 drawPrimitive(PE_IndicatorArrowDown, &arrowOpt, painter, widget);
1632             }
1633             if (cmb->subControls & SC_ComboBoxEditField) {
1634                 QRect re = subControlRect(CC_ComboBox, cmb, SC_ComboBoxEditField, widget);
1635                 if (cmb->state & State_HasFocus && !cmb->editable)
1636                     painter->fillRect(re.x(), re.y(), re.width(), re.height(),
1637                  cmb->palette.brush(QPalette::Highlight));
1638                  if (cmb->state & State_HasFocus) {
1639                     painter->setPen(cmb->palette.highlightedText().color());
1640                     painter->setBackground(cmb->palette.highlight());
1641                  } else {
1642                     painter->setPen(cmb->palette.text().color());
1643                     painter->setBackground(cmb->palette.background());
1644                  }
1645                  if (cmb->state & State_HasFocus && !cmb->editable) {
1646                     QStyleOptionFocusRect focus;
1647                     focus.QStyleOption::operator=(*cmb);
1648                     focus.rect = subElementRect(SE_ComboBoxFocusRect, cmb, widget);
1649                     focus.state |= State_FocusAtBorder;
1650                     focus.backgroundColor = cmb->palette.highlight().color();
1651                     drawPrimitive(PE_FrameFocusRect, &focus, painter, widget);
1652                }
1653             }
1654         }
1655         break;
1656 #endif // QT_NO_COMBOBOX
1657 #ifndef QT_NO_SPINBOX
1658     case CC_SpinBox:
1659         if (const QStyleOptionSpinBox *sb = qstyleoption_cast<const QStyleOptionSpinBox *>(option)) {
1660             QStyleOptionSpinBox copy = *sb;
1661             PrimitiveElement pe;
1662 
1663             if (sb->frame && (sb->subControls & SC_SpinBoxFrame)) {
1664                 QRect r = subControlRect(CC_SpinBox, sb, SC_SpinBoxFrame, widget);
1665                 QWindowsCEStylePrivate::drawWinCEPanel(painter, r, option->palette, true);
1666             }
1667             QPalette shadePal(option->palette);
1668             shadePal.setColor(QPalette::Button, option->palette.light().color());
1669             shadePal.setColor(QPalette::Light, option->palette.button().color());
1670 
1671             bool reverse = QApplication::layoutDirection() == Qt::RightToLeft;
1672 
1673             if (sb->subControls & SC_SpinBoxUp) {
1674                 copy.subControls = SC_SpinBoxUp;
1675                 QPalette pal2 = sb->palette;
1676                 if (!(sb->stepEnabled & QAbstractSpinBox::StepUpEnabled)) {
1677                     pal2.setCurrentColorGroup(QPalette::Disabled);
1678                     copy.state &= ~State_Enabled;
1679                 }
1680                 copy.palette = pal2;
1681                 if (sb->activeSubControls == SC_SpinBoxUp && (sb->state & State_Sunken)) {
1682                     copy.state |= State_On;
1683                     copy.state |= State_Sunken;
1684                 } else {
1685                     copy.state |= State_Raised;
1686                     copy.state &= ~State_Sunken;
1687                 }
1688                 if (reverse)
1689                     pe = (sb->buttonSymbols == QAbstractSpinBox::PlusMinus ? PE_IndicatorSpinMinus
1690                     : PE_IndicatorSpinDown);
1691                 else
1692                     pe = (sb->buttonSymbols == QAbstractSpinBox::PlusMinus ? PE_IndicatorSpinPlus
1693                     : PE_IndicatorSpinUp);
1694                 copy.rect = subControlRect(CC_SpinBox, sb, SC_SpinBoxUp, widget);
1695                 QWindowsCEStylePrivate::drawWinCEButton(painter, copy.rect, option->palette, copy.state & (State_Sunken | State_On),
1696                                 &copy.palette.brush(QPalette::Button));
1697                 copy.rect.adjust(3, 0, -4, 0);
1698                 drawPrimitive(pe, &copy, painter, widget);
1699             }
1700             if (sb->subControls & SC_SpinBoxDown) {
1701                 copy.subControls = SC_SpinBoxDown;
1702                 copy.state = sb->state;
1703                 QPalette pal2 = sb->palette;
1704                 if (!(sb->stepEnabled & QAbstractSpinBox::StepDownEnabled)) {
1705                     pal2.setCurrentColorGroup(QPalette::Disabled);
1706                     copy.state &= ~State_Enabled;
1707                 }
1708                 copy.palette = pal2;
1709 
1710                 if (sb->activeSubControls == SC_SpinBoxDown && (sb->state & State_Sunken)) {
1711                     copy.state |= State_On;
1712                     copy.state |= State_Sunken;
1713                 } else {
1714                     copy.state |= State_Raised;
1715                     copy.state &= ~State_Sunken;
1716                 }
1717                 if (reverse)
1718                     pe = (sb->buttonSymbols == QAbstractSpinBox::PlusMinus ? PE_IndicatorSpinPlus
1719                     : PE_IndicatorSpinUp);
1720                 else
1721                     pe = (sb->buttonSymbols == QAbstractSpinBox::PlusMinus ? PE_IndicatorSpinMinus
1722                     : PE_IndicatorSpinDown);
1723                 copy.rect = subControlRect(CC_SpinBox, sb, SC_SpinBoxDown, widget);
1724                 QWindowsCEStylePrivate::drawWinCEButton(painter, copy.rect, shadePal, copy.state & (State_Sunken | State_On),
1725                                 &copy.palette.brush(QPalette::Button));
1726 
1727                 copy.rect.adjust(3, 0, -4, 0);
1728                 if (pe == PE_IndicatorArrowUp || pe == PE_IndicatorArrowDown) {
1729                     copy.rect = copy.rect.adjusted(1, 1, -1, -1);
1730                     drawPrimitive(pe, &copy, painter, widget);
1731                 }
1732                 else {
1733                     drawPrimitive(pe, &copy, painter, widget);
1734                 }
1735                 if (sb->frame && (sb->subControls & SC_SpinBoxFrame)) {
1736                     QRect r = subControlRect(CC_SpinBox, sb, SC_SpinBoxEditField, widget);
1737                     painter->save();
1738                     painter->setPen(option->palette.light().color());
1739                     painter->drawLine(r.x() + 1 + r.width(), r.y() - 2, r.x() + 1 + r.width(), r.y() + r.height() + 1);
1740                     painter->setPen(option->palette.midlight().color());
1741                     painter->drawLine(r.x() + r.width(), r.y() - 1, r.x() + r.width(), r.y() + r.height());
1742                     painter->restore();
1743                 }
1744             }
1745         }
1746         break;
1747 #endif // QT_NO_SPINBOX
1748 
1749     default:
1750         QWindowsStyle::drawComplexControl(control, option, painter, widget);
1751         break;
1752     }
1753 }
1754 
drawItemText(QPainter * painter,const QRect & rect,int alignment,const QPalette & pal,bool enabled,const QString & text,QPalette::ColorRole textRole) const1755 void QWindowsCEStyle::drawItemText(QPainter *painter, const QRect &rect, int alignment, const QPalette &pal,
1756                           bool enabled, const QString& text, QPalette::ColorRole textRole) const {
1757     if (text.isEmpty())
1758         return;
1759     QPen savedPen;
1760     if (textRole != QPalette::NoRole) {
1761         savedPen = painter->pen();
1762         painter->setPen(pal.color(textRole));
1763     }
1764     if (!enabled) {
1765             QPen pen = painter->pen();
1766             painter->setPen(pal.light().color());
1767             //painter->drawText(rect.adjusted(1, 1, 1, 1), alignment, text);
1768             painter->setPen(pen);
1769         }
1770     painter->drawText(rect, alignment, text);
1771     if (textRole != QPalette::NoRole)
1772         painter->setPen(savedPen);
1773 }
1774 
1775 
sizeFromContents(ContentsType type,const QStyleOption * option,const QSize & size,const QWidget * widget) const1776 QSize QWindowsCEStyle::sizeFromContents(ContentsType type, const QStyleOption *option,
1777                                         const QSize &size, const QWidget *widget) const {
1778     QSize newSize = QWindowsStyle::sizeFromContents(type, option, size, widget);
1779     switch (type) {
1780     case CT_PushButton:
1781        if (const QStyleOptionButton *btn = qstyleoption_cast<const QStyleOptionButton *>(option)) {
1782             newSize = QWindowsStyle::sizeFromContents(type, option, size, widget);
1783             int w = newSize.width(),
1784                 h = newSize.height();
1785             int defwidth = 0;
1786             if (btn->features & QStyleOptionButton::AutoDefaultButton)
1787                 defwidth = 2 * pixelMetric(PM_ButtonDefaultIndicator, btn, widget);
1788             if (w < 75 + defwidth && btn->icon.isNull())
1789                 w = 75 + defwidth;
1790             if (h < 23 + defwidth)
1791                 h = 23 + defwidth;
1792             newSize = QSize(w+14, h);
1793         }
1794         break;
1795 
1796     case CT_RadioButton:
1797     case CT_CheckBox:
1798         if (const QStyleOptionButton *btn = qstyleoption_cast<const QStyleOptionButton *>(option)) {
1799             bool isRadio = (type == CT_RadioButton);
1800             QRect irect = visualRect(btn->direction, btn->rect,
1801                                      subElementRect(isRadio ? SE_RadioButtonIndicator
1802                                                             : SE_CheckBoxIndicator, btn, widget));
1803             int h = pixelMetric(isRadio ? PM_ExclusiveIndicatorHeight
1804                                         : PM_IndicatorHeight, btn, widget);
1805             int margins = (!btn->icon.isNull() && btn->text.isEmpty()) ? 0 : 10;
1806             newSize += QSize(irect.right() + margins, 4);
1807             newSize.setHeight(qMax(newSize.height(), h));
1808         }
1809         break;
1810     case CT_ComboBox:
1811         if (const QStyleOptionComboBox *cmb = qstyleoption_cast<const QStyleOptionComboBox *>(option)) {
1812             int fw = cmb->frame ? pixelMetric(PM_ComboBoxFrameWidth, option, widget) * 2 : 0;
1813             newSize = QSize(newSize.width() + fw -1, qMax(24, newSize.height() + fw-1));
1814         }
1815         break;
1816 #ifndef QT_NO_SPINBOX
1817     case CT_SpinBox:
1818         if (const QStyleOptionSpinBox *spnb = qstyleoption_cast<const QStyleOptionSpinBox *>(option)) {
1819             int fw = spnb->frame ? pixelMetric(PM_SpinBoxFrameWidth, option, widget) * 2 : 0;
1820             newSize = QSize(newSize.width() + fw - 5, newSize.height() + fw - 6);
1821         }
1822         break;
1823 #endif
1824     case CT_LineEdit:
1825         newSize += QSize(0,1);
1826         break;
1827     case CT_MenuBarItem:
1828         newSize += QSize(5, 1);
1829         break;
1830     case CT_MenuItem:
1831         newSize += QSize(0, -2);
1832         break;
1833     case CT_MenuBar:
1834         newSize += QSize(0, -1);
1835         break;
1836     case CT_ToolButton:
1837         if (const QStyleOptionToolButton *b = qstyleoption_cast<const QStyleOptionToolButton *>(option)) {
1838           if (b->toolButtonStyle != Qt::ToolButtonIconOnly)
1839             newSize = QSize(newSize.width() + 1, newSize.height() - 1);
1840           else
1841             newSize = QSize(newSize.width() + 1, newSize.height());
1842         }
1843         break;
1844 
1845     default:
1846         break;
1847     }
1848     return newSize;
1849 }
1850 
subElementRect(SubElement element,const QStyleOption * option,const QWidget * widget) const1851 QRect QWindowsCEStyle::subElementRect(SubElement element, const QStyleOption *option, const QWidget *widget) const {
1852     QRect rect = QWindowsStyle::subElementRect(element, option, widget);
1853     switch (element) {
1854 #ifndef QT_NO_COMBOBOX
1855     case SE_ComboBoxFocusRect:
1856         if (const QStyleOptionComboBox *cb = qstyleoption_cast<const QStyleOptionComboBox *>(option)) {
1857             int margin = cb->frame ? 3 : 0;
1858             rect.setRect(margin, margin, option->rect.width() - 2*margin - 20, option->rect.height() - 2*margin);
1859             rect = visualRect(option->direction, option->rect, rect);
1860         }
1861         break;
1862 #endif // QT_NO_COMBOBOX
1863     default:
1864         break;
1865     }
1866     return rect;
1867 }
1868 
subControlRect(ComplexControl control,const QStyleOptionComplex * option,SubControl subControl,const QWidget * widget) const1869 QRect QWindowsCEStyle::subControlRect(ComplexControl control, const QStyleOptionComplex *option,
1870                                       SubControl subControl, const QWidget *widget) const {
1871     QRect rect = QWindowsStyle::subControlRect(control, option, subControl, widget);
1872     switch (control) {
1873 #ifndef QT_NO_SLIDER
1874         case CC_Slider:
1875         if (const QStyleOptionSlider *slider = qstyleoption_cast<const QStyleOptionSlider *>(option)) {
1876             int tickOffset = pixelMetric(PM_SliderTickmarkOffset, slider, widget);
1877             int thickness = pixelMetric(PM_SliderControlThickness, slider, widget);
1878 
1879             switch (subControl) {
1880             case SC_SliderHandle: {
1881                 int sliderPos = 0;
1882                 int len = pixelMetric(PM_SliderLength, slider, widget);
1883                 bool horizontal = slider->orientation == Qt::Horizontal;
1884                 sliderPos = sliderPositionFromValue(slider->minimum, slider->maximum,
1885                                                     slider->sliderPosition,
1886                                                     (horizontal ? slider->rect.width()
1887                                                                 : slider->rect.height()) - len,
1888                                                     slider->upsideDown);
1889                 if (horizontal)
1890                     rect.setRect(slider->rect.x() + sliderPos, slider->rect.y() + tickOffset, len, thickness);
1891                 else
1892                     rect.setRect(slider->rect.x() + tickOffset, slider->rect.y() + sliderPos, thickness, len);
1893                 break; }
1894             default:
1895                 break;
1896             }
1897             rect = visualRect(slider->direction, slider->rect, rect);
1898         }
1899         break;
1900 #endif //QT_NO_SLIDER
1901 #ifndef QT_NO_COMBOBOX
1902     case CC_ComboBox:
1903         if (const QStyleOptionComboBox *cb = qstyleoption_cast<const QStyleOptionComboBox *>(option)) {
1904         int x = cb->rect.x(),
1905             y = cb->rect.y(),
1906             wi = cb->rect.width(),
1907             he = cb->rect.height();
1908         int xpos = x;
1909         int margin = cb->frame ? 3 : 0;
1910         int bmarg = cb->frame ? 2 : 0;
1911         xpos += wi - (he - 2*bmarg) - bmarg;
1912         switch (subControl) {
1913           case SC_ComboBoxArrow:
1914             rect.setRect(xpos, y + bmarg, he - 2*bmarg, he - 2*bmarg);
1915             break;
1916            case SC_ComboBoxEditField:
1917                 rect.setRect(x + margin, y + margin, wi - 2 * margin - (he - 2*bmarg), he - 2 * margin);
1918                 break;
1919             case SC_ComboBoxListBoxPopup:
1920                 rect = cb->rect;
1921                 break;
1922             case SC_ComboBoxFrame:
1923                 rect = cb->rect;
1924                 break;
1925         default:
1926         break;
1927         }
1928         rect = visualRect(cb->direction, cb->rect, rect);
1929     }
1930 #endif //QT_NO_COMBOBOX
1931 #ifndef QT_NO_SPINBOX
1932     case CC_SpinBox:
1933         if (const QStyleOptionSpinBox *spinbox = qstyleoption_cast<const QStyleOptionSpinBox *>(option)) {
1934             QSize bs;
1935             int fw = spinbox->frame ? pixelMetric(PM_SpinBoxFrameWidth, spinbox, widget) : 0;
1936             bs.setWidth(qMax(18, (spinbox->rect.height() / 2 - fw + 1)));
1937             // 1.6 -approximate golden mean
1938             bs.setHeight(qMax(18, qMin((bs.height() * 8 / 5), (spinbox->rect.width() / 4))));
1939             bs = bs.expandedTo(QApplication::globalStrut());
1940             int y = fw;
1941             int x, lx, rx;
1942             x = spinbox->rect.width() - y - bs.width() * 2;
1943             lx = fw;
1944             rx = x - fw;
1945           switch (subControl) {
1946           case SC_SpinBoxUp:
1947                 rect = QRect(x + bs.width(), y, bs.width(), bs.height());
1948                 break;
1949           case SC_SpinBoxDown:
1950                 rect = QRect(x, y , bs.width(), bs.height());
1951                 break;
1952           case SC_SpinBoxEditField:
1953                 if (spinbox->buttonSymbols == QAbstractSpinBox::NoButtons) {
1954                     rect = QRect(lx, fw, spinbox->rect.width() - 2*fw - 2, spinbox->rect.height() - 2*fw);
1955                 } else {
1956                     rect = QRect(lx, fw, rx-2, spinbox->rect.height() - 2*fw);
1957                 }
1958                 break;
1959           case SC_SpinBoxFrame:
1960                 rect = spinbox->rect;
1961           default:
1962                 break;
1963           }
1964           rect = visualRect(spinbox->direction, spinbox->rect, rect);
1965         }
1966         break;
1967 #endif // Qt_NO_SPINBOX
1968 #ifndef QT_NO_GROUPBOX
1969     case CC_GroupBox: {
1970         if (const QStyleOptionGroupBox *groupBox = qstyleoption_cast<const QStyleOptionGroupBox *>(option)) {
1971             switch (subControl) {
1972             case SC_GroupBoxFrame:
1973                 // FALL THROUGH
1974             case SC_GroupBoxContents: {
1975                 int topMargin = 0;
1976                 int topHeight = 0;
1977                 int bottomMargin = 0;
1978                 int noLabelMargin = 0;
1979                 QRect frameRect = groupBox->rect;
1980                 int verticalAlignment = styleHint(SH_GroupBox_TextLabelVerticalAlignment, groupBox, widget);
1981                 if (groupBox->text.size()) {
1982                     topHeight = groupBox->fontMetrics.height();
1983                     if (verticalAlignment & Qt::AlignVCenter)
1984                         topMargin = topHeight / 2;
1985                     else if (verticalAlignment & Qt::AlignTop)
1986                         topMargin = -topHeight/2;
1987                 }
1988                 else {
1989                   topHeight = groupBox->fontMetrics.height();
1990                   noLabelMargin = topHeight / 2;
1991                   if (verticalAlignment & Qt::AlignVCenter) {
1992                         topMargin = topHeight / 4 - 4;
1993                         bottomMargin = topHeight / 4 - 4;
1994                   }
1995                   else if (verticalAlignment & Qt::AlignTop) {
1996                         topMargin = topHeight/2 - 4;
1997                         bottomMargin = topHeight/2 - 4;
1998                   }
1999                 }
2000 
2001                 if (subControl == SC_GroupBoxFrame) {
2002                     frameRect.setTop(topMargin);
2003                     frameRect.setBottom(frameRect.height() + bottomMargin);
2004                     rect = frameRect;
2005                     break;
2006                 }
2007 
2008                 int frameWidth = 0;
2009                 if ((groupBox->features & QStyleOptionFrameV2::Flat) == 0)
2010                     frameWidth = pixelMetric(PM_DefaultFrameWidth, groupBox, widget);
2011                 rect = frameRect.adjusted(frameWidth, frameWidth + topHeight, -frameWidth, -frameWidth - noLabelMargin);
2012                 break;
2013             }
2014             case SC_GroupBoxCheckBox:
2015                 // FALL THROUGH
2016             case SC_GroupBoxLabel: {
2017                 QFontMetrics fontMetrics = groupBox->fontMetrics;
2018                 int h = fontMetrics.height();
2019                 int tw = fontMetrics.size(Qt::TextShowMnemonic, groupBox->text + QLatin1Char(' ')).width();
2020                 int marg = (groupBox->features & QStyleOptionFrameV2::Flat) ? 0 : 8;
2021                 rect = groupBox->rect.adjusted(marg, 0, -marg, 0);
2022                 rect.setHeight(h);
2023 
2024                 int indicatorWidth = pixelMetric(PM_IndicatorWidth, option, widget);
2025                 int indicatorSpace = pixelMetric(PM_CheckBoxLabelSpacing, option, widget) - 1;
2026                 bool hasCheckBox = groupBox->subControls & QStyle::SC_GroupBoxCheckBox;
2027                 int checkBoxSize = hasCheckBox ? (indicatorWidth + indicatorSpace) : 0;
2028 
2029                 // Adjusted rect for label + indicatorWidth + indicatorSpace
2030                 QRect totalRect = alignedRect(groupBox->direction, groupBox->textAlignment,
2031                                               QSize(tw + checkBoxSize, h), rect);
2032 
2033                 // Adjust totalRect if checkbox is set
2034                 if (hasCheckBox) {
2035                     bool ltr = groupBox->direction == Qt::LeftToRight;
2036                     int left = 0;
2037                     // Adjust for check box
2038                     if (subControl == SC_GroupBoxCheckBox) {
2039                         int indicatorHeight = pixelMetric(PM_IndicatorHeight, option, widget);
2040                         left = ltr ? totalRect.left() : (totalRect.right() - indicatorWidth);
2041                         int top = totalRect.top() + (fontMetrics.height() - indicatorHeight) / 2;
2042                         totalRect.setRect(left, top, indicatorWidth, indicatorHeight);
2043                     // Adjust for label
2044                     } else {
2045                         left = ltr ? (totalRect.left() + checkBoxSize - 2) : totalRect.left();
2046                         totalRect.setRect(left, totalRect.top(),
2047                                           totalRect.width() - checkBoxSize, totalRect.height());
2048                     }
2049                 }
2050                 rect = totalRect;
2051                 break;
2052             }
2053             default:
2054                 break;
2055             }
2056         }
2057         break;
2058     }
2059 #endif // QT_NO_GROUPBOX
2060     default:
2061         break;
2062     }
2063     return rect;
2064 }
2065 
hitTestComplexControl(ComplexControl control,const QStyleOptionComplex * option,const QPoint & pos,const QWidget * widget) const2066 QStyle::SubControl QWindowsCEStyle::hitTestComplexControl(ComplexControl control, const QStyleOptionComplex *option,
2067                                                           const QPoint &pos, const QWidget *widget) const {
2068     /*switch (control) {
2069     default:
2070         break;
2071     }*/
2072     return QWindowsStyle::hitTestComplexControl(control, option, pos, widget);
2073 }
2074 
2075 
standardPalette() const2076 QPalette QWindowsCEStyle::standardPalette() const {
2077     QPalette palette (Qt::black,QColor(198, 195, 198), QColor(222, 223, 222 ),
2078                       QColor(132, 130, 132), QColor(198, 195, 198) ,  Qt::black,  Qt::white, Qt::white, QColor(198, 195, 198));
2079     palette.setColor(QPalette::Window, QColor(198, 195, 198));
2080     palette.setColor(QPalette::Base, Qt::white);
2081     palette.setColor(QPalette::Button, QColor(198, 195, 198));
2082     palette.setColor(QPalette::Highlight, QColor(0, 0, 132));
2083     palette.setColor(QPalette::Light, Qt::white);
2084     palette.setColor(QPalette::Midlight, QColor(222, 223, 222 ));
2085     palette.setColor(QPalette::Dark, QColor(132, 130, 132));
2086     palette.setColor(QPalette::Mid, QColor(132, 130, 132));
2087     palette.setColor(QPalette::Shadow, QColor(0, 0, 0));
2088     palette.setColor(QPalette::BrightText, QColor(33, 162, 33)); //color for ItemView checked indicator (arrow)
2089     palette.setColor(QPalette::Link, QColor(24,81,132)); // color for the box around the ItemView indicator
2090 
2091     return palette;
2092 }
2093 
polish(QApplication * app)2094 void QWindowsCEStyle::polish(QApplication *app) {
2095     QWindowsStyle::polish(app);
2096 }
2097 
polish(QWidget * widget)2098 void QWindowsCEStyle::polish(QWidget *widget) {
2099     QWindowsStyle::polish(widget);
2100 }
2101 
polish(QPalette & palette)2102 void QWindowsCEStyle::polish(QPalette &palette) {
2103     QWindowsStyle::polish(palette);
2104 }
2105 
pixelMetric(PixelMetric pm,const QStyleOption * opt,const QWidget * widget) const2106 int QWindowsCEStyle::pixelMetric(PixelMetric pm, const QStyleOption *opt, const QWidget *widget) const {
2107     int ret;
2108 
2109     switch (pm) {
2110     case PM_DefaultFrameWidth:
2111         ret = 1;
2112         break;
2113 
2114     case PM_MenuBarHMargin:
2115         ret = 2;
2116         break;
2117     case PM_MenuBarVMargin:
2118         ret = 2;
2119         break;
2120     /*case PM_MenuBarItemSpacing:
2121         ret = 2;
2122         break;*/
2123 
2124     case PM_MenuButtonIndicator:
2125         ret = 10;
2126         break;
2127 
2128     case PM_SpinBoxFrameWidth:
2129         ret = 2;
2130         break;
2131     case PM_ButtonDefaultIndicator:
2132     case PM_ButtonShiftHorizontal:
2133     case PM_ButtonShiftVertical:
2134         ret = 1;
2135         break;
2136 #ifndef QT_NO_TABBAR
2137     case PM_TabBarTabShiftHorizontal:
2138         ret = 0;
2139         break;
2140     case PM_TabBarTabShiftVertical:
2141         ret = 6;
2142         break;
2143 #endif
2144     case PM_MaximumDragDistance:
2145         ret = 60;
2146         break;
2147 
2148       case PM_IndicatorWidth:
2149         ret = windowsCEIndicatorSize;
2150         break;
2151 
2152     case PM_IndicatorHeight:
2153         ret = windowsCEIndicatorSize;
2154         break;
2155 
2156     case PM_ExclusiveIndicatorWidth:
2157         ret = windowsCEExclusiveIndicatorSize;
2158         break;
2159 
2160     case PM_ExclusiveIndicatorHeight:
2161         ret = windowsCEExclusiveIndicatorSize;;
2162         break;
2163 
2164 #ifndef QT_NO_SLIDER
2165     case PM_SliderLength:
2166         ret = 12;
2167         break;
2168     case PM_SliderThickness:
2169         ret = windowsCESliderThickness;
2170         break;
2171 
2172      case PM_TabBarScrollButtonWidth:
2173         ret = 18;
2174         break;
2175 
2176         // Returns the number of pixels to use for the business part of the
2177         // slider (i.e., the non-tickmark portion). The remaining space is shared
2178         // equally between the tickmark regions.
2179     case PM_SliderControlThickness:
2180         if (const QStyleOptionSlider *sl = qstyleoption_cast<const QStyleOptionSlider *>(opt)) {
2181             int space = (sl->orientation == Qt::Horizontal) ? sl->rect.height() : sl->rect.width();
2182             int ticks = sl->tickPosition;
2183             int n = 0;
2184             if (ticks & QSlider::TicksAbove)
2185                 ++n;
2186             if (ticks & QSlider::TicksBelow)
2187                 ++n;
2188             if (!n) {
2189                 ret = space;
2190                 break;
2191             }
2192             int thick = 12;
2193             if (ticks != QSlider::TicksBothSides && ticks != QSlider::NoTicks)
2194                 thick += pixelMetric(PM_SliderLength, sl, widget) / 4;
2195 
2196             space -= thick;
2197             if (space > 0)
2198                 thick += (space * 2) / (n + 2);
2199             ret = thick;
2200         } else {
2201             ret = 0;
2202         }
2203         break;
2204 #endif // QT_NO_SLIDER
2205 
2206 #ifndef QT_NO_MENU
2207 
2208     case PM_SmallIconSize:
2209         ret = windowsCEIconSize;
2210         break;
2211     case PM_ButtonMargin:
2212         ret = 6;
2213         break;
2214 
2215     case PM_LargeIconSize:
2216         ret = 32;
2217         break;
2218 
2219     case PM_IconViewIconSize:
2220         ret = pixelMetric(PM_LargeIconSize, opt, widget);
2221         break;
2222 
2223     case PM_ToolBarIconSize:
2224         ret = windowsCEIconSize;
2225         break;
2226     case PM_DockWidgetTitleMargin:
2227         ret = 2;
2228         break;
2229 #if defined(Q_WS_WIN)
2230 //    case PM_DockWidgetFrameWidth:
2231 //        ret = GetSystemMetrics(SM_CXFRAME);
2232 //        break;
2233 #else
2234     case PM_DockWidgetFrameWidth:
2235         ret = 4;
2236         break;
2237 #endif // Q_WS_WIN
2238     break;
2239 
2240 #endif // QT_NO_MENU
2241 
2242    case PM_TitleBarHeight:
2243           ret = 30;
2244         break;
2245     case PM_ScrollBarExtent:
2246         ret = 19;
2247         break;
2248     case PM_SplitterWidth:
2249         ret = qMax(4, QApplication::globalStrut().width());
2250         break;
2251 
2252 #if defined(Q_WS_WIN)
2253     case PM_MDIFrameWidth:
2254         ret = 3;
2255         break;
2256 #endif
2257     case PM_ToolBarItemMargin:
2258         ret = 1;
2259         break;
2260     case PM_ToolBarItemSpacing:
2261         ret = 0;
2262         break;
2263     case PM_ToolBarHandleExtent:
2264         ret = 10;
2265         break;
2266     case PM_ButtonIconSize:
2267         ret = 22;
2268         break;
2269     default:
2270         ret = QWindowsStyle::pixelMetric(pm, opt, widget);
2271         break;
2272     }
2273     return ret;
2274 }
2275 
standardPixmap(StandardPixmap standardPixmap,const QStyleOption * opt,const QWidget * widget) const2276 QPixmap QWindowsCEStyle::standardPixmap(StandardPixmap standardPixmap, const QStyleOption *opt,
2277                                       const QWidget *widget) const {
2278 #ifndef QT_NO_IMAGEFORMAT_XPM
2279     /*switch (standardPixmap) {
2280 
2281     default:
2282         break;
2283     }*/
2284 #endif //QT_NO_IMAGEFORMAT_XPM
2285     return QWindowsStyle::standardPixmap(standardPixmap, opt, widget);
2286 }
2287 
styleHint(StyleHint hint,const QStyleOption * opt,const QWidget * widget,QStyleHintReturn * returnData) const2288 int QWindowsCEStyle::styleHint(StyleHint hint, const QStyleOption *opt, const QWidget *widget,
2289                              QStyleHintReturn *returnData) const {
2290     int ret;
2291     switch (hint) {
2292     case SH_TabBar_ElideMode:
2293         ret = Qt::ElideMiddle;
2294         break;
2295     case SH_EtchDisabledText:
2296         ret = false;
2297         break;
2298     case SH_RequestSoftwareInputPanel:
2299         ret = RSIP_OnMouseClick;
2300         break;
2301     default:
2302         ret = QWindowsStyle::styleHint(hint, opt, widget, returnData);
2303         break;
2304     }
2305     return ret;
2306 }
2307 
drawWinShades(QPainter * p,int x,int y,int w,int h,const QColor & c1,const QColor & c2,const QColor & c3,const QColor & c4,const QBrush * fill)2308 void QWindowsCEStylePrivate::drawWinShades(QPainter *p,
2309                            int x, int y, int w, int h,
2310                            const QColor &c1, const QColor &c2,
2311                            const QColor &c3, const QColor &c4,
2312                            const QBrush *fill) {
2313     if (w < 2 || h < 2)                        // can't do anything with that
2314         return;
2315     QPen oldPen = p->pen();
2316     QPoint a[3] = { QPoint(x, y+h-2), QPoint(x, y), QPoint(x+w-2, y) };
2317     p->setPen(c1);
2318     p->drawPolyline(a, 3);
2319     QPoint b[3] = { QPoint(x, y+h-1), QPoint(x+w-1, y+h-1), QPoint(x+w-1, y) };
2320     p->setPen(c2);
2321     p->drawPolyline(b, 3);
2322     if (w > 4 && h > 4) {
2323         QPoint c[3] = { QPoint(x+1, y+h-3), QPoint(x+1, y+1), QPoint(x+w-3, y+1) };
2324         p->setPen(c3);
2325         p->drawPolyline(c, 3);
2326         QPoint d[3] = { QPoint(x+1, y+h-2), QPoint(x+w-2, y+h-2), QPoint(x+w-2, y+1) };
2327         p->setPen(c4);
2328         p->drawPolyline(d, 3);
2329         if (fill)
2330             p->fillRect(QRect(x+2, y+2, w-4, h-4), *fill);
2331     }
2332     p->setPen(oldPen);
2333 }
2334 
drawWinCEShades(QPainter * p,int x,int y,int w,int h,const QColor & c1,const QColor & c2,const QColor & c3,const QColor & c4,const QBrush * fill)2335 void QWindowsCEStylePrivate::drawWinCEShades(QPainter *p,
2336                            int x, int y, int w, int h,
2337                            const QColor &c1, const QColor &c2,
2338                            const QColor &c3, const QColor &c4,
2339                            const QBrush *fill) {
2340     if (w < 2 || h < 2)                        // can't do anything with that
2341         return;
2342     QPen oldPen = p->pen();
2343     QPoint b[3] = { QPoint(x, y+h-1), QPoint(x+w-1, y+h-1), QPoint(x+w-1, y) };
2344     p->setPen(c2);
2345     p->drawPolyline(b, 3);
2346     if (w > 4 && h > 4) {
2347         QPoint c[3] = { QPoint(x+1, y+h-3), QPoint(x+1, y+1), QPoint(x+w-3, y+1) };
2348         p->setPen(c3);
2349         p->drawPolyline(c, 3);
2350         QPoint d[5] = { QPoint(x, y+h-2), QPoint(x+w-2, y+h-2), QPoint(x+w-2, y), QPoint(x, y), QPoint(x, y+h-2) };
2351         p->setPen(c4);
2352         p->drawPolyline(d, 5);
2353         if (fill)
2354             p->fillRect(QRect(x+2, y+2, w-4, h-4), *fill);
2355     }
2356     QPoint a[3] = { QPoint(x+1, y+h-3), QPoint(x+1, y+1), QPoint(x+w-3, y+1) };
2357     p->setPen(c1);
2358     p->drawPolyline(a, 3);
2359     p->setPen(oldPen);
2360 }
2361 
drawWinCEShadesSunken(QPainter * p,int x,int y,int w,int h,const QColor & c1,const QColor & c2,const QColor & c3,const QColor & c4,const QBrush * fill)2362 void QWindowsCEStylePrivate::drawWinCEShadesSunken(QPainter *p,
2363                            int x, int y, int w, int h,
2364                            const QColor &c1, const QColor &c2,
2365                            const QColor &c3, const QColor &c4,
2366                            const QBrush *fill) {
2367     if (w < 2 || h < 2)                        // can't do anything with that
2368         return;
2369     QPen oldPen = p->pen();
2370 
2371     QPoint b[3] = { QPoint(x, y+h-1), QPoint(x+w-1, y+h-1), QPoint(x+w-1, y) };
2372     p->setPen(c2);
2373     p->drawPolyline(b, 3);
2374     if (w > 4 && h > 4) {
2375         QPoint d[3] = { QPoint(x, y+h-2), QPoint(x+w-2, y+h-2), QPoint(x+w-2, y) };
2376         p->setPen(c4);
2377         p->drawPolyline(d, 3);
2378         QPoint c[3] = { QPoint(x, y+h-2), QPoint(x, y), QPoint(x+w-2, y) };
2379         p->setPen(c3);
2380         p->drawPolyline(c, 3);
2381         if (fill)
2382             p->fillRect(QRect(x+2, y+2, w-4, h-4), *fill);
2383     }
2384     QPoint a[3] = { QPoint(x+1, y+h-3), QPoint(x+1, y+1), QPoint(x+w-3, y+1) };
2385     p->setPen(c1);
2386     p->drawPolyline(a, 3);
2387     p->setPen(oldPen);
2388 }
2389 
2390 
drawWinCEButton(QPainter * p,int x,int y,int w,int h,const QPalette & pal,bool sunken,const QBrush * fill)2391 void QWindowsCEStylePrivate::drawWinCEButton(QPainter *p, int x, int y, int w, int h,
2392                      const QPalette &pal, bool sunken,
2393                      const QBrush *fill) {
2394     if (sunken)
2395         drawWinCEShadesSunken(p, x, y, w, h,
2396                        pal.shadow().color(), pal.light().color(), pal.shadow().color(),
2397                        pal.midlight().color(), fill);
2398     else
2399         drawWinCEShades(p, x, y, w, h,
2400                        pal.midlight().color(), pal.shadow().color(), pal.button().color(),
2401                        pal.dark().color(), fill);
2402 }
2403 
drawWinCEPanel(QPainter * p,int x,int y,int w,int h,const QPalette & pal,bool sunken,const QBrush * fill)2404 void QWindowsCEStylePrivate::drawWinCEPanel(QPainter *p, int x, int y, int w, int h,
2405                     const QPalette &pal, bool        sunken,
2406                     const QBrush *fill) {
2407     if (sunken)
2408         drawWinShades(p, x, y, w, h,
2409                         pal.dark().color(), pal.light().color(), pal.shadow().color(),
2410                        pal.midlight().color(), fill);
2411     else
2412         drawWinShades(p, x, y, w, h,
2413                        pal.light().color(), pal.shadow().color(), pal.button().color(),
2414                        pal.midlight().color(), fill);
2415 }
2416 
drawWinCEButton(QPainter * p,const QRect & r,const QPalette & pal,bool sunken,const QBrush * fill)2417 void QWindowsCEStylePrivate::drawWinCEButton(QPainter *p, const QRect &r,
2418                      const QPalette &pal, bool sunken, const QBrush *fill) {
2419     drawWinCEButton(p, r.x(), r.y(), r.width(), r.height(), pal, sunken, fill);
2420 }
2421 
drawWinCEPanel(QPainter * p,const QRect & r,const QPalette & pal,bool sunken,const QBrush * fill)2422 void QWindowsCEStylePrivate::drawWinCEPanel(QPainter *p, const QRect &r,
2423                     const QPalette &pal, bool sunken, const QBrush *fill) {
2424     drawWinCEPanel(p, r.x(), r.y(), r.width(), r.height(), pal, sunken, fill);
2425 }
2426 
2427 QT_END_NAMESPACE
2428 
2429 #endif // QT_NO_STYLE_WINDOWSCE
2430