/* QtCurve (C) Craig Drummond, 2003 - 2010 craig.p.drummond@gmail.com ---- Based upon B???Curve style (Copyright (c) 2002 R?d H?t, Inc) Bernhard Rosenkrazer Preston Brown Than Ngo This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License version 2 as published by the Free Software Foundation. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; see the file COPYING. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. ---- B???Curve is based on the KDE Light style, 2nd revision: Copyright(c)2000-2001 Trolltech AS (info@trolltech.com). The light style license is as follows: Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files(the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /* KHTML ----- Srollbars: For some reason Scrollbars in KHTML seem to lose the bottom/left pixels. As if KHTML expects the scrollbar to be 1 pixel smaller/thinner than it actually is. To 'fix' this, the pixelMetric function will return 1 scrollbar with 1 greater than standard for form widgets, or where widget==0L In the CC_ScrollBar draw code, the rects used for each component are shrunk by 1, in the appropriate dimension, so as to draw the scrollbar at the correct size. */ #include #include "config.h" #ifndef QTC_QT_ONLY #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define COMMON_FUNCTIONS #include "qtcurve.h" #define CONFIG_READ #include "config_file.c" #include "pixmaps.h" #include #include #include #include #include // Need access to classname from within QMetaObject... #define private public #include #include #include #include "qtc_fixx11h.h" static const Atom constNetMoveResize = XInternAtom(qt_xdisplay(), "_NET_WM_MOVERESIZE", False); static const QWidget * getTopLevel(const QWidget *widget) { const QWidget *w=widget; while(w && !w->isTopLevel()) w=w->parentWidget(); return w; } static void emitMenuSize(const QWidget *widget, unsigned short size) { const QWidget *w=getTopLevel(widget); if(w) { static const Atom constAtom = XInternAtom(qt_xdisplay(), MENU_SIZE_ATOM, False); XChangeProperty(qt_xdisplay(), w->parentWidget() ? w->parentWidget()->winId() : w->winId(), constAtom, XA_CARDINAL, 16, PropModeReplace, (unsigned char *)&size, 1); } } void setBgndProp(QWidget *widget, unsigned short app) { const QWidget *w=getTopLevel(widget); if(w) { static const Atom constAtom = XInternAtom(qt_xdisplay(), BGND_ATOM, False); XChangeProperty(qt_xdisplay(), w->parentWidget() ? w->parentWidget()->winId() : w->winId(), constAtom, XA_CARDINAL, 16, PropModeReplace, (unsigned char *)&app, 1); } } static void triggerWMMove(const QWidget *w, const QPoint &p) { //...Taken from bespin... // stolen... errr "adapted!" from QSizeGrip XEvent xev; xev.xclient.type = ClientMessage; xev.xclient.message_type = constNetMoveResize; xev.xclient.display = qt_xdisplay(); xev.xclient.window = w->parentWidget() ? w->parentWidget()->winId() : w->winId(); xev.xclient.format = 32; xev.xclient.data.l[0] = p.x(); xev.xclient.data.l[1] = p.y(); xev.xclient.data.l[2] = 8; // NET::Move xev.xclient.data.l[3] = Button1; xev.xclient.data.l[4] = 0; XUngrabPointer(qt_xdisplay(), CurrentTime); XSendEvent(qt_xdisplay(), qt_xrootwin(), False, SubstructureRedirectMask | SubstructureNotifyMask, &xev); } #define MO_ARROW_X(FLAGS, COL) (MO_NONE!=opts.coloredMouseOver && FLAGS&Style_MouseOver && FLAGS&Style_Enabled ? itsMouseOverCols[ARROW_MO_SHADE] : COL) #define MO_ARROW(COL) MO_ARROW_X(flags, COL) static const int constMenuPixmapWidth=22; static bool useQt3Settings() { static int ver=0; if(0==ver) { const char *sessionVersion=getenv("KDE_SESSION_VERSION"); ver=sessionVersion ? atoi(sessionVersion)<4 ? 3 : 4 #ifdef QTC_DEFAULT_TO_KDE3 : 3; #else : getenv("KDE_FULL_SESSION") ? 3 : 4; #endif } return 3==ver; } static QRect adjusted(const QRect r, int xp1, int yp1, int xp2, int yp2) { int x1, y1, x2, y2; r.coords(&x1, &y1, &x2, &y2); return QRect(QPoint(x1 + xp1, y1 + yp1), QPoint(x2 + xp2, y2 + yp2)); } static void adjust(QRect &r, int dx1, int dy1, int dx2, int dy2) { int x1, y1, x2, y2; r.coords(&x1, &y1, &x2, &y2); x1 += dx1; y1 += dy1; x2 += dx2; y2 += dy2; r.setCoords(x1, y1, x2, y2); } inline bool isSpecialHover(QWidget *w) { return w && ( #if QT_VERSION >= 0x030200 ::qt_cast(w) || ::qt_cast(w) || #endif ::qt_cast(w) || #if defined KDE_VERSION && KDE_VERSION >= 0x30400 && KDE_VERSION < 0x30500 ::qt_cast(w) || #endif ::qt_cast(w) || ::qt_cast(w) || ::qt_cast(w) || ::qt_cast(w) ); } static QString readEnvPath(const char *env) { QCString path=getenv(env); return path.isEmpty() ? QString::null : QFile::decodeName(path); } static QString kdeHome(bool kde3=false) { static QString kdeHome[2]; // Execute kde-config to ascertain users KDEHOME if(kdeHome[kde3 ? 0 : 1].isEmpty()) { FILE *fpipe; if (fpipe = (FILE*)popen(kde3 ? "kde-config --localprefix 2> /dev/null" : "kde4-config --localprefix 2> /dev/null", "r")) { char line[1024]; while(fgets(line, sizeof line, fpipe)) { kdeHome[kde3 ? 0 : 1]=QFile::decodeName(line).replace("\n", ""); break; } pclose(fpipe); } } // Try env vars... if(kdeHome[kde3 ? 0 : 1].isEmpty()) { kdeHome[kde3 ? 0 : 1]=readEnvPath(getuid() ? "KDEHOME" : "KDEROOTHOME"); if (kdeHome[kde3 ? 0 : 1].isEmpty()) { QDir homeDir(QDir::homeDirPath()); QString kdeConfDir("/.kde"); if (!kde3 && homeDir.exists(".kde4")) kdeConfDir = QString("/.kde4"); kdeHome[kde3 ? 0 : 1] = QDir::homeDirPath() + kdeConfDir; } } return kdeHome[kde3 ? 0 : 1]; } #ifdef QTC_STYLE_SUPPORT static void getStyles(const QString &dir, const char *sub, QStringList &styles) { QDir d(dir+sub); if(d.exists()) { d.setNameFilter(THEME_PREFIX"*"THEME_SUFFIX); QStringList entries(d.entryList()); QStringList::ConstIterator it(entries.begin()), end(entries.end()); for(; it!=end; ++it) { QString style((*it).left((*it).findRev(THEME_SUFFIX))); if(!styles.contains(style)) styles.append(style); } } } static void getStyles(const QString &dir, QStringList &styles) { getStyles(dir, THEME_DIR, styles); getStyles(dir, THEME_DIR4, styles); } static QString themeFile(const QString &dir, const QString &n, const char *sub) { QString name(dir+sub+n+THEME_SUFFIX); return QFile(name).exists() ? name : QString(); } static QString themeFile(const QString &dir, const QString &n, bool kde3=true) { QString name(themeFile(dir, n, kde3 ? THEME_DIR : THEME_DIR4)); if(name.isEmpty()) name=themeFile(dir, n, kde3 ? THEME_DIR4 : THEME_DIR); return name; } #endif class QtCurveStylePlugin : public QStylePlugin { public: QtCurveStylePlugin() : QStylePlugin() { } QStringList keys() const { QStringList list; list << "QtCurve"; #ifdef QTC_STYLE_SUPPORT getStyles(kdeHome(useQt3Settings()), list); getStyles(kdeHome(!useQt3Settings()), list); getStyles(KDE_PREFIX(useQt3Settings() ? 3 : 4), list); getStyles(KDE_PREFIX(useQt3Settings() ? 4 : 3), list); #endif return list; } QStyle * create(const QString &s) { return "qtcurve"==s.lower() ? new QtCurveStyle #ifdef QTC_STYLE_SUPPORT : 0==s.find(THEME_PREFIX) ? new QtCurveStyle(s) #endif : 0; } }; Q_EXPORT_PLUGIN(QtCurveStylePlugin) #define SKIP_TASKBAR (APP_SKIP_TASKBAR==itsThemedApp || APP_KPRINTER==itsThemedApp || APP_KDIALOG==itsThemedApp) #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 #include #endif #define NO_SECT -1 #define VERTICAL_TB_BUTTON 0x01000000 #define CHECK_BUTTON 0x02000000 #define STD_TOOLBUTTON 0x04000000 #define TOGGLE_BUTTON 0x08000000 #define NO_ETCH_BUTTON 0x10000000 #define DW_CLOSE_BUTTON 0x80000000 #define LISTVIEW_ITEM 0x20000000 #define MENU_ITEM 0x40000000 #define WINDOWTITLE_SPACER 0x10000000 #define DW_BGND 105 #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 // Try to read $KDEHOME/share/config/kickerrc to find out if kicker is transparent... static bool kickerIsTrans() { QString cfgFileName(kdeHome(true)+"/share/config/kickerrc"); bool trans(false); QFile cfgFile(cfgFileName); if (cfgFile.open(IO_ReadOnly)) { QTextStream stream(&cfgFile); QString line; bool stop(false), inGen(false); while (!stream.atEnd() && !stop) { line=stream.readLine(); if(inGen) { if(0==line.find("Transparent=", false)) // Found it! { if(-1!=line.find("true", false)) trans=true; stop=true; } else if(line[0]==QChar('[')) // Then wasn't in General section... stop=true; } else if(0==line.find("[General]", false)) inGen=true; } cfgFile.close(); } return trans; } #endif static bool isKhtmlWidget(const QWidget *w, int level=1) { return w && ((w->name() && 0==strcmp(w->name(), "__khtml")) || (level && isKhtmlWidget(w->parentWidget(), --level))); } static bool isKhtmlFormWidget(const QWidget *widget) { if(isKhtmlWidget(widget)) return true; // Copied from Keramik... //Form widgets are in the KHTMLView, but that has 2 further inner levels //of widgets - QClipperWidget, and outside of that, QViewportWidget QWidget *potentialClipPort(widget ? widget->parentWidget() : 0L); if (!potentialClipPort || potentialClipPort->isTopLevel()) return false; QWidget *potentialViewPort(potentialClipPort->parentWidget()); if (!potentialViewPort || potentialViewPort->isTopLevel() || qstrcmp(potentialViewPort->name(), "qt_viewport")) return false; QWidget *potentialKHTML(potentialViewPort->parentWidget()); if (!potentialKHTML || potentialKHTML->isTopLevel() || qstrcmp(potentialKHTML->className(), "KHTMLView")) return false; return true; } static bool inStackWidget(const QWidget *w) { while(w) { if(::qt_cast(w)) return true; w=w->parentWidget(); } return false; } static void setRgb(QColor *col, const QStringList &rgb) { if(3==rgb.size()) *col=QColor(rgb[0].toInt(), rgb[1].toInt(), rgb[2].toInt()); } struct KDESettings { KDESettings() { inactiveHighlight=false; } bool inactiveHighlight; QColor hover, focus; }; static KDESettings kdeSettings; static bool readKdeGlobals() { static int lastCheck=0; int now=time(0L); // Dont keep on reading kdeglobals file - only read if its been at least 2 seconds since the last time... if(abs(now-lastCheck)<3) return false; QColor highlight(QApplication::palette().active().highlight()); bool inactiveEnabled(false), changeSelectionColor(false), useQt3(useQt3Settings()); QFile f(kdeHome(useQt3)+"/share/config/kdeglobals"); lastCheck=now; if(useQt3) kdeSettings.hover=kdeSettings.focus=highlight; else { kdeSettings.hover=QColor(119, 183, 255); kdeSettings.focus=QColor( 43, 116, 199); } if(f.open(IO_ReadOnly)) { QTextStream in(&f); bool inPal(false), inInactive(false), donePal(useQt3), doneInactive(false); while (!in.atEnd() && (!donePal || !doneInactive)) { QString line(in.readLine()); if(inPal) { if(0==line.find("DecorationFocus=", false)) setRgb(&kdeSettings.focus, QStringList::split(",", line.mid(16))); else if(0==line.find("DecorationHover=", false)) setRgb(&kdeSettings.hover, QStringList::split(",", line.mid(16))); else if (-1!=line.find('[')) { donePal=true; inPal=false; } } else if(inInactive) { if(0==line.find("ChangeSelectionColor=", false)) changeSelectionColor=line.find("=true"); else if(0==line.find("Enable=", false)) inactiveEnabled=line.find("=true"); else if (-1!=line.find('[')) { doneInactive=true; inInactive=false; } } if(!inPal && !inInactive) if(!useQt3 && 0==line.find("[Colors:Button]", false)) inPal=true; else if(!useQt3 && 0==line.find("[ColorEffects:Inactive]", false)) inInactive=true; } f.close(); } kdeSettings.inactiveHighlight=changeSelectionColor && inactiveEnabled; return true; } static void drawLines(QPainter *p, const QRect &r, bool horiz, int nLines, int offset, const QColor *cols, int startOffset, int dark, ELine type) { int space((nLines*2)+(LINE_DASHES!=type ? (nLines-1) : 0)), step(LINE_DASHES!=type ? 3 : 2), etchedDisp(LINE_SUNKEN==type ? 1 : 0), x(horiz ? r.x(): r.x()+((r.width()-space)>>1)), y(horiz ? r.y()+((r.height()-space)>>1): r.y()), x2(r.x()+r.width()-1), y2(r.y()+r.height()-1), i; if(horiz) { if(startOffset && y+startOffset>0) y+=startOffset; p->setPen(cols[dark]); for(i=0; idrawLine(x+offset, y+i, x2-offset, y+i); if(LINE_FLAT!=type) { x+=etchedDisp; x2+=etchedDisp; p->setPen(cols[0]); for(i=1; idrawLine(x+offset, y+i, x2-offset, y+i); } } else { if(startOffset && x+startOffset>0) x+=startOffset; p->setPen(cols[dark]); for(i=0; idrawLine(x+i, y+offset, x+i, y2-offset); if(LINE_FLAT!=type) { y+=etchedDisp; y2+=etchedDisp; p->setPen(cols[0]); for(i=1; idrawLine(x+i, y+offset, x+i, y2-offset); } } } static void drawDots(QPainter *p, const QRect &r, bool horiz, int nLines, int offset, const QColor *cols, int startOffset, int dark) { int space((nLines*2)+(nLines-1)), x(horiz ? r.x() : r.x()+((r.width()-space)>>1)), y(horiz ? r.y()+((r.height()-space)>>1) : r.y()), i, j, numDots((horiz ? (r.width()-(2*offset))/3 : (r.height()-(2*offset))/3)+1); if(horiz) { if(startOffset && y+startOffset>0) y+=startOffset; p->setPen(cols[dark]); for(i=0; idrawPoint(x+offset+(3*j), y+i); p->setPen(cols[0]); for(i=1; idrawPoint(x+offset+1+(3*j), y+i); } else { if(startOffset && x+startOffset>0) x+=startOffset; p->setPen(cols[dark]); for(i=0; idrawPoint(x+i, y+offset+(3*j)); p->setPen(cols[0]); for(i=1; idrawPoint(x+i, y+offset+1+(3*j)); } } static bool onToolBar(QWidget *widget, int l=0) { return l<3 && widget && widget->parentWidget() ? widget->parentWidget()->inherits("QToolBar") || onToolBar(widget->parentWidget(), ++l) : false; } #define PIXMAP_DIMENSION 10 enum ECacheFlags { CACHE_STD, CACHE_COL_SEL_TAB }; static QString createKey(int size, QRgb color, bool horiz, int app, ECacheFlags flags) { QString key; QTextOStream(&key) << size << '-' << color << '-' << horiz << '-' << app << '-' << flags; return key; } static QString createKey(QRgb color, char type='p') { QString key; QTextOStream(&key) << type << color; return key; } static QString createKey(QRgb color, EPixmap p) { QString key; QTextOStream(&key) << 'P' << color << p; return key; } #ifdef SET_MDI_WINDOW_BUTTON_POSITIONS static void parseWindowLine(const QString &line, QValueList &data) { int len(line.length()); for(int i=0; iparent() && ::qt_cast(w) && ::qt_cast(w->parent()) && !qstrcmp(w->name(), "qt_groupbox_checkbox"); } static void drawArrow(QPainter *p, const QRect &r, const QColor &col, QStyle::PrimitiveElement pe, const Options &opts, bool small=false) { QPointArray a; if(small) switch(pe) { case QStyle::PE_ArrowUp: a.setPoints(opts.vArrows ? 6 : 3, 2,0, 0,-2, -2,0, -2,1, 0,-1, 2,1); break; case QStyle::PE_ArrowDown: a.setPoints(opts.vArrows ? 6 : 3, 2,0, 0,2, -2,0, -2,-1, 0,1, 2,-1); break; case QStyle::PE_ArrowRight: a.setPoints(opts.vArrows ? 6 : 3, 0,-2, 2,0, 0,2, -1,2, 1,0 -1,-2); break; case QStyle::PE_ArrowLeft: a.setPoints(opts.vArrows ? 6 : 3, 0,-2, -2,0, 0,2, 1,2, -1,0, 1,-2); break; default: return; } else // Large arrows... switch(pe) { case QStyle::PE_ArrowUp: a.setPoints(opts.vArrows ? 8 : 3, 3,1, 0,-2, -3,1, -3,2, -2,2, 0,0, 2,2, 3,2); break; case QStyle::PE_ArrowDown: a.setPoints(opts.vArrows ? 8 : 3, 3,-1, 0,2, -3,-1, -3,-2, -2,-2, 0,0, 2,-2, 3,-2); break; case QStyle::PE_ArrowRight: a.setPoints(opts.vArrows ? 8 : 3, -1,-3, 2,0, -1,3, -2,3, -2,2, 0,0, -2,-2, -2,-3); break; case QStyle::PE_ArrowLeft: a.setPoints(opts.vArrows ? 8 : 3, 1,-3, -2,0, 1,3, 2,3, 2,2, 0,0, 2,-2, 2,-3); break; default: return; } if(a.isNull()) return; p->save(); a.translate((r.x()+(r.width()>>1)),(r.y()+(r.height()>>1))); p->setBrush(col); p->setPen(col); p->drawPolygon(a); p->restore(); } #ifdef QTC_STYLE_SUPPORT QtCurveStyle::QtCurveStyle(const QString &name) #else QtCurveStyle::QtCurveStyle() #endif : BASE_STYLE(AllowMenuTransparency, WindowsStyleScrollBar), itsSliderCols(0L), itsDefBtnCols(0L), itsMouseOverCols(0L), itsComboBtnCols(0L), itsCheckRadioSelCols(0L), itsSortedLvColors(0L), itsProgressCols(0L), itsSidebarButtonsCols(0L), itsActiveMdiColors(0L), itsMdiColors(0L), itsThemedApp(APP_OTHER), itsPixmapCache(150000, 499), #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 itsIsTransKicker(false), #endif itsHover(HOVER_NONE), itsOldPos(-1, -1), itsFormMode(false), itsHoverWidget(0L), itsHoverSect(NO_SECT), itsHoverTab(0L), itsMactorPal(0L), itsActive(true), itsIsSpecialHover(false), itsDragWidget(0L), itsDragWidgetHadMouseTracking(false) { #ifdef QTC_STYLE_SUPPORT QString rcFile; if(!name.isEmpty()) { rcFile=themeFile(kdeHome(), name, useQt3Settings()); if(rcFile.isEmpty()) { rcFile=themeFile(kdeHome(true), name); if(rcFile.isEmpty()) { rcFile=themeFile(KDE_PREFIX(useQt3Settings() ? 3 : 4), name, useQt3Settings()); if(rcFile.isEmpty()) rcFile=themeFile(KDE_PREFIX(useQt3Settings() ? 4 : 3), name, !useQt3Settings()); } } } readConfig(rcFile, &opts); #else readConfig(QString(), &opts); #endif if(FRAME_LINE==opts.groupBox || opts.gbLabel&GB_LBL_BOLD) opts.groupBox=FRAME_NONE; opts.contrast=QSettings().readNumEntry("/Qt/KDE/contrast", DEFAULT_CONTRAST); if(opts.contrast<0 || opts.contrast>10) opts.contrast=DEFAULT_CONTRAST; itsPixmapCache.setAutoDelete(true); shadeColors(QApplication::palette().active().highlight(), itsHighlightCols); shadeColors(QApplication::palette().active().background(), itsBackgroundCols); shadeColors(QApplication::palette().active().button(), itsButtonCols); setDecorationColors(true); switch(opts.shadeSliders) { default: case SHADE_DARKEN: case SHADE_NONE: break; case SHADE_SELECTED: itsSliderCols=itsHighlightCols; break; case SHADE_BLEND_SELECTED: case SHADE_CUSTOM: if(!itsSliderCols) itsSliderCols=new QColor [TOTAL_SHADES+1]; shadeColors(SHADE_BLEND_SELECTED==opts.shadeSliders ? midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]) : opts.customSlidersColor, itsSliderCols); } switch(opts.defBtnIndicator) { case IND_GLOW: case IND_SELECTED: itsDefBtnCols=itsHighlightCols; break; case IND_TINT: itsDefBtnCols=new QColor [TOTAL_SHADES+1]; shadeColors(tint(itsButtonCols[ORIGINAL_SHADE], itsHighlightCols[ORIGINAL_SHADE], DEF_BNT_TINT), itsDefBtnCols); break; default: break; case IND_COLORED: if(SHADE_BLEND_SELECTED==opts.shadeSliders) itsDefBtnCols=itsSliderCols; else { itsDefBtnCols=new QColor [TOTAL_SHADES+1]; shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsDefBtnCols); } } switch(opts.comboBtn) { default: case SHADE_DARKEN: case SHADE_NONE: break; case SHADE_SELECTED: itsComboBtnCols=itsHighlightCols; break; case SHADE_BLEND_SELECTED: if(opts.shadeSliders==SHADE_BLEND_SELECTED) { itsComboBtnCols=itsSliderCols; break; } case SHADE_CUSTOM: if(opts.shadeSliders==SHADE_CUSTOM && opts.customSlidersColor==opts.customComboBtnColor) { itsComboBtnCols=itsSliderCols; break; } if(!itsComboBtnCols) itsComboBtnCols=new QColor [TOTAL_SHADES+1]; shadeColors(SHADE_BLEND_SELECTED==opts.comboBtn ? midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]) : opts.customComboBtnColor, itsComboBtnCols); } switch(opts.sortedLv) { case SHADE_DARKEN: if(!itsSortedLvColors) itsSortedLvColors=new QColor [TOTAL_SHADES+1]; shadeColors(shade(opts.lvButton ? itsButtonCols[ORIGINAL_SHADE] : itsBackgroundCols[ORIGINAL_SHADE], LV_HEADER_DARK_FACTOR), itsSortedLvColors); break; default: case SHADE_NONE: break; case SHADE_SELECTED: itsSortedLvColors=itsHighlightCols; break; case SHADE_BLEND_SELECTED: if(SHADE_BLEND_SELECTED==opts.shadeSliders) { itsSortedLvColors=itsSliderCols; break; } else if(SHADE_BLEND_SELECTED==opts.comboBtn) { itsSortedLvColors=itsComboBtnCols; break; } case SHADE_CUSTOM: if(opts.shadeSliders==SHADE_CUSTOM && opts.customSlidersColor==opts.customSortedLvColor) { itsSortedLvColors=itsSliderCols; break; } if(opts.comboBtn==SHADE_CUSTOM && opts.customComboBtnColor==opts.customSortedLvColor) { itsSortedLvColors=itsComboBtnCols; break; } if(!itsSortedLvColors) itsSortedLvColors=new QColor [TOTAL_SHADES+1]; shadeColors(SHADE_BLEND_SELECTED==opts.sortedLv ? midColor(itsHighlightCols[ORIGINAL_SHADE], (opts.lvButton ? itsButtonCols[ORIGINAL_SHADE] : itsBackgroundCols[ORIGINAL_SHADE])) : opts.customSortedLvColor, itsSortedLvColors); } switch(opts.crColor) { default: case SHADE_NONE: itsCheckRadioSelCols=itsButtonCols; break; case SHADE_DARKEN: if(!itsCheckRadioSelCols) itsCheckRadioSelCols=new QColor [TOTAL_SHADES+1]; shadeColors(shade(itsButtonCols[ORIGINAL_SHADE], LV_HEADER_DARK_FACTOR), itsCheckRadioSelCols); break; case SHADE_SELECTED: itsCheckRadioSelCols=itsHighlightCols; break; case SHADE_CUSTOM: if(SHADE_CUSTOM==opts.shadeSliders && opts.customSlidersColor==opts.customCrBgndColor) itsCheckRadioSelCols=itsSliderCols; else if(SHADE_CUSTOM==opts.comboBtn && opts.customComboBtnColor==opts.customCrBgndColor) itsCheckRadioSelCols=itsComboBtnCols; else if(SHADE_CUSTOM==opts.sortedLv && opts.customSortedLvColor==opts.customCrBgndColor) itsCheckRadioSelCols=itsSortedLvColors; else { if(!itsCheckRadioSelCols) itsCheckRadioSelCols=new QColor [TOTAL_SHADES+1]; shadeColors(opts.customCrBgndColor, itsCheckRadioSelCols); } break; case SHADE_BLEND_SELECTED: if(SHADE_BLEND_SELECTED==opts.shadeSliders) itsCheckRadioSelCols=itsSliderCols; else if(SHADE_BLEND_SELECTED==opts.comboBtn) itsCheckRadioSelCols=itsComboBtnCols; else if(SHADE_BLEND_SELECTED==opts.sortedLv) itsCheckRadioSelCols=itsSortedLvColors; else { if(!itsCheckRadioSelCols) itsCheckRadioSelCols=new QColor [TOTAL_SHADES+1]; shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsCheckRadioSelCols); } } switch(opts.progressColor) { case SHADE_NONE: itsProgressCols=itsBackgroundCols; break; default: // Not set! break; case SHADE_CUSTOM: if(SHADE_CUSTOM==opts.shadeSliders && opts.customSlidersColor==opts.customProgressColor) itsProgressCols=itsSliderCols; else if(SHADE_CUSTOM==opts.comboBtn && opts.customComboBtnColor==opts.customProgressColor) itsProgressCols=itsComboBtnCols; else if(SHADE_CUSTOM==opts.sortedLv && opts.customSortedLvColor==opts.customProgressColor) itsProgressCols=itsSortedLvColors; else if(SHADE_CUSTOM==opts.crColor && opts.customCrBgndColor==opts.customProgressColor) itsProgressCols=itsCheckRadioSelCols; else { if(!itsProgressCols) itsProgressCols=new QColor [TOTAL_SHADES+1]; shadeColors(opts.customProgressColor, itsProgressCols); } break; case SHADE_BLEND_SELECTED: if(SHADE_BLEND_SELECTED==opts.shadeSliders) itsProgressCols=itsSliderCols; else if(SHADE_BLEND_SELECTED==opts.comboBtn) itsProgressCols=itsComboBtnCols; else if(SHADE_BLEND_SELECTED==opts.sortedLv) itsProgressCols=itsSortedLvColors; else { if(!itsProgressCols) itsProgressCols=new QColor [TOTAL_SHADES+1]; shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsBackgroundCols[ORIGINAL_SHADE]), itsProgressCols); } } setMenuColors(QApplication::palette().active()); if(USE_LIGHTER_POPUP_MENU) itsLighterPopupMenuBgndCol=shade(itsBackgroundCols[ORIGINAL_SHADE], TO_FACTOR(opts.lighterPopupMenuBgnd)); if ((SHADE_CUSTOM==opts.shadeMenubars || SHADE_BLEND_SELECTED==opts.shadeMenubars || SHADE_SELECTED==opts.shadeMenubars) && "soffice.bin"==QString(qApp->argv()[0]) && TOO_DARK(SHADE_CUSTOM==opts.shadeMenubars ? opts.customMenubarsColor : itsHighlightCols[ORIGINAL_SHADE])) opts.shadeMenubars=SHADE_DARKEN; switch(opts.shadeCheckRadio) { default: itsCheckRadioCol=opts.crButton ? QApplication::palette().active().buttonText() : QApplication::palette().active().text(); break; case SHADE_BLEND_SELECTED: case SHADE_SELECTED: itsCheckRadioCol=QApplication::palette().active().highlight(); break; case SHADE_CUSTOM: itsCheckRadioCol=opts.customCheckRadioColor; } if (opts.animatedProgress) { itsAnimationTimer = new QTimer(this); connect(itsAnimationTimer, SIGNAL(timeout()), this, SLOT(updateProgressPos())); } setSbType(); } QtCurveStyle::~QtCurveStyle() { if(itsSidebarButtonsCols!=itsSliderCols && itsSidebarButtonsCols!=itsDefBtnCols) delete [] itsSidebarButtonsCols; if(itsActiveMdiColors && itsActiveMdiColors!=itsHighlightCols) delete [] itsActiveMdiColors; if(itsMdiColors && itsMdiColors!=itsBackgroundCols) delete [] itsMdiColors; if(itsMouseOverCols && itsMouseOverCols!=itsDefBtnCols && itsMouseOverCols!=itsSliderCols) delete [] itsMouseOverCols; if(itsDefBtnCols && itsDefBtnCols!=itsSliderCols && itsDefBtnCols!=itsFocusCols && itsDefBtnCols!=itsHighlightCols) delete [] itsDefBtnCols; if(itsProgressCols && itsProgressCols!=itsHighlightCols && itsProgressCols!=itsBackgroundCols && itsProgressCols!=itsSliderCols && itsProgressCols!=itsComboBtnCols && itsProgressCols!=itsCheckRadioSelCols && itsProgressCols!=itsSortedLvColors) delete [] itsProgressCols; if(itsCheckRadioSelCols && itsCheckRadioSelCols!=itsDefBtnCols && itsCheckRadioSelCols!=itsSliderCols && itsCheckRadioSelCols!=itsComboBtnCols && itsCheckRadioSelCols!=itsSortedLvColors && itsCheckRadioSelCols!=itsButtonCols && itsCheckRadioSelCols!=itsHighlightCols) delete [] itsCheckRadioSelCols; if(itsSortedLvColors && itsSortedLvColors!=itsHighlightCols && itsSortedLvColors!=itsSliderCols && itsSortedLvColors!=itsComboBtnCols) delete [] itsSortedLvColors; if(itsComboBtnCols && itsComboBtnCols!=itsHighlightCols && itsComboBtnCols!=itsSliderCols) delete [] itsComboBtnCols; if(itsSliderCols && itsSliderCols!=itsHighlightCols) delete [] itsSliderCols; delete itsMactorPal; } static QString getFile(const QString &f) { QString d(f); int slashPos(d.findRev('/')); if(slashPos!=-1) d.remove(0, slashPos+1); return d; } void QtCurveStyle::polish(QApplication *app) { QString appName(getFile(app->argv()[0])); if(NULL!=getenv("QTCURVE_DEBUG")) std::cout << "QtCurve: Application name: \"" << appName.latin1() << "\"\n"; if ("kicker"==appName || "appletproxy"==appName) { itsThemedApp=APP_KICKER; #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 itsIsTransKicker=kickerIsTrans(); #endif } else if ("kontact"==appName) itsThemedApp=APP_KONTACT; else if ("konqueror"==appName) itsThemedApp=APP_KONQUEROR; else if ("kate"==appName) itsThemedApp=APP_KATE; else if ("kpresenter"==appName) itsThemedApp=APP_KPRESENTER; else if ("soffice.bin"==appName) { itsThemedApp=APP_OPENOFFICE; opts.groupBox=FRAME_PLAIN; opts.gbLabel=0; } else if ("kdefilepicker"==appName) itsThemedApp=APP_SKIP_TASKBAR; else if ("kprinter"==appName) itsThemedApp=APP_KPRINTER; else if ("kdialog"==appName) itsThemedApp=APP_KDIALOG; else if ("kdialogd"==appName) itsThemedApp=APP_KDIALOGD; else if ("tora"==appName) itsThemedApp=APP_TORA; else if ("opera"==appName) itsThemedApp=APP_OPERA; else if ("systemsettings"==appName) itsThemedApp=APP_SYSTEMSETTINGS; else if ("korn"==appName) { itsThemedApp=APP_KORN; #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 itsIsTransKicker=kickerIsTrans(); #endif } else if ("mactor"==appName) { if(!itsMactorPal) itsMactorPal=new QPalette(QApplication::palette()); itsThemedApp=APP_MACTOR; } else itsThemedApp=APP_OTHER; if(APP_OPENOFFICE==itsThemedApp) { // // OO.o 2.x checks to see whether the used theme "inherits" from HighContrastStyle, // if so it uses the highlightedText color to draw highlighted menubar and popup menu // items. Otherwise it uses the standard color. Changing the metaobject's class name // works around this... if(opts.useHighlightForMenu) { QMetaObject *meta=(QMetaObject *)metaObject(); meta->classname="HighContrastStyle"; } if(opts.scrollbarType==SCROLLBAR_NEXT) opts.scrollbarType=SCROLLBAR_KDE; else if(opts.scrollbarType==SCROLLBAR_NONE) opts.scrollbarType=SCROLLBAR_WINDOWS; setSbType(); } if(SHADE_NONE!=opts.menuStripe && opts.noMenuStripeApps.contains(appName)) opts.menuStripe=SHADE_NONE; #ifdef QTC_ENABLE_PARENTLESS_DIALOG_FIX_SUPPORT if(opts.fixParentlessDialogs && (opts.noDlgFixApps.contains(appName) || opts.noDlgFixApps.contains("kde"))) opts.fixParentlessDialogs=false; #endif } void QtCurveStyle::polish(QPalette &pal) { if(APP_MACTOR==itsThemedApp && itsMactorPal && pal.active().background()!=itsMactorPal->active().background()) return; QSettings settings; int contrast(settings.readNumEntry("/Qt/KDE/contrast", DEFAULT_CONTRAST)); bool newContrast(false); readKdeGlobals(); if(!kdeSettings.inactiveHighlight)// Read in Qt3 palette... Required for the inactive settings... { QStringList active(settings.readListEntry("/Qt/Palette/active")), inactive(settings.readListEntry("/Qt/Palette/inactive")); // Only set if: the active highlight is the same, and the inactive highlight is different. // If the user has no ~/.qt/qtrc, then QSettings will return a default palette. However, the palette // passed in to this ::polish function will be the KDE one - which maybe different. Hence, we need to // check that Qt active == KDE active, before reading inactive... if (QColorGroup::NColorRoles==active.count() && QColorGroup::NColorRoles==inactive.count() && QColor(active[QColorGroup::Highlight])==pal.color(QPalette::Active, QColorGroup::Highlight) && QColor(active[QColorGroup::HighlightedText])==pal.color(QPalette::Active, QColorGroup::HighlightedText)) { QColor h(inactive[QColorGroup::Highlight]), t(inactive[QColorGroup::HighlightedText]); if(h!=pal.color(QPalette::Inactive, QColorGroup::Highlight) || t!=QPalette::Inactive, QColorGroup::HighlightedText) { pal.setColor(QPalette::Inactive, QColorGroup::Highlight, h); pal.setColor(QPalette::Inactive, QColorGroup::HighlightedText, t); } } } if(contrast<0 || contrast>10) contrast=DEFAULT_CONTRAST; if(contrast!=opts.contrast) { opts.contrast=contrast; newContrast=true; } if(kdeSettings.inactiveHighlight) { pal.setColor(QPalette::Inactive, QColorGroup::Highlight, tint(QApplication::palette().active().background(), QApplication::palette().active().highlight(), 0.4)); // KDE4 does not set text colour :-( //pal.setColor(QPalette::Inactive, QColorGroup::HighlightedText, pal.color(QPalette::Active, QColorGroup::Foreground)); } bool newMenu(newContrast || itsHighlightCols[ORIGINAL_SHADE]!=QApplication::palette().active().highlight()), newGray(newContrast || itsBackgroundCols[ORIGINAL_SHADE]!=QApplication::palette().active().background()), newButton(newContrast || itsButtonCols[ORIGINAL_SHADE]!=QApplication::palette().active().button()), newSlider(itsSliderCols && SHADE_BLEND_SELECTED==opts.shadeSliders && (newContrast || newButton || newMenu)), newDefBtn(itsDefBtnCols && /*( (IND_COLORED==opts.defBtnIndicator &&*/ SHADE_BLEND_SELECTED!=opts.shadeSliders/*) ||*/ /*(IND_TINT==opts.defBtnIndicator) )*/ && IND_SELECTED!=opts.defBtnIndicator && IND_GLOW!=opts.defBtnIndicator && (newContrast || newButton || newMenu)), newComboBtn(itsComboBtnCols && itsHighlightCols!=itsComboBtnCols && itsSliderCols!=itsComboBtnCols && SHADE_BLEND_SELECTED==opts.comboBtn && (newContrast || newButton || newMenu)), newSortedLv(itsSortedLvColors && ( (SHADE_BLEND_SELECTED==opts.sortedLv && itsHighlightCols!=itsSortedLvColors && itsSliderCols!=itsSortedLvColors && itsComboBtnCols!=itsSortedLvColors) || SHADE_DARKEN==opts.sortedLv) && (newContrast || (opts.lvButton ? newButton : newGray))), newCheckRadioSelCols(itsCheckRadioSelCols && ( (SHADE_BLEND_SELECTED==opts.crColor && itsDefBtnCols!=itsCheckRadioSelCols && itsSliderCols!=itsCheckRadioSelCols && itsComboBtnCols!=itsCheckRadioSelCols && itsSortedLvColors!=itsCheckRadioSelCols) || SHADE_DARKEN==opts.crColor) && (newContrast || newButton)), newProgressCols(itsProgressCols && SHADE_BLEND_SELECTED==opts.progressColor && itsSliderCols!=itsProgressCols && itsComboBtnCols!=itsProgressCols && itsSortedLvColors!=itsProgressCols && itsCheckRadioSelCols!=itsProgressCols && (newContrast || newButton)); if(newGray) shadeColors(QApplication::palette().active().background(), itsBackgroundCols); if(newButton) shadeColors(QApplication::palette().active().button(), itsButtonCols); if(newMenu) shadeColors(QApplication::palette().active().highlight(), itsHighlightCols); setDecorationColors(); setMenuColors(QApplication::palette().active()); if(newSlider) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsSliderCols); if(newComboBtn) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsComboBtnCols); if(newSortedLv) if(SHADE_BLEND_SELECTED==opts.sortedLv) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], opts.lvButton ? itsButtonCols[ORIGINAL_SHADE] : itsBackgroundCols[ORIGINAL_SHADE]), itsSortedLvColors); else shadeColors(shade(opts.lvButton ? itsButtonCols[ORIGINAL_SHADE] : itsBackgroundCols[ORIGINAL_SHADE], LV_HEADER_DARK_FACTOR), itsSortedLvColors); if(newDefBtn) if(IND_TINT==opts.defBtnIndicator) shadeColors(tint(itsButtonCols[ORIGINAL_SHADE], itsHighlightCols[ORIGINAL_SHADE], DEF_BNT_TINT), itsDefBtnCols); else if(IND_GLOW!=opts.defBtnIndicator) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsDefBtnCols); if(itsSidebarButtonsCols && SHADE_BLEND_SELECTED!=opts.shadeSliders && IND_COLORED!=opts.defBtnIndicator) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsSidebarButtonsCols); if(USE_LIGHTER_POPUP_MENU && newGray) itsLighterPopupMenuBgndCol=shade(itsBackgroundCols[ORIGINAL_SHADE], TO_FACTOR(opts.lighterPopupMenuBgnd)); if(newCheckRadioSelCols) if(SHADE_BLEND_SELECTED==opts.crColor) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsButtonCols[ORIGINAL_SHADE]), itsCheckRadioSelCols); else shadeColors(shade(itsButtonCols[ORIGINAL_SHADE], LV_HEADER_DARK_FACTOR), itsCheckRadioSelCols); if(newProgressCols) shadeColors(midColor(itsHighlightCols[ORIGINAL_SHADE], itsBackgroundCols[ORIGINAL_SHADE]), itsProgressCols); pal.setActive(setColorGroup(pal.active(), pal.active())); pal.setInactive(setColorGroup(pal.inactive(), pal.active())); pal.setDisabled(setColorGroup(pal.disabled(), pal.active(), true)); switch(opts.shadeCheckRadio) { default: itsCheckRadioCol=opts.crButton ? QApplication::palette().active().buttonText() : QApplication::palette().active().text(); break; case SHADE_SELECTED: case SHADE_BLEND_SELECTED: itsCheckRadioCol=QApplication::palette().active().highlight(); break; case SHADE_CUSTOM: itsCheckRadioCol=opts.customCheckRadioColor; } if(itsMactorPal) *itsMactorPal=pal; // Force this to be re-generated! if(SHADE_BLEND_SELECTED==opts.menuStripe) opts.customMenuStripeColor=Qt::black; if(APPEARANCE_STRIPED==opts.bgndAppearance) pal.setBrush(QColorGroup::Background, QBrush(pal.active().background(), *createStripePixmap(pal.active().background(), true))); } static QColor disable(const QColor &col, const QColor &bgnd) { QColor c = col; c = ColorUtils_darken(&c, 0.1, 1.0); c = ColorUtils_mix(&c, &bgnd, 0.65); return c; } QColorGroup QtCurveStyle::setColorGroup(const QColorGroup &old, const QColorGroup &act, bool dis) { QColor mid(old.mid()); if(dis) mid=disable(act.foreground(), old.background()); const QColor *use(backgroundColors(old)); QColorGroup newGrp(old.foreground(), old.button(), use[0], use[STD_BORDER], mid, old.text(), old.brightText(), old.base(), old.background()); QColorGroup::ColorRole roles[]={QColorGroup::Midlight, QColorGroup::ButtonText, QColorGroup::Shadow, QColorGroup::Highlight, QColorGroup::HighlightedText, QColorGroup::Link, QColorGroup::LinkVisited, QColorGroup::NColorRoles }; int r(0); for(r=0; roles[r]!=QColorGroup::NColorRoles; ++r) newGrp.setColor(roles[r], old.color(roles[r])); if(dis) { newGrp.setColor(QColorGroup::ButtonText, disable(act.buttonText(), old.button())); newGrp.setColor(QColorGroup::Text, disable(act.text(), old.background())); } return newGrp; } static const char * kdeToolbarWidget="kde toolbar widget"; void QtCurveStyle::polish(QWidget *widget) { bool enableFilter(opts.highlightFactor || opts.coloredMouseOver); if(::isKhtmlFormWidget(widget)) { itsKhtmlWidgets[widget]=true; connect(widget, SIGNAL(destroyed(QObject *)), this, SLOT(khtmlWidgetDestroyed(QObject *))); } if(enableFilter && isSpecialHover(widget)) connect(widget, SIGNAL(destroyed(QObject *)), this, SLOT(hoverWidgetDestroyed(QObject *))); if(isWindowDragWidget(widget)) widget->installEventFilter(this); if(APPEARANCE_STRIPED==opts.bgndAppearance && (::qt_cast(widget) || ::qt_cast(widget))) setBgndProp(widget, APPEARANCE_STRIPED); if(widget->parentWidget() && ::qt_cast(widget) && ::qt_cast(widget->parentWidget())) { QPalette pal(widget->palette()); #if 0 QPalette orig(pal); #endif QColorGroup act(pal.active()); #if 0 if(opts.gtkComboMenus) act.setColor(QColorGroup::Base, USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE]); act.setColor(QColorGroup::Background, opts.gtkComboMenus ? USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE] : QApplication::palette().active().base()); #endif act.setColor(QColorGroup::Foreground, itsBackgroundCols[STD_BORDER]); pal.setActive(act); widget->setPalette(pal); #if 0 //((QScrollView *)widget)->setMargin(1); const QObjectList *children(widget->children()); if(children) { QObjectList::Iterator it(children->begin()), end(children->end()); for(; it!=end; ++it) if(::qt_cast(*it)) ((QWidget *)(*it))->setPalette(orig); } #endif } if (APP_MACTOR==itsThemedApp && itsMactorPal && !widget->inherits("QTipLabel")) widget->setPalette(*itsMactorPal); // Get rid of Kontact's frame... if(APP_KONTACT==itsThemedApp && ::qt_cast(widget) && widget->parentWidget() && 0==qstrcmp(widget->parentWidget()->className(), "Kontact::MainWindow")) ((QHBox *)widget)->setLineWidth(0); if(!IS_FLAT_BGND(opts.menuBgndAppearance) && ::qt_cast(widget)) widget->installEventFilter(this); #if 0 if(opts.menubarHiding && ::qt_cast(widget) && static_cast(widget)->menuBar()) widget->installEventFilter(this); #endif if ((opts.square&SQUARE_SCROLLVIEW) && widget && (::qt_cast(widget) || (widget->parentWidget() && ::qt_cast(widget) && widget->parentWidget()->inherits("KateView"))) && ((QFrame *)widget)->lineWidth()>1) ((QFrame *)widget)->setLineWidth(opts.gtkScrollViews ? 1 : 2); else if(!opts.popupBorder && widget && (::qt_cast(widget) || (widget->parentWidget() && ::qt_cast(widget) && ::qt_cast(widget->parentWidget())))) ((QFrame *)widget)->setLineWidth(0); else if ((USE_LIGHTER_POPUP_MENU || !IS_FLAT_BGND(opts.menuBgndAppearance)) && !opts.borderMenuitems && widget && ::qt_cast(widget)) ((QFrame *)widget)->setLineWidth(1); if (::qt_cast(widget) || ::qt_cast(widget)) { bool framelessGroupBoxCheckBox=(NO_FRAME(opts.groupBox) && isCheckBoxOfGroupBox(widget)); if(framelessGroupBoxCheckBox || enableFilter) { #if QT_VERSION >= 0x030200 if(!isFormWidget(widget)) widget->setMouseTracking(true); #endif if(framelessGroupBoxCheckBox) { QFont fnt(widget->font()); fnt.setBold(true); widget->setFont(fnt); } widget->installEventFilter(this); } } else if (::qt_cast(widget) || ::qt_cast(widget) || ::qt_cast(widget)/* || ::qt_cast(widget)*/) { if(enableFilter) { widget->setMouseTracking(true); widget->installEventFilter(this); } } else if (::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteBackground); if(enableFilter) { widget->installEventFilter(this); #if defined KDE_VERSION && KDE_VERSION >= 0x30400 && KDE_VERSION < 0x30500 widget->setMouseTracking(true); #endif } } else if (::qt_cast(widget) || widget->inherits("QToolBarExtensionWidget")) { /*if(onToolBar(widget)) widget->setBackgroundMode(NoBackground); else*/ if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteBackground); if(enableFilter) widget->installEventFilter(this); } else if (::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteBackground); widget->installEventFilter(this); if(DO_EFFECT && onToolBar(widget)) widget->setName(kdeToolbarWidget); if(enableFilter) widget->setMouseTracking(true); if(((QComboBox *)widget)->listBox()) ((QComboBox *)widget)->listBox()->installEventFilter(this); } else if(::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) widget->setBackgroundMode(PaletteBackground); if(SHADE_NONE!=opts.shadeMenubars) widget->installEventFilter(this); if(BLEND_TITLEBAR || opts.windowBorder&WINDOW_BORDER_USE_MENUBAR_COLOR_FOR_TITLEBAR) emitMenuSize(widget, widget->rect().height()); if(SHADE_WINDOW_BORDER==opts.shadeMenubars) { QPalette pal(widget->palette()); QColorGroup act(pal.active()); QColorGroup inact(pal.inactive()); getMdiColors(act, true); act.setColor(QColorGroup::Foreground, itsActiveMdiTextColor); inact.setColor(QColorGroup::Foreground, opts.shadeMenubarOnlyWhenActive ? itsMdiTextColor : itsActiveMdiTextColor); pal.setInactive(inact); pal.setActive(act); widget->setPalette(pal); } else if(opts.customMenuTextColor || SHADE_BLEND_SELECTED==opts.shadeMenubars || SHADE_SELECTED==opts.shadeMenubars || (SHADE_CUSTOM==opts.shadeMenubars && TOO_DARK(itsMenubarCols[ORIGINAL_SHADE]))) { QPalette pal(widget->palette()); QColorGroup act(pal.active()); act.setColor(QColorGroup::Foreground, opts.customMenuTextColor ? opts.customMenuNormTextColor : QApplication::palette().active().highlightedText()); if(!opts.shadeMenubarOnlyWhenActive) { QColorGroup inact(pal.inactive()); inact.setColor(QColorGroup::Foreground, act.color(QColorGroup::Foreground)); pal.setInactive(inact); } pal.setActive(act); widget->setPalette(pal); } } else if(::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) widget->setBackgroundMode(PaletteBackground); } else if(::qt_cast(widget)) widget->setBackgroundMode(NoBackground); // PaletteBackground); else if (widget->inherits("KToolBarSeparator") || (widget->inherits("KListViewSearchLineWidget") && widget->parent() && ::qt_cast(widget->parent()))) { widget->setName(kdeToolbarWidget); widget->setBackgroundMode(NoBackground); widget->installEventFilter(this); } else if (::qt_cast(widget)) { if(enableFilter) { widget->setMouseTracking(true); widget->installEventFilter(this); } //widget->setBackgroundMode(NoBackground); } else if (::qt_cast(widget)) { if(enableFilter) widget->installEventFilter(this); if(widget->parent() && ::qt_cast(widget->parent())) { widget->setName(kdeToolbarWidget); widget->setBackgroundMode(NoBackground); // We paint whole background. if(!enableFilter) widget->installEventFilter(this); } // This bit stolen form polyester... connect(widget, SIGNAL(sliderMoved(int)), this, SLOT(sliderThumbMoved(int))); connect(widget, SIGNAL(valueChanged(int)), this, SLOT(sliderThumbMoved(int))); } else if (::qt_cast(widget) || ::qt_cast(widget)) { widget->installEventFilter(this); if(onToolBar(widget)) widget->setName(kdeToolbarWidget); if(widget && widget->parentWidget() && widget->inherits("KLineEdit") && widget->parentWidget()->inherits("KIO::DefaultProgress") && ::qt_cast(widget)) ((QFrame *)widget)->setLineWidth(0); } else if (widget->inherits("QSplitterHandle") || widget->inherits("QDockWindowHandle") || widget->inherits("QDockWindowResizeHandle")) { if(enableFilter) widget->installEventFilter(this); } else if (0==qstrcmp(widget->name(), kdeToolbarWidget)) { if(!widget->parent() || 0!=qstrcmp(static_cast(widget->parent())->className(), "KListViewSearchLineWidget") || onToolBar(widget)) { widget->installEventFilter(this); widget->setBackgroundMode(NoBackground); // We paint whole background. } } if (widget->parentWidget() && ::qt_cast(widget->parentWidget()) && !qstrcmp(widget->className(), "QFrame")) { widget->installEventFilter(this); widget->setBackgroundMode(NoBackground); // We paint whole background. } else if (Qt::X11ParentRelative!=widget->backgroundMode() && (::qt_cast(widget) || ::qt_cast(widget) || ::qt_cast(widget)) && widget->parent() && ( 0==qstrcmp(static_cast(widget->parent())->className(), "MainWindow") || onToolBar(widget))) { widget->setName(kdeToolbarWidget); widget->installEventFilter(this); widget->setBackgroundMode(NoBackground); // We paint the whole background. } else if(::qt_cast(widget)) { if(widget->palette().inactive().highlightedText()!=widget->palette().active().highlightedText()) { QPalette pal(widget->palette()); pal.setInactive(widget->palette().active()); widget->setPalette(pal); } if(opts.animatedProgress) { widget->installEventFilter(this); itsProgAnimWidgets[widget] = 0; connect(widget, SIGNAL(destroyed(QObject *)), this, SLOT(progressBarDestroyed(QObject *))); if (!itsAnimationTimer->isActive()) itsAnimationTimer->start(PROGRESS_ANIMATION, false); } } else if(opts.highlightScrollViews && ::qt_cast(widget)) widget->installEventFilter(this); else if(!qstrcmp(widget->className(), "KonqFrameStatusBar")) { // This disables the white background of the KonquerorFrameStatusBar. // When the green led is shown the background is set to // applications cg.midlight() so we override it to standard background. // Thanks Comix! (because this was ugly from day one!) // NOTE: Check if we can set it earlier (before painting), cause // on slow machines we can see the repainting of the bar (from white to background...) QPalette pal(QApplication::palette()); pal.setColor(QColorGroup::Midlight, pal.active().background()); QApplication::setPalette(pal); } else if(widget->inherits("KTabCtl")) widget->installEventFilter(this); else if(NO_FRAME(opts.groupBox) && ::qt_cast(widget)) { ((QGroupBox *)widget)->setFlat(false); ((QGroupBox *)widget)->setFrameShape(QFrame::NoFrame); } #ifdef QTC_ENABLE_PARENTLESS_DIALOG_FIX_SUPPORT else if(opts.fixParentlessDialogs && ::qt_cast(widget)) { QDialog *dlg=(QDialog *)widget; // The parent->isShown is needed for KWord. It's insert picure file dialog is a child of // the insert picture dialog - but the file dialog is shown *before* the picture dialog! if( (SKIP_TASKBAR && !dlg->parentWidget()) || ( (!dlg->parentWidget() || !dlg->parentWidget()->isShown())// && /*(dlg->isModal() || ::qt_cast(widget))*/) ) widget->installEventFilter(this); } if(opts.fixParentlessDialogs && (APP_KPRINTER==itsThemedApp || APP_KDIALOG==itsThemedApp || APP_KDIALOGD==itsThemedApp)) { QString cap(widget->caption()); int index=-1; // Remove horrible "Open - KDialog" titles... if( cap.length() && ( (APP_KPRINTER==itsThemedApp && (-1!=(index=cap.find(" - KPrinter"))) && (index+11)==(int)cap.length()) || (APP_KDIALOG==itsThemedApp && (-1!=(index=cap.find(" - KDialog"))) && (index+10)==(int)cap.length()) || (APP_KDIALOGD==itsThemedApp && (-1!=(index=cap.find(" - KDialog Daemon"))) && (index+17)==(int)cap.length())) ) widget->QWidget::setCaption(cap.left(index)); } #endif if(APP_SYSTEMSETTINGS==itsThemedApp) { if(widget && widget->parentWidget() && widget->parentWidget()->parentWidget() && ::qt_cast(widget) && QFrame::NoFrame!=((QFrame *)widget)->frameShape() && ::qt_cast(widget->parentWidget()) && ::qt_cast(widget->parentWidget()->parentWidget())) ((QFrame *)widget)->setFrameShape(QFrame::NoFrame); if(widget->parentWidget() && widget->parentWidget()->parentWidget() && ::qt_cast(widget->parentWidget()->parentWidget()) && widget->inherits("KCMultiWidget") && widget->parentWidget()->inherits("QViewportWidget")) ((QScrollView *)(widget->parentWidget()->parentWidget()))->setLineWidth(0); } if(opts.tabBgnd && widget && widget->parentWidget() && ::qt_cast(widget) && ::qt_cast(widget->parentWidget()) && 0==qstrcmp(widget->name(), "tab pages")) { QPalette pal(widget->palette()); pal.setColor(QColorGroup::Background, shade(pal.active().background(), TO_FACTOR(opts.tabBgnd))); widget->setBackgroundMode(PaletteBackground); widget->setPalette(pal); } if(APPEARANCE_STRIPED==opts.bgndAppearance) widget->setBackgroundOrigin(QWidget::WindowOrigin); BASE_STYLE::polish(widget); } void QtCurveStyle::unPolish(QWidget *widget) { if(isFormWidget(widget)) itsKhtmlWidgets.remove(widget); if(!IS_FLAT_BGND(opts.menuBgndAppearance) && ::qt_cast(widget)) widget->removeEventFilter(this); #if 0 if(opts.menubarHiding && ::qt_cast(widget) && static_cast(widget)->menuBar()) widget->removeEventFilter(this); #endif if(isWindowDragWidget(widget)) widget->removeEventFilter(this); if (::qt_cast(widget) || ::qt_cast(widget)) { #if QT_VERSION >= 0x030200 widget->setMouseTracking(false); #endif widget->removeEventFilter(this); } else if (::qt_cast(widget) || ::qt_cast(widget) || ::qt_cast(widget) /*|| ::qt_cast(widget)*/) { widget->setMouseTracking(false); widget->removeEventFilter(this); } else if (::qt_cast(widget) || widget->inherits("QToolBarExtensionWidget")) { if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteButton); widget->removeEventFilter(this); } else if (::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteButton); widget->removeEventFilter(this); #if defined KDE_VERSION && KDE_VERSION >= 0x30400 && KDE_VERSION < 0x30500 widget->setMouseTracking(false); #endif } else if (::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) // && onToolBar(widget)) widget->setBackgroundMode(PaletteButton); widget->removeEventFilter(this); widget->setMouseTracking(false); if(((QComboBox *)widget)->listBox()) ((QComboBox *)widget)->listBox()->removeEventFilter(this); } else if (::qt_cast(widget) || ::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) widget->setBackgroundMode(PaletteBackground); } else if (::qt_cast(widget)) { if(NoBackground!=widget->backgroundMode()) widget->setBackgroundMode(PaletteBackground); if(SHADE_NONE!=opts.shadeMenubars) widget->removeEventFilter(this); if(SHADE_WINDOW_BORDER==opts.shadeMenubars || opts.customMenuTextColor || SHADE_BLEND_SELECTED==opts.shadeMenubars || SHADE_SELECTED==opts.shadeMenubars || (SHADE_CUSTOM==opts.shadeMenubars &&TOO_DARK(itsMenubarCols[ORIGINAL_SHADE]))) widget->setPalette(QApplication::palette()); } else if (widget->inherits("KToolBarSeparator")) { widget->setBackgroundMode(PaletteBackground); widget->removeEventFilter(this); } else if (::qt_cast(widget)) { widget->setMouseTracking(false); widget->removeEventFilter(this); widget->setBackgroundMode(PaletteButton); } else if (::qt_cast(widget)) { widget->removeEventFilter(this); if(widget->parent() && ::qt_cast(widget->parent())) widget->setBackgroundMode(PaletteBackground); } else if (::qt_cast(widget) || ::qt_cast(widget)) widget->removeEventFilter(this); else if (widget->inherits("QSplitterHandle") || widget->inherits("QDockWindowHandle") || widget->inherits("QDockWindowResizeHandle")) widget->removeEventFilter(this); else if (::qt_cast(widget)) { itsProgAnimWidgets.remove(widget); widget->removeEventFilter(this); } else if(opts.highlightScrollViews && ::qt_cast(widget)) widget->removeEventFilter(this); else if(0==qstrcmp(widget->name(), kdeToolbarWidget)) { widget->removeEventFilter(this); widget->setBackgroundMode(PaletteBackground); } if (widget->parentWidget() && ::qt_cast(widget->parentWidget()) && !qstrcmp(widget->className(), "QFrame")) { widget->removeEventFilter(this); widget->setBackgroundMode(PaletteBackground); // We paint whole background. } else if(widget->inherits("KTabCtl")) widget->removeEventFilter(this); #ifdef QTC_ENABLE_PARENTLESS_DIALOG_FIX_SUPPORT else if(opts.fixParentlessDialogs && ::qt_cast(widget)) widget->removeEventFilter(this); #endif BASE_STYLE::unPolish(widget); } static void sendXEvent(QDialog *dlg, const char *msg) { static Atom msgTypeAtom = XInternAtom(qt_xdisplay(), "_NET_WM_STATE", False); XEvent xev; Atom atom=XInternAtom(qt_xdisplay(), msg, False); xev.xclient.type = ClientMessage; xev.xclient.serial = 0; xev.xclient.send_event = True; xev.xclient.window = dlg->winId(); xev.xclient.message_type = msgTypeAtom; xev.xclient.format = 32; xev.xclient.data.l[0] = 1; xev.xclient.data.l[1] = atom; xev.xclient.data.l[2] = 0; xev.xclient.data.l[3] = 0; xev.xclient.data.l[4] = 0; XSendEvent(qt_xdisplay(), qt_xrootwin(), False, SubstructureRedirectMask | SubstructureNotifyMask, &xev); } bool QtCurveStyle::appIsNotEmbedded(QDialog *dlg) { Window win; if(!XGetTransientForHint(qt_xdisplay(), dlg->winId(), &win) || (int)win < 1000) return true; // OK, dialog has been set transient, so there is no need for this event filter anymore :-) dlg->removeEventFilter(this); return false; } bool QtCurveStyle::eventFilter(QObject *object, QEvent *event) { if(itsHoverWidget && object==itsHoverWidget && (QEvent::Destroy==event->type() || QEvent::Hide==event->type())) resetHover(); #if 0 // Works for qtconfig, but k3b hangs? if(opts.menubarHiding && QEvent::KeyRelease==event->type() && ::qt_cast(object)) { QMainWindow *window=static_cast(object); if(window->isVisible() && window->menuBar()) { QKeyEvent *k=static_cast(event); if(k->state()&Qt::ControlButton && k->state()&Qt::AltButton && Qt::Key_M==k->key()) window->menuBar()->setHidden(window->menuBar()->isVisible()); } } #endif if(object->parent() && 0==qstrcmp(object->name(), kdeToolbarWidget)) { // Draw background for custom widgets in the toolbar that have specified a // "kde toolbar widget" name. if(QEvent::Paint==event->type()) { QWidget *widget(static_cast(object)), *parent(static_cast(object->parent())); if(IS_FLAT(opts.toolbarAppearance)) QPainter(widget).fillRect(widget->rect(), parent->colorGroup().background()); else { int y_offset(widget->y()); while(parent && parent->parent() && 0==qstrcmp(parent->name(), kdeToolbarWidget)) { y_offset += parent->y(); parent = static_cast(parent->parent()); } QRect r(widget->rect()), pr(parent->rect()); bool horiz=pr.width() > pr.height(); QPainter p(widget); QToolBar *tb(::qt_cast(parent)); // If parent is a QToolbar use its orientation, else just base on width>height. if (tb) horiz = Qt::Horizontal==tb->orientation(); QRect bgndRect(r.x(), r.y()-y_offset, r.width(), pr.height()); if(!IS_FLAT(opts.toolbarAppearance)) if(horiz) bgndRect.addCoords(0, -1, 0, 1); else bgndRect.addCoords(-1, 0, 1, 0); drawMenuOrToolBarBackground(&p, bgndRect, parent->colorGroup(), false, horiz); } if(!::qt_cast(object) && !::qt_cast(object) && !(DO_EFFECT && ::qt_cast(object))) return false; // Now draw the contents } } else if (NO_FRAME(opts.groupBox) && QEvent::Move==event->type() && isCheckBoxOfGroupBox(object)) { QCheckBox *cb=static_cast(object); QRect r(cb->geometry()); cb->removeEventFilter(this); if(QApplication::reverseLayout()) r.setWidth(r.width()+8); else r.setX(0); cb->setGeometry(r); cb->installEventFilter(this); return false; } else if (QEvent::Paint==event->type()) { if(!IS_FLAT_BGND(opts.menuBgndAppearance) && ::qt_cast(object)) { QWidget *widget=(QWidget*)object; QPainter painter(widget); QColor col(USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : widget->palette().active().background()); if(APPEARANCE_STRIPED==opts.menuBgndAppearance) painter.drawTiledPixmap(widget->rect(), *createStripePixmap(col, false)); else drawBevelGradientReal(col, &painter, widget->rect(), GT_HORIZ==opts.menuBgndGrad, false, opts.menuBgndAppearance, WIDGET_OTHER); return false; } else if (object->inherits("KToolBarSeparator")) { QFrame *frame(::qt_cast(object)); if(frame && QFrame::NoFrame!=frame->frameShape()) { QPainter painter(frame); if (QFrame::VLine==frame->frameShape()) drawPrimitive(PE_DockWindowSeparator, &painter, frame->rect(), frame->colorGroup(), Style_Horizontal); else if (QFrame::HLine==frame->frameShape()) drawPrimitive(PE_DockWindowSeparator, &painter, frame->rect(), frame->colorGroup()); else return false; return true; // been drawn! } } else if(object->inherits("KTabCtl") && ::qt_cast(object)) { QWidget *widget((QWidget*)object); QObject *child(object->child("_tabbar")); QTabBar *tb(child ? ::qt_cast(child) : 0L); QPainter painter(widget); QRect r(widget->rect()); int tbHeight(tb ? tb->height()-1 : 28); if(tb && (QTabBar::RoundedBelow == tb->shape() || QTabBar::TriangularBelow == tb->shape())) r.addCoords(0, 0, 0, -tbHeight); else r.addCoords(0, tbHeight, 0, 0); drawPrimitive(PE_PanelTabWidget, &painter, r, widget->colorGroup(), Style_Horizontal|Style_Enabled); return true; } } // Fix mdi buttons in menubars... if(::qt_cast(object) && ((QWidget *)object)->parentWidget() && ::qt_cast(((QWidget *)object)->parentWidget())) { bool drawMenubar=false; switch(event->type()) { case QEvent::Paint: drawMenubar=true; break; case QEvent::WindowActivate: itsActive=true; drawMenubar=opts.shadeMenubarOnlyWhenActive && SHADE_NONE!=opts.shadeMenubars; break; case QEvent::WindowDeactivate: itsActive=false; drawMenubar=opts.shadeMenubarOnlyWhenActive && SHADE_NONE!=opts.shadeMenubars; default: break; } if(drawMenubar) { QWidget *widget(static_cast(object)), *parent(static_cast(object->parent())); QRect r(widget->rect()); QPainter p(widget); int y_offset(widget->y()+parent->y()); r.setY(r.y()-y_offset); r.setHeight(parent->rect().height()); drawMenuOrToolBarBackground(&p, r, parent->colorGroup()); return true; } } // Taken from plastik... // focus highlight if (::qt_cast(object) || ::qt_cast(object)/* || ::qt_cast(object)*/) { if(QEvent::FocusIn==event->type() || QEvent::FocusOut==event->type() || QEvent::Enter==event->type() || QEvent::Leave==event->type()) { QWidget *widget(static_cast(object)); if (::qt_cast(widget->parentWidget())) { widget->parentWidget()->repaint(false); return false; } widget->repaint(false); } return false; } if(::qt_cast(object)) { bool useWindowCols=SHADE_WINDOW_BORDER==opts.shadeMenubars; if( (useWindowCols || opts.customMenuTextColor || SHADE_BLEND_SELECTED==opts.shadeMenubars || SHADE_SELECTED==opts.shadeMenubars || SHADE_CUSTOM==opts.shadeMenubars) && QEvent::Paint==event->type()) { const QColor &col(((QWidget *)object)->palette().active().color(QColorGroup::Foreground)); // If we're relouring the menubar text, check to see if menubar palette has changed, if so set back to // our values. This fixes opera - which seems to change the widgets palette after it is polished. if((opts.customMenuTextColor && col!=opts.customMenuNormTextColor) || ( (SHADE_BLEND_SELECTED==opts.shadeMenubars || SHADE_SELECTED==opts.shadeMenubars || (SHADE_CUSTOM==opts.shadeMenubars && TOO_DARK(itsMenubarCols[ORIGINAL_SHADE]))) && col!=QApplication::palette().active().highlightedText())) { QPalette pal(((QWidget *)object)->palette()); QColorGroup act(pal.active()); act.setColor(QColorGroup::Foreground, useWindowCols ? itsActiveMdiTextColor : opts.customMenuTextColor ? opts.customMenuNormTextColor : QApplication::palette().active().highlightedText()); if(!opts.shadeMenubarOnlyWhenActive || useWindowCols) { QColorGroup inact(pal.inactive()); inact.setColor(QColorGroup::Foreground, useWindowCols ? itsMdiTextColor : act.color(QColorGroup::Foreground)); pal.setInactive(inact); } pal.setActive(act); ((QWidget *)object)->setPalette(pal); } } if(opts.shadeMenubarOnlyWhenActive && SHADE_NONE!=opts.shadeMenubars) switch(event->type()) { case QEvent::WindowActivate: itsActive=true; ((QWidget *)object)->repaint(false); return false; case QEvent::WindowDeactivate: itsActive=false; ((QWidget *)object)->repaint(false); return false; default: break; } if(BLEND_TITLEBAR || opts.windowBorder&WINDOW_BORDER_USE_MENUBAR_COLOR_FOR_TITLEBAR) switch(event->type()) { case QEvent::Resize: { QResizeEvent *re = static_cast(event); if (re->size().height() != re->oldSize().height()) emitMenuSize((QMenuBar *)object, re->size().height()); break; } } } if(dynamic_cast(event)) switch(event->type()) { case QEvent::MouseMove: // Only occurs for widgets with mouse tracking enabled if(itsDragWidget) { itsDragWidget->setMouseTracking(itsDragWidgetHadMouseTracking); bool move=isWindowDragWidget(object); if(move) triggerWMMove(itsDragWidget, ((QMouseEvent *)event)->globalPos()); itsDragWidget = 0L; return move; } case QEvent::MouseButtonPress: { QMouseEvent *mev = (QMouseEvent *)event; if(isWindowDragWidget(object, mev->pos())) { if(/*Qt::NoModifier==mev->modifiers() && */ Qt::LeftButton==mev->button()) { QWidget *wid = static_cast(object); itsDragWidget=wid; itsDragWidgetHadMouseTracking=itsDragWidget->hasMouseTracking(); itsDragWidget->setMouseTracking(true); return false; } } break; } case QEvent::MouseButtonRelease: if(itsDragWidget) { itsDragWidget->setMouseTracking(itsDragWidgetHadMouseTracking); itsDragWidget = 0L; return false; } break; } #ifdef QTC_ENABLE_PARENTLESS_DIALOG_FIX_SUPPORT if(opts.fixParentlessDialogs && ::qt_cast(object)) { QDialog *dlg=(QDialog *)object; switch(event->type()) { case QEvent::ShowMinimized: if(SKIP_TASKBAR && appIsNotEmbedded(dlg)) { // Ugly hack :-( Cant seem to get KWin to remove the minimize button. So when // the dialog gets minimized, restore. dlg->setWindowState(dlg->windowState() & ~WindowMinimized | WindowActive); return true; } break; case QEvent::WindowActivate: if(SKIP_TASKBAR && appIsNotEmbedded(dlg)) { // OO.o's filepicker is a spawned process - but is not set transient :-( // --plus no reliable way of finding which widget to make it transient for... sendXEvent(dlg, "_NET_WM_STATE_SKIP_PAGER"); sendXEvent(dlg, "_NET_WM_STATE_SKIP_TASKBAR"); sendXEvent(dlg, "_NET_WM_STATE_ABOVE"); sendXEvent(dlg, "_NET_WM_STATE_STAYS_ON_TOP"); //setActions(dlg); } break; case QEvent::Show: // The parent->isShown is needed for KWord. It's insert picure file dialog is a // child of the insert picture dialog - but the file dialog is shown *before* the // picture dialog! if((!dlg->parentWidget() || !dlg->parentWidget()->isShown())) // && //(dlg->isModal() || ::qt_cast(object))) { QWidget *activeWindow=qApp->activeWindow(); if(activeWindow) { XWindowAttributes attr; int rx, ry; Window win; if(!XGetTransientForHint(qt_xdisplay(), dlg->winId(), &win) || win!=activeWindow->winId()) { XSetTransientForHint(qt_xdisplay(), dlg->winId(), activeWindow->winId()); if(XGetWindowAttributes(qt_xdisplay(), activeWindow->winId(), &attr)) { XTranslateCoordinates(qt_xdisplay(), activeWindow->winId(), attr.root, -attr.border_width, -16, &rx, &ry, &win); rx=(rx+(attr.width/2))-(dlg->width()/2); if(rx<0) rx=0; ry=(ry+(attr.height/2))-(dlg->height()/2); if(ry<0) ry=0; dlg->move(rx, ry); if(!dlg->isModal()) dlg->setModal(true); } } } } default: break; } return false; } #endif // Track show events for progress bars if (opts.animatedProgress && ::qt_cast(object)) { if(QEvent::Show==event->type() && !itsAnimationTimer->isActive()) itsAnimationTimer->start(PROGRESS_ANIMATION, false); return false; } switch(event->type()) { case QEvent::FocusIn: case QEvent::FocusOut: if(opts.highlightScrollViews && object->isWidgetType() && ::qt_cast(object)) ((QWidget *)object)->repaint(false); break; case QEvent::Hide: case QEvent::Show: if(::qt_cast(object) && (((QListBox *)object)->parentWidget() && ::qt_cast(((QListBox *)object)->parentWidget()))) ((QComboBox *)(((QListBox *)object)->parentWidget()))->repaint(false); // else if(::qt_cast(object) && // (QFrame::Box==((QFrame *)object)->frameShape() || QFrame::Panel==((QFrame *)object)->frameShape() || // QFrame::WinPanel==((QFrame *)object)->frameShape())) // ((QFrame *)object)->setFrameShape(QFrame::StyledPanel); break; case QEvent::Enter: if(object->isWidgetType()) { itsHoverWidget=(QWidget *)object; if(itsHoverWidget && itsHoverWidget->isEnabled()) { if(::qt_cast(object) && static_cast(object)->isEnabled()) { itsHoverTab=0L; itsHoverWidget->repaint(false); } else if(!itsHoverWidget->hasMouseTracking() || (itsFormMode=isFormWidget(itsHoverWidget))) { itsHoverWidget->repaint(false); itsFormMode=false; } } else itsHoverWidget=0L; if(itsHoverWidget && !itsIsSpecialHover && isSpecialHover(itsHoverWidget)) itsIsSpecialHover=true; } break; case QEvent::Leave: if(itsHoverWidget && object==itsHoverWidget) { resetHover(); ((QWidget *)object)->repaint(false); } break; case QEvent::MouseMove: // Only occurs for widgets with mouse tracking enabled { QMouseEvent *me = static_cast(event); if(me && itsHoverWidget && object->isWidgetType()) { if(!me->pos().isNull() && itsIsSpecialHover && redrawHoverWidget(me->pos())) itsHoverWidget->repaint(false); itsOldPos=me->pos(); } break; } default: break; } return BASE_STYLE::eventFilter(object, event); } void QtCurveStyle::drawLightBevel(const QColor &bgnd, QPainter *p, const QRect &rOrig, const QColorGroup &cg, SFlags flags, int round, const QColor &fill, const QColor *custom, bool doBorder, bool doCorners, EWidget w) const { EAppearance app(widgetApp(w, &opts)); QRect r(rOrig), br(r); bool bevelledButton(WIDGET_BUTTON(w) && APPEARANCE_BEVELLED==app), sunken(flags &(Style_Down|Style_On|Style_Sunken)), flatWidget(WIDGET_PROGRESSBAR==w && !opts.borderProgress), lightBorder(!flatWidget && DRAW_LIGHT_BORDER(sunken , w, app)), draw3dfull(!flatWidget && !lightBorder && DRAW_3D_FULL_BORDER(sunken, app)), draw3d(!flatWidget && (draw3dfull || (!lightBorder && DRAW_3D_BORDER(sunken, app)))), doColouredMouseOver(!sunken && doBorder && opts.coloredMouseOver && flags&Style_MouseOver && WIDGET_SPIN!=w && WIDGET_COMBO_BUTTON!=w && WIDGET_SB_BUTTON!=w && (WIDGET_SB_SLIDER!=w || !opts.colorSliderMouseOver) && !(flags&DW_CLOSE_BUTTON) && (opts.coloredTbarMo || !(flags&STD_TOOLBUTTON)) && (flags&CHECK_BUTTON || flags&TOGGLE_BUTTON || !sunken)), plastikMouseOver(doColouredMouseOver && MO_PLASTIK==opts.coloredMouseOver), colouredMouseOver(doColouredMouseOver && (MO_COLORED==opts.coloredMouseOver || MO_COLORED_THICK==opts.coloredMouseOver || (MO_GLOW==opts.coloredMouseOver && itsFormMode))), doEtch(!itsFormMode && doBorder && ETCH_WIDGET(w) && !(flags&CHECK_BUTTON) && DO_EFFECT), glowFocus(doEtch && USE_GLOW_FOCUS(flags&Style_MouseOver) && flags&Style_HasFocus && flags&Style_Enabled), sunkenToggleMo(sunken && !(flags&Style_Down) && flags&(Style_MouseOver|TOGGLE_BUTTON)), horiz(flags&Style_Horizontal); const QColor *cols(custom ? custom : itsBackgroundCols), *border(colouredMouseOver ? borderColors(flags, cols) : cols); p->save(); if(doEtch) { r.addCoords(1, 1, -1, -1); br=r; } // fill if(br.width()>0 && br.height()>0) { // Adjust paint rect, so that gradient is drawn from the same coords as KDE4 and Gtk2 if(WIDGET_PROGRESSBAR==w && opts.stripedProgress) { p->save(); p->setClipRegion(p->clipRegion().eor(QRegion(br))); } br.addCoords(1, 1,-1,-1); drawBevelGradient(fill, p, br, horiz, sunken, app, w); br.addCoords(-1, -1, 1, 1); if(WIDGET_PROGRESSBAR==w && opts.stripedProgress) p->restore(); } if(!colouredMouseOver && lightBorder) br.addCoords(1, 1,-1,-1); else if(colouredMouseOver || (draw3d && flags&Style_Raised)) { int dark(/*bevelledButton ? */2/* : 4*/); if(colouredMouseOver) p->setPen(border[MO_STD_LIGHT(w, sunken)]); else p->setPen(border[sunken ? dark : 0]); if(colouredMouseOver || bevelledButton || draw3dfull) { //Left & top p->drawLine(br.x()+1, br.y()+2, br.x()+1, br.y()+br.height()-3); p->drawLine(br.x()+1, br.y()+1, br.x()+br.width()-2, br.y()+1); if(colouredMouseOver) p->setPen(border[MO_STD_DARK(w)]); else p->setPen(border[sunken ? 0 : dark]); //Right & bottom p->drawLine(br.x()+br.width()-2, br.y()+1, br.x()+br.width()-2, br.y()+br.height()-3); p->drawLine(br.x()+1, br.y()+br.height()-2, br.x()+br.width()-2, br.y()+br.height()-2); br.addCoords(2, 2,-2,-2); } else { //Left & top p->drawLine(br.x()+1, br.y()+2, br.x()+1, br.y()+br.height()-2); p->drawLine(br.x()+1, br.y()+1, br.x()+br.width()-2, br.y()+1); br.addCoords(2, 2,-1,-1); } } else br.addCoords(1, 1,-1,-1); if(!colouredMouseOver && lightBorder && br.width()>0 && br.height()>0) { QColor col(cols[APPEARANCE_DULL_GLASS==app ? 1 : 0]); p->setPen(col); br=r; br.addCoords(1,1,-1,-1); p->drawRect(br); if(IS_CUSTOM(app) || (WIDGET_PROGRESSBAR==w && (!IS_GLASS(app) || opts.fillProgress))) br.addCoords(1,1,-1,-1); else if(horiz) br.addCoords(1,0,-1,-1); else br.addCoords(0,1,-1,-1); } // fill if(br.width()>0 && br.height()>0 && (!sunken || sunkenToggleMo)) if(plastikMouseOver) { if(WIDGET_SB_SLIDER==w) { int len(SB_SLIDER_MO_LEN(horiz ? r.width() : r.height())), so(lightBorder ? SLIDER_MO_PLASTIK_BORDER : 1), eo(len+so), col(SLIDER_MO_SHADE); if(horiz) { drawBevelGradient(itsMouseOverCols[col], p, QRect(r.x()+so, r.y(), len, r.height()), horiz, sunken, app, w); drawBevelGradient(itsMouseOverCols[col], p, QRect(r.x()+r.width()-eo, r.y(), len, r.height()), horiz, sunken, app, w); } else { drawBevelGradient(itsMouseOverCols[col], p, QRect(r.x(), r.y()+so, r.width(), len), horiz, sunken, app, w); drawBevelGradient(itsMouseOverCols[col], p, QRect(r.x(), r.y()+r.height()-eo, r.width(), len), horiz, sunken, app, w); } } else { bool horizontal((horiz && WIDGET_SB_BUTTON!=w)|| (!horiz && WIDGET_SB_BUTTON==w)), thin(WIDGET_SB_BUTTON==w || WIDGET_SPIN==w || ((horiz ? r.height() : r.width())<16)); p->setPen(itsMouseOverCols[MO_PLASTIK_DARK(w)]); if(horizontal) { p->drawLine(r.x()+1, r.y()+1, r.x()+r.width()-2, r.y()+1); p->drawLine(r.x()+1, r.y()+r.height()-2, r.x()+r.width()-2, r.y()+r.height()-2); } else { p->drawLine(r.x()+1, r.y()+1, r.x()+1, r.y()+r.height()-2); p->drawLine(r.x()+r.width()-2, r.y()+1, r.x()+r.width()-2, r.y()+r.height()-2); } if(!thin) { p->setPen(itsMouseOverCols[MO_PLASTIK_LIGHT(w)]); if(horizontal) { p->drawLine(r.x()+1, r.y()+2, r.x()+r.width()-2, r.y()+2); p->drawLine(r.x()+1, r.y()+r.height()-3, r.x()+r.width()-2, r.y()+r.height()-3); } else { p->drawLine(r.x()+2, r.y()+1, r.x()+2, r.y()+r.height()-2); p->drawLine(r.x()+r.width()-3, r.y()+1, r.x()+r.width()-3, r.y()+r.height()-2); } } } } else if(colouredMouseOver && 0!=round && FULLLY_ROUNDED) { p->setPen(itsMouseOverCols[MO_STD_LIGHT(w, sunken)]); if(round&CORNER_TL) p->drawPoint(br.left(), br.top()); if(round&CORNER_BL) p->drawPoint(br.left(), br.bottom()); if(round&CORNER_BR) p->drawPoint(br.right(), br.bottom()); if(round&CORNER_TR) p->drawPoint(br.right(), br.top()); } if(doBorder) { const QColor *borderCols=glowFocus || (WIDGET_COMBO==w && USE_GLOW_FOCUS(flags&Style_MouseOver) && flags&Style_HasFocus && flags&Style_Enabled) ? itsFocusCols : (WIDGET_COMBO==w || WIDGET_COMBO_BUTTON==w) && cols==itsComboBtnCols ? flags&Style_MouseOver && MO_GLOW==opts.coloredMouseOver && !sunken ? itsMouseOverCols : itsButtonCols : cols; if((!sunken || sunkenToggleMo) && flags&Style_Enabled && !glowFocus && ((((doEtch && WIDGET_OTHER!=w && WIDGET_SLIDER_TROUGH!=w) || WIDGET_COMBO==w || WIDGET_SB_SLIDER==w) && MO_GLOW==opts.coloredMouseOver && flags&Style_MouseOver) || (WIDGET_DEF_BUTTON==w && IND_GLOW==opts.defBtnIndicator))) drawBorder(bgnd, p, r, cg, flags, round, WIDGET_DEF_BUTTON==w && IND_GLOW==opts.defBtnIndicator && (!(flags&Style_MouseOver) || !itsMouseOverCols) ? itsDefBtnCols : itsMouseOverCols, w, doCorners); else drawBorder(bgnd, p, r, cg, flags, round, colouredMouseOver && MO_COLORED_THICK==opts.coloredMouseOver ? itsMouseOverCols : borderCols, w, doCorners); } if(doEtch || glowFocus) if( (!sunken || sunkenToggleMo) && ((WIDGET_OTHER!=w && WIDGET_SLIDER_TROUGH!=w && MO_GLOW==opts.coloredMouseOver && flags&Style_MouseOver) || glowFocus || (WIDGET_DEF_BUTTON==w && IND_GLOW==opts.defBtnIndicator)/* || (flags&Style_HasFocus && FOCUS_FULL==opts.focus)*/ )) drawGlow(p, rOrig, cg, WIDGET_DEF_BUTTON==w && flags&Style_MouseOver ? WIDGET_STD_BUTTON : w, glowFocus ? itsFocusCols : 0); else drawEtch(p, rOrig, cg, EFFECT_SHADOW==opts.buttonEffect && WIDGET_BUTTON(w) && !sunken, ROUNDED_NONE==round); p->restore(); } void QtCurveStyle::drawGlow(QPainter *p, const QRect &r, const QColorGroup &cg, EWidget w, const QColor *cols) const { if(itsMouseOverCols || itsDefBtnCols || cols) { bool def(WIDGET_DEF_BUTTON==w && IND_GLOW==opts.defBtnIndicator), defShade=def && (!itsDefBtnCols || (itsMouseOverCols && itsDefBtnCols[ORIGINAL_SHADE]==itsMouseOverCols[ORIGINAL_SHADE])); QColor col(cols ? cols[GLOW_MO] : (def && itsDefBtnCols) || !itsMouseOverCols ? itsDefBtnCols[GLOW_DEFBTN] : itsMouseOverCols[GLOW_MO]); col=midColorF(cg.background(), col, 1.5-GLOW_ALPHA(defShade)); p->setPen(col); if(ROUND_NONE==opts.round) p->drawRect(r); else { p->drawLine(r.x()+2, r.y()+r.height()-1, r.x()+r.width()-3, r.y()+r.height()-1); p->drawLine(r.x()+r.width()-1, r.y()+2, r.x()+r.width()-1, r.y()+r.height()-3); p->drawLine(r.x()+3, r.y(), r.x()+r.width()-4, r.y()); p->drawLine(r.x(), r.y()+3, r.x(), r.y()+r.height()-4); //p->setPen(midColor(col, cg.background())); p->drawLine(r.x()+r.width()-1, r.y()+r.height()-3, r.x()+r.width()-3, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+r.height()-3, r.x()+2, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+2, r.x()+2, r.y()); p->drawLine(r.x()+r.width()-3, r.y(), r.x()+r.width()-1, r.y()+2); p->setPen(midColor(col, cg.background())); p->drawLine(r.x()+r.width()-1, r.y()+r.height()-2, r.x()+r.width()-2, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+r.height()-2, r.x()+1, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+1, r.x()+1, r.y()); p->drawLine(r.x()+r.width()-2, r.y(), r.x()+r.width()-1, r.y()+1); } } } void QtCurveStyle::drawEtch(QPainter *p, const QRect &r, const QColorGroup &cg, bool raised, bool square) const { square=square || ROUND_NONE==opts.round; int mod(square ? 0 : 2); { QColor col(raised ? shade(cg.background(), ETCHED_DARK) : itsBackgroundCols[1]); p->setPen(col); p->drawLine(r.x()+mod, r.y()+r.height()-1, r.x()+r.width()-(1+mod), r.y()+r.height()-1); p->drawLine(r.x()+r.width()-1, r.y()+mod, r.x()+r.width()-1, r.y()+r.height()-(1+mod)); if(!square) { p->setPen(midColor(raised ? col : itsBackgroundCols[0], cg.background())); p->drawLine(r.x()+r.width()-1, r.y()+r.height()-3, r.x()+r.width()-3, r.y()+r.height()-1); p->drawLine(r.x()+1, r.y()+r.height()-2, r.x()+2, r.y()+r.height()-1); p->drawLine(r.x()+r.width()-2, r.y()+1, r.x()+r.width()-1, r.y()+2); } } if(!raised) { QColor darkCol(shade(cg.background(), ETCHED_DARK)); p->setPen(darkCol); p->drawLine(r.x()+1+mod, r.y(), r.x()+r.width()-(2+mod), r.y()); p->drawLine(r.x(), r.y()+1+mod, r.x(), r.y()+r.height()-(2+mod)); if(!square) { p->setPen(midColor(darkCol, cg.background())); p->drawLine(r.x(), r.y()+2, r.x()+2, r.y()); p->drawLine(r.x()+r.width()-3, r.y(), r.x()+r.width()-2, r.y()+1); p->drawLine(r.x(), r.y()+r.height()-3, r.x()+1, r.y()+r.height()-2); } } } void QtCurveStyle::drawBorder(const QColor &bgnd, QPainter *p, const QRect &r, const QColorGroup &cg, SFlags flags, int round, const QColor *custom, EWidget w, bool doCorners, EBorder borderProfile, bool blendBorderColors, int borderVal) const { EAppearance app(widgetApp(w, &opts)); const QColor *cols(custom ? custom : itsBackgroundCols); QColor border(flags&Style_ButtonDefault && IND_FONT_COLOR==opts.defBtnIndicator && flags&Style_Enabled ? cg.buttonText() : cols[WIDGET_PROGRESSBAR==w ? PBAR_BORDER : !(flags&Style_Enabled) && (WIDGET_BUTTON(w) || WIDGET_SLIDER_TROUGH==w || flags&CHECK_BUTTON) ? DISABLED_BORDER : itsMouseOverCols==cols && IS_SLIDER(w) ? SLIDER_MO_BORDER_VAL : borderVal]); bool hasFocus(cols==itsFocusCols /* CPD USED TO INDICATE FOCUS! */), hasMouseOver(cols==itsMouseOverCols && ENTRY_MO); if(WIDGET_TAB_BOT==w || WIDGET_TAB_TOP==w) cols=itsBackgroundCols; switch(borderProfile) { case BORDER_FLAT: break; case BORDER_RAISED: case BORDER_SUNKEN: case BORDER_LIGHT: if(flags&Style_Enabled && (hasMouseOver || hasFocus) && (WIDGET_ENTRY==w || WIDGET_SCROLLVIEW==w || WIDGET_COMBO==w || WIDGET_SPIN==w)) p->setPen(midColorF(cg.background(), cols[BORDER_RAISED==borderProfile || BORDER_LIGHT==borderProfile ? 0 : FRAME_DARK_SHADOW], 1.5-ENTRY_INNER_ALPHA)); else p->setPen(flags&Style_Enabled && (BORDER_RAISED==borderProfile || BORDER_LIGHT==borderProfile || APPEARANCE_FLAT!=app) ? blendBorderColors ? midColor(cg.background(), cols[BORDER_RAISED==borderProfile ? 0 : FRAME_DARK_SHADOW]) // Was base??? : cols[BORDER_RAISED==borderProfile || BORDER_LIGHT==borderProfile ? 0 : FRAME_DARK_SHADOW] : cg.background()); p->drawLine(r.x()+1, r.y()+1, r.x()+1, r.y()+r.height()-2); p->drawLine(r.x()+1, r.y()+1, r.x()+r.width()-2, r.y()+1); if(!hasFocus && !hasMouseOver && BORDER_LIGHT!=borderProfile) p->setPen(WIDGET_SCROLLVIEW==w ? cg.background() : WIDGET_ENTRY==w ? cg.base() : flags&Style_Enabled && (BORDER_SUNKEN==borderProfile || APPEARANCE_FLAT!=app || WIDGET_TAB_TOP==w || WIDGET_TAB_BOT==w) ? blendBorderColors ? midColor(cg.background(), cols[BORDER_RAISED==borderProfile ? FRAME_DARK_SHADOW : 0]) // Was base??? : cols[BORDER_RAISED==borderProfile ? FRAME_DARK_SHADOW : 0] : cg.background()); p->drawLine(r.x()+r.width()-2, r.y()+1, r.x()+r.width()-2, r.y()+r.height()-2); p->drawLine(r.x()+1, r.y()+r.height()-2, r.x()+r.width()-2, r.y()+r.height()-2); } if(ROUNDED && ROUNDED_NONE!=round) { bool largeArc(WIDGET_FOCUS!=w && FULLLY_ROUNDED && !(flags&CHECK_BUTTON) && r.width()>=MIN_ROUND_FULL_SIZE && r.height()>=MIN_ROUND_FULL_SIZE && !(flags&DW_CLOSE_BUTTON) && (WIDGET_PROGRESSBAR!=w || opts.fillProgress)); p->setPen(border); if(itsFormMode) { // If we're itsFormMode (KHTML) then we need to draw the aa borders using pixmaps // - so we need to draw 2 pixels away from each corner (so that the alpha // blend lets through the background color... p->drawLine(r.x()+2, r.y(), r.x()+r.width()-3, r.y()); p->drawLine(r.x()+2, r.y()+r.height()-1, r.x()+r.width()-3, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+2, r.x(), r.y()+r.height()-3); p->drawLine(r.x()+r.width()-1, r.y()+2, r.x()+r.width()-1, r.y()+r.height()-3); // If not rounding a corner need to draw the missing pixels! if(!(round&CORNER_TL) || !largeArc) { p->drawPoint(r.x()+1, r.y()); p->drawPoint(r.x(), r.y()+1); } if(!(round&CORNER_TR) || !largeArc) { p->drawPoint(r.x()+r.width()-2, r.y()); p->drawPoint(r.x()+r.width()-1, r.y()+1); } if(!(round&CORNER_BR) || !largeArc) { p->drawPoint(r.x()+r.width()-2, r.y()+r.height()-1); p->drawPoint(r.x()+r.width()-1, r.y()+r.height()-2); } if(!(round&CORNER_BL) || !largeArc) { p->drawPoint(r.x()+1, r.y()+r.height()-1); p->drawPoint(r.x(), r.y()+r.height()-2); } } else { // If we're not itsFormMode (ie. not KHTML) then we can just draw 1 pixel in - as // we can overwrite with the alpha colour. p->drawLine(r.x()+1, r.y(), r.x()+r.width()-2, r.y()); p->drawLine(r.x()+1, r.y()+r.height()-1, r.x()+r.width()-2, r.y()+r.height()-1); p->drawLine(r.x(), r.y()+1, r.x(), r.y()+r.height()-2); p->drawLine(r.x()+r.width()-1, r.y()+1, r.x()+r.width()-1, r.y()+r.height()-2); } //if(!opts.fillProgress || WIDGET_PROGRESSBAR!=w) { QColor largeArcMid(midColor(border, bgnd)), aaColor(midColor(custom ? custom[3] : itsBackgroundCols[3], bgnd)); QPixmap *pix=itsFormMode ? getPixelPixmap(border) : 0L; if(round&CORNER_TL) { if(largeArc) { p->drawPoint(r.x()+1, r.y()+1); if(itsFormMode) { p->drawPixmap(r.x(), r.y()+1, *pix); p->drawPixmap(r.x()+1, r.y(), *pix); } else { p->setPen(largeArcMid); p->drawLine(r.x(), r.y()+1, r.x()+1, r.y()); } } if(doCorners) if(itsFormMode) { if(!largeArc) p->drawPixmap(r.x(), r.y(), *pix); } else { p->setPen(largeArc ? bgnd : aaColor); p->drawPoint(r.x(), r.y()); } } else p->drawPoint(r.x(), r.y()); p->setPen(border); if(round&CORNER_TR) { if(largeArc) { p->drawPoint(r.x()+r.width()-2, r.y()+1); if(itsFormMode) { p->drawPixmap(r.x()+r.width()-2, r.y(), *pix); p->drawPixmap(r.x()+r.width()-1, r.y()+1, *pix); } else { p->setPen(largeArcMid); p->drawLine(r.x()+r.width()-2, r.y(), r.x()+r.width()-1, r.y()+1); } } if(doCorners) if(itsFormMode) { if(!largeArc) p->drawPixmap(r.x()+r.width()-1, r.y(), *pix); } else { p->setPen(largeArc ? bgnd : aaColor); p->drawPoint(r.x()+r.width()-1, r.y()); } } else p->drawPoint(r.x()+r.width()-1, r.y()); p->setPen(border); if(round&CORNER_BR) { if(largeArc) { p->drawPoint(r.x()+r.width()-2, r.y()+r.height()-2); if(itsFormMode) { p->drawPixmap(r.x()+r.width()-2, r.y()+r.height()-1, *pix); p->drawPixmap(r.x()+r.width()-1, r.y()+r.height()-2, *pix); } else { p->setPen(largeArcMid); p->drawLine(r.x()+r.width()-2, r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-2); } } if(doCorners) if(itsFormMode) { if(!largeArc) p->drawPixmap(r.x()+r.width()-1, r.y()+r.height()-1, *pix); } else { p->setPen(largeArc ? bgnd : aaColor); p->drawPoint(r.x()+r.width()-1, r.y()+r.height()-1); } } else p->drawPoint(r.x()+r.width()-1, r.y()+r.height()-1); p->setPen(border); if(round&CORNER_BL) { if(largeArc) { p->drawPoint(r.x()+1, r.y()+r.height()-2); if(itsFormMode) { p->drawPixmap(r.x(), r.y()+r.height()-2, *pix); p->drawPixmap(r.x()+1, r.y()+r.height()-1, *pix); } else { p->setPen(largeArcMid); p->drawLine(r.x(), r.y()+r.height()-2, r.x()+1, r.y()+r.height()-1); } } if(doCorners) if(itsFormMode) { if(!largeArc) p->drawPixmap(r.x(), r.y()+r.height()-1, *pix); } else { p->setPen(largeArc ? bgnd : aaColor); p->drawPoint(r.x(), r.y()+r.height()-1); } } else p->drawPoint(r.x(), r.y()+r.height()-1); } } else { p->setPen(border); p->setBrush(NoBrush); p->drawRect(r); } } void QtCurveStyle::drawMdiIcon(QPainter *painter, const QColor &color, const QColor &shadow, const QRect &r, bool sunken, int margin, SubControl button) const { if(!sunken) drawWindowIcon(painter, shadow, adjusted(r, 1, 1, 1, 1), sunken, margin, button); drawWindowIcon(painter, color, r, sunken, margin, button); } void QtCurveStyle::drawWindowIcon(QPainter *painter, const QColor &color, const QRect &r, bool sunken, int margin, SubControl button) const { QRect rect(r); // Icons look best at 22x22... if(rect.height()>22) { int diff=(rect.height()-22)/2; adjust(rect, diff, diff, -diff, -diff); } if(sunken) adjust(rect, 1, 1, 1, 1); if(margin) adjust(rect, margin, margin, -margin, -margin); painter->setPen(color); switch(button) { case SC_TitleBarMinButton: painter->drawLine(rect.center().x() - 2, rect.center().y() + 3, rect.center().x() + 3, rect.center().y() + 3); painter->drawLine(rect.center().x() - 2, rect.center().y() + 4, rect.center().x() + 3, rect.center().y() + 4); painter->drawLine(rect.center().x() - 3, rect.center().y() + 3, rect.center().x() - 3, rect.center().y() + 4); painter->drawLine(rect.center().x() + 4, rect.center().y() + 3, rect.center().x() + 4, rect.center().y() + 4); break; case SC_TitleBarMaxButton: painter->drawRect(rect); // adjusted(rect, 0, 0, -1, -1)); painter->drawLine(rect.left() + 1, rect.top() + 1, rect.right() - 1, rect.top() + 1); painter->drawPoint(rect.topLeft()); painter->drawPoint(rect.topRight()); painter->drawPoint(rect.bottomLeft()); painter->drawPoint(rect.bottomRight()); break; case SC_TitleBarCloseButton: painter->drawLine(rect.left() + 1, rect.top(), rect.right(), rect.bottom() - 1); painter->drawLine(rect.left(), rect.top() + 1, rect.right() - 1, rect.bottom()); painter->drawLine(rect.right() - 1, rect.top(), rect.left(), rect.bottom() - 1); painter->drawLine(rect.right(), rect.top() + 1, rect.left() + 1, rect.bottom()); painter->drawPoint(rect.topLeft()); painter->drawPoint(rect.topRight()); painter->drawPoint(rect.bottomLeft()); painter->drawPoint(rect.bottomRight()); painter->drawLine(rect.left() + 1, rect.top() + 1, rect.right() - 1, rect.bottom() - 1); painter->drawLine(rect.left() + 1, rect.bottom() - 1, rect.right() - 1, rect.top() + 1); break; case SC_TitleBarNormalButton: { QRect r2 = adjusted(rect, 0, 3, -3, 0); painter->drawRect(r2); // adjusted(r2, 0, 0, -1, -1)); painter->drawLine(r2.left() + 1, r2.top() + 1, r2.right() - 1, r2.top() + 1); painter->drawPoint(r2.topLeft()); painter->drawPoint(r2.topRight()); painter->drawPoint(r2.bottomLeft()); painter->drawPoint(r2.bottomRight()); QRect backWindowRect(adjusted(rect, 3, 0, 0, -3)); QRegion clipRegion(backWindowRect); clipRegion -= r2; if(sunken) adjust(backWindowRect, 1, 1, 1, 1); painter->drawRect(backWindowRect); // adjusted(backWindowRect, 0, 0, -1, -1)); painter->drawLine(backWindowRect.left() + 1, backWindowRect.top() + 1, backWindowRect.right() - 1, backWindowRect.top() + 1); painter->drawPoint(backWindowRect.topLeft()); painter->drawPoint(backWindowRect.topRight()); painter->drawPoint(backWindowRect.bottomLeft()); painter->drawPoint(backWindowRect.bottomRight()); break; } case SC_TitleBarShadeButton: ::drawArrow(painter, rect, color, PE_ArrowUp, opts, true); break; case SC_TitleBarUnshadeButton: ::drawArrow(painter, rect, color, PE_ArrowDown, opts, true); default: break; } } void QtCurveStyle::drawEntryField(QPainter *p, const QRect &rx, const QColorGroup &cg, SFlags flags, EntryColor coloration, int round, EWidget w) const { const QColor *use(ENTRY_MOUSE_OVER==coloration && itsMouseOverCols ? itsMouseOverCols : ENTRY_FOCUS==coloration && itsFocusCols ? itsFocusCols : backgroundColors(cg)); bool isSpin(WIDGET_SPIN==w), doEtch(!itsFormMode && opts.etchEntry && (!isSpin || opts.unifySpin) && WIDGET_COMBO!=w && DO_EFFECT), reverse(QApplication::reverseLayout()); if(WIDGET_SCROLLVIEW!=w && (opts.square&SQUARE_ENTRY)) round=ROUNDED_NONE; QRect r(rx); if(doEtch) r.addCoords(1, 1, -1, -1); if(!itsFormMode) { p->setPen(cg.background()); p->drawRect(rx); } if(isSpin || WIDGET_ENTRY==w || WIDGET_COMBO==w) { if(reverse && isSpin) r.addCoords(-1, 0, 0, 0); if(isSpin || WIDGET_COMBO==w) p->fillRect(r, flags&Style_Enabled ? cg.base() : cg.background()); } if(ENTRY_NONE!=coloration && isSpin && !opts.unifySpin) if(reverse) r.addCoords(1, 0, 0, 0); else r.addCoords(0, 0, -1, 0); drawBorder(cg.background(), p, r, cg, (SFlags)(flags|Style_Horizontal), round, use, WIDGET_SCROLLVIEW==w ? w : WIDGET_ENTRY, true, isSpin && !(flags&Style_Enabled) ? BORDER_FLAT : BORDER_SUNKEN); if(doEtch) { QRect r(rx); p->setClipRegion(r); if(!(round&CORNER_TR) && !(round&CORNER_BR)) r.addCoords(0, 0, 2, 0); if(!(round&CORNER_TL) && !(round&CORNER_BL)) r.addCoords(-2, 0, 0, 0); drawEtch(p, r, cg, EFFECT_SHADOW==opts.buttonEffect && WIDGET_BUTTON(w) && !(flags &(Style_Down | Style_On | Style_Sunken)), ROUNDED_NONE==round); p->setClipping(false); } } void QtCurveStyle::drawArrow(QPainter *p, const QRect &r, const QColorGroup &cg, SFlags flags, PrimitiveElement pe, bool small, bool checkActive) const { const QColor &col(flags&Style_Enabled ? checkActive && flags&Style_Active ? cg.highlightedText() : cg.text() : cg.mid()); ::drawArrow(p, r, p->pen()==QPen::NoPen ? col : p->pen().color(), pe, opts, small); } void QtCurveStyle::drawPrimitive(PrimitiveElement pe, QPainter *p, const QRect &r, const QColorGroup &cg, SFlags flags, const QStyleOption &data) const { switch(pe) { case PE_HeaderSection: { // Is it a taskbar button? Kicker uses PE_HeaderSection for these! :-( // If the painter device is a QWidger, assume its not a taskbar button... if(APP_KICKER==itsThemedApp && (!p->device() || !dynamic_cast(p->device()))) { const QColor *use(buttonColors(cg)); if(flags&Style_Down) flags=((flags|Style_Down)^Style_Down)| Style_Sunken; flags|=Style_Enabled; #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 #if defined KDE_VERSION && KDE_VERSION >= 0x30400 && KDE_VERSION < 0x30500 if(HOVER_KICKER==itsHover && itsHoverWidget) // && itsHoverWidget==p->device()) flags|=Style_MouseOver; #endif itsFormMode=itsIsTransKicker; #endif drawLightBevel(p, r, cg, flags|Style_Horizontal, ROUNDED_ALL, getFill(flags, use), use, true, false); #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 itsFormMode=false; #endif } else { bool isFirst(false), isLast(false), isTable(false), isSort(false); QHeader *header(p && p->device() ? dynamic_cast(p->device()) : 0L); if (header) { if(header->parent() && ::qt_cast(header->parent())) { QTable *tbl((QTable *)(header->parent())); isTable=true; if(flags&Style_Horizontal) isFirst=tbl->columnAt(r.x()+header->offset())==0; else isLast=tbl->rowAt(r.y()+header->offset())==(tbl->numRows()-1); } else { int index=header->mapToIndex(header->sectionAt(r.x()+header->offset())); isFirst = index == 0; isSort = header->sortIndicatorSection() == index; } } else if(0==flags) // Header on popup menu? { QWidget *widget(p && p->device() ? dynamic_cast(p->device()) : 0L); bool menuTitle(widget && 0==qstrcmp(widget->className(), "KPopupTitle")); const QColor *use(buttonColors(cg)); QRect r2(r); if(menuTitle) r2.addCoords(2, 2, -2, -2); drawLightBevel(p, r2, cg, flags|Style_Horizontal, ROUNDED_ALL, getFill(flags, use), use); break; } const QColor *use(flags&Style_Enabled && itsSortedLvColors && isSort ? itsSortedLvColors : opts.lvButton ? buttonColors(cg) : backgroundColors(cg)); flags=((flags|Style_Sunken)^Style_Sunken)| Style_Raised; if(NO_SECT!=itsHoverSect && HOVER_HEADER==itsHover && itsHoverWidget) { QHeader *hd(::qt_cast(itsHoverWidget)); if(hd && hd->isClickEnabled(itsHoverSect) && r==hd->sectionRect(itsHoverSect)) flags|=Style_MouseOver; } bool sunken(flags &(Style_Down | Style_On | Style_Sunken)); drawBevelGradient(getFill(flags, use), p, r, flags&Style_Horizontal, sunken, opts.lvAppearance, WIDGET_LISTVIEW_HEADER); if(APPEARANCE_RAISED==opts.lvAppearance) { p->setPen(use[4]); if(flags&Style_Horizontal) p->drawLine(r.x(), r.y()+r.height()-2, r.x()+r.width()-1, r.y()+r.height()-2); else p->drawLine(r.x()+r.width()-2, r.y(), r.x()+r.width()-2, r.y()+r.height()-1); } if(flags&Style_Horizontal) { p->setPen(use[STD_BORDER]); p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); if(itsMouseOverCols && opts.coloredMouseOver && flags&Style_MouseOver) drawHighlight(p, QRect(r.x(), r.y()+r.height()-2, r.width(), 2), cg, true, true); if(!isFirst) { p->setPen(use[STD_BORDER]); p->drawLine(r.x(), r.y()+5, r.x(), r.y()+r.height()-6); p->setPen(use[0]); p->drawLine(r.x()+1, r.y()+5, r.x()+1, r.y()+r.height()-6); } } else { p->setPen(use[STD_BORDER]); p->drawLine(r.x()+r.width()-1, r.y(), r.x()+r.width()-1, r.y()+r.height()-1); if(!isLast) { p->setPen(use[STD_BORDER]); p->drawLine(r.x()+5, r.y()+r.height()-2, r.x()+r.width()-6, r.y()+r.height()-2); p->setPen(use[0]); p->drawLine(r.x()+5, r.y()+r.height()-1, r.x()+r.width()-6, r.y()+r.height()-1); } if(itsMouseOverCols && opts.coloredMouseOver && flags&Style_MouseOver) drawHighlight(p, QRect(r.x(), r.y()+r.height()-3, r.width(), 2), cg, true, true); } } break; } case PE_HeaderArrow: ::drawArrow(p, r, MO_ARROW(cg.buttonText()), flags&Style_Up ? PE_ArrowUp : PE_ArrowDown, opts, false); break; case PE_ButtonBevel: flags|=Style_Enabled; case PE_ButtonCommand: case PE_ButtonTool: case PE_ButtonDropDown: { const QColor *use((IND_TINT==opts.defBtnIndicator || IND_SELECTED==opts.defBtnIndicator) && flags&Style_Enabled && flags&Style_ButtonDefault ? itsDefBtnCols : buttonColors(cg)); bool glassMod(PE_ButtonTool==pe && IS_GLASS(opts.appearance) && IS_GLASS(opts.toolbarAppearance)), mdi(!(flags&CHECK_BUTTON) && (!(flags&STD_TOOLBUTTON)||flags&NO_ETCH_BUTTON) && PE_ButtonTool==pe && r.width()<=16 && r.height()<=16), operaMdi(PE_ButtonTool==pe && APP_OPERA==itsThemedApp && r.width()==16 && r.height()==16); // If its not sunken, its raised-don't want flat buttons. if(!(flags&Style_Sunken)) flags|=Style_Raised; if(PE_ButtonTool==pe && flags&VERTICAL_TB_BUTTON) { flags-=VERTICAL_TB_BUTTON; if(flags&Style_Horizontal) flags-=Style_Horizontal; } // Dont AA' MDI windows' control buttons... itsFormMode=itsFormMode || mdi || operaMdi; if(mdi || operaMdi) { flags|=Style_Horizontal; if(!operaMdi) { if(flags<0x14000000 && !(flags&(Style_Down|Style_On|Style_Sunken|Style_MouseOver))) break; if(flags<0x14000000) use=getMdiColors(cg, true); } } drawLightBevel(/*flags&DW_CLOSE_BUTTON ? cg.background().dark(DW_BGND) : */cg.background(), p, r, cg, glassMod ? flags : flags|Style_Horizontal, #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 (APP_KORN==itsThemedApp && itsIsTransKicker && PE_ButtonTool==pe) || #endif operaMdi || mdi ? ROUNDED_NONE : ROUNDED_ALL, getFill(flags, use, false, flags&Style_ButtonDefault && flags&Style_Enabled && IND_DARKEN==opts.defBtnIndicator), use, true, true, flags&NO_ETCH_BUTTON ? WIDGET_NO_ETCH_BTN : flags&Style_ButtonDefault && flags&Style_Enabled && IND_COLORED!=opts.defBtnIndicator ? WIDGET_DEF_BUTTON : WIDGET_STD_BUTTON); if(IND_COLORED==opts.defBtnIndicator && flags&Style_ButtonDefault && flags&Style_Enabled) { QRegion outer(r); QRect r2(r); if(!itsFormMode && DO_EFFECT) r2.addCoords(1, 1, -1, -1); r2.addCoords(COLORED_BORDER_SIZE, COLORED_BORDER_SIZE, -COLORED_BORDER_SIZE, -COLORED_BORDER_SIZE); QRegion inner(r2); p->setClipRegion(outer.eor(inner)); drawLightBevel(p, r, cg, glassMod ? flags : flags|Style_Horizontal, flags&CHECK_BUTTON #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 || (APP_KORN==itsThemedApp && itsIsTransKicker && PE_ButtonTool==pe) #endif ? ROUNDED_NONE : ROUNDED_ALL, itsDefBtnCols[MO_DEF_BTN], itsDefBtnCols, true, true, WIDGET_DEF_BUTTON); p->setClipping(false); } itsFormMode=false; break; } case PE_ButtonDefault: switch(opts.defBtnIndicator) { case IND_CORNER: { QPointArray points; bool sunken(flags&Style_Down || flags&Style_Sunken); int offset(sunken ? 5 : 4), etchOffset(DO_EFFECT ? 1 : 0); const QColor *cols(itsFocusCols ? itsFocusCols : itsHighlightCols); points.setPoints(3, r.x()+offset+etchOffset, r.y()+offset+etchOffset, r.x()+offset+6+etchOffset, r.y()+offset+etchOffset, r.x()+offset+etchOffset, r.y()+offset+6+etchOffset); p->setBrush(cols[sunken ? 0 : 4]); p->setPen(cols[sunken ? 0 : 4]); p->drawPolygon(points); break; } default: break; } break; case PE_CheckMark: if(flags&Style_On) { QPixmap *pix(getPixmap(checkRadioCol(flags, cg), PIX_CHECK, 1.0)); p->drawPixmap(r.center().x()-(pix->width()/2), r.center().y()-(pix->height()/2), *pix); } else if (!(flags&Style_Off)) // tri-state { int x(r.center().x()), y(r.center().y()); p->setPen(checkRadioCol(flags, cg)); p->drawLine(x-3, y, x+3, y); p->drawLine(x-3, y+1, x+3, y+1); } break; case PE_CheckListController: { QCheckListItem *item(data.checkListItem()); if(item) { const QColor *bc(borderColors(flags, 0L)), *btn(buttonColors(cg)), *use(bc ? bc : btn); int x(r.x()+1), y(r.y()+2); p->drawPixmap(x, y, *getPixmap(use[opts.coloredMouseOver && flags&Style_MouseOver ? 4 : BORDER_VAL(flags&Style_Enabled)], PIX_RADIO_BORDER, 0.8)); ::drawArrow(p, QRect(r.x()-1, r.y()-1, r.width(), r.height()), use[opts.coloredMouseOver && flags&Style_MouseOver ? 4:5], PE_ArrowDown, opts); } break; } case PE_CheckListIndicator: { QCheckListItem *item(data.checkListItem()); if(item) { QListView *lv(item->listView()); p->setPen(QPen(flags&Style_Enabled ? cg.text() : lv->palette().color(QPalette::Disabled, QColorGroup::Text))); if (flags&Style_Selected) { flags-=Style_Selected; if(!lv->rootIsDecorated() && !((item->parent() && 1==item->parent()->rtti() && QCheckListItem::Controller==((QCheckListItem*)item->parent())->type()))) { p->fillRect(0, 0, r.x()+lv->itemMargin()+r.width()+4, item->height(), cg.brush(QColorGroup::Highlight)); if(item->isEnabled()) { p->setPen(QPen(cg.highlightedText())); flags+=Style_Selected; } } } QRect checkRect(r.x()+1, r.y()+1, opts.crSize, opts.crSize); drawPrimitive(PE_Indicator, p, checkRect, cg, flags|LISTVIEW_ITEM); } break; } case PE_IndicatorMask: if(ROUNDED) { p->fillRect(r, color0); p->fillRect(r.x()+1, r.y(), r.width()-2, r.height(), color1); p->setPen(color1); p->drawLine(r.x(), r.y()+1, r.x(), r.y()+r.height()-2); p->drawLine(r.x()+r.width()-1, r.y()+1, r.x()+r.width()-1, r.y()+r.height()-2); } else p->fillRect(r, color1); break; case PE_Indicator: { bool doEtch(DO_EFFECT && !itsFormMode && !(flags&LISTVIEW_ITEM)), on(flags&Style_On || !(flags&Style_Off)), sunken(flags&Style_Down); QRect rect(doEtch ? QRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2) : r); SFlags sflags(!(flags&Style_Off) ? flags|Style_On : flags); if(sunken || (!itsFormMode && HOVER_NONE==itsHover)) sflags&=~Style_MouseOver; bool glowFocus(USE_GLOW_FOCUS(flags&Style_MouseOver) && sflags&Style_Enabled && sflags&Style_HasFocus), glow(doEtch && sflags&Style_Enabled && ((MO_GLOW==opts.coloredMouseOver && sflags&Style_MouseOver) || glowFocus)); const QColor *bc(glowFocus ? itsFocusCols : borderColors(sflags, 0L)), *btn(checkRadioColors(cg, sflags)), *use(bc ? bc : btn), &bgnd(opts.crButton ? getFill(flags, btn, true) : sflags&Style_Enabled && !sunken ? MO_NONE==opts.coloredMouseOver && !opts.crHighlight && sflags&Style_MouseOver ? use[CR_MO_FILL] : cg.base() : cg.background()); EWidget wid=opts.crButton ? WIDGET_STD_BUTTON : WIDGET_TROUGH; EAppearance app=opts.crButton ? opts.appearance : APPEARANCE_INVERTED; bool drawSunken=opts.crButton ? sunken : false, lightBorder=DRAW_LIGHT_BORDER(drawSunken, wid, app), draw3dFull=!lightBorder && DRAW_3D_FULL_BORDER(drawSunken, app), draw3d=draw3dFull || (!lightBorder && DRAW_3D_BORDER(drawSunken, app)), drawLight=opts.crButton && !drawSunken && (lightBorder || draw3d), drawDark=drawLight && draw3dFull && !lightBorder; if(IS_FLAT(opts.appearance)) p->fillRect(QRect(rect.x()+1, rect.y()+1, rect.width()-2, rect.height()-2), bgnd); else drawBevelGradient(bgnd, p, QRect(rect.x()+1, rect.y()+1, rect.width()-2, rect.height()-2), true, drawSunken, app, wid); if(MO_NONE!=opts.coloredMouseOver && !glow && sflags&Style_MouseOver && sflags&Style_Enabled) { p->setPen(use[CR_MO_FILL]); p->drawRect(QRect(rect.x()+1, rect.y()+1, rect.width()-2, rect.height()-2)); // p->drawRect(QRect(rect.x()+2, rect.y()+2, rect.width()-4, rect.height()-4)); } else if(!opts.crButton || drawLight) { p->setPen(drawLight ? btn[LIGHT_BORDER(app)] : midColor(sflags&Style_Enabled ? cg.base() : cg.background(), use[3])); if(lightBorder) p->drawRect(QRect(rect.x()+1, rect.y()+1, rect.width()-2, rect.height()-2)); else { p->drawLine(rect.x()+1, rect.y()+1, rect.x()+1, rect.y()+rect.height()-2); p->drawLine(rect.x()+1, rect.y()+1, rect.x()+rect.width()-2, rect.y()+1); if(drawDark) { p->setPen(btn[2]); p->drawLine(rect.x()+rect.width()-2, rect.y()+1, rect.x()+rect.width()-2, rect.y()+rect.height()-2); p->drawLine(rect.x()+1, rect.y()+rect.height()-2, rect.x()+rect.width()-2, rect.y()+rect.height()-2); } } } drawBorder(cg.background(), p, rect, cg, (SFlags)(sflags|Style_Horizontal|CHECK_BUTTON), ROUNDED_ALL, use, WIDGET_OTHER, !(flags&LISTVIEW_ITEM)); if(doEtch) { QColor topCol(glow ? glowFocus ? itsFocusCols[GLOW_MO] : itsMouseOverCols[GLOW_MO] : shade(cg.background(), ETCHED_DARK)), botCol(glow ? topCol : itsBackgroundCols[1]); p->setBrush(Qt::NoBrush); p->setPen(topCol); if(!opts.crButton || EFFECT_SHADOW!=opts.buttonEffect || drawSunken || glow) { p->drawLine(r.x()+1, r.y(), r.x()+r.width()-2, r.y()); p->drawLine(r.x(), r.y()+1, r.x(), r.y()+r.height()-2); p->setPen(botCol); } p->drawLine(r.x()+1, r.y()+r.height()-1, r.x()+r.width()-2, r.y()+r.height()-1); p->drawLine(r.x()+r.width()-1, r.y()+1, r.x()+r.width()-1, r.y()+r.height()-2); } if(on) drawPrimitive(PE_CheckMark, p, rect, cg, flags); break; } case PE_CheckListExclusiveIndicator: { QCheckListItem *item(data.checkListItem()); if(item) { const QColor *bc(borderColors(flags, 0L)), *btn(buttonColors(cg)), *use(bc ? bc : btn), &on(checkRadioCol(flags, cg)); int x(r.x()), y(r.y()+2); p->drawPixmap(x, y, *getPixmap(use[opts.coloredMouseOver && flags&Style_MouseOver ? 4 : BORDER_VAL(flags&Style_Enabled)], PIX_RADIO_BORDER, 0.8)); if(flags&Style_On) p->drawPixmap(x, y, *getPixmap(on, PIX_RADIO_ON, 1.0)); } break; } case PE_ExclusiveIndicator: case PE_ExclusiveIndicatorMask: if(PE_ExclusiveIndicatorMask==pe) { p->fillRect(r, color0); p->setPen(Qt::color1); p->setBrush(Qt::color1); p->drawPie(r, 0, 5760); } else { bool doEtch(DO_EFFECT && !itsFormMode), sunken(flags&Style_Down); QRect rect(doEtch ? QRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2) : r); int x(rect.x()), y(rect.y()); QPointArray clipRegion; clipRegion.setPoints(8, x, y+8, x, y+4, x+4, y, x+8, y, x+12, y+4, x+12, y+8, x+8, y+12, x+4, y+12); SFlags sflags(flags); if(sunken || (!itsFormMode && HOVER_NONE==itsHover)) sflags&=~Style_MouseOver; bool glowFocus(USE_GLOW_FOCUS(flags&Style_MouseOver) && sflags&Style_Enabled && sflags&Style_HasFocus), glow(doEtch && sflags&Style_Enabled && ((MO_GLOW==opts.coloredMouseOver && sflags&Style_MouseOver) || glowFocus)), set(sflags&Style_On), coloredMo(MO_NONE!=opts.coloredMouseOver && !glow && sflags&Style_MouseOver && sflags&Style_Enabled); const QColor *bc(glowFocus ? itsFocusCols : borderColors(sflags, 0L)), *btn(checkRadioColors(cg, sflags)), *use(bc ? bc : btn); const QColor &on(checkRadioCol(flags, cg)), &bgnd(opts.crButton ? getFill(flags, btn, true) : sflags&Style_Enabled && !sunken ? MO_NONE==opts.coloredMouseOver && !opts.crHighlight && sflags&Style_MouseOver ? use[CR_MO_FILL] : cg.base() : cg.background()); EWidget wid=opts.crButton ? WIDGET_STD_BUTTON : WIDGET_TROUGH; EAppearance app=opts.crButton ? opts.appearance : APPEARANCE_INVERTED; bool drawSunken=opts.crButton ? sunken : EFFECT_NONE!=opts.buttonEffect, lightBorder=DRAW_LIGHT_BORDER(drawSunken, wid, app), draw3d=!lightBorder && (DRAW_3D_BORDER(drawSunken, app) || DRAW_3D_FULL_BORDER(drawSunken, app)), drawLight=opts.crButton && !drawSunken && (lightBorder || draw3d), doneShadow=false; p->save(); if(opts.crHighlight && sflags&Style_MouseOver) drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.crHighlight)), p, r, true, false, opts.selectionAppearance, WIDGET_SELECTION); else p->fillRect(r, cg.background()); if(doEtch && !glow && opts.crButton && !drawSunken && EFFECT_SHADOW==opts.buttonEffect) { p->setBrush(Qt::NoBrush); p->setPen(shade(cg.background(), ETCHED_DARK)); p->drawArc(QRect(r.x(), r.y(), opts.crSize, opts.crSize), 225*16, 180*16); doneShadow=true; } p->setClipRegion(QRegion(clipRegion)); if(IS_FLAT(opts.appearance)) p->fillRect(QRect(x+1, y+1, rect.width()-2, rect.height()-2), bgnd); else drawBevelGradient(bgnd, p, QRect(x+1, y+1, rect.width()-2, rect.height()-2), true, drawSunken, app, wid); if(coloredMo) { p->setPen(use[CR_MO_FILL]); p->drawArc(QRect(x+1, y+1, opts.crSize-2, opts.crSize-2), 0, 360*16); // p->drawArc(QRect(x+2, y+2, opts.crSize-4, opts.crSize-4), 0, 360*16); // p->drawArc(QRect(x+3, y+3, opts.crSize-6, opts.crSize-6), 0, 360*16); p->drawPoint(x+2, y+4); p->drawPoint(x+4, y+2); p->drawPoint(x+8, y+2); p->drawPoint(x+10, y+4); p->drawPoint(x+2, y+8); p->drawPoint(x+4, y+10); p->drawPoint(x+8, y+10); p->drawPoint(x+10, y+8); } p->setClipping(false); if(doEtch && !doneShadow) { QColor topCol(glow ? glowFocus ? itsFocusCols[GLOW_MO] : itsMouseOverCols[GLOW_MO] : shade(cg.background(), ETCHED_DARK)), botCol(glow ? topCol : itsBackgroundCols[1]); p->setBrush(Qt::NoBrush); p->setPen(topCol); if(drawSunken || glow) { p->drawArc(QRect(r.x(), r.y(), opts.crSize, opts.crSize), 45*16, 180*16); p->setPen(botCol); } p->drawArc(QRect(r.x(), r.y(), opts.crSize, opts.crSize), 225*16, 180*16); } p->drawPixmap(rect.x(), rect.y(), *getPixmap(use[BORDER_VAL(flags&Style_Enabled)], PIX_RADIO_BORDER, 0.8)); if(QApplication::NormalColor!=QApplication::colorSpec() || itsFormMode) { p->setPen(QPen(use[opts.coloredMouseOver && sflags&Style_MouseOver ? 4 : BORDER_VAL(flags&Style_Enabled)], 1)); p->drawArc(rect, 0, 5760); } if(set) p->drawPixmap(rect.x(), rect.y(), *getPixmap(on, PIX_RADIO_ON, 1.0)); if(!coloredMo && (!opts.crButton || drawLight) && (QApplication::NormalColor==QApplication::colorSpec() || itsFormMode)) p->drawPixmap(rect.x(), rect.y(), *getPixmap(btn[drawLight ? LIGHT_BORDER(app) : (sflags&Style_MouseOver ? 3 : 4)], lightBorder ? PIX_RADIO_INNER : PIX_RADIO_LIGHT)); p->restore(); } break; case PE_DockWindowSeparator: { QRect r2(r); r2.addCoords(-1, -1, 2, 2); drawMenuOrToolBarBackground(p, r2, cg, false, flags&Style_Horizontal); switch(opts.toolbarSeparators) { case LINE_NONE: break; case LINE_FLAT: case LINE_SUNKEN: if(r.width()setPen(itsBackgroundCols[LINE_SUNKEN==opts.toolbarSeparators ? 3 : 4]); p->drawLine(x, r.y()+6, x, r.y()+r.height()-7); if(LINE_SUNKEN==opts.toolbarSeparators) { p->setPen(itsBackgroundCols[0]); p->drawLine(x+1, r.y()+6, x+1, r.y()+r.height()-7); } } else { int y(r.y()+((r.height()-2) / 2)); p->setPen(itsBackgroundCols[LINE_SUNKEN==opts.toolbarSeparators ? 3 : 4]); p->drawLine(r.x()+6, y, r.x()+r.width()-7, y); if(LINE_SUNKEN==opts.toolbarSeparators) { p->setPen(itsBackgroundCols[0]); p->drawLine(r.x()+6, y+1, r.x()+r.width()-7, y+1); } } break; case LINE_1DOT: drawDot(p, r, itsBackgroundCols); break; default: case LINE_DOTS: drawDots(p, r, !(flags & Style_Horizontal), 1, 5, itsBackgroundCols, 0, 5); } break; } case PE_DockWindowResizeHandle: if(flags&Style_Horizontal) flags-=Style_Horizontal; else flags+=Style_Horizontal; // Fall through intentional case PE_Splitter: { if(itsHoverWidget && itsHoverWidget == p->device()) flags|=Style_MouseOver; const QColor *use(buttonColors(cg)); const QColor *border(borderColors(flags, use)); QColor color(cg.background()); if(0!=opts.tabBgnd && p->device() && inStackWidget(dynamic_cast(p->device()))) color=shade(color, TO_FACTOR(opts.tabBgnd)); if(flags&Style_MouseOver && opts.splitterHighlight) drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.splitterHighlight)), p, r, !(flags&Style_Horizontal), false, opts.selectionAppearance, WIDGET_SELECTION); else p->fillRect(r, color); switch(opts.splitters) { case LINE_NONE: break; default: case LINE_1DOT: drawDot(p, r, border); break; case LINE_DOTS: drawDots(p, r, flags&Style_Horizontal, NUM_SPLITTER_DASHES, 1, border, 0, 5); break; case LINE_FLAT: case LINE_SUNKEN: case LINE_DASHES: drawLines(p, r, flags&Style_Horizontal, NUM_SPLITTER_DASHES, 3, border, 0, 3, opts.splitters); } break; } case PE_GroupBoxFrame: case PE_PanelGroupBox: if(FRAME_LINE==opts.groupBox) { QRect r2(r); if(p && p->device() && dynamic_cast(p->device()) && (!((QGroupBox *)(p->device()))->title().isEmpty() || ((QGroupBox *)(p->device()))->isCheckable())) r2.addCoords(8, 0, -8, 0); p->setPen(backgroundColors(cg)[STD_BORDER]); p->drawLine(r2.x(), r2.y(), r2.x()+r2.width()-1, r2.y()); } else if (FRAME_NONE!=opts.groupBox) if(APP_OPENOFFICE==itsThemedApp || data.lineWidth()>0 || data.isDefault()) { const QColor *use(backgroundColors(cg)); drawBorder(cg.background(), p, r, cg, (SFlags)(flags|Style_Horizontal), opts.square&SQUARE_FRAME ? ROUNDED_NONE : ROUNDED_ALL, use, WIDGET_OTHER, true, BORDER_FLAT); } else QCommonStyle::drawPrimitive(pe, p, r, cg, flags, data); break; case PE_WindowFrame: if(data.lineWidth()>0 || data.isDefault()) drawBorder(cg.background(), p, r, cg, (SFlags)(flags|Style_Horizontal), ROUNDED_NONE, backgroundColors(cg), WIDGET_MDI_WINDOW, true, BORDER_RAISED, false); break; case PE_Panel: if((APP_KICKER==itsThemedApp && data.isDefault()) || dynamic_cast(p->device())) break; if(APP_OPENOFFICE==itsThemedApp || data.lineWidth()>0 || data.isDefault()) { const QWidget *widget=p && p->device() ? dynamic_cast(p->device()) : 0L; bool sv(widget && ::qt_cast(widget)), square((opts.square&SQUARE_SCROLLVIEW) && (sv || (widget && widget->parentWidget() && ::qt_cast(widget) && widget->parentWidget()->inherits("KateView")))); const QColor *use(opts.highlightScrollViews && /*!square &&*/ flags&Style_HasFocus ? itsHighlightCols : backgroundColors(cg)); // if(square) // { // p->setPen(use[STD_BORDER]); // p->drawLine(r.bottomLeft(), r.topLeft()); // p->drawLine(r.topLeft(), r.topRight()); // if(!opts.gtkScrollViews) // p->setPen(use[STD_BORDER_BR]); // p->drawLine(r.topRight(), r.bottomRight()); // p->drawLine(r.bottomRight(), r.bottomLeft()); // } // else { itsFormMode=itsIsTransKicker; if(sv && !opts.highlightScrollViews) flags&=~Style_HasFocus; if(sv && opts.etchEntry && ((QFrame *)widget)->lineWidth()>2) { drawEntryField(p, r, cg, flags, flags&Style_Enabled ? /*flags&Style_MouseOver ? ENTRY_MOUSE_OVER :*/ flags&Style_HasFocus ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, square ? ROUNDED_NONE : ROUNDED_ALL, WIDGET_SCROLLVIEW); } else drawBorder(cg.background(), p, r, cg, (SFlags)(flags|Style_Horizontal|Style_Enabled), square ? ROUNDED_NONE : ROUNDED_ALL, use, sv ? WIDGET_SCROLLVIEW : WIDGET_OTHER, APP_KICKER!=itsThemedApp, itsIsTransKicker ? BORDER_FLAT : (flags&Style_Sunken ? BORDER_SUNKEN : BORDER_RAISED) ); itsFormMode=false; } } else QCommonStyle::drawPrimitive(pe, p, r, cg, flags, data); break; case PE_PanelTabWidget: { const QColor *use(backgroundColors(cg)); drawBorder(cg.background(), p, r, cg, (SFlags)(flags|Style_Horizontal|Style_Enabled), opts.square&SQUARE_TAB_FRAME ? ROUNDED_NONE : ROUNDED_ALL, use, WIDGET_OTHER, true, opts.borderTab ? BORDER_LIGHT : BORDER_RAISED, false); break; } case PE_PanelPopup: { const QColor *use(backgroundColors(cg)); p->setPen(use[STD_BORDER]); p->setBrush(NoBrush); p->drawRect(r); if(!IS_FLAT_BGND(opts.menuBgndAppearance)) ; else if(USE_LIGHTER_POPUP_MENU) { p->setPen(/*USE_LIGHTER_POPUP_MENU ? */itsLighterPopupMenuBgndCol/* : cg.background()*/); p->drawRect(QRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2)); } else { p->setPen(use[0]); p->drawLine(r.x()+1, r.y()+1, r.x()+r.width()-2, r.y()+1); p->drawLine(r.x()+1, r.y()+1, r.x()+1, r.y()+r.height()-2); p->setPen(use[FRAME_DARK_SHADOW]); p->drawLine(r.x()+1, r.y()+r.height()-2, r.x()+r.width()-2, r.y()+r.height()-2); p->drawLine(r.x()+r.width()-2, r.y()+1, r.x()+r.width()-2, r.y()+r.height()-2); } break; } case PE_TabBarBase: { const QColor *use(backgroundColors(cg)); bool flat(APPEARANCE_FLAT==opts.appearance); if(data.isDefault() || data.lineWidth()>1) { p->setPen(use[STD_BORDER]); p->setBrush(NoBrush); p->drawRect(r); qDrawShadePanel(p, r.x()+1, r.y()+1, r.width()-2, r.height()-2, QColorGroup(use[flat ? ORIGINAL_SHADE : 4], use[ORIGINAL_SHADE], use[0], use[flat ? ORIGINAL_SHADE : 4], use[2], cg.text(), use[ORIGINAL_SHADE]), flags & Style_Sunken, data.isDefault() ? 1 : data.lineWidth()-1); } else qDrawShadePanel(p, r, QColorGroup(use[flat ? ORIGINAL_SHADE : 5], use[ORIGINAL_SHADE], use[0], use[flat ? ORIGINAL_SHADE : 5], use[2], cg.text(), use[ORIGINAL_SHADE]), flags & Style_Sunken, data.isDefault() ? 2 : data.lineWidth()); break; } case PE_PanelDockWindow: case PE_PanelMenuBar: { // fix for toolbar lag (from Mosfet Liquid) QWidget *w = dynamic_cast(p->device()); if(w) { if(PaletteButton==w->backgroundMode()) w->setBackgroundMode(PaletteBackground); if(itsActive && opts.shadeMenubarOnlyWhenActive && SHADE_NONE!=opts.shadeMenubars) { QWidget *top=w->topLevelWidget(); if(top && !top->isActiveWindow()) itsActive=false; } } drawMenuOrToolBarBackground(p, r, cg, PE_PanelMenuBar==pe, PE_PanelMenuBar==pe || r.width()>r.height()); if(TB_NONE!=opts.toolbarBorders) { const QColor *use=PE_PanelMenuBar==pe ? menuColors(cg, itsActive) : backgroundColors(cg.background()); bool dark(TB_DARK==opts.toolbarBorders || TB_DARK_ALL==opts.toolbarBorders); if(TB_DARK_ALL==opts.toolbarBorders || TB_LIGHT_ALL==opts.toolbarBorders) { p->setPen(use[0]); p->drawLine(r.x(), r.y(), r.x()+r.width()-1, r.y()); p->drawLine(r.x(), r.y(), r.x(), r.y()+r.width()-1); p->setPen(use[dark ? 3 : 4]); p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); p->drawLine(r.x()+r.width()-1, r.y(), r.x()+r.width()-1, r.y()+r.height()-1); } else if(PE_PanelMenuBar==pe || r.width()>r.height()) { if(PE_PanelMenuBar!=pe) { p->setPen(use[0]); p->drawLine(r.x(), r.y(), r.x()+r.width()-1, r.y()); } p->setPen(use[dark ? 3 : 4]); p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); } else { p->setPen(use[0]); p->drawLine(r.x(), r.y(), r.x(), r.y()+r.height()-1); p->setPen(use[dark ? 3 : 4]); p->drawLine(r.x()+r.width()-1, r.y(), r.x()+r.width()-1, r.y()+r.height()-1); } } break; } case PE_ScrollBarAddLine: case PE_ScrollBarSubLine: { QRect br(r), ar(r); const QColor *use(flags&Style_Enabled ? itsButtonCols : itsBackgroundCols); // buttonColors(cg)); pe=flags&Style_Horizontal ? PE_ScrollBarAddLine==pe ? PE_ArrowRight : PE_ArrowLeft : PE_ScrollBarAddLine==pe ? PE_ArrowDown : PE_ArrowUp; int round=PE_ArrowRight==pe ? ROUNDED_RIGHT : PE_ArrowLeft==pe ? ROUNDED_LEFT : PE_ArrowDown==pe ? ROUNDED_BOTTOM : PE_ArrowUp==pe ? ROUNDED_TOP : ROUNDED_NONE; if(flags&Style_Down && !opts.flatSbarButtons) ar.addCoords(1, 1, 1, 1); switch(opts.scrollbarType) { default: case SCROLLBAR_WINDOWS: break; case SCROLLBAR_KDE: case SCROLLBAR_PLATINUM: if(PE_ArrowLeft==pe && r.x()>3) { round=ROUNDED_NONE; br.addCoords(0, 0, 1, 0); if(opts.flatSbarButtons || !opts.vArrows) ar.addCoords(1, 0, 1, 0); } else if(PE_ArrowUp==pe && r.y()>3) { round=ROUNDED_NONE; br.addCoords(0, 0, 0, 1); if(opts.flatSbarButtons || !opts.vArrows) ar.addCoords(0, 1, 0, 1); } break; case SCROLLBAR_NEXT: if(PE_ArrowRight==pe) { round=ROUNDED_NONE; br.addCoords(-1, 0, 0, 0); if(opts.flatSbarButtons || !opts.vArrows) ar.addCoords(-1, 0, 0, -1); } else if(PE_ArrowDown==pe) { round=ROUNDED_NONE; br.addCoords(0, -1, 0, 0); if(opts.flatSbarButtons || !opts.vArrows) ar.addCoords(0, -1, 0, -1); } break; } if(!opts.flatSbarButtons) // No need to draw background here - drawn in CC_ScrollBar // { // if(!IS_FLAT(opts.sbarBgndAppearance) && SCROLLBAR_NONE!=opts.scrollbarType) // drawBevelGradient(itsBackgroundCols[ORIGINAL_SHADE], p, r, flags&Style_Horizontal, false, // opts.sbarBgndAppearance, WIDGET_SB_BGND); // else // p->fillRect(br, itsBackgroundCols[ORIGINAL_SHADE]); // } // else drawLightBevel(p, br, cg, flags|Style_Raised, round, getFill(flags, use), use, true, true, WIDGET_SB_BUTTON); ::drawArrow(p, ar, MO_ARROW(cg.buttonText()), pe, opts, false); break; } case PE_ScrollBarSlider: drawSbSliderHandle(p, r, cg, flags); break; case PE_FocusRect: #if 0 // Menu item style selection... if(opts.gtkComboMenus) { QWidget *widget(dynamic_cast(p->device())); if(widget && 0==qstrcmp(widget->className(), "QViewportWidget") && widget->parentWidget() && ::qt_cast(widget->parentWidget()) && widget->parentWidget()->parentWidget() && ::qt_cast(widget->parentWidget()->parentWidget())) { struct QtCurveListBoxItem : public QListBoxItem { void paintContents(QPainter *p) { paint(p); } }; QListBox *box=(QListBox *)widget->parentWidget(); QtCurveListBoxItem *item=(QtCurveListBoxItem *)(box->item(box->currentItem())); if(item) { //p->fillRect(r, Qt::black); drawMenuItem(p, r, cg, false, ROUNDED_ALL, USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE], itsHighlightCols); item->paintContents(p); break; } } } #endif if(FOCUS_STANDARD==opts.focus) { p->setPen(Qt::black); p->drawWinFocusRect(r); } else { //Figuring out in what beast we are painting... QWidget *widget(dynamic_cast(p->device())); bool view(widget && (dynamic_cast(widget->parent()) || dynamic_cast(widget->parent()))); if(widget && FOCUS_GLOW==opts.focus && (dynamic_cast(widget) || dynamic_cast(widget))) return; if(FOCUS_LINE==opts.focus) { p->setPen(view && flags&Style_Selected ? cg.highlightedText() : itsFocusCols[FOCUS_SHADE(flags&Style_Selected)]); p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); } else if(r.width()<4 || r.height()<4 || view) { // QRect r2(r); p->setPen(view ? (flags&Style_Selected ? cg.highlightedText() : cg.text()) : itsFocusCols[FOCUS_SHADE(flags&Style_Selected)]); // if(view) // r2.addCoords(0, 0, 0, -2); p->drawRect(r); // r2); } else drawBorder(cg.background(), p, r, cg, Style_Horizontal, ROUNDED_ALL, itsFocusCols, WIDGET_FOCUS, false, BORDER_FLAT, true, FOCUS_SHADE(flags&Style_Selected)); } break; case PE_ArrowUp: case PE_ArrowDown: case PE_ArrowRight: case PE_ArrowLeft: drawArrow(p, r, cg, flags, pe); break; case PE_SpinWidgetUp: case PE_SpinWidgetDown: case PE_SpinWidgetPlus: case PE_SpinWidgetMinus: { QRect sr(r); const QColor *use(buttonColors(cg)); bool reverse(QApplication::reverseLayout()); if((!opts.unifySpinBtns || flags&Style_Sunken) && !opts.unifySpin) drawLightBevel(p, sr, cg, flags|Style_Horizontal, PE_SpinWidgetDown==pe || PE_SpinWidgetMinus==pe ? reverse ? ROUNDED_BOTTOMLEFT : ROUNDED_BOTTOMRIGHT : reverse ? ROUNDED_TOPLEFT : ROUNDED_TOPRIGHT, getFill(flags, use), use, true, true, WIDGET_SPIN); if(PE_SpinWidgetUp==pe || PE_SpinWidgetDown==pe) { sr.setY(sr.y()+(PE_SpinWidgetDown==pe ? -2 : 1)); if(opts.unifySpin) { sr.addCoords(reverse ? 1 : -1, 0, reverse ? 1 : -1, 0); if(!opts.vArrows) sr.setY(sr.y()+(PE_SpinWidgetDown==pe ? -2 : 2)); } else if(flags&Style_Sunken) sr.addCoords(1, 1, 1, 1); ::drawArrow(p, sr, MO_ARROW(cg.buttonText()), PE_SpinWidgetUp==pe ? PE_ArrowUp : PE_ArrowDown, opts, !opts.unifySpin); } else { int l(QMIN(r.width()-6, r.height()-6)); QPoint c(r.x()+(r.width()/2), r.y()+(r.height()/2)); l/=2; if(l%2 != 0) --l; if(flags&Style_Sunken && !opts.unifySpin) c+=QPoint(1, 1); p->setPen(MO_ARROW(cg.buttonText())); p->drawLine(c.x()-l, c.y(), c.x()+l, c.y()); if(PE_SpinWidgetPlus==pe) p->drawLine(c.x(), c.y()-l, c.x(), c.y()+l); } break; } case PE_PanelLineEdit: { const QWidget *widget=p && p->device() ? dynamic_cast(p->device()) : 0L; bool scrollView=widget && ::qt_cast(widget); // if((opts.square&SQUARE_SCROLLVIEW) && scrollView) // { // const QColor *use(backgroundColors(cg)); // // p->setPen(use[STD_BORDER]); // p->drawLine(r.bottomLeft(), r.topLeft()); // p->drawLine(r.topLeft(), r.topRight()); // if(!opts.gtkScrollViews) // p->setPen(use[STD_BORDER_BR]); // p->drawLine(r.topRight(), r.bottomRight()); // p->drawLine(r.bottomRight(), r.bottomLeft()); // break; // } bool isReadOnly(false), isEnabled(true); // panel is highlighted by default if it has focus, but if we have access to the // widget itself we can try to avoid highlighting in case it's readOnly or disabled. if (!scrollView && widget && dynamic_cast(widget)) { const QLineEdit *lineEdit(dynamic_cast(widget)); isReadOnly = lineEdit->isReadOnly(); isEnabled = lineEdit->isEnabled(); if(flags&Style_Enabled && isReadOnly) flags-=Style_Enabled; } // HACK!! (From Plastik) // // In this place there is no reliable way to detect if we are in khtml; the // only thing we know is that khtml buffers its widgets into a pixmap. So // when the paint device is a QPixmap, chances are high that we are in khtml. // It's possible that this breaks other things, so let's see how it works... if (p->device() && dynamic_cast(p->device())) itsFormMode=true; if(scrollView && !opts.highlightScrollViews) flags&=~Style_HasFocus; QRect r2(r); r2.addCoords(1, 1, -1, -1); // p->fillRect(r2, flags&Style_Enabled ? cg.base() : cg.background()); drawEntryField(p, r, cg, flags, !isReadOnly && isEnabled ? flags&Style_MouseOver && !scrollView ? ENTRY_MOUSE_OVER : flags&Style_HasFocus ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, (opts.square&SQUARE_SCROLLVIEW) && scrollView ? ROUNDED_NONE : ROUNDED_ALL, scrollView ? WIDGET_SCROLLVIEW : WIDGET_ENTRY); itsFormMode=false; break; } case PE_StatusBarSection: if(opts.drawStatusBarFrames) BASE_STYLE::drawPrimitive(pe, p, r, cg, flags, data); break; case PE_SizeGrip: { QPointArray a; if (QApplication::reverseLayout()) { a.setPoints(3, 0,0, SIZE_GRIP_SIZE,SIZE_GRIP_SIZE, 0,SIZE_GRIP_SIZE); a.translate(r.x(), r.y()+(r.height()-SIZE_GRIP_SIZE)); } else { a.setPoints(3, SIZE_GRIP_SIZE,0, SIZE_GRIP_SIZE,SIZE_GRIP_SIZE, 0,SIZE_GRIP_SIZE); a.translate(r.x()+(r.width()-SIZE_GRIP_SIZE), r.y()+(r.height()-SIZE_GRIP_SIZE)); } p->save(); p->setBrush(itsBackgroundCols[2]); p->setPen(itsBackgroundCols[2]); p->drawPolygon(a); p->restore(); break; } default: BASE_STYLE::drawPrimitive(pe, p, r, cg, flags, data); } } static QString elliditide(const QString &text, const QFontMetrics &fontMetrics, int space) { // Chop and insert ellide into title if text is too wide QString title(text); if (fontMetrics.width(text) > space) { QString ellipsis("..."); while (fontMetrics.width(title+ellipsis)>space && !title.isEmpty()) title=title.left(title.length()-1); return title+ellipsis; } return title; } void QtCurveStyle::drawKStylePrimitive(KStylePrimitive kpe, QPainter *p, const QWidget *widget, const QRect &r, const QColorGroup &cg, SFlags flags, const QStyleOption &opt) const { ELine handles(kpe!=KPE_ToolBarHandle && LINE_DASHES==opts.handles ? LINE_SUNKEN : opts.handles); switch(kpe) { case KPE_ToolBarHandle: { if(APPEARANCE_STRIPED!=opts.bgndAppearance) { QRect r2(r); r2.addCoords(-1, -1, 2, 2); drawMenuOrToolBarBackground(p, r2, cg, false, flags&Style_Horizontal); } drawHandleMarkers(p, r, flags, true, handles); break; } case KPE_DockWindowHandle: { int x, y, w, h; bool horizontal(flags & Style_Horizontal); r.rect(&x, &y, &w, &h); if(!IS_FLAT(opts.dwtAppearance)) drawBevelGradient(cg.background(), p, r, horizontal, false, opts.dwtAppearance, WIDGET_DOCK_WIDGET_TITLE); else p->fillRect(r, cg.background()); // .dark(DW_BGND)); // p->setPen(itsBackgroundCols[STD_BORDER]); // if(horizontal) // p->drawLine(r.right(), r.top()-1, r.right(), r.bottom()); // else // p->drawLine(r.left(), r.bottom(), r.right(), r.bottom()); if (w > 2 && h > 2) { QWidget *wid(const_cast(widget)); bool hasClose(dynamic_cast(wid->parentWidget()) && ((QDockWindow *)(wid->parentWidget()))->area() && ((QDockWindow *)(wid->parentWidget()))->isCloseEnabled()); QFont fnt(QApplication::font(wid)); QPixmap pix; QString title(wid->parentWidget()->caption()); QPainter p2; fnt.setPointSize(fnt.pointSize()-2); if(hasClose) if (horizontal) h-=15; else w-=15; // Draw the item on an off-screen pixmap to preserve Xft antialiasing for // vertically oriented handles. if (horizontal) pix.resize(h, w); else pix.resize(w, h); p2.begin(&pix); p2.fillRect(pix.rect(), cg.background()); // .dark(DW_BGND)); p2.setPen(itsBackgroundCols[STD_BORDER]); p2.drawLine(pix.rect().left(), pix.rect().bottom(), pix.rect().right(), pix.rect().bottom()); p2.setPen(cg.text()); p2.setFont(fnt); QRect textRect(pix.rect()); textRect.addCoords(2, -3, -2, 0); p2.drawText(textRect, AlignVCenter|(QApplication::reverseLayout() ? AlignRight : AlignLeft), elliditide(title, QFontMetrics(fnt), pix.width())); p2.end(); if (horizontal) { QWMatrix m; m.rotate(-90.0); QPixmap vpix(pix.xForm(m)); bitBlt(wid, r.x(), r.y()+(hasClose ? 15 : 0), &vpix); } else bitBlt(wid, r.x(), r.y(), &pix); } break; } case KPE_GeneralHandle: drawHandleMarkers(p, r, flags, false, handles); break; case KPE_SliderGroove: drawSliderGroove(p, r, cg, flags, widget); break; case KPE_SliderHandle: drawSliderHandle(p, r, cg, flags, widget ? ::qt_cast(widget) : 0L); break; case KPE_ListViewExpander: { QRect ar(r.x()+((r.width()-(LV_SIZE+4))>>1), r.y()+((r.height()-(LV_SIZE+4))>>1), LV_SIZE+4, LV_SIZE+4); if(LV_OLD==opts.lvLines) { int lo(ROUNDED ? 2 : 0); p->setPen(cg.mid()); p->drawLine(ar.x()+lo, ar.y(), (ar.x()+ar.width()-1)-lo, ar.y()); p->drawLine(ar.x()+lo, ar.y()+ar.height()-1, (ar.x()+ar.width()-1)-lo, ar.y()+ar.height()-1); p->drawLine(ar.x(), ar.y()+lo, ar.x(), (ar.y()+ar.height()-1)-lo); p->drawLine(ar.x()+ar.width()-1, ar.y()+lo, ar.x()+ar.width()-1, (ar.y()+ar.height()-1)-lo); if(ROUNDED) { p->drawPoint(ar.x()+1, ar.y()+1); p->drawPoint(ar.x()+1, ar.y()+ar.height()-2); p->drawPoint(ar.x()+ar.width()-2, ar.y()+1); p->drawPoint(ar.x()+ar.width()-2, ar.y()+ar.height()-2); p->setPen(midColor(cg.mid(), cg.background())); p->drawLine(ar.x(), ar.y()+1, ar.x()+1, ar.y()); p->drawLine(ar.x()+ar.width()-2, ar.y(), ar.x()+ar.width()-1, ar.y()+1); p->drawLine(ar.x(), ar.y()+ar.height()-2, ar.x()+1, ar.y()+ar.height()-1); p->drawLine(ar.x()+ar.width()-2, ar.y()+ar.height()-1, ar.x()+ar.width()-1, ar.y()+ar.height()-2); } } ::drawArrow(p, ar, flags&Style_Enabled ? cg.mid() : cg.text(), flags&Style_On // Collapsed = On ? QApplication::reverseLayout() ? PE_ArrowLeft : PE_ArrowRight : PE_ArrowDown, opts); break; } case KPE_ListViewBranch: if(opts.lvLines) { p->setPen(cg.mid()); if (flags&Style_Horizontal) { if(r.width()>0) p->drawLine(r.x(), r.y(), r.x()+r.width()-1, r.y()); } else if(r.height()>0) p->drawLine(r.x(), r.y(), r.x(), r.y()+r.height()-1); } break; default: BASE_STYLE::drawKStylePrimitive(kpe, p, widget, r, cg, flags, opt); } } void QtCurveStyle::drawControl(ControlElement control, QPainter *p, const QWidget *widget, const QRect &r, const QColorGroup &cg, SFlags flags, const QStyleOption &data) const { if(widget==itsHoverWidget) flags|=Style_MouseOver; switch(control) { case CE_TabBarTab: { const QTabBar *tb((const QTabBar *)widget); int tabIndex(tb->indexOf(data.tab()->identifier())), dark(APPEARANCE_FLAT==opts.appearance ? ORIGINAL_SHADE : FRAME_DARK_SHADOW), moOffset(ROUNDED_NONE==opts.round || TAB_MO_TOP!=opts.tabMouseOver ? 1 : opts.round); bool cornerWidget(false), bottomCornerWidget(false), reverse(QApplication::reverseLayout()), firstTab(0==tabIndex), lastTab((tb->count()-1)==tabIndex), // isFirstKTabCtlTab(firstTab && widget->parent() // ? 0==qstrcmp("KTabCtl", widget->parent()->className()) // : false), active(flags & Style_Selected), itsHover(itsHoverTab && itsHoverTab->isEnabled() && data.tab()==itsHoverTab && !(flags&Style_Selected) && tb->currentTab()!=tabIndex), glowMo(!active && itsHover && opts.coloredMouseOver && TAB_MO_GLOW==opts.tabMouseOver); int sizeAdjust(!active && TAB_MO_GLOW==opts.tabMouseOver ? 1 : 0); const QColor &fill(getTabFill(flags&Style_Selected, itsHover, itsBackgroundCols)); EBorder borderProfile(active || opts.borderInactiveTab ? opts.borderTab ? BORDER_LIGHT : opts.colorSelTab && active ? BORDER_FLAT : BORDER_RAISED : BORDER_FLAT); if(reverse) { bool oldLast=lastTab; lastTab=firstTab; firstTab=oldLast; } if(::qt_cast(tb->parent())) { const QTabWidget *tw((const QTabWidget*)tb->parent()); // is there a corner widget in the (top) left edge? if(tw->cornerWidget(Qt::TopLeft)) cornerWidget=true; if(tw->cornerWidget(Qt::BottomLeft)) bottomCornerWidget=true; } QRect tr(r); bool top(QTabBar::TriangularAbove==tb->shape() || QTabBar::RoundedAbove==tb->shape()); if(active && opts.tabBgnd) { QRect rx(tr); if(top) rx.addCoords(1, 6, -1, 0); else rx.addCoords(1, 0, -1, -6); p->fillRect(rx, shade(cg.background(), TO_FACTOR(opts.tabBgnd))); } if(!active) if(top) tr.addCoords(0, 2, 0, 0); else tr.addCoords(0, 0, 0, -2); if(!firstTab && top && (APP_TORA==itsThemedApp || (APP_OPENOFFICE==itsThemedApp && !active))) tr.addCoords(-1, 0, 0, 0); QRect glowTr(tr); if(!active && TAB_MO_GLOW==opts.tabMouseOver) glowTr.addCoords(sizeAdjust, 0, -sizeAdjust, 0); p->setClipRect(QRect(tr.x(), top ? tr.y()-sizeAdjust : tr.y()+2, tr.width(), top ? tr.height()-2+(2*sizeAdjust) : tr.height()), QPainter::CoordPainter); bool invertedSel=APPEARANCE_INVERTED==opts.appearance && active; QColor col(invertedSel ? cg.background() : fill); if(opts.tabBgnd) col=shade(col, TO_FACTOR(opts.tabBgnd)); if(invertedSel) p->fillRect(glowTr, col); else drawBevelGradient(col, p, glowTr, true, active, active ? SEL_TAB_APP : NORM_TAB_APP, top ? WIDGET_TAB_TOP : WIDGET_TAB_BOT); drawBorder(cg.background(), p, glowTr, cg, flags|Style_Horizontal|Style_Enabled, active || TAB_MO_GLOW==opts.tabMouseOver || opts.roundAllTabs ? (top ? ROUNDED_TOP : ROUNDED_BOTTOM) : firstTab ? (top ? ROUNDED_TOPLEFT : ROUNDED_BOTTOMLEFT) : lastTab ? (top ? ROUNDED_TOPRIGHT : ROUNDED_BOTTOMRIGHT) : ROUNDED_NONE, glowMo ? itsMouseOverCols : 0L, top ? WIDGET_TAB_TOP : WIDGET_TAB_BOT, true, borderProfile, false); if(glowMo) { glowTr.addCoords(-1, -1, 1, 1); drawGlow(p, glowTr, cg, top ? WIDGET_TAB_TOP : WIDGET_TAB_BOT); } p->setClipping(false); if(top) { if(active) { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawPoint(r.x(), r.y()+r.height()-2); p->drawPoint(r.x()+r.width()-1, r.y()+r.height()-2); p->setPen(itsBackgroundCols[0]); p->drawLine(r.x()+1, r.y()+r.height()-3, r.x()+1, r.y()+r.height()-1); //p->drawPoint(r.x()+r.width()-2, r.y()+r.height()-1); p->setPen(itsBackgroundCols[opts.borderTab ? 0 : FRAME_DARK_SHADOW]); p->drawPoint(r.x()+r.width()-2, r.y()+r.height()-2); } else { p->setPen(itsBackgroundCols[0]); p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); p->setPen(itsBackgroundCols[STD_BORDER]); p->drawLine(r.x(), r.y()+r.height()-2, r.x()+r.width()-1, r.y()+r.height()-2); if(opts.coloredMouseOver && itsHover && TAB_MO_GLOW!=opts.tabMouseOver) drawHighlight(p, QRect(tr.x()+(firstTab ? moOffset : 1), tr.y()+(TAB_MO_TOP==opts.tabMouseOver ? 0 : tr.height()-3), tr.width()-(firstTab || lastTab ? moOffset : 1), 2), cg, true, !TAB_MO_TOP==opts.tabMouseOver); } if(((!reverse && firstTab) || (lastTab && reverse)) && !cornerWidget) { int x(reverse ? r.x()+r.width()-1 : r.x()), x2(reverse ? x-1 : x+1); p->setPen(itsBackgroundCols[!active && TAB_MO_GLOW==opts.tabMouseOver && opts.round>ROUND_SLIGHT && !(opts.square&SQUARE_TAB_FRAME) ? ORIGINAL_SHADE : STD_BORDER]); p->drawLine(x, r.y()+r.height()-1, x, r.height()-2); if(active) { p->setPen(itsBackgroundCols[reverse ? dark : 0]); p->drawLine(x2, r.y()+r.height()-1, x2, r.y()+r.height()-2); } } if(active && opts.highlightTab) { p->setPen(itsHighlightCols[0]); p->drawLine(tr.left(), tr.top()+1, tr.right(), tr.top()+1); p->setPen(midColor(fill, itsHighlightCols[0])); // , IS_FLAT(opts.activeTabAppearance) ? 1.0 : 1.2)); p->drawLine(tr.left(), tr.top()+2, tr.right(), tr.top()+2); p->setClipRect(QRect(tr.x(), tr.y(), tr.width(), 3), QPainter::CoordPainter); drawBorder(cg.background(), p, tr, cg, flags|Style_Horizontal|Style_Enabled, ROUNDED_ALL, itsHighlightCols, top ? WIDGET_TAB_TOP : WIDGET_TAB_BOT, true, BORDER_FLAT, false, 3); p->setClipping(false); } // Round top-left corner... if(!(opts.square&SQUARE_TAB_FRAME) && FULLLY_ROUNDED && APP_TORA!=itsThemedApp && firstTab && !active && !cornerWidget && !reverse) // && !isFirstKTabCtlTab) { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawPoint(r.x()+1, r.y()+r.height()-1); p->setPen(TAB_MO_GLOW==opts.tabMouseOver ? itsBackgroundCols[STD_BORDER] : midColor(itsBackgroundCols[STD_BORDER], cg.background())); p->drawPoint(r.x()+1, r.y()+r.height()-2); } } else { if(active) { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawPoint(r.x(), r.y()+1); p->drawPoint(r.x()+r.width()-1, r.y()+1); p->setPen(itsBackgroundCols[0]); p->drawLine(r.x()+1, r.y()+2, r.x()+1, r.y()); p->setPen(itsBackgroundCols[opts.borderTab ? 0 : FRAME_DARK_SHADOW]); p->drawLine(r.x()+r.width()-2, r.y()+1, r.x()+r.width()-2, r.y()); p->drawPoint(r.x()+r.width()-1, r.y()); } else { p->setPen(itsBackgroundCols[opts.borderTab ? 0 : dark]); p->drawLine(r.x(), r.y(), r.x()+r.width()-1, r.y()); p->setPen(itsBackgroundCols[STD_BORDER]); p->drawLine(r.x(), r.y()+1, r.x()+r.width()-1, r.y()+1); if(opts.coloredMouseOver && itsHover && TAB_MO_GLOW!=opts.tabMouseOver) drawHighlight(p, QRect(tr.x()+(firstTab ? moOffset : 1), tr.y()+(TAB_MO_TOP==opts.tabMouseOver ? tr.height()-2 : 1), tr.width()-(firstTab || lastTab ? moOffset : 1), 2), cg, true, TAB_MO_TOP==opts.tabMouseOver); } if(TAB_MO_GLOW==opts.tabMouseOver && opts.round<=ROUND_SLIGHT && !(opts.square&SQUARE_TAB_FRAME) && !reverse && firstTab && !cornerWidget) { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawPoint(r.x(), r.y()); } if(active && opts.highlightTab) { p->setPen(itsHighlightCols[0]); p->drawLine(tr.left(), tr.bottom()-1, tr.right(), tr.bottom()-1); p->setPen(midColor(fill, itsHighlightCols[0])); p->drawLine(tr.left(), tr.bottom()-2, tr.right(), tr.bottom()-2); p->setClipRect(QRect(tr.x(), tr.y()+r.height()-3, tr.width(), 3), QPainter::CoordPainter); drawBorder(cg.background(), p, tr, cg, flags|Style_Horizontal|Style_Enabled, ROUNDED_ALL, itsHighlightCols, top ? WIDGET_TAB_TOP : WIDGET_TAB_BOT, true, BORDER_FLAT, false, 3); p->setClipping(false); } if(!(opts.square&SQUARE_TAB_FRAME) && FULLLY_ROUNDED && APP_TORA!=itsThemedApp && firstTab && !bottomCornerWidget)// && !isFirstKTabCtlTab) { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawPoint(r.x(), reverse ? r.y()+r.width()-1 : r.y()); // Round bottom-left corner... if(!active&& !reverse) { p->drawPoint(r.x()+1, r.y()-1); p->setPen(midColor(itsBackgroundCols[STD_BORDER], cg.background())); p->drawPoint(r.x()+1, r.y()); } } } break; } #if QT_VERSION >= 0x030200 case CE_TabBarLabel: { if (data.isDefault()) break; const QTabBar *tb((const QTabBar *) widget); QTab *t(data.tab()); QRect tr(r); int shift(pixelMetric(PM_TabBarTabShiftVertical, tb)); if (t->identifier() == tb->currentTab()) { if(QTabBar::RoundedAbove==tb->shape() || QTabBar::TriangularAbove==tb->shape()) tr.addCoords(0, -shift, 0, -shift); } else if(QTabBar::RoundedBelow==tb->shape() || QTabBar::TriangularBelow==tb->shape()) tr.addCoords(0, shift, 0, shift); if(APP_MACTOR==itsThemedApp) { drawControl(CE_TabBarTab, p, widget, t->rect(), cg, flags, data); if(t->iconSet()) { QIconSet::Mode mode((t->isEnabled() && tb->isEnabled()) ? QIconSet::Normal : QIconSet::Disabled); if (mode == QIconSet::Normal && (flags&Style_HasFocus)) mode = QIconSet::Active; QPixmap pixmap(t->iconSet()->pixmap(QIconSet::Small, mode)); int pixh(pixmap.height()), xoff(0), yoff(0); if(!(flags&Style_Selected)) { xoff = pixelMetric(PM_TabBarTabShiftHorizontal, widget); yoff = pixelMetric(PM_TabBarTabShiftVertical, widget); } p->drawPixmap(t->rect().left()+8+xoff, t->rect().center().y()-pixh/2 + yoff, pixmap); } } drawItem(p, tr, AlignCenter | ShowPrefix, cg, flags & Style_Enabled, 0, t->text()); if ((flags & Style_HasFocus) && !t->text().isEmpty()) { QRect fr(r); if(QTabBar::RoundedAbove==tb->shape() || QTabBar::TriangularAbove==tb->shape()) fr.addCoords(0, 1, 0, -1); else fr.addCoords(0, 0, 0, -1); drawPrimitive(PE_FocusRect, p, fr, cg); } break; } #endif case CE_PushButtonLabel: // Taken from Highcolor and Plastik... { int x, y, w, h, arrowOffset=DO_EFFECT ? 1 : 0; r.rect(&x, &y, &w, &h); const QPushButton *button(static_cast(widget)); bool active(button->isOn() || button->isDown()), cornArrow(false); // Shift button contents if pushed. if (active) { x += pixelMetric(PM_ButtonShiftHorizontal, widget); y += pixelMetric(PM_ButtonShiftVertical, widget); flags |= Style_Sunken; } // Does the button have a popup menu? if (button->isMenuButton()) { int dx(pixelMetric(PM_MenuButtonIndicator, widget)), margin(pixelMetric(PM_ButtonMargin, widget)); if(button->iconSet() && !button->iconSet()->isNull() && (dx+button->iconSet()->pixmap(QIconSet::Small, QIconSet::Normal, QIconSet::Off ).width()) >= w ) cornArrow = true; //To little room. Draw the arrow in the corner, don't adjust //the widget else { ::drawArrow(p, visualRect(QRect((x + w) - (dx + margin + arrowOffset), y, dx, h), r), MO_ARROW(cg.buttonText()), PE_ArrowDown, opts); w-=(dx+arrowOffset); } } // Draw the icon if there is one if (button->iconSet() && !button->iconSet()->isNull()) { QIconSet::Mode mode(QIconSet::Disabled); QIconSet::State state(QIconSet::Off); if (button->isEnabled()) mode = button->hasFocus() ? QIconSet::Active : QIconSet::Normal; if (button->isToggleButton() && button->isOn()) state = QIconSet::On; QPixmap pixmap = button->iconSet()->pixmap(QIconSet::Small, mode, state); static const int constSpace(2); int xo(0), pw(pixmap.width()), iw(0); if (button->text().isEmpty() && !button->pixmap()) p->drawPixmap(x + (w>>1) - (pixmap.width()>>1), y + (h>>1) - (pixmap.height()>>1), pixmap); else { iw=button->pixmap() ? button->pixmap()->width() : widget->fontMetrics().size(Qt::ShowPrefix, button->text()).width(); int cw(iw+pw+constSpace); xo=cw>1 : constSpace; p->drawPixmap(x+xo, y + (h>>1) - (pixmap.height()>>1), pixmap); xo+=pw; } if (cornArrow) //Draw over the icon ::drawArrow(p, visualRect(QRect(x + w - (6+arrowOffset), y + h - (6+arrowOffset), 7, 7), r), MO_ARROW(cg.buttonText()), PE_ArrowDown, opts); if(xo && iw) { x+= xo+constSpace; w=iw; } else { x+= pw+constSpace; w-= pw+constSpace; } } // Make the label indicate if the button is a default button or not int i, j(opts.embolden && button->isDefault() ? 2 : 1); bool sidebar(!opts.stdSidebarButtons && ((button->isFlat() && button->inherits("KMultiTabBarTab")) || (button->parentWidget() && button->inherits("Ideal::Button") && button->parentWidget()->inherits("Ideal::ButtonBar")))); const QColor &textCol(sidebar && (button->isOn() || flags&Style_On) ? QApplication::palette().active().highlightedText() : button->colorGroup().buttonText()); for(i=0; icolorGroup(), button->isEnabled(), button->pixmap(), button->text(), -1, &textCol); // Draw a focus rect if the button has focus if (flags&Style_HasFocus && FOCUS_GLOW!=opts.focus && !(flags&Style_MouseOver && FOCUS_FULL==opts.focus && MO_NONE!=opts.coloredMouseOver)) drawPrimitive(PE_FocusRect, p, visualRect(subRect(SR_PushButtonFocusRect, widget), widget), cg, flags); break; } case CE_PopupMenuItem: { if(!widget || data.isDefault()) break; const QPopupMenu *popupmenu((const QPopupMenu *)widget); QMenuItem *mi(data.menuItem()); int tab(data.tabWidth()), maxpmw(data.maxIconWidth()), x, y, w, h; bool reverse(QApplication::reverseLayout()); maxpmw=QMAX(maxpmw, constMenuPixmapWidth); r.rect(&x, &y, &w, &h); if(widget->erasePixmap() && !widget->erasePixmap()->isNull()) p->drawPixmap(x, y, *widget->erasePixmap(), x, y, w, h); else { if(IS_FLAT_BGND(opts.menuBgndAppearance)) p->fillRect(r, USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE]); if(opts.menuStripe) drawBevelGradient(menuStripeCol(), p, QRect(reverse ? r.right()-maxpmw : r.x(), r.y(), maxpmw, r.height()), false, false, opts.menuStripeAppearance, WIDGET_OTHER); } if((flags&Style_Active) && (flags&Style_Enabled)) drawMenuItem(p, r, flags, cg, false, ROUNDED_ALL, USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE], opts.useHighlightForMenu ? itsHighlightCols : itsBackgroundCols); if(!mi) break; if(mi->isSeparator()) { y=r.y()+(r.height()>>1); p->setPen(itsBackgroundCols[MENU_SEP_SHADE]); p->drawLine(r.x()+3+(!reverse && opts.menuStripe ? maxpmw : 0), y, r.x()+r.width()-4-(reverse && opts.menuStripe ? maxpmw : 0), y); // p->setPen(itsBackgroundCols[0]); // p->drawLine(r.x()+4, y+1, r.x()+r.width()-5, y+1); break; } QRect cr, ir, tr, sr; // check column cr.setRect(r.left(), r.top(), maxpmw, r.height()); // submenu indicator column sr.setCoords(r.right()-maxpmw, r.top(), r.right(), r.bottom()); // tab/accelerator column tr.setCoords(sr.left()-tab-4, r.top(), sr.left(), r.bottom()); // item column ir.setCoords(cr.right()+4, r.top(), tr.right()-4, r.bottom()); if(reverse) { cr=visualRect(cr, r); sr=visualRect(sr, r); tr=visualRect(tr, r); ir=visualRect(ir, r); } if(mi->iconSet() && opts.menuIcons) { // Select the correct icon from the iconset QIconSet::Mode mode=flags & Style_Active ? (mi->isEnabled() ? QIconSet::Active : QIconSet::Disabled) : (mi->isEnabled() ? QIconSet::Normal : QIconSet::Disabled); cr=visualRect(QRect(x, y, maxpmw, h), r); // Do we have an icon and are checked at the same time? // Then draw a "pressed" background behind the icon if(popupmenu->isCheckable() && mi->isChecked()) drawLightBevel((flags & Style_Active)&&(flags & Style_Enabled) ? itsHighlightCols[ORIGINAL_SHADE] : cg.background(), p, QRect(cr.x()+1, cr.y()+2, cr.width()-2, cr.height()-4), cg, flags|Style_Sunken|Style_Horizontal, ROUNDED_ALL, getFill(flags|Style_Sunken|Style_Enabled, itsBackgroundCols), itsBackgroundCols, true, false, WIDGET_NO_ETCH_BTN); // Draw the icon QPixmap pixmap(mi->iconSet()->pixmap(QIconSet::Small, mode)); QRect pmr(0, 0, pixmap.width(), pixmap.height()); pmr.moveCenter(cr.center()); p->drawPixmap(pmr.topLeft(), pixmap); } else if(popupmenu->isCheckable() && mi->isChecked()) drawPrimitive(PE_CheckMark, p, cr, cg, (flags &(Style_Enabled|(opts.useHighlightForMenu ? Style_Active : 0)))| Style_On|MENU_ITEM); QColor textCol(flags&Style_Enabled ? flags&Style_Active && opts.useHighlightForMenu ? cg.highlightedText() : cg.foreground() : cg.mid()); p->setPen(textCol); if(mi->custom()) { p->save(); mi->custom()->paint(p, cg,(flags & Style_Enabled)?(flags & Style_Active): 0, flags & Style_Enabled, ir.x(), ir.y(), ir.width(), ir.height()); p->restore(); } QString text=mi->text(); if(!text.isNull()) { int t(text.find('\t')); // draw accelerator/tab-text if(t>=0) p->drawText(tr, AlignVCenter|ShowPrefix|DontClip|SingleLine|(reverse ? AlignLeft : AlignRight), text.mid(t+1)); p->drawText(ir, AlignVCenter|ShowPrefix|DontClip|SingleLine|(reverse ? AlignRight : AlignLeft), text, t); } else if(mi->pixmap()) { QPixmap *pixmap(mi->pixmap()); if(1==pixmap->depth()) p->setBackgroundMode(OpaqueMode); int diffw(((r.width() - pixmap->width())/2) + ((r.width() - pixmap->width())%2)); p->drawPixmap(r.x()+diffw, r.y()+1, *pixmap ); if(1==pixmap->depth()) p->setBackgroundMode(TransparentMode); } if(mi->popup()) ::drawArrow(p, sr, textCol, reverse ? PE_ArrowLeft : PE_ArrowRight, opts); break; } case CE_MenuBarItem: { bool down( (flags&Style_Enabled) && (flags&Style_Active) && (flags&Style_Down) ), active( (flags&Style_Enabled) && (flags&Style_Active) && ( (flags&Style_Down) || opts.menubarMouseOver ) ); if(!active || IS_GLASS(opts.menubarAppearance) || SHADE_NONE!=opts.shadeMenubars) { QMenuBar *mb((QMenuBar*)widget); QRect r2(r); r2.setY(mb->rect().y()+1); r2.setHeight(mb->rect().height()-2); drawMenuOrToolBarBackground(p, r2, cg); } if(active) drawMenuItem(p, r, flags, cg, true, down && opts.roundMbTopOnly ? ROUNDED_TOP : ROUNDED_ALL, itsMenubarCols[ORIGINAL_SHADE], opts.useHighlightForMenu && (opts.colorMenubarMouseOver || down) ? itsHighlightCols : itsBackgroundCols); if(data.isDefault()) break; QMenuItem *mi(data.menuItem()); if(mi->text().isEmpty()) // Draw pixmap... drawItem(p, r, AlignCenter|ShowPrefix|DontClip|SingleLine, cg, flags&Style_Enabled, mi->pixmap(), QString::null); else { const QColor *col=((opts.colorMenubarMouseOver && active) || (!opts.colorMenubarMouseOver && down)) ? opts.customMenuTextColor ? &opts.customMenuSelTextColor : opts.useHighlightForMenu ? &cg.highlightedText() : &cg.foreground() : &cg.foreground(); p->setPen(*col); p->drawText(r, AlignCenter|ShowPrefix|DontClip|SingleLine, mi->text()); } break; } case CE_MenuBarEmptyArea: drawMenuOrToolBarBackground(p, r, cg); break; case CE_DockWindowEmptyArea: if(widget && widget->inherits("QToolBar")) { QDockWindow *wind((QDockWindow*)widget); drawMenuOrToolBarBackground(p, r, cg, false, Qt::Horizontal==wind->orientation()); } else BASE_STYLE::drawControl(control, p, widget, r, cg, flags, data); break; case CE_ProgressBarGroove: { QRect rx(r); bool doEtch(DO_EFFECT && opts.borderProgress); QColor col; if(doEtch) rx.addCoords(1, 1, -1, -1); switch(opts.progressGrooveColor) { default: case ECOLOR_BASE: col=cg.base(); break; case ECOLOR_BACKGROUND: col=cg.background(); break; case ECOLOR_DARK: col=itsBackgroundCols[2]; } drawBevelGradient(col, p, rx, true, false, opts.progressGrooveAppearance, WIDGET_PBAR_TROUGH); const QColor *use(backgroundColors(cg)); if(opts.borderProgress) drawBorder(cg.background(), p, rx, cg, (SFlags)(flags|Style_Horizontal), (opts.square&SQUARE_PROGRESS) ? ROUNDED_NONE : ROUNDED_ALL, use, WIDGET_OTHER, true, IS_FLAT(opts.progressGrooveAppearance) && ECOLOR_DARK!=opts.progressGrooveColor ? BORDER_SUNKEN : BORDER_FLAT); else { p->setPen(itsBackgroundCols[STD_BORDER]); p->drawLine(r.topLeft(), r.topRight()); p->drawLine(r.bottomLeft(), r.bottomRight()); } if(doEtch) drawEtch(p, r, cg, false, (opts.square&SQUARE_PROGRESS)); break; } case CE_ProgressBarContents: { const QProgressBar *pb((const QProgressBar*)widget); int steps(pb->totalSteps()); if(0==steps)//Busy indicator { static const int barWidth(PROGRESS_CHUNK_WIDTH*3.4); int progress(pb->progress() % (2*(r.width()-barWidth))); if(progress < 0) progress = 0; else if(progress > r.width()-barWidth) progress = (r.width()-barWidth)-(progress-(r.width()-barWidth)); drawProgress(p, QRect(r.x()+progress, r.y(), barWidth, r.height()), cg, flags, (opts.square&SQUARE_PROGRESS) ? ROUNDED_NONE : ROUNDED_ALL, widget); } else { QRect cr(subRect(SR_ProgressBarContents, widget)); if(cr.isValid() && pb->progress()>0) { double pg(((double)pb->progress()) / steps); int width(QMIN(cr.width(), (int)(pg * cr.width()))); if(QApplication::reverseLayout()) drawProgress(p, QRect(cr.x()+(cr.width()-width), cr.y(), width, cr.height()), cg, flags, width==cr.width() || (opts.square&SQUARE_PROGRESS) ? ROUNDED_NONE : ROUNDED_ALL, widget); else drawProgress(p, QRect(cr.x(), cr.y(), width, cr.height()), cg, flags, width==cr.width() || (opts.square&SQUARE_PROGRESS) ? ROUNDED_NONE : ROUNDED_ALL, widget); } } break; } case CE_ProgressBarLabel: { const QProgressBar* pb = (const QProgressBar*)widget; QRect cr = subRect(SR_ProgressBarContents, widget); double progress = pb->progress(); bool reverse = QApplication::reverseLayout(); int steps = pb->totalSteps(); if (!cr.isValid()) return; if(opts.boldProgress) // This is the only change fro the KStyle code! { QFont font = p->font(); font.setBold(true); p->setFont(font); } // Draw label if (progress > 0 || steps == 0) { double pg = (steps == 0) ? 1.0 : progress / steps; int width = QMIN(cr.width(), (int)(pg * cr.width())); QRect crect; if (reverse) crect.setRect(cr.x()+(cr.width()-width), cr.y(), cr.width(), cr.height()); else crect.setRect(cr.x()+width, cr.y(), cr.width(), cr.height()); p->save(); p->setPen(pb->isEnabled() ? (reverse ? cg.text() : cg.highlightedText()) : cg.text()); p->drawText(r, AlignCenter, pb->progressString()); p->setClipRect(crect); p->setPen(reverse ? cg.highlightedText() : cg.text()); p->drawText(r, AlignCenter, pb->progressString()); p->restore(); } else { p->setPen(cg.text()); p->drawText(r, AlignCenter, pb->progressString()); } break; } case CE_PushButton: { const QPushButton *button(static_cast(widget)); bool sidebar(!opts.stdSidebarButtons && ((button->isFlat() && button->inherits("KMultiTabBarTab")) || (button->parentWidget() && button->inherits("Ideal::Button") && button->parentWidget()->inherits("Ideal::ButtonBar")))); if(sidebar) { QRect r2(r); flags|=TOGGLE_BUTTON; if(button->isOn()) flags|=Style_On; const QColor *use(flags&Style_On ? getSidebarButtons() : buttonColors(cg)); if((flags&Style_On ) || flags&Style_MouseOver) { r2.addCoords(-1, -1, 1, 1); drawLightBevel(p, r2, cg, flags|Style_Horizontal, ROUNDED_NONE, getFill(flags, use), use, false, false, WIDGET_MENU_ITEM); } else p->fillRect(r2, cg.background()); if(flags&Style_MouseOver && opts.coloredMouseOver) { r2=r; if(MO_PLASTIK==opts.coloredMouseOver) r2.addCoords(0, 1, 0, -1); else r2.addCoords(1, 1, -1, -1); p->setPen(itsMouseOverCols[flags&Style_On ? 0 : 1]); p->drawLine(r.x(), r.y(), r.x()+r.width()-1, r.y()); p->drawLine(r2.x(), r2.y(), r2.x()+r2.width()-1, r2.y()); if(MO_PLASTIK!=opts.coloredMouseOver) { p->drawLine(r.x(), r.y(), r.x(), r.y()+r.height()-1); p->drawLine(r2.x(), r2.y(), r2.x(), r2.y()+r2.height()-1); p->setPen(itsMouseOverCols[flags&Style_On ? 1 : 2]); } p->drawLine(r.x(), r.y()+r.height()-1, r.x()+r.width()-1, r.y()+r.height()-1); p->drawLine(r2.x(), r2.y()+r2.height()-1, r2.x()+r2.width()-1, r2.y()+r2.height()-1); if(MO_PLASTIK!=opts.coloredMouseOver) { p->drawLine(r.x()+r.width()-1, r.y(), r.x()+r.width()-1, r.y()+r.height()-1); p->drawLine(r2.x()+r2.width()-1, r2.y(), r2.x()+r2.width()-1, r2.y()+r2.height()-1); } } } else { itsFormMode = isFormWidget(widget); if(IND_FONT_COLOR==opts.defBtnIndicator && button->isDefault()) flags|=Style_ButtonDefault; if(button->isToggleButton()) flags|=TOGGLE_BUTTON; if(sidebar) flags|=NO_ETCH_BUTTON; drawPrimitive(PE_ButtonCommand, p, r, cg, flags); if (button->isDefault() && IND_CORNER==opts.defBtnIndicator) drawPrimitive(PE_ButtonDefault, p, r, cg, flags); itsFormMode = false; } break; } case CE_CheckBox: itsFormMode = isFormWidget(widget); drawPrimitive(PE_Indicator, p, r, cg, flags, data); itsFormMode = false; break; case CE_CheckBoxLabel: if(opts.crHighlight || FOCUS_GLOW==opts.focus) { const QCheckBox *checkbox((const QCheckBox *)widget); if(flags&Style_MouseOver && opts.crHighlight && #if QT_VERSION >= 0x030200 HOVER_CHECK==itsHover && itsHoverWidget && itsHoverWidget==widget && #endif !isFormWidget(widget)) { #if QT_VERSION >= 0x030200 QRect cr(checkbox->rect()); QRegion r(QRect(cr.x(), cr.y(), visualRect(subRect(SR_CheckBoxFocusRect, widget), widget).width()+ pixelMetric(PM_IndicatorWidth)+4, cr.height())); #else QRegion r(checkbox->rect()); #endif r-=visualRect(subRect(SR_CheckBoxIndicator, widget), widget); p->setClipRegion(r); drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.crHighlight)), p, checkbox->rect(), true, false, opts.selectionAppearance, WIDGET_SELECTION); p->setClipping(false); } int alignment(QApplication::reverseLayout() ? AlignRight : AlignLeft); drawItem(p, r, alignment | AlignVCenter | ShowPrefix, cg, flags & Style_Enabled, checkbox->pixmap(), checkbox->text()); if(checkbox->hasFocus() && FOCUS_GLOW!=opts.focus) drawPrimitive(PE_FocusRect, p, visualRect(subRect(SR_CheckBoxFocusRect, widget), widget), cg, flags); } else BASE_STYLE::drawControl(control, p, widget, r, cg, flags, data); break; case CE_RadioButton: itsFormMode=isFormWidget(widget); drawPrimitive(PE_ExclusiveIndicator, p, r, cg, flags, data); itsFormMode=false; break; case CE_RadioButtonLabel: if(opts.crHighlight || FOCUS_GLOW==opts.focus) { const QRadioButton *radiobutton((const QRadioButton *)widget); if(flags&Style_MouseOver && opts.crHighlight && #if QT_VERSION >= 0x030200 HOVER_RADIO==itsHover && itsHoverWidget && itsHoverWidget==widget && #endif !isFormWidget(widget)) { #if QT_VERSION >= 0x030200 QRect rb(radiobutton->rect()); QRegion r(QRect(rb.x(), rb.y(), visualRect(subRect(SR_RadioButtonFocusRect, widget), widget).width()+ pixelMetric(PM_ExclusiveIndicatorWidth)+4, rb.height())); #else QRegion r(radiobutton->rect()); #endif r-=visualRect(subRect(SR_RadioButtonIndicator, widget), widget); p->setClipRegion(r); drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.crHighlight)), p, radiobutton->rect(), true, false, opts.selectionAppearance, WIDGET_SELECTION); p->setClipping(false); } int alignment(QApplication::reverseLayout() ? AlignRight : AlignLeft); drawItem(p, r, alignment | AlignVCenter | ShowPrefix, cg, flags & Style_Enabled, radiobutton->pixmap(), radiobutton->text()); if(radiobutton->hasFocus() && FOCUS_GLOW!=opts.focus) drawPrimitive(PE_FocusRect, p, visualRect(subRect(SR_RadioButtonFocusRect, widget), widget), cg, flags); break; } // Fall through intentional! default: BASE_STYLE::drawControl(control, p, widget, r, cg, flags, data); } } void QtCurveStyle::drawControlMask(ControlElement control, QPainter *p, const QWidget *widget, const QRect &r, const QStyleOption &data) const { switch(control) { case CE_PushButton: case CE_MenuBarItem: { int offset(r.width()fillRect(r, color0); p->fillRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2, color1); p->setPen(color1); p->drawLine(r.x()+offset, r.y(), r.x()+r.width()-(offset+1), r.y()); p->drawLine(r.x()+offset, r.y()+r.height()-1, r.x()+r.width()-(offset+1), r.y()+r.height()-1); p->drawLine(r.x(), r.y()+offset, r.x(), r.y()+r.height()-(offset+1)); p->drawLine(r.x()+r.width()-1, r.y()+offset, r.x()+r.width()-1, r.y()+r.height()-(offset+1)); break; } default: BASE_STYLE::drawControlMask(control, p, widget, r, data); } } void QtCurveStyle::drawComplexControlMask(ComplexControl control, QPainter *p, const QWidget *widget, const QRect &r, const QStyleOption &data) const { switch (control) { case CC_SpinWidget: case CC_ComboBox: case CC_ToolButton: drawControlMask(CE_PushButton, p, widget, r, data); break; default: BASE_STYLE::drawComplexControlMask(control, p, widget, r, data); } } QRect QtCurveStyle::subRect(SubRect subrect, const QWidget *widget)const { QRect rect, wrect(widget->rect()); switch(subrect) { case SR_PushButtonFocusRect: { if(FOCUS_FULL==opts.focus) rect=wrect; else { int dbw1(pixelMetric(PM_ButtonDefaultIndicator, widget)), dbw2(dbw1*2), border(3), border2=(border*2); rect.setRect(wrect.x()+border +dbw1, wrect.y()+border +dbw1, wrect.width()-border2-dbw2, wrect.height()-border2-dbw2); } if(!isFormWidget(widget) && DO_EFFECT) rect.addCoords(1, 1, -1, -1); return rect; } case SR_ProgressBarContents: return opts.fillProgress ? DO_EFFECT && opts.borderProgress ? wrect : QRect(wrect.left()-1, wrect.top()-1, wrect.width()+2, wrect.height()+2) : DO_EFFECT && opts.borderProgress ? QRect(wrect.left()+2, wrect.top()+2, wrect.width()-4, wrect.height()-4) : QRect(wrect.left()+1, wrect.top()+1, wrect.width()-2, wrect.height()-2); case SR_ProgressBarLabel: case SR_ProgressBarGroove: return wrect; case SR_DockWindowHandleRect: return wrect; default: return BASE_STYLE::subRect(subrect, widget); } return rect; } // This is a hack, as QTitleBar is private!!! class QTitleBar : public QWidget { public: bool isActive() const; QWidget *window() const; }; void QtCurveStyle::drawComplexControl(ComplexControl control, QPainter *p, const QWidget *widget, const QRect &r, const QColorGroup &cg, SFlags flags, SCFlags controls, SCFlags active, const QStyleOption &data) const { if(widget==itsHoverWidget) flags |=Style_MouseOver; switch(control) { case CC_ToolButton: { const QToolButton *toolbutton((const QToolButton *)widget); QRect button(querySubControlMetrics(control, widget, SC_ToolButton, data)), menuarea(querySubControlMetrics(control, widget, SC_ToolButtonMenu, data)); SFlags bflags(flags|STD_TOOLBUTTON), mflags(flags); if (APP_KORN==itsThemedApp) { drawPrimitive(PE_ButtonTool, p, button, cg, bflags, data); break; } const QToolBar *tb(widget->parentWidget() ? ::qt_cast(widget->parentWidget()) : 0L); bool onControlButtons(false), onExtender(!tb && widget->parentWidget() && widget->parentWidget()->inherits( "QToolBarExtensionWidget") && ::qt_cast(widget->parentWidget()->parentWidget())), isDWClose(!tb && !onExtender && widget->parentWidget() && widget->parentWidget()->inherits( "QDockWindowHandle")); if(isDWClose) { p->fillRect(r, cg.background());//.dark(DW_BGND)); if(!(flags&Style_MouseOver) && !(active & SC_ToolButton)) break; bflags|=DW_CLOSE_BUTTON; } if (!tb && !onExtender && widget->parentWidget() && !qstrcmp(widget->parentWidget()->name(), "qt_maxcontrols")) onControlButtons = true; if(active & SC_ToolButton) bflags |=Style_Down; if(active & SC_ToolButtonMenu) mflags |=Style_Down; itsFormMode = isFormWidget(widget); if(controls&SC_ToolButton) { if(onControlButtons || (toolbutton->parentWidget() && toolbutton->parentWidget()->parentWidget() && ::qt_cast(toolbutton->parentWidget()->parentWidget()))) bflags|=NO_ETCH_BUTTON; // If we're pressed, on, or raised... #if defined QTC_QT_ONLY || !defined KDE_VERSION || KDE_VERSION >= 0x30200 if(bflags &(Style_Down | Style_On | Style_Raised) || onControlButtons) #else if(bflags &(Style_Down | Style_On | Style_Raised | Style_MouseOver) || onControlButtons) #endif { //Make sure the standalone toolbuttons have a gradient in the right direction if (!tb && !onControlButtons) bflags |= Style_Horizontal; if(tb) if(Qt::Vertical==tb->orientation()) bflags|=VERTICAL_TB_BUTTON; else bflags|=Style_Horizontal; if(toolbutton->isToggleButton()) bflags|=TOGGLE_BUTTON; drawPrimitive(PE_ButtonTool, p, button, cg, bflags, data); } // Check whether to draw a background pixmap else if(APP_MACTOR!=itsThemedApp && toolbutton->parentWidget() && toolbutton->parentWidget()->backgroundPixmap() && !toolbutton->parentWidget()->backgroundPixmap()->isNull()) p->drawTiledPixmap(r, *(toolbutton->parentWidget()->backgroundPixmap()), toolbutton->pos()); else if(widget->parent()) { QToolBar *tb(0L); if(::qt_cast(widget->parent())) tb=(QToolBar*)widget->parent(); else if(widget->parent()->inherits("QToolBarExtensionWidget")) { QWidget *parent=(QWidget*)widget->parent(); tb=(QToolBar*)parent->parent(); } if(tb) { QRect tbr(tb->rect()); bool horiz(Qt::Horizontal==tb->orientation()); if(!IS_FLAT(opts.toolbarAppearance)) if(horiz) tbr.addCoords(0, -1, 0, 0); else tbr.addCoords(-1, 0, 0, 0); drawMenuOrToolBarBackground(p, tbr, cg, false, horiz); } } } if(controls&SC_ToolButtonMenu) { if(mflags &(Style_Down | Style_On | Style_Raised)) drawPrimitive(PE_ButtonDropDown, p, menuarea, cg, mflags, data); ::drawArrow(p, menuarea, MO_ARROW(cg.buttonText()), PE_ArrowDown, opts, true); } if(toolbutton->hasFocus() && !toolbutton->focusProxy()) { QRect fr(toolbutton->rect()); if(FOCUS_FULL!=opts.focus) fr.addCoords(2, 2,-2,-2); if(DO_EFFECT) fr.addCoords(1, 1,-1,-1); drawPrimitive(PE_FocusRect, p, fr, cg); } itsFormMode=false; break; } case CC_ComboBox: { if(APP_OPENOFFICE==itsThemedApp) flags&=~Style_MouseOver; itsFormMode = isFormWidget(widget); const QComboBox *combobox((const QComboBox *)widget); QRect frame(QStyle::visualRect(querySubControlMetrics(CC_ComboBox, widget, SC_ComboBoxFrame, data), widget)), arrow(QStyle::visualRect(querySubControlMetrics(CC_ComboBox, widget, SC_ComboBoxArrow, data), widget)), field(QStyle::visualRect(querySubControlMetrics(CC_ComboBox, widget, SC_ComboBoxEditField, data), widget)); const QColor *use(buttonColors(cg)); bool editable(combobox->editable()), sunken(combobox->listBox() ? combobox->listBox()->isShown() : false), reverse(QApplication::reverseLayout()); SFlags fillFlags(flags), doEtch(!itsFormMode && DO_EFFECT && (!editable || opts.etchEntry)); if(doEtch) { frame.addCoords(1, 1, -1, -1); field.addCoords(reverse ? -1 : 1, 1, reverse ? -1 : 0, -1); } if(sunken) { fillFlags|=Style_Sunken; if(fillFlags&Style_MouseOver) fillFlags-=Style_MouseOver; } if(editable ||(!itsFormMode && DO_EFFECT && qstrcmp(widget->name(), kdeToolbarWidget))) { p->setPen(cg.background()); p->drawRect(r); } if(controls&SC_ComboBoxFrame && frame.isValid()) { if(editable && opts.unifyCombo) { if(reverse) frame.addCoords(0, 1, 2, -1); else frame.addCoords(-1, 1, -1, -1); p->fillRect(frame, flags&Style_Enabled ? cg.base() : cg.background()); } else { const QColor *cols=itsComboBtnCols && editable && flags&Style_Enabled ? itsComboBtnCols : use; if(editable && HOVER_CB_ARROW!=itsHover) fillFlags&=~Style_MouseOver; // if(opts.coloredMouseOver && fillFlags&Style_MouseOver && editable && !sunken) // frame.addCoords(reverse ? 0 : 1, 0, reverse ? 1 : 0, 0); drawLightBevel(p, frame, cg, fillFlags|Style_Raised|Style_Horizontal, controls&SC_ComboBoxEditField && field.isValid() && editable ? (reverse ? ROUNDED_LEFT : ROUNDED_RIGHT) : ROUNDED_ALL, getFill(fillFlags, cols, false, (SHADE_DARKEN==opts.comboBtn || (SHADE_NONE!=opts.comboBtn && !(flags&Style_Enabled))) && editable), cols, true, true, editable ? WIDGET_COMBO_BUTTON : WIDGET_COMBO); } } if(controls&SC_ComboBoxEditField && field.isValid()) { if(editable) { if(opts.unifyCombo) { field=r; if(DO_EFFECT) field.addCoords(1, 1, -1, -1); } else field.addCoords(-1,-1, 0, 1); p->setPen(flags&Style_Enabled ? cg.base() : cg.background()); p->drawRect(field); if(!opts.unifyCombo) field.addCoords(-2,-2, 2, 2); SFlags fieldFlags(flags); if(!opts.unifyCombo && HOVER_CB_ENTRY!=itsHover) fieldFlags&=~Style_MouseOver; drawEntryField(p, field, cg, fillFlags, fieldFlags&Style_Enabled ? fieldFlags&Style_MouseOver ? ENTRY_MOUSE_OVER : fieldFlags&Style_HasFocus ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, (opts.square&SQUARE_ENTRY) ? ROUNDED_NONE : opts.unifyCombo ? ROUNDED_ALL : reverse ? ROUNDED_RIGHT : ROUNDED_LEFT, WIDGET_COMBO); } else if(opts.comboSplitter && !(SHADE_DARKEN==opts.comboBtn || itsComboBtnCols)) { field.addCoords(1, sunken ? 2 : 1, sunken ? 2 : 1, -1); p->setPen(use[BORDER_VAL(flags&Style_Enabled)]); p->drawLine(reverse ? field.left()-3 : field.right(), field.top(), reverse ? field.left()-3 : field.right(), field.bottom()); if(!sunken) { p->setPen(use[0]); p->drawLine(reverse ? field.left()-2 : field.right()+1, field.top(), reverse ? field.left()-2 : field.right()+1, field.bottom()); } } if(flags&Style_HasFocus && !editable && FOCUS_GLOW!=opts.focus) { QRect fr; if(FOCUS_FULL==opts.focus) fr=frame; else if(opts.comboSplitter) { fr=QStyle::visualRect(subRect(SR_ComboBoxFocusRect, widget), widget); if(reverse) fr.addCoords(3, 0, 0, 0); else fr.addCoords(0, 0, -2, 0); if(!itsFormMode && DO_EFFECT) fr.addCoords(1, 1, -1, -1); } else { fr=frame; fr.addCoords(3, 3, -3, -3); } if(!(flags&Style_MouseOver && FOCUS_FULL==opts.focus && MO_NONE!=opts.coloredMouseOver)) drawPrimitive(PE_FocusRect, p, fr, cg, flags | Style_FocusAtBorder, QStyleOption(cg.highlight())); } } if(controls&SC_ComboBoxArrow && arrow.isValid()) { if(!editable && (SHADE_DARKEN==opts.comboBtn || itsComboBtnCols)) { SFlags btnFlags(flags); QRect btn(arrow.x(), frame.y(), arrow.width()+1, frame.height()); const QColor *cols=SHADE_DARKEN==opts.comboBtn || !(flags&Style_Enabled) ? use : itsComboBtnCols; if(!sunken) btnFlags|=Style_Raised; p->save(); p->setClipRect(btn); if(!opts.comboSplitter) btn.addCoords(reverse ? 0 : -2, 0, reverse ? 2 : 0, 0); if(!DO_EFFECT) btn.addCoords(0, 0, 1, 0); drawLightBevel(p, btn, cg, btnFlags|Style_Horizontal, reverse ? ROUNDED_LEFT : ROUNDED_RIGHT, getFill(btnFlags, cols, false, SHADE_DARKEN==opts.comboBtn || (SHADE_NONE!=opts.comboBtn && !(flags&Style_Enabled))), cols, true, true, WIDGET_COMBO); p->restore(); } SFlags arrowFlags(flags); if(sunken && !opts.unifyCombo) arrow.addCoords(1, 1, 1, 1); if(editable && HOVER_CB_ARROW!=itsHover) arrowFlags&=~Style_MouseOver; ::drawArrow(p, arrow, MO_ARROW_X(arrowFlags, cg.buttonText()), PE_ArrowDown, opts); } if(doEtch) { bool glowFocus(USE_GLOW_FOCUS(flags&Style_MouseOver) && flags&Style_HasFocus && flags&Style_Enabled); if(!sunken && !editable && ((MO_GLOW==opts.coloredMouseOver && flags&Style_MouseOver)/* || (FOCUS_FULL==opts.focus && flags&Style_HasFocus)*/ || glowFocus)) drawGlow(p, widget ? widget->rect() : r, cg, WIDGET_COMBO, glowFocus ? itsFocusCols : NULL); else drawEtch(p, widget ? widget->rect() : r, cg, !editable && EFFECT_SHADOW==opts.buttonEffect && !sunken, editable && (opts.square&SQUARE_ENTRY)); } p->setPen(cg.buttonText()); itsFormMode = false; break; } case CC_SpinWidget: { itsFormMode = isFormWidget(widget); const QSpinWidget *spinwidget((const QSpinWidget *)widget); QRect frame(querySubControlMetrics(CC_SpinWidget, widget, SC_SpinWidgetFrame, data)), up(spinwidget->upRect()), down(spinwidget->downRect()), all(frame.unite(up).unite(down)); bool hw(itsHoverWidget && itsHoverWidget==spinwidget), reverse(QApplication::reverseLayout()), doFrame((controls&SC_SpinWidgetFrame) && frame.isValid()), doEtch(!itsFormMode && DO_EFFECT && opts.etchEntry); if(doEtch) { down.addCoords(reverse ? 1 : 0, 0, reverse ? 0 : -1, -1); up.addCoords(reverse ? 1 : 0, 1, reverse ? 0 : -1, 0); frame.addCoords(reverse ? 0 : 1, 1, reverse ? -1 : 0, -1); } if(flags&Style_MouseOver) flags-=Style_MouseOver; if(opts.unifySpin) drawEntryField(p, all, cg, flags, spinwidget && flags&Style_Enabled ? flags&Style_MouseOver || hw ? ENTRY_MOUSE_OVER : flags&Style_HasFocus || spinwidget->hasFocus() ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, ROUNDED_ALL, WIDGET_SPIN); else { if(!reverse && doFrame) { frame.setWidth(frame.width()+1); drawEntryField(p, frame, cg, flags, spinwidget && flags&Style_Enabled ? flags&Style_MouseOver || hw ? ENTRY_MOUSE_OVER : flags&Style_HasFocus || spinwidget->hasFocus() ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, ROUNDED_LEFT, WIDGET_SPIN); } if(opts.unifySpinBtns) { QRect btns=up.unite(down); const QColor *use(buttonColors(cg)); int btnFlags=flags; btnFlags&=~(Style_Sunken|Style_MouseOver); btnFlags|=Style_Horizontal; drawLightBevel(p, btns, cg, btnFlags, reverse ? ROUNDED_LEFT : ROUNDED_RIGHT, getFill(btnFlags, use), use, true, true, WIDGET_SPIN); if(hw && (HOVER_SW_DOWN==itsHover || HOVER_SW_UP==itsHover) && flags&Style_Enabled && !(flags&Style_Sunken)) { btnFlags|=Style_MouseOver; p->save(); p->setClipRect(HOVER_SW_UP==itsHover ? up : down); drawLightBevel(p, btns, cg, btnFlags, reverse ? ROUNDED_LEFT : ROUNDED_RIGHT, getFill(btnFlags, use), use, true, true, WIDGET_SPIN); p->restore(); } p->setPen(use[BORDER_VAL(style&Style_Enabled)]); p->drawLine(down.x()+2, down.y(), down.x()+down.width()-3, down.y()); } } if((controls&SC_SpinWidgetUp) && up.isValid()) { PrimitiveElement pe(PE_SpinWidgetUp); SFlags upflags(flags); if(hw && HOVER_SW_UP==itsHover) upflags|=Style_MouseOver; up.setHeight(up.height()+1); if(spinwidget->buttonSymbols()==QSpinWidget::PlusMinus) pe=PE_SpinWidgetPlus; if(!spinwidget->isUpEnabled()) upflags&=~Style_Enabled; drawPrimitive(pe, p, up, !(upflags&Style_Enabled) && spinwidget ? spinwidget->palette().disabled() : cg, upflags |((active==SC_SpinWidgetUp) ? Style_On | Style_Sunken : Style_Raised)); } if((controls&SC_SpinWidgetDown) && down.isValid()) { PrimitiveElement pe(PE_SpinWidgetDown); SFlags downflags(flags); if(hw && HOVER_SW_DOWN==itsHover) downflags|=Style_MouseOver; if(spinwidget->buttonSymbols()==QSpinWidget::PlusMinus) pe=PE_SpinWidgetMinus; if(!spinwidget->isDownEnabled()) downflags&=~Style_Enabled; drawPrimitive(pe, p, down, !(downflags&Style_Enabled) && spinwidget ? spinwidget->palette().disabled() : cg, downflags |((active==SC_SpinWidgetDown) ? Style_On | Style_Sunken : Style_Raised)); } if(!opts.unifySpin) { if(reverse && doFrame) { frame.setWidth(frame.width()+1); drawEntryField(p, frame, cg, flags, spinwidget && flags&Style_Enabled ? flags&Style_MouseOver || hw ? ENTRY_MOUSE_OVER : flags&Style_HasFocus || spinwidget->hasFocus() ? ENTRY_FOCUS : ENTRY_NONE : ENTRY_NONE, ROUNDED_RIGHT, WIDGET_SPIN); } if(doEtch) drawEtch(p, spinwidget ? spinwidget->rect() : r, cg, false, (opts.square&SQUARE_ENTRY)); } itsFormMode=false; break; } case CC_ScrollBar: { const QScrollBar *sb((const QScrollBar *)widget); bool hw(itsHoverWidget && itsHoverWidget==sb), useThreeButtonScrollBar(SCROLLBAR_KDE==opts.scrollbarType), horiz(Qt::Horizontal==sb->orientation()), maxed(sb->minValue() == sb->maxValue()), atMin(maxed || sb->value()==sb->minValue()), atMax(maxed || sb->value()==sb->maxValue()); SFlags sflags((horiz ? Style_Horizontal : Style_Default) | (maxed || !widget->isEnabled() ? Style_Default : Style_Enabled)); QRect subline(querySubControlMetrics(control, widget, SC_ScrollBarSubLine, data)), addline(querySubControlMetrics(control, widget, SC_ScrollBarAddLine, data)), subpage(querySubControlMetrics(control, widget, SC_ScrollBarSubPage, data)), addpage(querySubControlMetrics(control, widget, SC_ScrollBarAddPage, data)), slider(querySubControlMetrics(control, widget, SC_ScrollBarSlider, data)), first(querySubControlMetrics(control, widget, SC_ScrollBarFirst, data)), last(querySubControlMetrics(control, widget, SC_ScrollBarLast, data)), subline2(addline), sbRect(sb->rect()); itsFormMode=isFormWidget(widget); if(itsFormMode) { // See KHTML note at top of file if(horiz) { subline.addCoords(0, 0, 0, -1); addline.addCoords(0, 0, 0, -1); subpage.addCoords(0, 0, 0, -1); addpage.addCoords(0, 0, 0, -1); slider.addCoords(0, 0, 0, -1); first.addCoords(0, 0, 0, -1); last.addCoords(0, 0, 0, -1); subline2.addCoords(0, 0, 0, -1); sbRect.addCoords(0, 0, 0, -1); } else { subline.addCoords(0, 0, -1, 0); addline.addCoords(0, 0, -1, 0); subpage.addCoords(0, 0, -1, 0); addpage.addCoords(0, 0, -1, 0); slider.addCoords(0, 0, -1, 0); first.addCoords(0, 0, -1, 0); last.addCoords(0, 0, -1, 0); subline2.addCoords(0, 0, -1, 0); sbRect.addCoords(0, 0, -1, 0); } #ifndef SIMPLE_SCROLLBARS if(sbRect.isValid() && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons)) if(horiz) sbRect.addCoords(0, 0, -1, 0); else sbRect.addCoords(0, 0, 0, -1); #endif } else if (useThreeButtonScrollBar) if (horiz) subline2.moveBy(-addline.width(), 0); else subline2.moveBy(0, -addline.height()); if(opts.flatSbarButtons) switch(opts.scrollbarType) { case SCROLLBAR_KDE: if(horiz) sbRect.addCoords(subline.width(), 0, -(addline.width()+subline2.width()), 0); else sbRect.addCoords(0, subline.height(), 0, -(addline.height()+subline2.height())); break; case SCROLLBAR_WINDOWS: if(horiz) sbRect.addCoords(subline.width(), 0, -(addline.width()), 0); else sbRect.addCoords(0, subline.height(), 0, -(addline.height())); break; case SCROLLBAR_NEXT: if(horiz) sbRect.addCoords(subline.width()+subline2.width(), 0, 0, 0); else sbRect.addCoords(0, subline.height()+subline2.height(), 0, 0); break; case SCROLLBAR_PLATINUM: if(horiz) sbRect.addCoords(0, 0, -(addline.width()+subline2.width()), 0); else sbRect.addCoords(0, 0, 0, -(addline.height()+subline2.height())); default: break; } // Draw trough... const QColor *trough(itsBackgroundCols); // backgroundColors(cg)); bool noButtons((SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons) && ROUNDED); QRect s2(subpage), a2(addpage); #ifndef SIMPLE_SCROLLBARS if(noButtons) { // Increase clipping to allow trough to "bleed" into slider corners... a2.addCoords(-2, -2, 2, 2); s2.addCoords(-2, -2, 2, 2); } #endif p->save(); if(opts.flatSbarButtons) p->setClipRegion(QRegion(s2)+QRegion(addpage)+QRegion(addline)+QRegion(subline)+QRegion(subline2)); else p->setClipRegion(QRegion(s2)+QRegion(addpage)); if(opts.flatSbarButtons && SCROLLBAR_NONE!=opts.scrollbarType && ROUNDED && !IS_FLAT(opts.sbarBgndAppearance)) drawBevelGradient(itsBackgroundCols[ORIGINAL_SHADE], p, r, flags&Style_Horizontal, false, opts.sbarBgndAppearance, WIDGET_SB_BGND); else if(opts.thinSbarGroove && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons) && IS_FLAT(opts.sbarBgndAppearance)) { QColor color(cg.background()); if(0!=opts.tabBgnd && inStackWidget(widget)) color=shade(color, TO_FACTOR(opts.tabBgnd)); p->fillRect(sbRect, cg.background()); } sflags&=~(Style_Down|Style_On|Style_Sunken); if(opts.thinSbarGroove && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons)) if(horiz) sbRect.addCoords(0, THIN_SBAR_MOD, 0, -THIN_SBAR_MOD); else sbRect.addCoords(THIN_SBAR_MOD, 0, -THIN_SBAR_MOD, 0); drawLightBevel(p, sbRect, cg, sflags/*|Style_Down*/, #ifndef SIMPLE_SCROLLBARS !(opts.square&SQUARE_SB_SLIDER) && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons) ? ROUNDED_ALL : #endif ROUNDED_NONE, trough[2], trough, true, true, opts.thinSbarGroove && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons) ? WIDGET_SLIDER_TROUGH : WIDGET_TROUGH); p->restore(); if(/*(controls&SC_ScrollBarSubLine) && */subline.isValid()) { bool enable=!atMin; drawPrimitive(PE_ScrollBarSubLine, p, subline, !enable && sb ? sb->palette().disabled() : cg, sflags | //(enable ? Style_Enabled : Style_Default) | (enable && hw && HOVER_SB_SUB==itsHover ? Style_MouseOver : Style_Default) | (enable && (!hw || HOVER_SB_SUB==itsHover || HOVER_NONE==itsHover) && SC_ScrollBarSubLine==active ? Style_Down : Style_Default)); if (useThreeButtonScrollBar && subline2.isValid()) { if(IS_FLAT(opts.sbarBgndAppearance)) p->fillRect(subline2, cg.background()); drawPrimitive(PE_ScrollBarSubLine, p, subline2, !enable && sb ? sb->palette().disabled() : cg, sflags | //(enable ? Style_Enabled : Style_Default) | (enable && hw && HOVER_SB_SUB2==itsHover ? Style_MouseOver : Style_Default) | (enable && (!hw || HOVER_SB_SUB2==itsHover || HOVER_NONE==itsHover) && SC_ScrollBarSubLine==active ? Style_Down : Style_Default)); } } if(/*(controls&SC_ScrollBarAddLine) && */addline.isValid()) { bool enable=!atMax; // See KHTML note at top of file if(itsFormMode && SCROLLBAR_NEXT!=opts.scrollbarType) if(horiz) addline.addCoords(0, 0, -1, 0); else addline.addCoords(0, 0, 0, -1); drawPrimitive(PE_ScrollBarAddLine, p, addline, !enable && sb ? sb->palette().disabled() : cg, sflags | //(enable ? Style_Enabled : Style_Default) | (enable && hw && HOVER_SB_ADD==itsHover ? Style_MouseOver : Style_Default) | (enable && SC_ScrollBarAddLine==active ? Style_Down : Style_Default)); } if((controls&SC_ScrollBarFirst) && first.isValid()) drawPrimitive(PE_ScrollBarFirst, p, first, cg, sflags | //(maxed ? Style_Default : Style_Enabled) | (!maxed && SC_ScrollBarFirst==active ? Style_Down : Style_Default)); if((controls&SC_ScrollBarLast) && last.isValid()) drawPrimitive(PE_ScrollBarLast, p, last, cg, sflags | //(maxed ? Style_Default : Style_Enabled) | (!maxed && SC_ScrollBarLast==active ? Style_Down : Style_Default)); if(((controls&SC_ScrollBarSlider) || noButtons) && slider.isValid()) { // If "SC_ScrollBarSlider" wasn't pecified, then we only want to draw the portion // of the slider that overlaps with the tough. So, once again set the clipping // region... if(!(controls&SC_ScrollBarSlider)) p->setClipRegion(QRegion(s2)+QRegion(addpage)); #ifdef INCREASE_SB_SLIDER else if(!opts.flatSbarButtons) { if(atMax) switch(opts.scrollbarType) { case SCROLLBAR_KDE: case SCROLLBAR_WINDOWS: case SCROLLBAR_PLATINUM: if(horiz) slider.addCoords(0, 0, 1, 0); else slider.addCoords(0, 0, 0, 1); default: break; } if(atMin) switch(opts.scrollbarType) { case SCROLLBAR_KDE: case SCROLLBAR_WINDOWS: case SCROLLBAR_NEXT: if(horiz) slider.addCoords(-1, 0, 0, 0); else slider.addCoords(0, -1, 0, 0); default: break; } } #endif if(opts.thinSbarGroove) if(opts.flatSbarButtons && SCROLLBAR_NONE!=opts.scrollbarType && ROUNDED) drawBevelGradient(itsBackgroundCols[ORIGINAL_SHADE], p, slider, flags&Style_Horizontal, false, opts.sbarBgndAppearance, WIDGET_SB_BGND); else if(opts.thinSbarGroove && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons) && IS_FLAT(opts.sbarBgndAppearance)) p->fillRect(slider, cg.background()); drawPrimitive(PE_ScrollBarSlider, p, slider, cg, sflags | //(maxed ? Style_Default : Style_Enabled) | (!maxed && hw && HOVER_SB_SLIDER==itsHover ? Style_MouseOver : Style_Default) | (!maxed && SC_ScrollBarSlider==active ? Style_Down : Style_Default)); // ### perhaps this should not be able to accept focus if maxedOut? if(sb->hasFocus()) drawPrimitive(PE_FocusRect, p, QRect(slider.x()+2, slider.y()+2, slider.width()-5, slider.height()-5), cg, Style_Default); #ifndef SIMPLE_SCROLLBARS if(noButtons && (!atMin || !atMax) && !opts.thinSbarGroove) { p->setPen(backgroundColors(cg)[STD_BORDER]); if(horiz) { if(!atMin) { p->drawLine(slider.x(), slider.y(), slider.x()+1, slider.y()); p->drawLine(slider.x(), slider.y()+slider.height()-1, slider.x()+1, slider.y()+slider.height()-1); } if(!atMax) { p->drawLine(slider.x()+slider.width()-1, slider.y(), slider.x()+slider.width()-2, slider.y()); p->drawLine(slider.x()+slider.width()-1, slider.y()+slider.height()-1, slider.x()+slider.width()-2, slider.y()+slider.height()-1); } } else { if(!atMin) { p->drawLine(slider.x(), slider.y(), slider.x(), slider.y()+1); p->drawLine(slider.x()+slider.width()-1, slider.y(), slider.x()+slider.width()-1, slider.y()+1); } if(!atMax) { p->drawLine(slider.x(), slider.y()+slider.height()-1, slider.x(), slider.y()+slider.height()-2); p->drawLine(slider.x()+slider.width()-1, slider.y()+slider.height()-1, slider.x()+slider.width()-1, slider.y()+slider.height()-2); } } } #endif // if(!(controls&SC_ScrollBarSlider)) // p->setClipping(false); } break; } case CC_Slider: // // Note: Can't use KStyle's drawing routine, as this doesnt work for sliders on gradient // toolbars. It also draws groove, focus, slider - wherease QtCurve needs groove, // slider, focus. We also ony double-buffer if not on a toolbar, as we dont know // the background, etc, if on a toolbar - and that is handled in eventFilter { bool tb(!IS_FLAT(opts.toolbarAppearance) && widget && 0==qstrcmp(widget->name(), kdeToolbarWidget)); QRect groove=querySubControlMetrics(CC_Slider, widget, SC_SliderGroove, data), handle=querySubControlMetrics(CC_Slider, widget, SC_SliderHandle, data); QPixmap pix(widget->size()); QPainter p2, *paint(tb ? p : &p2); if(!tb) { paint->begin(&pix); if (widget->parentWidget() && widget->parentWidget()->backgroundPixmap() && !widget->parentWidget()->backgroundPixmap()->isNull()) paint->drawTiledPixmap(r, *(widget->parentWidget()->backgroundPixmap()), widget->pos()); else pix.fill(cg.background()); } if((controls & SC_SliderGroove)&& groove.isValid()) drawSliderGroove(paint, groove, cg, flags, widget); if((controls & SC_SliderHandle)&& handle.isValid()) drawSliderHandle(paint, handle, cg, flags, widget ? ::qt_cast(widget) : 0L, tb); if(controls & SC_SliderTickmarks) QCommonStyle::drawComplexControl(control, paint, widget, r, cg, flags, SC_SliderTickmarks, active, data); if(flags&Style_HasFocus && FOCUS_GLOW!=opts.focus) drawPrimitive(PE_FocusRect, paint, groove, cg); if(!tb) { paint->end(); bitBlt((QWidget*)widget, r.x(), r.y(), &pix); } break; } case CC_TitleBar: { const int buttonMargin(3); const QTitleBar *tb((const QTitleBar *)widget); bool isActive((tb->isActive() && widget->isActiveWindow()) || (!tb->window() && widget->topLevelWidget()->isActiveWindow())); QColorGroup cgroup(isActive ? widget->palette().active() : widget->palette().inactive()); const QColor *cols(getMdiColors(cg, isActive)); QColor textCol(isActive ? itsActiveMdiTextColor : itsMdiTextColor), shdCol(shadowColor(textCol)), shadowCol(midColor(cols[ORIGINAL_SHADE], shdCol)); if (controls&SC_TitleBarLabel) { int alignment=AlignVCenter|SingleLine; bool full=false; switch(opts.titlebarAlignment) { default: case ALIGN_LEFT: alignment|=Qt::AlignLeft; break; case ALIGN_CENTER: alignment|=Qt::AlignHCenter; break; case ALIGN_FULL_CENTER: alignment|=Qt::AlignHCenter; full=true; break; case ALIGN_RIGHT: alignment|=Qt::AlignRight; } QRect ir(visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarLabel), widget)), textRect(full ? tb->rect().x() : ir.x(), ir.y(), full ? tb->rect().width() : ir.width(), ir.height()); EAppearance app=isActive ? opts.titlebarAppearance : opts.inactiveTitlebarAppearance; drawBevelGradient(cols[ORIGINAL_SHADE], p, r, true, false, app, WIDGET_MDI_WINDOW); ir.addCoords(2, 0, -4, 0); QFontMetrics fm(QFontMetrics(widget->font())); QString titleString(elliditide(widget->caption(), fm, textRect.width())); if(full) { int textWidth=fm.boundingRect(titleString).width(); if(ir.left()>((textRect.width()-textWidth)>>1)) { alignment=Qt::AlignVCenter|Qt::AlignLeft; textRect=ir; full=false; } else if(ir.right()<((textRect.width()+textWidth)>>1)) { alignment=Qt::AlignVCenter|Qt::AlignRight; textRect=ir; full=false; } else p->setClipRect(ir); } p->setPen(shadowCol); p->drawText(textRect.x()+1, textRect.y()+1, textRect.width(), textRect.height(), alignment, titleString); p->setPen(textCol); p->drawText(textRect.x(), textRect.y(), textRect.width(), textRect.height(), alignment, titleString); if(full) p->setClipping(false); //controls-=SC_TitleBarLabel; } QRect ir; bool down(false); QPixmap pm; if (controls&SC_TitleBarCloseButton) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarCloseButton), widget); down = active & SC_TitleBarCloseButton; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawMdiIcon(p, textCol, shadowCol, ir, down, buttonMargin, SC_TitleBarCloseButton); } if (tb->window()) { if (controls &SC_TitleBarMaxButton) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarMaxButton), widget); down = active & SC_TitleBarMaxButton; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawMdiIcon(p, textCol, shadowCol, ir, down, buttonMargin, SC_TitleBarMaxButton); } if (controls&SC_TitleBarNormalButton || controls&SC_TitleBarMinButton) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarMinButton), widget); QStyle::SubControl ctrl = (controls & SC_TitleBarNormalButton ? SC_TitleBarNormalButton : SC_TitleBarMinButton); down = active & ctrl; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawMdiIcon(p, textCol, shadowCol, ir, down, buttonMargin, ctrl); } if (controls&SC_TitleBarShadeButton) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarShadeButton), widget); down = active & SC_TitleBarShadeButton; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawMdiIcon(p, textCol, shadowCol, ir, down, buttonMargin, SC_TitleBarShadeButton); } if (controls&SC_TitleBarUnshadeButton) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarUnshadeButton), widget); down = active & SC_TitleBarUnshadeButton; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawMdiIcon(p, textCol, shadowCol, ir, down, buttonMargin, SC_TitleBarUnshadeButton); } } if (controls&SC_TitleBarSysMenu && tb->icon()) { ir = visualRect(querySubControlMetrics(CC_TitleBar, widget, SC_TitleBarSysMenu), widget); down = active & SC_TitleBarSysMenu; drawPrimitive(PE_ButtonTool, p, ir, tb->colorGroup(), down ? Style_Down : Style_Raised); drawItem(p, ir, AlignCenter, tb->colorGroup(), true, tb->icon(), QString::null); } break; } default: BASE_STYLE::drawComplexControl(control, p, widget, r, cg, flags, controls, active, data); } } QRect QtCurveStyle::querySubControlMetrics(ComplexControl control, const QWidget *widget, SubControl sc, const QStyleOption &data) const { bool reverse(QApplication::reverseLayout()); switch(control) { case CC_SpinWidget: { if(!widget) return QRect(); int fw(pixelMetric(PM_SpinBoxFrameWidth, 0)); QSize bs; bs.setHeight(widget->height()>>1); if(bs.height()< 8) bs.setHeight(8); bs.setWidth(DO_EFFECT ? 16 : 15); bs=bs.expandedTo(QApplication::globalStrut()); int extra(bs.height()*2==widget->height()? 0 : 1), y(0), x(widget->width()-bs.width()), rx(x-fw*2); switch(sc) { case SC_SpinWidgetUp: return QRect(x, y, bs.width(), bs.height()); case SC_SpinWidgetDown: return QRect(x, y+bs.height(), bs.width(), bs.height()+extra); case SC_SpinWidgetButtonField: return QRect(x, y, bs.width(), widget->height()-2*fw); case SC_SpinWidgetEditField: return QRect(fw, fw, rx, widget->height()-2*fw); case SC_SpinWidgetFrame: return reverse ? QRect(widget->x()+bs.width(), widget->y(), widget->width()-bs.width()-1, widget->height()) : QRect(widget->x(), widget->y(), widget->width()-bs.width(),widget->height()); default: break; // Remove compiler warnings... } } case CC_ComboBox: { QRect r(BASE_STYLE::querySubControlMetrics(control, widget, sc, data)); if(SC_ComboBoxFrame==sc) { const QComboBox *cb(::qt_cast(widget)); if(cb && cb->editable()) r=QRect(r.x()+r.width()-19, r.y(), 19, r.height()); } else if (SC_ComboBoxEditField==sc && !DO_EFFECT) r.addCoords(0, 0, -1, 0); return r; } case CC_ScrollBar: { // Taken from kstyle.cpp, and modified so as to allow for no scrollbar butttons... bool threeButtonScrollBar(SCROLLBAR_KDE==opts.scrollbarType), platinumScrollBar(SCROLLBAR_PLATINUM==opts.scrollbarType), nextScrollBar(SCROLLBAR_NEXT==opts.scrollbarType), noButtons(SCROLLBAR_NONE==opts.scrollbarType); QRect ret; const QScrollBar *sb((const QScrollBar*)widget); bool horizontal(sb->orientation() == Qt::Horizontal); int sliderstart(sb->sliderStart()), sbextent(pixelMetric(PM_ScrollBarExtent, widget)), maxlen((horizontal ? sb->width() : sb->height()) - (noButtons ? 0 : (sbextent * (threeButtonScrollBar ? 3 : 2)))), sliderlen; // calculate slider length if (sb->maxValue() != sb->minValue()) { uint range = sb->maxValue() - sb->minValue(); sliderlen = (sb->pageStep() * maxlen) / (range + sb->pageStep()); int slidermin = pixelMetric( PM_ScrollBarSliderMin, widget ); if ( sliderlen < slidermin || range > INT_MAX / 2 ) sliderlen = slidermin; if ( sliderlen > maxlen ) sliderlen = maxlen; } else sliderlen = maxlen; // Subcontrols switch(sc) { case SC_ScrollBarSubLine: if(noButtons) return QRect(); // top/left button if (platinumScrollBar) if (horizontal) ret.setRect(sb->width() - 2 * sbextent, 0, sbextent, sbextent); else ret.setRect(0, sb->height() - 2 * sbextent, sbextent, sbextent); else ret.setRect(0, 0, sbextent, sbextent); break; case SC_ScrollBarAddLine: if(noButtons) return QRect(); // bottom/right button if (nextScrollBar) if (horizontal) ret.setRect(sbextent, 0, sbextent, sbextent); else ret.setRect(0, sbextent, sbextent, sbextent); else if (horizontal) ret.setRect(sb->width() - sbextent, 0, sbextent, sbextent); else ret.setRect(0, sb->height() - sbextent, sbextent, sbextent); break; case SC_ScrollBarSubPage: // between top/left button and slider if (platinumScrollBar) if (horizontal) ret.setRect(0, 0, sliderstart, sbextent); else ret.setRect(0, 0, sbextent, sliderstart); else if (nextScrollBar) if (horizontal) ret.setRect(sbextent*2, 0, sliderstart-2*sbextent, sbextent); else ret.setRect(0, sbextent*2, sbextent, sliderstart-2*sbextent); else if (horizontal) ret.setRect(noButtons ? 0 : sbextent, 0, noButtons ? sliderstart : (sliderstart - sbextent), sbextent); else ret.setRect(0, noButtons ? 0 : sbextent, sbextent, noButtons ? sliderstart : (sliderstart - sbextent)); break; case SC_ScrollBarAddPage: { // between bottom/right button and slider int fudge; if (platinumScrollBar) fudge = 0; else if (nextScrollBar) fudge = 2*sbextent; else if(noButtons) fudge = 0; else fudge = sbextent; if (horizontal) ret.setRect(sliderstart + sliderlen, 0, maxlen - sliderstart - sliderlen + fudge, sbextent); else ret.setRect(0, sliderstart + sliderlen, sbextent, maxlen - sliderstart - sliderlen + fudge); break; } case SC_ScrollBarGroove: if(noButtons) { if (horizontal) ret.setRect(0, 0, sb->width(), sb->height()); else ret.setRect(0, 0, sb->width(), sb->height()); } else { int multi = threeButtonScrollBar ? 3 : 2, fudge; if (platinumScrollBar) fudge = 0; else if (nextScrollBar) fudge = 2*sbextent; else fudge = sbextent; if (horizontal) ret.setRect(fudge, 0, sb->width() - sbextent * multi, sb->height()); else ret.setRect(0, fudge, sb->width(), sb->height() - sbextent * multi); } break; case SC_ScrollBarSlider: if (horizontal) ret.setRect(sliderstart, 0, sliderlen, sbextent); else ret.setRect(0, sliderstart, sbextent, sliderlen); break; default: ret = QCommonStyle::querySubControlMetrics(control, widget, sc, data); break; } return ret; } #ifdef SET_MDI_WINDOW_BUTTON_POSITIONS // TODO case CC_TitleBar: if (widget) { bool isMinimized(tb->titleBarState&Qt::WindowMinimized), isMaximized(tb->titleBarState&Qt::WindowMaximized); if( (isMaximized && SC_TitleBarMaxButton==subControl) || (isMinimized && SC_TitleBarMinButton==subControl) || (isMinimized && SC_TitleBarShadeButton==subControl) || (!isMinimized && SC_TitleBarUnshadeButton==subControl)) return QRect(); readMdiPositions(); const int windowMargin(2); const int controlSize(tb->rect.height() - windowMargin *2); QList::ConstIterator it(itsMdiButtons[0].begin()), end(itsMdiButtons[0].end()); int sc(SC_TitleBarUnshadeButton==subControl ? SC_TitleBarShadeButton : SC_TitleBarNormalButton==subControl ? isMaximized ? SC_TitleBarMaxButton : SC_TitleBarMinButton : subControl), pos(0), totalLeft(0), totalRight(0); bool rhs(false), found(false); for(; it!=end; ++it) if(SC_TitleBarCloseButton==(*it) || WINDOWTITLE_SPACER==(*it) || tb->titleBarFlags&(toHint(*it))) { totalLeft+=WINDOWTITLE_SPACER==(*it) ? controlSize/2 : controlSize; if(*it==sc) found=true; else if(!found) pos+=WINDOWTITLE_SPACER==(*it) ? controlSize/2 : controlSize; } if(!found) { pos=0; rhs=true; } it=itsMdiButtons[1].begin(); end=itsMdiButtons[1].end(); for(; it!=end; ++it) if(SC_TitleBarCloseButton==(*it) || WINDOWTITLE_SPACER==(*it) || tb->titleBarFlags&(toHint(*it))) { if(WINDOWTITLE_SPACER!=(*it) || totalRight) totalRight+=WINDOWTITLE_SPACER==(*it) ? controlSize/2 : controlSize; if(rhs) if(*it==sc) { pos+=controlSize; found=true; } else if(found) pos+=WINDOWTITLE_SPACER==(*it) ? controlSize/2 : controlSize; } totalLeft+=(windowMargin*(totalLeft ? 2 : 1)); totalRight+=(windowMargin*(totalRight ? 2 : 1)); if(SC_TitleBarLabel==subControl) r.adjust(totalLeft, 0, -totalRight, 0); else if(!found) return QRect(); else if(rhs) r.setRect(r.right()-(pos+windowMargin), r.top()+windowMargin, controlSize, controlSize); else r.setRect(r.left()+windowMargin+pos, r.top()+windowMargin, controlSize, controlSize); return visualRect(tb->direction, tb->rect, r); } } #endif default: break; // Remove compiler warnings... } return BASE_STYLE::querySubControlMetrics(control, widget, sc, data); } int QtCurveStyle::pixelMetric(PixelMetric metric, const QWidget *widget) const { switch(metric) { case PM_MenuBarFrameWidth: return TB_NONE==opts.toolbarBorders ? 0 : 1; case PM_MenuButtonIndicator: return 7; case PM_ButtonMargin: return 3; #if QT_VERSION >= 0x030200 case PM_TabBarTabShiftVertical: { const QTabBar *tb=widget ? ::qt_cast(widget) : 0; return tb ? QTabBar::RoundedAbove==tb->shape() || QTabBar::TriangularAbove==tb->shape() ? 1 : -1 : BASE_STYLE::pixelMetric(metric, widget); } case PM_TabBarTabShiftHorizontal: return 0; #endif case PM_ButtonShiftHorizontal: case PM_ButtonShiftVertical: return 1; case PM_ButtonDefaultIndicator: return 0; case PM_DefaultFrameWidth: if(APP_KATE==itsThemedApp && widget && widget->parentWidget() && widget->parentWidget()->parentWidget() && ::qt_cast(widget) && ::qt_cast(widget->parentWidget()) && ::qt_cast(widget->parentWidget()->parentWidget())) return 0; if ((opts.square&SQUARE_SCROLLVIEW) && widget && ::qt_cast(widget)) return (opts.gtkScrollViews || opts.thinSbarGroove) && !opts.highlightScrollViews ? 1 : 2; if(DO_EFFECT && opts.etchEntry && widget && !isFormWidget(widget) && (::qt_cast(widget) || ::qt_cast(widget) || ::qt_cast(widget) || ::qt_cast(widget))) return 3; else return 2; case PM_SpinBoxFrameWidth: return DO_EFFECT && !isFormWidget(widget) ? 3 : 2; case PM_IndicatorWidth: case PM_IndicatorHeight: return DO_EFFECT && widget && !isFormWidget(widget) ? opts.crSize+2 : opts.crSize; case PM_ExclusiveIndicatorWidth: case PM_ExclusiveIndicatorHeight: return DO_EFFECT && widget && !isFormWidget(widget) ? opts.crSize+2 : opts.crSize; case PM_TabBarTabOverlap: return TAB_MO_GLOW==opts.tabMouseOver ? 0 : 1; case PM_ProgressBarChunkWidth: return PROGRESS_CHUNK_WIDTH*3.4; case PM_DockWindowSeparatorExtent: return 4; case PM_DockWindowHandleExtent: return 10; case PM_SplitterWidth: return widget && widget->inherits("QDockWindowResizeHandle") ? 9 : LINE_1DOT==opts.splitters ? 7 : 6; case PM_ScrollBarSliderMin: return opts.sliderWidth+1; case PM_SliderThickness: return SLIDER_TRIANGULAR==opts.sliderStyle ? 22 : (SLIDER_SIZE+(ROTATED_SLIDER ? 8 : 3)); case PM_SliderControlThickness: return SLIDER_TRIANGULAR==opts.sliderStyle ? 19 : (SLIDER_SIZE+(ROTATED_SLIDER ? 8 : 0)); // This equates to 13, as we draw the handle 2 pix smaller for focus rect... case PM_SliderLength: return SLIDER_TRIANGULAR==opts.sliderStyle ? 11 : (SLIDER_SIZE+(ROTATED_SLIDER ? -2 : 6)); case PM_ScrollBarExtent: // See KHTML note at top of file return opts.sliderWidth+ (APP_KPRESENTER==itsThemedApp || ((APP_KONQUEROR==itsThemedApp || APP_KONTACT==itsThemedApp) && (!widget || isFormWidget(widget))) ? 1 : 0); case PM_MaximumDragDistance: return -1; case PM_TabBarTabVSpace: return opts.highlightTab ? 11 : 9; default: return BASE_STYLE::pixelMetric(metric, widget); } } int QtCurveStyle::kPixelMetric(KStylePixelMetric kpm, const QWidget *widget) const { switch(kpm) { case KPM_MenuItemSeparatorHeight: return 2; default: return BASE_STYLE::kPixelMetric(kpm, widget); } } QSize QtCurveStyle::sizeFromContents(ContentsType contents, const QWidget *widget, const QSize &contentsSize, const QStyleOption &data) const { switch(contents) { case CT_PushButton: { const QPushButton *button(static_cast(widget)); if (button && !button->text().isEmpty()) { int margin(2*pixelMetric(PM_ButtonMargin, widget)), mbi(button->isMenuButton() ? pixelMetric(PM_MenuButtonIndicator, widget) : 0), w(contentsSize.width() + margin + mbi + 16); // if(button->text()=="...") // w+=24; // else if("..."!=button->text()) { const int constMinW(84); if(opts.embolden) w+=6; // add room for bold font - Assume all buttons can be default! if(w(widget)); int maxpmw(data.maxIconWidth()), w(contentsSize.width()), h(contentsSize.height()); if (mi->custom()) { w = mi->custom()->sizeHint().width(); h = mi->custom()->sizeHint().height(); if (!mi->custom()->fullSpan() && h < constMinH) h = constMinH; } else if(mi->widget()) ; else if (mi->isSeparator()) { w = 10; h = 7; } else { // check is at least 16x16 if (h < 16) h = 16; if (mi->pixmap()) h = QMAX(h, mi->pixmap()->height()); else if (!mi->text().isNull()) h = QMAX(h, popupmenu->fontMetrics().height() + 2); if (mi->iconSet()!= 0) h = QMAX(h, mi->iconSet()->pixmap(QIconSet::Small, QIconSet::Normal).height()); h+=(opts.thinnerMenuItems ? 2 : 4); } // check | 4 pixels | item | 8 pixels | accel | 4 pixels | check // check is at least 16x16 maxpmw=QMAX(maxpmw, constMenuPixmapWidth); w += (maxpmw * 2) + 8; if (! mi->text().isNull() && mi->text().find('\t') >= 0) w += 8; return QSize(w, h); } case CT_SpinBox: { QSize size(BASE_STYLE::sizeFromContents(contents, widget, contentsSize, data)); if(!(size.height()%2)) size.setHeight(size.height()+1); // if(!isFormWidget(widget)) // size.setHeight(size.height()+2); return size; } case CT_ToolButton: if(widget->parent() && ::qt_cast(widget->parent())) return QSize(contentsSize.width()+8, contentsSize.height()+8); default: break; // Remove compiler warnings... } return BASE_STYLE::sizeFromContents(contents, widget, contentsSize, data); } int QtCurveStyle::styleHint(StyleHint stylehint, const QWidget *widget, const QStyleOption &option, QStyleHintReturn *returnData) const { switch(stylehint) { case SH_PopupMenu_SubMenuPopupDelay: return opts.menuDelay; case SH_ScrollView_FrameOnlyAroundContents: return opts.gtkScrollViews; case SH_EtchDisabledText: return 0; case SH_Slider_SnapToValue: case SH_PrintDialog_RightAlignButtons: case SH_FontDialog_SelectAssociatedText: case SH_PopupMenu_MouseTracking: case SH_PopupMenu_SpaceActivatesItem: case SH_ComboBox_ListMouseTracking: case SH_ScrollBar_MiddleClickAbsolutePosition: return 1; case SH_MenuBar_AltKeyNavigation: return 0; case SH_LineEdit_PasswordCharacter: if(opts.passwordChar) { int chars[4]={opts.passwordChar, 0x25CF, 0x2022, 0}; const QFontMetrics &fm(widget ? widget->fontMetrics() : QFontMetrics(QFont())); for(int i=0; chars[i]; ++i) if (fm.inFont(QChar(chars[i]))) return chars[i]; return '*'; } else return '\0'; case SH_MainWindow_SpaceBelowMenuBar: return 0; case SH_PopupMenu_AllowActiveAndDisabled: return 0; case SH_MenuBar_MouseTracking: return opts.menubarMouseOver ? 1 : 0; case SH_TabBar_Alignment: return AlignLeft; default: return BASE_STYLE::styleHint(stylehint, widget, option, returnData); } } void QtCurveStyle::drawItem(QPainter *p, const QRect &r, int flags, const QColorGroup &cg, bool enabled, const QPixmap *pixmap, const QString &text, int len, const QColor *penColor) const { QRect r2(r); if((opts.gbLabel&GB_LBL_BOLD) && text.length() && p->device() && dynamic_cast(p->device())) { QGroupBox *box=static_cast(p->device()); if (!box->isCheckable()) { int left, top, width, height; QFontMetrics fm(p->fontMetrics()); QRect rb(box->rect()); int th(fm.height()+2); QFont f(p->font()); rb.rect(&left, &top, &width, &height); //rb.coords(&left, &top, &right, &bottom); f.setBold(true); p->setPen(box->colorGroup().foreground()); p->setFont(f); p->drawText(QRect(left, top, width, th), (QApplication::reverseLayout() ? AlignRight : AlignLeft)|AlignVCenter|ShowPrefix|SingleLine, text); return; } } int x = r.x(), y = r.y(), w = r.width(), h = r.height(); p->setPen(penColor ? *penColor : cg.foreground()); if (pixmap) { QPixmap pm(*pixmap); bool clip = (flags&Qt::DontClip) == 0; if (clip) { if (pm.width() < w && pm.height() < h) clip = false; else { p->save(); QRegion cr = QRect(x, y, w, h); if (p->hasClipping()) cr &= p->clipRegion(QPainter::CoordPainter); p->setClipRegion(cr); } } if ((flags&Qt::AlignVCenter) == Qt::AlignVCenter) y += h/2 - pm.height()/2; else if ((flags&Qt::AlignBottom) == Qt::AlignBottom) y += h - pm.height(); if ((flags&Qt::AlignRight) == Qt::AlignRight) x += w - pm.width(); else if ((flags&Qt::AlignHCenter) == Qt::AlignHCenter) x += w/2 - pm.width()/2; else if (((flags&Qt::AlignLeft) != Qt::AlignLeft) && QApplication::reverseLayout()) // AlignAuto && rightToLeft x += w - pm.width(); if (!enabled) { if (pm.mask()) // pixmap with a mask { if (!pm.selfMask()) // mask is not pixmap itself { QPixmap pmm(*pm.mask()); pmm.setMask(*((QBitmap *)&pmm)); pm = pmm; } } else if (pm.depth() == 1) // monochrome pixmap, no mask { pm.setMask(*((QBitmap *)&pm)); #ifndef QT_NO_IMAGE_HEURISTIC_MASK } else // color pixmap, no mask { QString k; k.sprintf("$qt-drawitem-%x", pm.serialNumber()); QPixmap *mask = QPixmapCache::find(k); bool del=false; if (!mask) { mask = new QPixmap(pm.createHeuristicMask()); mask->setMask(*((QBitmap*)mask)); del = !QPixmapCache::insert(k, mask); } pm = *mask; if (del) delete mask; #endif } p->setPen(cg.text()); } p->drawPixmap(x, y, pm); if (clip) p->restore(); } else if (!text.isNull()) { if (!enabled) p->setPen(cg.text()); p->drawText(x, y, w, h, flags, text, len); } } void QtCurveStyle::drawMenuItem(QPainter *p, const QRect &r, int flags, const QColorGroup &cg, bool mbi, int round, const QColor &bgnd, const QColor *cols) const { int fill=opts.useHighlightForMenu && (!mbi || itsHighlightCols==cols) ? ORIGINAL_SHADE : 4, border=opts.borderMenuitems ? 0 : fill; if(itsHighlightCols!=cols && mbi && !((flags&Style_Enabled) && (flags&Style_Active) && (flags&Style_Down)) && !opts.colorMenubarMouseOver && (opts.borderMenuitems || !IS_FLAT(opts.menuitemAppearance))) fill=ORIGINAL_SHADE; if(!mbi && APPEARANCE_FADE==opts.menuitemAppearance) { bool reverse=QApplication::reverseLayout(); int roundOffet=ROUNDED ? 1 : 0; QRect main(r.x()+(reverse ? 1+MENUITEM_FADE_SIZE : roundOffet+1), r.y()+roundOffet+1, r.width()-(1+MENUITEM_FADE_SIZE), r.height()-(2+(roundOffet*2))), fade(reverse ? r.x()+1 : r.width()-MENUITEM_FADE_SIZE, r.y()+1, MENUITEM_FADE_SIZE, r.height()-2); p->fillRect(main, cols[fill]); if(ROUNDED) { main.addCoords(-1, -1, 1, 1); drawBorder(USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE], p, main, cg, Style_Horizontal|Style_Raised, reverse ? ROUNDED_RIGHT : ROUNDED_LEFT, cols, WIDGET_MENU_ITEM, false, BORDER_FLAT, false, fill); } QColor bgnd(USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE]); drawGradient(reverse ? bgnd : cols[fill], reverse ? cols[fill] : bgnd, p, fade, false); } else if(mbi || opts.borderMenuitems) { int flags(Style_Raised); bool stdColor(!mbi || (SHADE_BLEND_SELECTED!=opts.shadeMenubars && SHADE_SELECTED!=opts.shadeMenubars)); itsFormMode=true; flags|=Style_Horizontal; if(stdColor && opts.borderMenuitems) drawLightBevel(bgnd, p, r, cg, flags, round, cols[fill], cols, stdColor, !(mbi && IS_GLASS(opts.menubarAppearance)), WIDGET_MENU_ITEM); else { QRect fr(r); fr.addCoords(1, 1, -1, -1); if(fr.width()>0 && fr.height()>0) drawBevelGradient(cols[fill], p, fr, true, false, opts.menuitemAppearance, WIDGET_MENU_ITEM); drawBorder(bgnd, p, r, cg, flags, round, cols, WIDGET_OTHER, false, BORDER_FLAT, false, border); } itsFormMode=false; } else drawBevelGradient(cols[fill], p, r, true, false, opts.menuitemAppearance, WIDGET_MENU_ITEM); } void QtCurveStyle::drawProgress(QPainter *p, const QRect &rx, const QColorGroup &cg, SFlags flags, int round, const QWidget *widget) const { if(rx.width()<1) return; QRect r=opts.borderProgress ? QRect(rx.x()+1, rx.y()+1, rx.width()-2, rx.height()-2) : rx; int minWidth(3); bool drawFull(r.width()>minWidth), drawStripe(r.width()>(minWidth*1.5)); QRegion outer(r); if(r.width()<3) r.setWidth(3); if(drawStripe) { int animShift=-PROGRESS_CHUNK_WIDTH; if (opts.animatedProgress) { // find the animation Offset for the current Widget QWidget *nonConstWidget(const_cast(widget)); QMapConstIterator it(itsProgAnimWidgets.find(nonConstWidget)); if (it!=itsProgAnimWidgets.end()) animShift += it.data(); } switch(opts.stripedProgress) { default: case STRIPE_NONE: break; case STRIPE_PLAIN: for(int offset=0; offset<(r.width()+PROGRESS_CHUNK_WIDTH); offset+=(PROGRESS_CHUNK_WIDTH*2)) { QRect r2(r.x()+offset+animShift, r.y(), PROGRESS_CHUNK_WIDTH, r.height()); QRegion inner(r2); outer=outer.eor(inner); } break; case STRIPE_DIAGONAL: { QPointArray a; int shift(r.height()); for(int offset=0; offset<(r.width()+shift+2); offset+=(PROGRESS_CHUNK_WIDTH*2)) { a.setPoints(4, r.x()+offset+animShift, r.y(), r.x()+offset+animShift+PROGRESS_CHUNK_WIDTH, r.y(), (r.x()+offset+animShift+PROGRESS_CHUNK_WIDTH)-shift, r.y()+r.height()-1, (r.x()+offset+animShift)-shift, r.y()+r.height()-1); outer=outer.eor(QRegion(a)); } } } } const QColor *use=flags&Style_Enabled || ECOLOR_BACKGROUND==opts.progressGrooveColor ? itsProgressCols ? itsProgressCols : itsHighlightCols : itsBackgroundCols; flags|=Style_Raised|Style_Horizontal; drawLightBevel(cg.background(), p, r, cg, flags, round, use[ORIGINAL_SHADE], use, false, true, WIDGET_PROGRESSBAR); if(drawStripe && opts.stripedProgress) { p->setClipRegion(outer); drawLightBevel(cg.background(), p, r, cg, flags, round, use[1], use, false, true, WIDGET_PROGRESSBAR); p->setClipping(false); } if(opts.borderProgress) drawBorder(cg.background(), p, r, cg, flags, !(opts.square&SQUARE_PROGRESS) && opts.fillProgress ? ROUNDED_ALL : round, use, WIDGET_PROGRESSBAR, false, BORDER_FLAT, false, PBAR_BORDER); else { r.addCoords(1, 1, -1, -1); p->setPen(use[PBAR_BORDER]); p->drawLine(r.topLeft(), r.topRight()); p->drawLine(r.bottomLeft(), r.bottomRight()); } } void QtCurveStyle::drawBevelGradient(const QColor &base, QPainter *p, const QRect &origRect, bool horiz, bool sel, EAppearance bevApp, EWidget w) const { if(IS_FLAT(bevApp) && opts.colorSelTab && sel) bevApp=APPEARANCE_GRADIENT; if(IS_FLAT(bevApp)) p->fillRect(origRect, base); else { bool tab(WIDGET_TAB_TOP==w || WIDGET_TAB_BOT==w), selected(tab ? false : sel); EAppearance app(selected ? opts.sunkenAppearance : WIDGET_LISTVIEW_HEADER==w && APPEARANCE_BEVELLED==bevApp ? APPEARANCE_LV_BEVELLED : APPEARANCE_BEVELLED!=bevApp || WIDGET_BUTTON(w) || WIDGET_LISTVIEW_HEADER==w || WIDGET_NO_ETCH_BTN==w || WIDGET_MENU_BUTTON==w ? bevApp : APPEARANCE_GRADIENT); QRect r(0, 0, horiz ? PIXMAP_DIMENSION : origRect.width(), horiz ? origRect.height() : PIXMAP_DIMENSION); QString key(createKey(horiz ? r.height() : r.width(), base.rgb(), horiz, app, tab && sel && opts.colorSelTab ? CACHE_COL_SEL_TAB : CACHE_STD)); QPixmap *pix(itsPixmapCache.find(key)); bool inCache(true); if(!pix) { pix=new QPixmap(r.width(), r.height()); QPainter pixPainter(pix); drawBevelGradientReal(base, &pixPainter, r, horiz, sel, app, w); pixPainter.end(); int cost(pix->width()*pix->height()*(pix->depth()/8)); if(costdrawTiledPixmap(origRect, *pix); if(!inCache) delete pix; } } void QtCurveStyle::drawBevelGradientReal(const QColor &base, QPainter *p, const QRect &r, bool horiz, bool sel, EAppearance app, EWidget w) const { const Gradient *grad=getGradient(app, &opts); int numStops(grad->stops.size()), lastPos(0), size(horiz ? r.height() : r.width()); bool topTab(WIDGET_TAB_TOP==w), botTab(WIDGET_TAB_BOT==w); QColor prev; if(botTab) { GradientStopCont::reverse_iterator it(grad->stops.rbegin()), end(grad->stops.rend()); for(int i=0; it!=end; ++it, ++i) { QColor col; int pos((int)(((1.0-(*it).pos)*size)+0.5)); if(sel && 0==i) col=base; else shade(base, &col, opts.invertBotTab ? QMAX(INVERT_SHADE((*it).val), 0.9) : (*it).val); if(/*sel && */opts.colorSelTab && i>0) col=tint(col, itsHighlightCols[0], (1.0-(*it).pos)*(0.2+TO_ALPHA(opts.colorSelTab))); if(i) drawGradient(prev, col, p, horiz ? QRect(r.x(), lastPos, r.width(), pos-lastPos) : QRect(lastPos, r.y(), pos-lastPos, r.height()), horiz); prev=col; lastPos=pos; } } else { GradientStopCont::const_iterator it(grad->stops.begin()), end(grad->stops.end()); for(int i=0; it!=end; ++it, ++i) { QColor col; int pos((int)(((*it).pos*size)+0.5)); if(/*sel && */topTab && i==numStops-1) col=base; else shade(base, &col, WIDGET_TAB_BOT==w ? QMAX((*it).val, 0.9) : (*it).val); if(sel && opts.colorSelTab && topTab && i0 && r.height()>0) { if(top==bot) p->fillRect(r, top); else { int rh(r.height()), rw(r.width()), rTop(top.red()), gTop(top.green()), bTop(top.blue()), rx, ry, rx2, ry2, size(horiz ? rh : rw); r.coords(&rx, &ry, &rx2, &ry2); register int rl(rTop << 16); register int gl(gTop << 16); register int bl(bTop << 16); register int i; int dr(((1<<16) * (bot.red() - rTop)) / size), dg(((1<<16) * (bot.green() - gTop)) / size), db(((1<<16) * (bot.blue() - bTop)) / size); if(horiz) { for (i=0; i < size; i++) { p->setPen(QColor(rl>>16, gl>>16, bl>>16)); p->drawLine(rx, ry+i, rx2, ry+i); rl += dr; gl += dg; bl += db; } } else for(i=0; i < size; i++) { p->setPen(QColor(rl>>16, gl>>16, bl>>16)); p->drawLine(rx+i, ry, rx+i, ry2); rl += dr; gl += dg; bl += db; } } } } void QtCurveStyle::drawSbSliderHandle(QPainter *p, const QRect &orig, const QColorGroup &cg, SFlags flags, bool slider) const { int min(MIN_SLIDER_SIZE(opts.sliderThumbs)); const QColor *use(sliderColors(/*cg, */flags)); QRect r(orig); // EShade shade(opts.shadeSliders); if(flags&(Style_Sunken|Style_Down)) flags|=Style_MouseOver; flags&=~Style_Down; if(r.width()>r.height()) flags|=Style_Horizontal; flags|=Style_Raised; drawLightBevel(p, r, cg, flags, (slider && !(opts.square&SQUARE_SLIDER)) #ifndef SIMPLE_SCROLLBARS || (!slider && !(opts.square&SQUARE_SB_SLIDER) && (SCROLLBAR_NONE==opts.scrollbarType || opts.flatSbarButtons)) #endif ? ROUNDED_ALL : ROUNDED_NONE, getFill(flags, use, false, SHADE_DARKEN==opts.shadeSliders), use, true, false, WIDGET_SB_SLIDER); if(LINE_NONE!=opts.sliderThumbs && (slider || ((flags & Style_Horizontal && r.width()>=min)|| r.height()>=min))) { const QColor *markers(/*opts.coloredMouseOver && flags&Style_MouseOver ? itsMouseOverCols : */use); bool horiz(flags&Style_Horizontal); if(LINE_SUNKEN==opts.sliderThumbs) if(horiz) r.addCoords(0, -1, 0, 0); else r.addCoords(-1, 0, 0, 0); else r.addCoords(horiz ? 1 : 0, horiz ? 0 : 1, 0, 0); switch(opts.sliderThumbs) { case LINE_FLAT: drawLines(p, r, !horiz, 3, 5, markers, 0, 5, opts.sliderThumbs); break; case LINE_SUNKEN: drawLines(p, r, !horiz, 4, 3, markers, 0, 3, opts.sliderThumbs); break; case LINE_1DOT: drawDot(p, r, markers); break; case LINE_DOTS: default: drawDots(p, r, !horiz, slider ? 3 : 5, slider ? 5 : 2, markers, 0, 5); } } } void QtCurveStyle::drawSliderHandle(QPainter *p, const QRect &r, const QColorGroup &cg, SFlags flags, QSlider *slider, bool tb) const { bool horiz(SLIDER_TRIANGULAR==opts.sliderStyle ? r.height()>r.width() : r.width()>r.height()); if(SLIDER_TRIANGULAR==opts.sliderStyle || ((SLIDER_ROUND==opts.sliderStyle || SLIDER_ROUND_ROTATED==opts.sliderStyle) && FULLLY_ROUNDED)) { const QColor *use(sliderColors(/*cg, */flags)), *border(flags&Style_MouseOver && (MO_GLOW==opts.coloredMouseOver || MO_COLORED==opts.coloredMouseOver) ? itsMouseOverCols : use); const QColor &fill(getFill(flags, use, false, SHADE_DARKEN==opts.shadeSliders)); int x(r.x()), y(r.y()), xo(horiz ? 8 : 0), yo(horiz ? 0 : 8); PrimitiveElement direction(horiz ? PE_ArrowDown : PE_ArrowRight); bool drawLight(MO_PLASTIK!=opts.coloredMouseOver || !(flags&Style_MouseOver) || ((SLIDER_ROUND==opts.sliderStyle || SLIDER_ROUND_ROTATED)==opts.sliderStyle && (SHADE_BLEND_SELECTED==opts.shadeSliders || SHADE_SELECTED==opts.shadeSliders))); int size(SLIDER_TRIANGULAR==opts.sliderStyle ? 15 : 13), borderVal(itsMouseOverCols==border ? SLIDER_MO_BORDER_VAL : BORDER_VAL(flags&Style_Enabled)); if(SLIDER_ROUND_ROTATED!=opts.sliderStyle) if(horiz) y++; else x++; QPointArray clipRegion; p->save(); if(SLIDER_TRIANGULAR==opts.sliderStyle) { if(slider) switch(slider->tickmarks()) { case QSlider::Both: case QSlider::NoMarks: case QSlider::Below: direction=horiz ? PE_ArrowDown : PE_ArrowRight; break; case QSlider::Above: direction=horiz ? PE_ArrowUp : PE_ArrowLeft; } switch(direction) { default: case PE_ArrowDown: y+=2; clipRegion.setPoints(7, x, y+2, x+2, y, x+8, y, x+10, y+2, x+10, y+9, x+5, y+14, x, y+9); break; case PE_ArrowUp: y-=2; clipRegion.setPoints(7, x, y+12, x+2, y+14, x+8, y+14, x+10, y+12, x+10, y+5, x+5, y, x, y+5); break; case PE_ArrowLeft: x-=2; clipRegion.setPoints(7, x+12, y, x+14, y+2, x+14, y+8, x+12, y+10, x+5, y+10, x, y+5, x+5, y ); break; case PE_ArrowRight: x+=2; clipRegion.setPoints(7, x+2, y, x, y+2, x, y+8, x+2, y+10, x+9, y+10, x+14, y+5, x+9, y); } } else clipRegion.setPoints(8, x, y+8+yo, x, y+4, x+4, y, x+8+xo, y, x+12+xo, y+4, x+12+xo, y+8+yo, x+8+xo, y+12+yo, x+4, y+12+yo); if(!tb) p->fillRect(QRect(x, y, r.width()-(horiz ? 0 : 2), r.height()-(horiz ? 2 : 0)), cg.background()); p->setClipRegion(QRegion(clipRegion)); // , QPainter::CoordPainter); if(IS_FLAT(opts.sliderAppearance)) { p->fillRect(r, fill); if(MO_PLASTIK==opts.coloredMouseOver && flags&Style_MouseOver && !opts.colorSliderMouseOver) { int col(SLIDER_MO_SHADE), len(SLIDER_MO_LEN); if(horiz) { p->fillRect(QRect(x+1, y+1, len, size-2), itsMouseOverCols[col]); p->fillRect(QRect(x+r.width()-(1+len), y+1, len, r.height()-2), itsMouseOverCols[col]); } else { p->fillRect(QRect(x+1, y+1, size-2, len), itsMouseOverCols[col]); p->fillRect(QRect(x+1, y+r.height()-(1+len), r.width()-2, len), itsMouseOverCols[col]); } } } else { drawBevelGradient(fill, p, QRect(x, y, horiz ? r.width()-1 : size, horiz ? size : r.height()-1), horiz, false, opts.sliderAppearance); if(MO_PLASTIK==opts.coloredMouseOver && flags&Style_MouseOver && !opts.colorSliderMouseOver) { int col(SLIDER_MO_SHADE), len(SLIDER_MO_LEN); if(horiz) { drawBevelGradient(itsMouseOverCols[col], p, QRect(x+1, y+1, len, size-2), horiz, false, opts.sliderAppearance); drawBevelGradient(itsMouseOverCols[col], p, QRect(x+r.width()-((SLIDER_ROUND_ROTATED==opts.sliderStyle ? 3 : 1)+len), y+1, len, size-2), horiz, false, opts.sliderAppearance); } else { drawBevelGradient(itsMouseOverCols[col], p, QRect(x+1, y+1, size-2, len), horiz, false, opts.sliderAppearance); drawBevelGradient(itsMouseOverCols[col], p, QRect(x+1, y+r.height()-((SLIDER_ROUND_ROTATED==opts.sliderStyle ? 3 : 1)+len), size-2, len), horiz, false, opts.sliderAppearance); } } } p->setClipping(false); if(SLIDER_TRIANGULAR==opts.sliderStyle) { QPointArray aa, light; switch(direction) { default: case PE_ArrowDown: aa.setPoints(8, x, y+1, x+1, y, x+9, y, x+10, y+1, x+10, y+10, x+6, y+14, x+4, y+14, x, y+10); light.setPoints(3, x+1, y+9, x+1, y+1, x+8, y+1); break; case PE_ArrowUp: aa.setPoints(8, x, y+13, x+1, y+14, x+9, y+14, x+10, y+13, x+10, y+4, x+6, y, x+4, y, x, y+4); light.setPoints(3, x+1, y+13, x+1, y+5, x+5, y+1); break; case PE_ArrowLeft: aa.setPoints(8, x+13, y, x+14, y+1, x+14, y+9, x+13, y+10, x+4, y+10, x, y+6, x, y+4, x+4, y); light.setPoints(3, x+1, y+5, x+5, y+1, x+13, y+1); break; case PE_ArrowRight: aa.setPoints(8, x+1, y, x, y+1, x, y+9, x+1, y+10, x+10, y+10, x+14, y+6, x+14, y+4, x+10, y); light.setPoints(3, x+1, y+8, x+1, y+1, x+9, y+1); } p->setPen(midColor(border[borderVal], cg.background())); p->drawPolygon(aa); if(drawLight) { p->setPen(use[APPEARANCE_DULL_GLASS==opts.sliderAppearance ? 1 : 0]); p->drawPolyline(light); } p->setPen(border[borderVal]); p->drawPolygon(clipRegion); } else { p->drawPixmap(x, y, *getPixmap(border[borderVal], horiz ? PIX_SLIDER : PIX_SLIDER_V, 0.8)); if(drawLight) p->drawPixmap(x, y, *getPixmap(use[0], horiz ? PIX_SLIDER_LIGHT : PIX_SLIDER_LIGHT_V)); } p->restore(); } else { QRect sr(r); if(!ROTATED_SLIDER) if(horiz) sr.addCoords(0, 1, 0, 0); else sr.addCoords(1, 0, 0, 0); drawSbSliderHandle(p, sr, cg, flags|(horiz ? Style_Horizontal : 0), true); } } void QtCurveStyle::drawSliderGroove(QPainter *p, const QRect &r, const QColorGroup &cg, SFlags flags, const QWidget *widget) const { const QSlider *sliderWidget((const QSlider *)widget); QRect groove(r); bool horiz(Qt::Horizontal==sliderWidget->orientation()), reverse(QApplication::reverseLayout()); flags&=~Style_MouseOver; if(horiz) { int dh=(groove.height()-5)>>1; groove.addCoords(0, dh, 0, -dh); flags|=Style_Horizontal; if(!itsFormMode && DO_EFFECT) groove.addCoords(0, -1, 0, 1); } else { int dw=(groove.width()-5)>>1; groove.addCoords(dw, 0, -dw, 0); if(!itsFormMode && DO_EFFECT) groove.addCoords(-1, 0, 1, 0); } drawLightBevel(p, groove, cg, flags, opts.square&SQUARE_SLIDER ? ROUNDED_NONE : ROUNDED_ALL, itsBackgroundCols[flags&Style_Enabled ? 2 : ORIGINAL_SHADE], itsBackgroundCols, true, true, WIDGET_SLIDER_TROUGH); if(opts.fillSlider && (horiz ? sliderWidget->value()>0 : sliderWidget->value()maxValue()) && sliderWidget->maxValue()!=sliderWidget->minValue() && flags&Style_Enabled) { QRect used(groove); int pos((int)(((double)(horiz ? groove.width() : groove.height()) / (sliderWidget->maxValue()-sliderWidget->minValue())) * (sliderWidget->value() - sliderWidget->minValue()))); if(pos>0) { const QColor *usedCols=itsSliderCols ? itsSliderCols : itsHighlightCols; if(horiz) { pos+=(groove.width()>10 && pos<(groove.width()/2)) ? 3 : 0; if(reverse) used.addCoords(groove.width()-pos, 0, 0, 0); else used.addCoords(0, 0, -(groove.width()-pos), 0); } else { pos+=(groove.height()>10 && pos<(groove.height()/2)) ? 3 : 0; used.addCoords(0, pos, 0, 0); } if(used.height()>0 && used.width()>0) drawLightBevel(p, used, cg, flags, opts.square&SQUARE_SLIDER ? ROUNDED_NONE : ROUNDED_ALL, usedCols[ORIGINAL_SHADE], usedCols, true, true, WIDGET_FILLED_SLIDER_TROUGH); } } } void QtCurveStyle::drawMenuOrToolBarBackground(QPainter *p, const QRect &r, const QColorGroup &cg, bool menu, bool horiz) const { if(menu && APPEARANCE_STRIPED==opts.bgndAppearance && IS_FLAT(opts.menubarAppearance) && SHADE_NONE==opts.shadeMenubars) return; QRect rx(r); EAppearance app(menu ? opts.menubarAppearance : opts.toolbarAppearance); QColor color(menu ? menuColors(cg, itsActive)[ORIGINAL_SHADE] : cg.background()); if(menu && BLEND_TITLEBAR) rx.addCoords(0, -qtcGetWindowBorderSize().titleHeight, 0, 0); drawBevelGradient(color, p, rx, horiz, false, app); } void QtCurveStyle::drawHandleMarkers(QPainter *p, const QRect &r, SFlags flags, bool tb, ELine handles) const { if(r.width()<2 || r.height()<2) return; // if(!(flags&Style_MouseOver) && p->device()==itsHoverWidget) // flags|=Style_MouseOver; flags&=~Style_MouseOver; // Dont mouse-over handles - we dont do this for KDE4... const QColor *border(borderColors(flags, itsBackgroundCols)); switch(handles) { case LINE_NONE: break; case LINE_1DOT: drawDot(p, r, border); break; case LINE_DOTS: drawDots(p, r, !(flags & Style_Horizontal), 2, APP_KICKER==itsThemedApp ? 1 : tb ? 5 : 3, border, APP_KICKER==itsThemedApp ? 1 : tb ? -2 : 0, 5); break; case LINE_DASHES: if(flags&Style_Horizontal) { QRect r1(r.x()+(tb ? 2 : (r.width()-6)/2), r.y(), 3, r.height()); drawLines(p, r1, true, (r.height()-8)/2, tb ? 0 : (r.width()-5)/2, border, 0, 5, handles); } else { QRect r1(r.x(), r.y()+(tb ? 2 : (r.height()-6)/2), r.width(), 3); drawLines(p, r1, false, (r.width()-8)/2, tb ? 0 : (r.height()-5)/2, border, 0, 5, handles); } break; case LINE_FLAT: drawLines(p, r, !(flags & Style_Horizontal), 2, APP_KICKER==itsThemedApp ? 1 : tb ? 4 : 2, border, APP_KICKER==itsThemedApp ? 1 : tb ? -2 : 0, 4, handles); break; default: drawLines(p, r, !(flags & Style_Horizontal), 2, APP_KICKER==itsThemedApp ? 1 : tb ? 4 : 2, border, APP_KICKER==itsThemedApp ? 1 : tb ? -2 : 0, 3, handles); } } void QtCurveStyle::drawHighlight(QPainter *p, const QRect &r, const QColorGroup &cg, bool horiz, bool inc) const { QColor col1(midColor(cg.background(), itsMouseOverCols[ORIGINAL_SHADE])); QRect r2(r); p->setPen(inc ? col1 : itsMouseOverCols[ORIGINAL_SHADE]); p->drawLine(r2.x(), r2.y(), r2.x()+(horiz ? r2.width()-1 : 0), r2.y()+(horiz ? 0 : r2.height()-1)); p->setPen(inc ? itsMouseOverCols[ORIGINAL_SHADE] : col1); r2.addCoords(horiz ? 0 : 1, horiz ? 1 : 0, horiz ? 0 : 1, horiz ? 1 : 0); p->drawLine(r2.x(), r2.y(), r2.x()+(horiz ? r2.width()-1 : 0), r2.y()+(horiz ? 0 : r2.height()-1)); } void QtCurveStyle::shadeColors(const QColor &base, QColor *vals) const { SHADES bool useCustom(USE_CUSTOM_SHADES(opts)); double hl=TO_FACTOR(opts.highlightFactor); for(int i=0; imaxPos ? (minPos==-1 ? 0 : minPos) : (maxPos==-1 ? 0 : maxPos)), SC_TitleBarShadeButton); } } } } #endif bool QtCurveStyle::redrawHoverWidget(const QPoint &pos) { if(!itsHoverWidget || !itsHoverWidget->isShown() || !itsHoverWidget->isVisible()) return false; #if QT_VERSION >= 0x030200 // // Qt>=3.2 sets the sensitive part of a check/radio to the image + label -> anything else // is not sensitive. But, the widget can ocupy a larger area - and this whole area will // react to mouse over. This needs to be counteracted so that it looks as if only the // sensitive area mouse-overs... QRadioButton *rb(::qt_cast(itsHoverWidget)); if(rb) { QRect rect(0, 0, visualRect(subRect(SR_RadioButtonFocusRect, rb), rb).width()+ pixelMetric(PM_ExclusiveIndicatorWidth)+4, itsHoverWidget->height()); itsHover=rect.contains(pos) ? HOVER_RADIO : HOVER_NONE; return (HOVER_NONE!=itsHover && !rect.contains(itsOldPos)) || (HOVER_NONE==itsHover && rect.contains(itsOldPos)); } else { QCheckBox *cb(::qt_cast(itsHoverWidget)); if(cb) { QRect rect(0, 0, visualRect(subRect(SR_CheckBoxFocusRect, cb), cb).width()+ pixelMetric(PM_IndicatorWidth)+4, itsHoverWidget->height()); itsHover=rect.contains(pos) ? HOVER_CHECK : HOVER_NONE; return (HOVER_NONE!=itsHover && !rect.contains(itsOldPos)) || (HOVER_NONE==itsHover && rect.contains(itsOldPos)); } else { #endif QScrollBar *sb(::qt_cast(itsHoverWidget)); if(sb) // So, are we over add button, sub button, slider, or none? { bool useThreeButtonScrollBar(SCROLLBAR_KDE==opts.scrollbarType); QRect subline(querySubControlMetrics(CC_ScrollBar, itsHoverWidget, SC_ScrollBarSubLine)), addline(querySubControlMetrics(CC_ScrollBar, itsHoverWidget, SC_ScrollBarAddLine)), slider(querySubControlMetrics(CC_ScrollBar, itsHoverWidget, SC_ScrollBarSlider)), subline2(addline); if (useThreeButtonScrollBar) if (Qt::Horizontal==sb->orientation()) subline2.moveBy(-addline.width(), 0); else subline2.moveBy(0, -addline.height()); if(slider.contains(pos)) itsHover=HOVER_SB_SLIDER; else if(subline.contains(pos)) itsHover=HOVER_SB_SUB; else if(addline.contains(pos)) itsHover=HOVER_SB_ADD; else if(subline2.contains(pos)) itsHover=HOVER_SB_SUB2; else itsHover=HOVER_NONE; return (HOVER_SB_SLIDER==itsHover && !slider.contains(itsOldPos)) || (HOVER_SB_SLIDER!=itsHover && slider.contains(itsOldPos)) || (HOVER_SB_SUB==itsHover && !subline.contains(itsOldPos)) || (HOVER_SB_SUB!=itsHover && subline.contains(itsOldPos)) || (useThreeButtonScrollBar && (HOVER_SB_SUB2==itsHover && !subline2.contains(itsOldPos)) || (HOVER_SB_SUB2!=itsHover && subline2.contains(itsOldPos))) || (HOVER_SB_ADD==itsHover && !addline.contains(itsOldPos)) || (HOVER_SB_ADD!=itsHover && addline.contains(itsOldPos)); } else { #if defined KDE_VERSION && KDE_VERSION >= 0x30400 && KDE_VERSION < 0x30500 QToolButton *tb(::qt_cast(itsHoverWidget)); if(tb) { itsHover=APP_KICKER==itsThemedApp ? HOVER_KICKER : HOVER_NONE; return HOVER_KICKER==itsHover; } else #endif { QHeader *hd(::qt_cast(itsHoverWidget)); if(hd) { // Hmm... this ones tricky, as there's only 1 widget - but it has different // sections... // and the ones that aren't clickable should not highlight on mouse over! QRect rect(0, 0, itsHoverWidget->width(), itsHoverWidget->height()); int s(0); bool redraw(false); itsHover=rect.contains(pos) ? HOVER_HEADER : HOVER_NONE; itsHoverSect=NO_SECT; for(s=0; scount() && (NO_SECT==itsHoverSect || !redraw); ++s) { QRect r(hd->sectionRect(s)); bool hasNew(r.contains(pos)); if(hasNew) itsHoverSect=s; if(!redraw) { bool hasOld(r.contains(itsOldPos)); if((hasNew && !hasOld) || (!hasNew && hasOld)) redraw=true; } } return redraw; } else { QSpinWidget *sw(::qt_cast(itsHoverWidget)); if(sw) // So, are we over up or down? { QRect up(querySubControlMetrics(CC_SpinWidget, itsHoverWidget, SC_SpinWidgetUp)), down(querySubControlMetrics(CC_SpinWidget, itsHoverWidget, SC_SpinWidgetDown)); if(up.contains(pos)) itsHover=HOVER_SW_UP; else if(down.contains(pos)) itsHover=HOVER_SW_DOWN; else itsHover=HOVER_SW_ENTRY; return (HOVER_SW_UP==itsHover && !up.contains(itsOldPos)) || (HOVER_SW_UP!=itsHover && up.contains(itsOldPos)) || (HOVER_SW_DOWN==itsHover && !down.contains(itsOldPos)) || (HOVER_SW_DOWN!=itsHover && down.contains(itsOldPos)) || (HOVER_SW_ENTRY==itsHover); } else { QTabBar *tabbar(::qt_cast(itsHoverWidget)); if(tabbar) { bool redraw(false); QTab *tab(tabbar->selectTab(pos)); int tabIndex(tab ? tabbar->indexOf(tab->identifier()) : -1), selectedTab(tabbar->currentTab()); redraw=tab!=itsHoverTab && tabIndex!=selectedTab; itsHoverTab=tab; return redraw; } else { QComboBox *cb(::qt_cast(itsHoverWidget)); if(cb) { QRect arrow(cb->rect()); if(!cb->editable()) itsHover=HOVER_CB_ARROW; else { arrow=(querySubControlMetrics(CC_ComboBox, itsHoverWidget, SC_ComboBoxArrow)); if(arrow.contains(pos)) itsHover=HOVER_CB_ARROW; else { QRect r(cb->rect()); if(QApplication::reverseLayout()) r.addCoords(6, 0, 0, 0); else r.addCoords(0, 0, -6, 0); if(DO_EFFECT && opts.etchEntry) r.addCoords(1, 0, -1, 0); if(r.contains(pos)) itsHover=HOVER_CB_ENTRY; else itsHover=HOVER_NONE; } } return (HOVER_CB_ARROW==itsHover && !arrow.contains(itsOldPos)) || (HOVER_CB_ARROW!=itsHover && arrow.contains(itsOldPos)) || (HOVER_CB_ENTRY==itsHover); } else return itsOldPos==QPoint(-1, -1); } } } } } #if QT_VERSION >= 0x030200 } } #endif return false; } const QColor & QtCurveStyle::getFill(SFlags flags, const QColor *use, bool cr, bool darker) const { return !(flags&Style_Enabled) ? use[darker ? 2 : ORIGINAL_SHADE] : flags&Style_Down ? use[darker ? 5 : 4] : flags&Style_MouseOver ? !cr && (flags&(Style_On | Style_Sunken)) ? use[darker ? 3 : SHADE_4_HIGHLIGHT] : use[darker ? SHADE_2_HIGHLIGHT : SHADE_ORIG_HIGHLIGHT] : !cr && (flags&(Style_On | Style_Sunken)) ? use[darker ? 5 : 4] : use[darker ? 2 : ORIGINAL_SHADE]; } const QColor & QtCurveStyle::getTabFill(bool current, bool highlight, const QColor *use) const { return current ? use[ORIGINAL_SHADE] : highlight ? use[SHADE_2_HIGHLIGHT] : use[2]; } const QColor & QtCurveStyle::menuStripeCol() const { switch(opts.menuStripe) { default: case SHADE_NONE: return itsBackgroundCols[ORIGINAL_SHADE]; case SHADE_CUSTOM: return opts.customMenuStripeColor; case SHADE_BLEND_SELECTED: // Hack! Use opts.customMenuStripeColor to store this setting! if(IS_BLACK(opts.customMenuStripeColor)) opts.customMenuStripeColor=midColor(itsHighlightCols[ORIGINAL_SHADE], opts.lighterPopupMenuBgnd<0 ? itsLighterPopupMenuBgndCol : itsBackgroundCols[ORIGINAL_SHADE]); return opts.customMenuStripeColor; case SHADE_SELECTED: return itsHighlightCols[MENU_STRIPE_SHADE]; case SHADE_DARKEN: return USE_LIGHTER_POPUP_MENU ? itsLighterPopupMenuBgndCol : itsBackgroundCols[MENU_STRIPE_SHADE]; } } const QColor & QtCurveStyle::checkRadioCol(SFlags flags, const QColorGroup &cg) const { if(flags&MENU_ITEM) return flags&Style_Enabled && flags&Style_Active && opts.useHighlightForMenu ? cg.highlightedText() : cg.foreground(); return flags&Style_Enabled ? itsCheckRadioCol : opts.crButton ? cg.buttonText() : cg.text(); } QColor QtCurveStyle::shade(const QColor &a, float k) const { QColor mod; ::shade(&opts, a, &mod, k); return mod; } void QtCurveStyle::shade(const color &ca, color *cb, double k) const { ::shade(&opts, ca, cb, k); } QPixmap * QtCurveStyle::getPixelPixmap(const QColor col) const { QRgb rgb(col.rgb()); QString key(createKey(rgb)); QPixmap *pix=itsPixmapCache.find(key); if(!pix) { static const int constAlpha=110; QImage img(1, 1, 32); img.setAlphaBuffer(true); img.setPixel(0, 0, qRgba(qRed(rgb), qGreen(rgb), qBlue(rgb), constAlpha)); pix=new QPixmap(img); itsPixmapCache.insert(key, pix, pix->depth()/8); } return pix; } QPixmap * QtCurveStyle::createStripePixmap(const QColor &col, bool forWindow) const { QRgb rgb(col.rgb()); QString key(createKey(rgb, forWindow ? 'S' : 's')); QPixmap *pix=itsPixmapCache.find(key); if(!pix) { QColor col2(shade(col, BGND_STRIPE_SHADE)); int i, adjust=forWindow ? qtcGetWindowBorderSize().titleHeight%4 : 0; pix=new QPixmap(64, 64); pix->fill(col.rgb()); QPainter p; p.begin(pix); p.setPen(QColor((3*col.red()+col2.red())/4, (3*col.green()+col2.green())/4, (3*col.blue()+col2.blue())/4)); for (i=1; i<68; i+=4) { p.drawLine(0, i-adjust, 63, i-adjust); p.drawLine(0, i+2-adjust, 63, i+2-adjust); } p.setPen(col2); for (i=2; i<67; i+=4) p.drawLine(0, i-adjust, 63, i-adjust); p.end(); } return pix; } static QImage rotateImage(const QImage &img, double angle=90.0) { QWMatrix matrix; matrix.translate(img.width()/2, img.height()/2); matrix.rotate(angle); QRect newRect(matrix.mapRect(QRect(0, 0, img.width(), img.height()))); return img.xForm(QWMatrix(matrix.m11(), matrix.m12(), matrix.m21(), matrix.m22(), matrix.dx() - newRect.left(), matrix.dy() - newRect.top())); } static void recolour(QImage &img, const QColor &col, double shade) { if (img.depth()<32) img=img.convertDepth(32); adjustPix(img.bits(), 4, img.width(), img.height(), img.bytesPerLine(), col.red(), col.green(), col.blue(), shade); } void QtCurveStyle::drawDot(QPainter *p, const QRect &r, const QColor *cols) const { QPixmap *pix=getPixmap(cols[STD_BORDER], PIX_DOT, 0.9); p->drawPixmap(r.x()+((r.width()-pix->width())>>1), r.y()+((r.height()-pix->height())>>1), *pix); } QPixmap * QtCurveStyle::getPixmap(const QColor col, EPixmap p, double shade) const { QRgb rgb(col.rgb()); QString key(createKey(rgb, p)); QPixmap *pix=itsPixmapCache.find(key); if(!pix) { pix=new QPixmap(); QImage img; switch(p) { case PIX_RADIO_BORDER: img.loadFromData(qembed_findData("radio_frame.png")); break; case PIX_RADIO_INNER: img.loadFromData(qembed_findData("radio_inner.png")); break; case PIX_RADIO_LIGHT: img.loadFromData(qembed_findData("radio_light.png")); break; case PIX_RADIO_ON: img.loadFromData(qembed_findData(opts.smallRadio ? "radio_on_small.png" : "radio_on.png")); break; case PIX_CHECK: img.loadFromData(qembed_findData(opts.xCheck ? "check_x_on.png" : "check_on.png")); break; case PIX_SLIDER: img.loadFromData(qembed_findData("slider.png")); break; case PIX_SLIDER_LIGHT: img.loadFromData(qembed_findData("slider_light.png")); break; case PIX_SLIDER_V: img.loadFromData(qembed_findData("slider.png")); img=rotateImage(img); break; case PIX_SLIDER_LIGHT_V: img.loadFromData(qembed_findData("slider_light.png")); img=rotateImage(img).mirror(true, false); break; case PIX_DOT: img.loadFromData(qembed_findData("dot.png")); break; default: break; } if (img.depth()<32) img=img.convertDepth(32); adjustPix(img.bits(), 4, img.width(), img.height(), img.bytesPerLine(), col.red(), col.green(), col.blue(), shade); pix->convertFromImage(img); itsPixmapCache.insert(key, pix, pix->depth()/8); } return pix; } void QtCurveStyle::setSbType() { switch(opts.scrollbarType) { case SCROLLBAR_KDE: this->setScrollBarType(BASE_STYLE::ThreeButtonScrollBar); break; default: case SCROLLBAR_WINDOWS: this->setScrollBarType(BASE_STYLE::WindowsStyleScrollBar); break; case SCROLLBAR_PLATINUM: this->setScrollBarType(BASE_STYLE::PlatinumStyleScrollBar); break; case SCROLLBAR_NEXT: this->setScrollBarType(BASE_STYLE::NextStyleScrollBar); break; } } void QtCurveStyle::resetHover() { itsIsSpecialHover=false; itsOldPos.setX(-1); itsOldPos.setY(-1); itsHoverWidget=0L; itsHoverSect=NO_SECT; itsHover=HOVER_NONE; itsHoverTab=0L; } struct QtcMenuBar : public QMenuBar { bool itemUnderPos(const QPoint &pos) { return -1!=itemAtPos(pos); } }; bool QtCurveStyle::isWindowDragWidget(QObject *o, const QPoint &pos) { return opts.windowDrag && (//qobject_cast(o) || (::qt_cast(o) && (pos.isNull() || !((QtcMenuBar *)o)->itemUnderPos(pos))) //|| qobject_cast(o) //|| (o->inherits("QToolButton") && !static_cast(o)->isEnabled()) // || qobject_cast(o) //|| qobject_cast(o) // || ((*appType == Hacks::SMPlayer) && o->inherits(SMPlayerVideoWidget)) // || ((*appType == Hacks::Dragon) && o->inherits(DragonVideoWidget)) // || o->inherits("QStatusBar") // || (o->inherits("QLabel") && o->parent() && o->parent()->inherits("QStatusBar")) ); } void QtCurveStyle::updateProgressPos() { // Taken from lipstik! QMap::iterator it(itsProgAnimWidgets.begin()), end(itsProgAnimWidgets.end()); bool visible(false); for (; it!=end; ++it) { QProgressBar *pb(::qt_cast(it.key())); if (!pb) continue; if(pb->isEnabled() && pb->progress()!=pb->totalSteps()) { // update animation Offset of the current Widget it.data() = (it.data() + (QApplication::reverseLayout() ? -1 : 1)) % (PROGRESS_CHUNK_WIDTH*2); pb->update(); } if(pb->isVisible()) visible = true; } if (!visible) itsAnimationTimer->stop(); } void QtCurveStyle::progressBarDestroyed(QObject *bar) { itsProgAnimWidgets.remove(static_cast(bar)); } void QtCurveStyle::sliderThumbMoved(int) { QSlider *slider(::qt_cast(sender())); if(slider) slider->update(); } void QtCurveStyle::khtmlWidgetDestroyed(QObject *o) { itsKhtmlWidgets.remove(static_cast(o)); } void QtCurveStyle::hoverWidgetDestroyed(QObject *o) { if(o==itsHoverWidget) resetHover(); } #include "qtcurve.moc"