diff options
author | Darrell Anderson <[email protected]> | 2013-08-18 10:14:48 -0500 |
---|---|---|
committer | Darrell Anderson <[email protected]> | 2013-08-18 10:14:48 -0500 |
commit | dad42352f4ad47d34caf50040367dc2a95772baa (patch) | |
tree | 6d2887d13f9b1403b8ce15be48a6ea7cec32fd96 /kstyles/plastik/plastik.cpp | |
parent | 365f03061337a81bcffb4a45c4ad637edad27019 (diff) | |
download | tdelibs-dad42352f4ad47d34caf50040367dc2a95772baa.tar.gz tdelibs-dad42352f4ad47d34caf50040367dc2a95772baa.zip |
Rename KStyle to TDEStyle to avoid conflicts with KDE4.
Diffstat (limited to 'kstyles/plastik/plastik.cpp')
-rw-r--r-- | kstyles/plastik/plastik.cpp | 3593 |
1 files changed, 0 insertions, 3593 deletions
diff --git a/kstyles/plastik/plastik.cpp b/kstyles/plastik/plastik.cpp deleted file mode 100644 index e7b6acd7f..000000000 --- a/kstyles/plastik/plastik.cpp +++ /dev/null @@ -1,3593 +0,0 @@ -/* Plastik widget style for KDE 3 - Copyright (C) 2003 Sandro Giessl <[email protected]> - - based on the KDE style "dotNET": - - Copyright (C) 2001-2002, Chris Lee <[email protected]> - Carsten Pfeiffer <[email protected]> - Karol Szwed <[email protected]> - Drawing routines completely reimplemented from KDE3 HighColor, which was - originally based on some stuff from the KDE2 HighColor. - - based on drawing routines of the style "Keramik": - - Copyright (c) 2002 Malte Starostik <[email protected]> - (c) 2002,2003 Maksim Orlovich <[email protected]> - based on the KDE3 HighColor Style - Copyright (C) 2001-2002 Karol Szwed <[email protected]> - (C) 2001-2002 Fredrik H�glund <[email protected]> - Drawing routines adapted from the KDE2 HCStyle, - Copyright (C) 2000 Daniel M. Duley <[email protected]> - (C) 2000 Dirk Mueller <[email protected]> - (C) 2001 Martijn Klingens <[email protected]> - Progressbar code based on TDEStyle, - Copyright (C) 2001-2002 Karol Szwed <[email protected]> - - This library is free software; you can redistribute it and/or - modify it under the terms of the GNU Library General Public - License version 2 as published by the Free Software Foundation. - - This library 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 - Library General Public License for more details. - - You should have received a copy of the GNU Library General Public License - along with this library; see the file COPYING.LIB. If not, write to - the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, - Boston, MA 02110-1301, USA. - */ - -#include <tqimage.h> -#include <tqstylefactory.h> -#include <tqpointarray.h> -#include <tqpainter.h> -#include <tqtabbar.h> -#include <tqprogressbar.h> -#include <tqcheckbox.h> -#include <tqcombobox.h> -#include <tqcleanuphandler.h> -#include <tqheader.h> -#include <tqlineedit.h> -#include <tqlistbox.h> -#include <tqscrollbar.h> -#include <tqstyleplugin.h> -#include <tqpushbutton.h> -#include <tqtabwidget.h> -#include <tqtimer.h> -#include <tqtoolbutton.h> -#include <tqtoolbar.h> -#include <tqmenubar.h> -#include <tqpopupmenu.h> -#include <tqdrawutil.h> -#include <tqapplication.h> -#include <tqvariant.h> -#include <tqradiobutton.h> -#include <tqregion.h> -#include <tqslider.h> -#include <tqsettings.h> -#include <kpixmap.h> - -#include "plastik.h" -#include "plastik.moc" -#include "misc.h" - -// some bitmaps for the radio button so it's easier to handle the circle stuff... -// 13x13 -static const unsigned char radiobutton_mask_bits[] = { - 0xf8, 0x03, 0xfc, 0x07, 0xfe, 0x0f, 0xff, 0x1f, 0xff, 0x1f, 0xff, 0x1f, - 0xff, 0x1f, 0xff, 0x1f, 0xff, 0x1f, 0xff, 0x1f, 0xfe, 0x0f, 0xfc, 0x07, - 0xf8, 0x03}; -static const unsigned char radiobutton_contour_bits[] = { - 0xf0, 0x01, 0x0c, 0x06, 0x02, 0x08, 0x02, 0x08, 0x01, 0x10, 0x01, 0x10, - 0x01, 0x10, 0x01, 0x10, 0x01, 0x10, 0x02, 0x08, 0x02, 0x08, 0x0c, 0x06, - 0xf0, 0x01}; -static const unsigned char radiobutton_aa_inside_bits[] = { - 0x00, 0x00, 0x10, 0x01, 0x04, 0x04, 0x00, 0x00, 0x02, 0x08, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x02, 0x08, 0x00, 0x00, 0x04, 0x04, 0x10, 0x01, - 0x00, 0x00}; -static const unsigned char radiobutton_aa_outside_bits[] = { - 0x08, 0x02, 0x00, 0x00, 0x00, 0x00, 0x01, 0x10, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x10, 0x00, 0x00, 0x00, 0x00, - 0x08, 0x02}; -static const unsigned char radiobutton_highlight1_bits[] = { - 0x00, 0x00, 0xf0, 0x01, 0x1c, 0x07, 0x04, 0x04, 0x06, 0x0c, 0x02, 0x08, - 0x02, 0x08, 0x02, 0x08, 0x06, 0x0c, 0x04, 0x04, 0x1c, 0x07, 0xf0, 0x01, - 0x00, 0x00}; -static const unsigned char radiobutton_highlight2_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0xe0, 0x00, 0x18, 0x03, 0x08, 0x02, 0x04, 0x04, - 0x04, 0x04, 0x04, 0x04, 0x08, 0x02, 0x18, 0x03, 0xe0, 0x00, 0x00, 0x00, - 0x00, 0x00}; -// check mark -const uint CHECKMARKSIZE = 9; // 9x9 -static const unsigned char checkmark_aa_bits[] = { - 0x45, 0x01, 0x28, 0x00, 0x11, 0x01, 0x82, 0x00, 0x44, 0x00, 0x82, 0x00, - 0x11, 0x01, 0x28, 0x00, 0x45, 0x01}; -static const unsigned char checkmark_dark_bits[] = { - 0x82, 0x00, 0x45, 0x01, 0xaa, 0x00, 0x54, 0x00, 0x28, 0x00, 0x74, 0x00, - 0xea, 0x00, 0xc5, 0x01, 0x82, 0x00}; -static const unsigned char checkmark_light_bits[] = { - 0x00, 0xfe, 0x82, 0xfe, 0x44, 0xfe, 0x28, 0xfe, 0x10, 0xfe, 0x08, 0xfe, - 0x04, 0xfe, 0x02, 0xfe, 0x00, 0xfe}; -static const unsigned char checkmark_tristate_bits[] = { - 0x00, 0x00, 0xff, 0x01, 0x00, 0x00, 0xff, 0x01, 0x00, 0x00, 0xff, 0x01, - 0x00, 0x00, 0xff, 0x01, 0x00, 0x00}; -// radio mark -const uint RADIOMARKSIZE = 9; // 9x9 -static const unsigned char radiomark_aa_bits[] = { - 0x00, 0x00, 0x44, 0x00, 0x82, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x82, 0x00, 0x44, 0x00, 0x00, 0x00}; -static const unsigned char radiomark_dark_bits[] = { - 0x00, 0x00, 0x38, 0x00, 0x44, 0x00, 0xf2, 0x00, 0xfa, 0x00, 0xfa, 0x00, - 0x7c, 0x00, 0x38, 0x00, 0x00, 0x00}; -static const unsigned char radiomark_light_bits[] = { - 0x00, 0x00, 0x00, 0x00, 0x38, 0x00, 0x0c, 0x00, 0x04, 0x00, 0x04, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; - -// popupmenu item constants... -static const int itemHMargin = 6; -static const int itemFrame = 2; -static const int arrowHMargin = 6; -static const int rightBorder = 12; - -// -- Style Plugin Interface ------------------------- -class PlastikStylePlugin : public TQStylePlugin -{ - public: - PlastikStylePlugin() {} - ~PlastikStylePlugin() {} - - TQStringList keys() const { - return TQStringList() << "Plastik"; - } - - TQStyle* create( const TQString& key ) { - if (key.lower() == "plastik") - return new PlastikStyle; - return 0; - } -}; - -KDE_Q_EXPORT_PLUGIN( PlastikStylePlugin ) -// -- end -- - -PlastikStyle::PlastikStyle() : TDEStyle( AllowMenuTransparency, ThreeButtonScrollBar), - kickerMode(false), - kornMode(false), - flatMode(false) -{ - horizontalLine = 0; - verticalLine = 0; - - TQSettings settings; - _contrast = settings.readNumEntry("/Qt/KDE/contrast", 6); - settings.beginGroup("/plastikstyle/Settings"); - _scrollBarLines = settings.readBoolEntry("/scrollBarLines", false); - _animateProgressBar = settings.readBoolEntry("/animateProgressBar", false); - _drawToolBarSeparator = settings.readBoolEntry("/drawToolBarSeparator", false); - _drawToolBarItemSeparator = settings.readBoolEntry("/drawToolBarItemSeparator", true); - _drawFocusRect = settings.readBoolEntry("/drawFocusRect", true); - _drawTriangularExpander = settings.readBoolEntry("/drawTriangularExpander", false); - _inputFocusHighlight = settings.readBoolEntry("/inputFocusHighlight", true); - _customOverHighlightColor = settings.readBoolEntry("/customOverHighlightColor", false); - _overHighlightColor.setNamedColor( settings.readEntry("/overHighlightColor", "black") ); - _customFocusHighlightColor = settings.readBoolEntry("/customFocusHighlightColor", false); - _focusHighlightColor.setNamedColor( settings.readEntry("/focusHighlightColor", "black") ); - _customCheckMarkColor = settings.readBoolEntry("/customCheckMarkColor", false); - _checkMarkColor.setNamedColor( settings.readEntry("/checkMarkColor", "black") ); - settings.endGroup(); - - // setup pixmap cache... - pixmapCache = new TQIntCache<CacheEntry>(150000, 499); - pixmapCache->setAutoDelete(true); - - if ( _animateProgressBar ) - { - animationTimer = new TQTimer( this ); - connect( animationTimer, TQT_SIGNAL(timeout()), this, TQT_SLOT(updateProgressPos()) ); - } -} - - -void PlastikStyle::updateProgressPos() -{ - TQProgressBar* pb; - //Update the registered progressbars. - TQMap<TQWidget*, int>::iterator iter; - bool visible = false; - for (iter = progAnimWidgets.begin(); iter != progAnimWidgets.end(); ++iter) - { - if ( !::tqqt_cast<TQProgressBar*>(iter.key()) ) - continue; - - pb = dynamic_cast<TQProgressBar*>(iter.key()); - if ( iter.key() -> isEnabled() && - pb -> progress() != pb->totalSteps() ) - { - // update animation Offset of the current Widget - iter.data() = (iter.data() + 1) % 20; - iter.key()->update(); - } - if (iter.key()->isVisible()) - visible = true; - } - if (!visible) - animationTimer->stop(); -} - - -PlastikStyle::~PlastikStyle() -{ - delete pixmapCache; - delete horizontalLine; - delete verticalLine; -} - -void PlastikStyle::applicationPolish(const TQStyleControlElementData &ceData, ControlElementFlags, void *ptr) -{ - if (ceData.widgetObjectTypes.contains(TQAPPLICATION_OBJECT_NAME_STRING)) { - TQApplication *app = reinterpret_cast<TQApplication*>(ptr); - - if (!qstrcmp(app->argv()[0], "kicker")) - kickerMode = true; - else if (!qstrcmp(app->argv()[0], "korn")) - kornMode = true; - } -} - -void PlastikStyle::polish(const TQStyleControlElementData &ceData, ControlElementFlags elementFlags, void *ptr) -{ - if (ceData.widgetObjectTypes.contains(TQWIDGET_OBJECT_NAME_STRING)) { - TQWidget *widget = reinterpret_cast<TQWidget*>(ptr); - - if( !strcmp(widget->name(), "__tdehtml") ) { // is it a tdehtml widget...? - tdehtmlWidgets[widget] = true; - connect(widget, TQT_SIGNAL(destroyed(TQObject*)), this, TQT_SLOT(tdehtmlWidgetDestroyed(TQObject*))); - } - - // use tqqt_cast where possible to check if the widget inheits one of the classes. might improve - // performance compared to TQObject::inherits() - if ( ::tqqt_cast<TQPushButton*>(widget) || ::tqqt_cast<TQComboBox*>(widget) || - ::tqqt_cast<TQSpinWidget*>(widget) || ::tqqt_cast<TQSlider*>(widget) || - ::tqqt_cast<TQCheckBox*>(widget) || ::tqqt_cast<TQRadioButton*>(widget) || - ::tqqt_cast<TQToolButton*>(widget) || widget->inherits(TQSPLITTERHANDLE_OBJECT_NAME_STRING) ) - { - // widget->setBackgroundMode(PaletteBackground); - installObjectEventHandler(ceData, elementFlags, ptr, this); - } else if (::tqqt_cast<TQLineEdit*>(widget)) { - installObjectEventHandler(ceData, elementFlags, ptr, this); - } else if (::tqqt_cast<TQTabBar*>(widget)) { - widget->setMouseTracking(true); - installObjectEventHandler(ceData, elementFlags, ptr, this); - } else if (::tqqt_cast<TQPopupMenu*>(widget)) { - widget->setBackgroundMode( NoBackground ); - } else if ( !qstrcmp(widget->name(), "kde toolbar widget") ) { - installObjectEventHandler(ceData, elementFlags, ptr, this); - } - - if( _animateProgressBar && ::tqqt_cast<TQProgressBar*>(widget) ) - { - installObjectEventHandler(ceData, elementFlags, ptr, this); - progAnimWidgets[widget] = 0; - connect(widget, TQT_SIGNAL(destroyed(TQObject*)), this, TQT_SLOT(progressBarDestroyed(TQObject*))); - if (!animationTimer->isActive()) - animationTimer->start( 50, false ); - } - } - - TDEStyle::polish(ceData, elementFlags, ptr); -} - -void PlastikStyle::unPolish(const TQStyleControlElementData &ceData, ControlElementFlags elementFlags, void *ptr) -{ - if (ceData.widgetObjectTypes.contains(TQWIDGET_OBJECT_NAME_STRING)) { - TQWidget *widget = reinterpret_cast<TQWidget*>(ptr); - - if( !strcmp(widget->name(), "__tdehtml") ) { // is it a tdehtml widget...? - tdehtmlWidgets.remove(widget); - } - - // use tqqt_cast to check if the widget inheits one of the classes. - if ( ::tqqt_cast<TQPushButton*>(widget) || ::tqqt_cast<TQComboBox*>(widget) || - ::tqqt_cast<TQSpinWidget*>(widget) || ::tqqt_cast<TQSlider*>(widget) || - ::tqqt_cast<TQCheckBox*>(widget) || ::tqqt_cast<TQRadioButton*>(widget) || - ::tqqt_cast<TQToolButton*>(widget) || ::tqqt_cast<TQLineEdit*>(widget) || - widget->inherits(TQSPLITTERHANDLE_OBJECT_NAME_STRING) ) - { - removeObjectEventHandler(ceData, elementFlags, ptr, this); - } - else if (::tqqt_cast<TQTabBar*>(widget)) { - widget->setMouseTracking(false); - removeObjectEventHandler(ceData, elementFlags, ptr, this); - } else if (::tqqt_cast<TQPopupMenu*>(widget)) { - widget->setBackgroundMode( PaletteBackground ); - } else if ( !qstrcmp(widget->name(), "kde toolbar widget") ) { - removeObjectEventHandler(ceData, elementFlags, ptr, this); - } - - if ( ::tqqt_cast<TQProgressBar*>(widget) ) - { - progAnimWidgets.remove(widget); - } - } - - TDEStyle::unPolish(ceData, elementFlags, ptr); -} - -void PlastikStyle::tdehtmlWidgetDestroyed(TQObject* obj) -{ - tdehtmlWidgets.remove(TQT_TQWIDGET(obj)); -} - -void PlastikStyle::progressBarDestroyed(TQObject* obj) -{ - progAnimWidgets.remove(TQT_TQWIDGET(obj)); -} - -void PlastikStyle::renderContour(TQPainter *p, - const TQRect &r, - const TQColor &backgroundColor, - const TQColor &contour, - const uint flags) const -{ - if((r.width() <= 0)||(r.height() <= 0)) - return; - - const bool drawLeft = flags&Draw_Left; - const bool drawRight = flags&Draw_Right; - const bool drawTop = flags&Draw_Top; - const bool drawBottom = flags&Draw_Bottom; - const bool disabled = flags&Is_Disabled; - const bool alphaBlend = flags&Draw_AlphaBlend; - - TQColor contourColor; - if (disabled) { - contourColor = backgroundColor.dark(150); - } else { - contourColor = contour; - } - -// sides - p->setPen( alphaBlendColors(backgroundColor, contourColor, 50) ); - if(drawLeft) - p->drawLine(r.left(), drawTop?r.top()+2:r.top(), r.left(), drawBottom?r.bottom()-2:r.bottom()); - if(drawRight) - p->drawLine(r.right(), drawTop?r.top()+2:r.top(), r.right(), drawBottom?r.bottom()-2:r.bottom()); - if(drawTop) - p->drawLine(drawLeft?r.left()+2:r.left(), r.top(), drawRight?r.right()-2:r.right(), r.top()); - if(drawBottom) - p->drawLine(drawLeft?r.left()+2:r.left(), r.bottom(), drawRight?r.right()-2:r.right(), r.bottom()); - -// edges - const int alphaAA = 110; // the alpha value for anti-aliasing... - - // first part... - p->setPen(alphaBlendColors(backgroundColor, contourColor, 50) ); - if(drawLeft && drawTop) { - switch(flags&Round_UpperLeft) { - case false: - p->drawPoint(r.left()+1, r.top()); - p->drawPoint(r.left(), r.top()+1); - break; - default: - p->drawPoint(r.left()+1, r.top()+1); - } - } - if(drawLeft && drawBottom) { - switch(flags&Round_BottomLeft) { - case false: - p->drawPoint(r.left()+1, r.bottom()); - p->drawPoint(r.left(), r.bottom()-1); - break; - default: - p->drawPoint(r.left()+1, r.bottom()-1); - } - } - if(drawRight && drawTop) { - switch(flags&Round_UpperRight) { - case false: - p->drawPoint(r.right()-1, r.top()); - p->drawPoint(r.right(), r.top()+1); - break; - default: - p->drawPoint(r.right()-1, r.top()+1); - } - } - if(drawRight && drawBottom) { - switch(flags&Round_BottomRight) { - case false: - p->drawPoint(r.right()-1, r.bottom()); - p->drawPoint(r.right(), r.bottom()-1); - break; - default: - p->drawPoint(r.right()-1, r.bottom()-1); - } - } - - // second part... fill edges in case we don't paint alpha-blended - p->setPen( backgroundColor ); - if (!alphaBlend) { - if(flags&Round_UpperLeft && drawLeft && drawTop) { - p->drawPoint( r.x(), r.y() ); - } - if(flags&Round_BottomLeft && drawLeft && drawBottom) { - p->drawPoint( r.x(), r.bottom() ); - } - if(flags&Round_UpperRight && drawRight && drawTop) { - p->drawPoint( r.right(), r.y() ); - } - if(flags&Round_BottomRight && drawRight && drawBottom) { - p->drawPoint( r.right(), r.bottom() ); - } - } - - // third part... anti-aliasing... - if(drawLeft && drawTop) { - switch(flags&Round_UpperLeft) { - case false: - renderPixel(p,TQPoint(r.left(),r.top()),alphaAA,contourColor,backgroundColor,alphaBlend); - break; - default: - renderPixel(p,TQPoint(r.left()+1,r.top()),alphaAA,contourColor,backgroundColor,alphaBlend); - renderPixel(p,TQPoint(r.left(),r.top()+1),alphaAA,contourColor,backgroundColor,alphaBlend); - } - } - if(drawLeft && drawBottom) { - switch(flags&Round_BottomLeft) { - case false: - renderPixel(p,TQPoint(r.left(),r.bottom()),alphaAA,contourColor,backgroundColor,alphaBlend); - break; - default: - renderPixel(p,TQPoint(r.left()+1,r.bottom()),alphaAA,contourColor,backgroundColor,alphaBlend); - renderPixel(p,TQPoint(r.left(),r.bottom()-1),alphaAA,contourColor,backgroundColor,alphaBlend); - } - } - if(drawRight && drawTop) { - switch(flags&Round_UpperRight) { - case false: - renderPixel(p,TQPoint(r.right(),r.top()),alphaAA,contourColor,backgroundColor,alphaBlend); - break; - default: - renderPixel(p,TQPoint(r.right()-1,r.top()),alphaAA,contourColor,backgroundColor,alphaBlend); - renderPixel(p,TQPoint(r.right(),r.top()+1),alphaAA,contourColor,backgroundColor,alphaBlend); - } - } - if(drawRight && drawBottom) { - switch(flags&Round_BottomRight) { - case false: - renderPixel(p,TQPoint(r.right(),r.bottom()),alphaAA,contourColor,backgroundColor,alphaBlend); - break; - default: - renderPixel(p,TQPoint(r.right()-1,r.bottom()),alphaAA,contourColor,backgroundColor,alphaBlend); - renderPixel(p,TQPoint(r.right(),r.bottom()-1),alphaAA,contourColor,backgroundColor,alphaBlend); - } - } - -} - -void PlastikStyle::renderMask(TQPainter *p, - const TQRect &r, - const TQColor &color, - const uint flags) const -{ - if((r.width() <= 0)||(r.height() <= 0)) - return; - - const bool roundUpperLeft = flags&Round_UpperLeft; - const bool roundUpperRight = flags&Round_UpperRight; - const bool roundBottomLeft = flags&Round_BottomLeft; - const bool roundBottomRight = flags&Round_BottomRight; - - - p->fillRect (TQRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2) , color); - - p->setPen(color); - // sides - p->drawLine(roundUpperLeft?r.x()+1:r.x(), r.y(), - roundUpperRight?r.right()-1:r.right(), r.y() ); - p->drawLine(roundBottomLeft?r.x()+1:r.x(), r.bottom(), - roundBottomRight?r.right()-1:r.right(), r.bottom() ); - p->drawLine(r.x(), roundUpperLeft?r.y()+1:r.y(), - r.x(), roundBottomLeft?r.bottom()-1:r.bottom() ); - p->drawLine(r.right(), roundUpperLeft?r.y()+1:r.y(), - r.right(), roundBottomLeft?r.bottom()-1:r.bottom() ); -} - -void PlastikStyle::renderSurface(TQPainter *p, - const TQRect &r, - const TQColor &backgroundColor, - const TQColor &buttonColor, - const TQColor &highlightColor, - int intensity, - const uint flags) const -{ - if((r.width() <= 0)||(r.height() <= 0)) - return; - - const bool disabled = flags&Is_Disabled; - - const bool drawLeft = flags&Draw_Left; - const bool drawRight = flags&Draw_Right; - const bool drawTop = flags&Draw_Top; - const bool drawBottom = flags&Draw_Bottom; - const bool roundUpperLeft = flags&Round_UpperLeft; - const bool roundUpperRight = flags&Round_UpperRight; - const bool roundBottomLeft = flags&Round_BottomLeft; - const bool roundBottomRight = flags&Round_BottomRight; - const bool sunken = flags&Is_Sunken; - const bool horizontal = flags&Is_Horizontal; - bool highlight = false, - highlightLeft = false, - highlightRight = false, - highlightTop = false, - highlightBottom = false; - // only highlight if not sunken & not disabled... - if(!sunken && !disabled) { - highlight = (flags&Is_Highlight); - highlightLeft = (flags&Highlight_Left); - highlightRight = (flags&Highlight_Right); - highlightTop = (flags&Highlight_Top); - highlightBottom = (flags&Highlight_Bottom); - } - - TQColor baseColor = alphaBlendColors(backgroundColor, disabled?backgroundColor:buttonColor, 10); - if (disabled) { - intensity = 2; - } else if (highlight) { - // blend this _slightly_ with the background - baseColor = alphaBlendColors(baseColor, highlightColor, 240); - } else if (sunken) { - // enforce a common sunken-style... - baseColor = baseColor.dark(110+intensity); - intensity = _contrast/2; - } -// some often needed colors... - // 1 more intensive than 2 and 3. - const TQColor colorTop1 = alphaBlendColors(baseColor, - sunken?baseColor.dark(100+intensity*2):baseColor.light(100+intensity*2), 80); - const TQColor colorTop2 = alphaBlendColors(baseColor, - sunken?baseColor.dark(100+intensity):baseColor.light(100+intensity), 80); - const TQColor colorBottom1 = alphaBlendColors(baseColor, - sunken?baseColor.light(100+intensity*2):baseColor.dark(100+intensity*2), 80); - const TQColor colorBottom2 = alphaBlendColors(baseColor, - sunken?baseColor.light(100+intensity):baseColor.dark(100+intensity), 80); - -// sides - if (drawLeft) { - if (horizontal) { - int height = r.height(); - if (roundUpperLeft || !drawTop) height--; - if (roundBottomLeft || !drawBottom) height--; - renderGradient(p, TQRect(r.left(), (roundUpperLeft&&drawTop)?r.top()+1:r.top(), 1, height), - colorTop1, baseColor); - } else { - p->setPen(colorTop1 ); - p->drawLine(r.left(), (roundUpperLeft&&drawTop)?r.top()+1:r.top(), - r.left(), (roundBottomLeft&&drawBottom)?r.bottom()-1:r.bottom() ); - } - } - if (drawRight) { - if (horizontal) { - int height = r.height(); - // TODO: there's still a bogus in it: when edge4 is Thick - // and we don't whant to draw the Top, we have a unpainted area - if (roundUpperRight || !drawTop) height--; - if (roundBottomRight || !drawBottom) height--; - renderGradient(p, TQRect(r.right(), (roundUpperRight&&drawTop)?r.top()+1:r.top(), 1, height), - baseColor, colorBottom1); - } else { - p->setPen(colorBottom1 ); - p->drawLine(r.right(), (roundUpperRight&&drawTop)?r.top()+1:r.top(), - r.right(), (roundBottomRight&&drawBottom)?r.bottom()-1:r.bottom() ); - } - } - if (drawTop) { - if (horizontal) { - p->setPen(colorTop1 ); - p->drawLine((roundUpperLeft&&drawLeft)?r.left()+1:r.left(), r.top(), - (roundUpperRight&&drawRight)?r.right()-1:r.right(), r.top() ); - } else { - int width = r.width(); - if (roundUpperLeft || !drawLeft) width--; - if (roundUpperRight || !drawRight) width--; - renderGradient(p, TQRect((roundUpperLeft&&drawLeft)?r.left()+1:r.left(), r.top(), width, 1), - colorTop1, colorTop2); - } - } - if (drawBottom) { - if (horizontal) { - p->setPen(colorBottom1 ); - p->drawLine((roundBottomLeft&&drawLeft)?r.left()+1:r.left(), r.bottom(), - (roundBottomRight&&drawRight)?r.right()-1:r.right(), r.bottom() ); - } else { - int width = r.width(); - if (roundBottomLeft || !drawLeft) width--; - if (roundBottomRight || !drawRight) width--; - renderGradient(p, TQRect((roundBottomLeft&&drawLeft)?r.left()+1:r.left(), r.bottom(), width, 1), - colorBottom2, colorBottom1); - } - } - -// button area... - int width = r.width(); - int height = r.height(); - if (drawLeft) width--; - if (drawRight) width--; - if (drawTop) height--; - if (drawBottom) height--; - renderGradient(p, TQRect(drawLeft?r.left()+1:r.left(), drawTop?r.top()+1:r.top(), width, height), - colorTop2, colorBottom2, horizontal); - - -// highlighting... - if(highlightTop) { - p->setPen(alphaBlendColors(colorTop1 , highlightColor, 80) ); - p->drawLine((roundUpperLeft&&drawLeft)?r.left()+1:r.left(), r.top(), - (roundUpperRight&&drawRight)?r.right()-1:r.right(), r.top() ); - p->setPen(alphaBlendColors(colorTop2 , highlightColor, 150) ); - p->drawLine(highlightLeft?r.left()+1:r.left(), r.top()+1, - highlightRight?r.right()-1:r.right(), r.top()+1 ); - } - if(highlightBottom) { - p->setPen(alphaBlendColors(colorBottom1 , highlightColor, 80) ); - p->drawLine((roundBottomLeft&&drawLeft)?r.left()+1:r.left(), r.bottom(), - (roundBottomRight&&drawRight)?r.right()-1:r.right(), r.bottom() ); - p->setPen(alphaBlendColors(colorBottom2 , highlightColor, 150) ); - p->drawLine(highlightLeft?r.left()+1:r.left(), r.bottom()-1, - highlightRight?r.right()-1:r.right(), r.bottom()-1 ); - } - if(highlightLeft) { - p->setPen(alphaBlendColors(colorTop1 , highlightColor, 80) ); - p->drawLine(r.left(), (roundUpperLeft&&drawTop)?r.top()+1:r.top(), - r.left(), (roundBottomLeft&&drawBottom)?r.bottom()-1:r.bottom() ); - p->setPen(alphaBlendColors(colorTop2 , highlightColor, 150) ); - p->drawLine(r.left()+1, highlightTop?r.top()+1:r.top(), - r.left()+1, highlightBottom?r.bottom()-1:r.bottom() ); - } - if(highlightRight) { - p->setPen(alphaBlendColors(colorBottom1 , highlightColor, 80) ); - p->drawLine(r.right(), (roundUpperRight&&drawTop)?r.top()+1:r.top(), - r.right(), (roundBottomRight&&drawBottom)?r.bottom()-1:r.bottom() ); - p->setPen(alphaBlendColors(colorBottom2 , highlightColor, 150) ); - p->drawLine(r.right()-1, highlightTop?r.top()+1:r.top(), - r.right()-1, highlightBottom?r.bottom()-1:r.bottom() ); - } -} - -void PlastikStyle::renderPixel(TQPainter *p, - const TQPoint &pos, - const int alpha, - const TQColor &color, - const TQColor &background, - bool fullAlphaBlend) const -{ - if(fullAlphaBlend) - // full alpha blend: paint into an image with alpha buffer and convert to a pixmap ... - { - QRgb rgb = color.rgb(); - // generate a quite unique key -- use the unused width field to store the alpha value. - CacheEntry search(cAlphaDot, alpha, 0, rgb); - int key = search.key(); - - CacheEntry *cacheEntry; - if( (cacheEntry = pixmapCache->find(key)) ) { - if( search == *cacheEntry ) { // match! we can draw now... - if(cacheEntry->pixmap) - p->drawPixmap(pos, *(cacheEntry->pixmap) ); - return; - } else { //Remove old entry in case of a conflict! - pixmapCache->remove( key ); - } - } - - - TQImage aImg(1,1,32); // 1x1 - aImg.setAlphaBuffer(true); - aImg.setPixel(0,0,tqRgba(tqRed(rgb),tqGreen(rgb),tqBlue(rgb),alpha)); - TQPixmap *result = new TQPixmap(aImg); - - p->drawPixmap(pos, *result); - - // add to the cache... - CacheEntry *toAdd = new CacheEntry(search); - toAdd->pixmap = result; - bool insertOk = pixmapCache->insert( key, toAdd, result->depth()/8); - if(!insertOk) - delete result; - } else - // don't use an alpha buffer: calculate the resulting color from the alpha value, the fg- and the bg-color. - { - QRgb rgb_a = color.rgb(); - QRgb rgb_b = background.rgb(); - int a = alpha; - if(a>255) a = 255; - if(a<0) a = 0; - int a_inv = 255 - a; - - TQColor res = TQColor( tqRgb(tqRed(rgb_b)*a_inv/255 + tqRed(rgb_a)*a/255, - tqGreen(rgb_b)*a_inv/255 + tqGreen(rgb_a)*a/255, - tqBlue(rgb_b)*a_inv/255 + tqBlue(rgb_a)*a/255) ); - p->setPen(res); - p->drawPoint(pos); - } -} - -void PlastikStyle::renderButton(TQPainter *p, - const TQRect &r, - const TQColorGroup &g, - bool sunken, - bool mouseOver, - bool horizontal, - bool enabled, - bool tdehtmlMode) const -{ - // small fix for the kicker buttons... - if(kickerMode) enabled = true; - - const TQPen oldPen( p->pen() ); - - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(!enabled) contourFlags|=Is_Disabled; - if(tdehtmlMode) contourFlags|=Draw_AlphaBlend; - - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(horizontal) surfaceFlags|=Is_Horizontal; - if(!enabled) surfaceFlags|=Is_Disabled; - else { - if(sunken) surfaceFlags|=Is_Sunken; - else { - if(mouseOver) { - surfaceFlags|=Is_Highlight; - if(horizontal) { - surfaceFlags|=Highlight_Top; - surfaceFlags|=Highlight_Bottom; - } else { - surfaceFlags|=Highlight_Left; - surfaceFlags|=Highlight_Right; - } - } - } - } - - if (!flatMode) { - contourFlags |= Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight; - surfaceFlags |= Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight; - - renderContour(p, r, g.background(), getColor(g,ButtonContour), - contourFlags); - renderSurface(p, TQRect(r.left()+1, r.top()+1, r.width()-2, r.height()-2), - g.background(), g.button(), getColor(g,MouseOverHighlight), _contrast, surfaceFlags); - } else { - renderContour(p, r, g.background(), g.button().dark(105+_contrast*3), - contourFlags); - renderSurface(p, TQRect(r.left()+1, r.top()+1, r.width()-2, r.height()-2), - g.background(), g.button(), getColor(g,MouseOverHighlight), _contrast/2, surfaceFlags); - - flatMode = false; - } - - p->setPen(oldPen); -} - -void PlastikStyle::renderDot(TQPainter *p, - const TQPoint &point, - const TQColor &baseColor, - const bool thick, - const bool sunken) const -{ - const TQColor topColor = alphaBlendColors(baseColor, sunken?baseColor.dark(130):baseColor.light(150), 70); - const TQColor bottomColor = alphaBlendColors(baseColor, sunken?baseColor.light(150):baseColor.dark(130), 70); - p->setPen(topColor ); - p->drawLine(point.x(), point.y(), point.x()+1, point.y()); - p->drawPoint(point.x(), point.y()+1); - p->setPen(bottomColor ); - if(thick) { - p->drawLine(point.x()+1, point.y()+2, point.x()+2, point.y()+2); - p->drawPoint(point.x()+2, point.y()+1); - } else { - p->drawPoint(point.x()+1, point.y()+1); - } -} - -void PlastikStyle::renderGradient(TQPainter *painter, - const TQRect &rect, - const TQColor &c1, - const TQColor &c2, - bool horizontal) const -{ - if((rect.width() <= 0)||(rect.height() <= 0)) - return; - - // generate a quite unique key for this surface. - CacheEntry search(cGradientTile, - horizontal ? 0 : rect.width(), - horizontal ? rect.height() : 0, - c1.rgb(), c2.rgb(), horizontal ); - int key = search.key(); - - CacheEntry *cacheEntry; - if( (cacheEntry = pixmapCache->find(key)) ) { - if( search == *cacheEntry ) { // match! we can draw now... - if(cacheEntry->pixmap) { - painter->drawTiledPixmap(rect, *(cacheEntry->pixmap) ); - } - return; - } else { - // Remove old entry in case of a conflict! - // This shouldn't happen very often, see comment in CacheEntry. - pixmapCache->remove(key); - } - } - - // there wasn't anything matching in the cache, create the pixmap now... - TQPixmap *result = new TQPixmap(horizontal ? 10 : rect.width(), - horizontal ? rect.height() : 10); - TQPainter p(result); - - int r_w = result->rect().width(); - int r_h = result->rect().height(); - int r_x, r_y, r_x2, r_y2; - TQT_TQRECT_OBJECT(result->rect()).coords(&r_x, &r_y, &r_x2, &r_y2); - - int rDiff, gDiff, bDiff; - int rc, gc, bc; - - register int x, y; - - rDiff = ( c2.red()) - (rc = c1.red()); - gDiff = ( c2.green()) - (gc = c1.green()); - bDiff = ( c2.blue()) - (bc = c1.blue()); - - register int rl = rc << 16; - register int gl = gc << 16; - register int bl = bc << 16; - - int rdelta = ((1<<16) / (horizontal ? r_h : r_w)) * rDiff; - int gdelta = ((1<<16) / (horizontal ? r_h : r_w)) * gDiff; - int bdelta = ((1<<16) / (horizontal ? r_h : r_w)) * bDiff; - - // these for-loops could be merged, but the if's in the inner loop - // would make it slow - if(horizontal) { - for ( y = 0; y < r_h; y++ ) { - rl += rdelta; - gl += gdelta; - bl += bdelta; - - p.setPen(TQColor(rl>>16, gl>>16, bl>>16)); - p.drawLine(r_x, r_y+y, r_x2, r_y+y); - } - } else { - for( x = 0; x < r_w; x++) { - rl += rdelta; - gl += gdelta; - bl += bdelta; - - p.setPen(TQColor(rl>>16, gl>>16, bl>>16)); - p.drawLine(r_x+x, r_y, r_x+x, r_y2); - } - } - - p.end(); - - // draw the result... - painter->drawTiledPixmap(rect, *result); - - // insert into cache using the previously created key. - CacheEntry *toAdd = new CacheEntry(search); - toAdd->pixmap = result; - bool insertOk = pixmapCache->insert( key, toAdd, result->width()*result->height()*result->depth()/8 ); - - if(!insertOk) - delete result; -} - -void PlastikStyle::renderPanel(TQPainter *p, - const TQRect &r, - const TQColorGroup &g, - const bool pseudo3d, - const bool sunken) const -{ - int x, x2, y, y2, w, h; - r.rect(&x,&y,&w,&h); - r.coords(&x, &y, &x2, &y2); - - if (kickerMode && - p->device() && p->device()->devType() == TQInternal::Widget && - TQCString(TQT_TQWIDGET(static_cast<TQPaintDevice*>(p->device()))->className()) == "FittsLawFrame") { - // Stolen wholesale from Keramik. I don't like it, but oh well. - if (sunken) { - const TQCOORD corners[] = { x2, y, x2, y2, x, y2, x, y }; - p->setPen(g.background().dark()); - p->drawConvexPolygon(TQPointArray(4, corners)); - p->setPen(g.background().light()); - p->drawPolyline(TQPointArray(4, corners), 0, 3); - } else { - const TQCOORD corners[] = { x, y2, x, y, x2, y, x2, y2 }; - p->setPen(g.background().dark()); - p->drawPolygon(TQPointArray(4, corners)); - p->setPen(g.background().light()); - p->drawPolyline(TQPointArray(4, corners), 0, 3); - } - } else { - renderContour(p, r, g.background(), getColor(g, PanelContour) ); - - if(pseudo3d) { - if (sunken) { - p->setPen(getColor(g, PanelDark) ); - } else { - p->setPen(getColor(g, PanelLight) ); - } - p->drawLine(r.left()+2, r.top()+1, r.right()-2, r.top()+1); - p->drawLine(r.left()+1, r.top()+2, r.left()+1, r.bottom()-2); - if (sunken) { - p->setPen(getColor(g, PanelLight) ); - } else { - p->setPen(getColor(g, PanelDark) ); - } - p->drawLine(r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1); - p->drawLine(r.right()-1, r.top()+2, r.right()-1, r.bottom()-2); - } - } -} - -void PlastikStyle::renderMenuBlendPixmap( KPixmap &pix, const TQColorGroup &cg, - const TQPopupMenu* /* popup */ ) const -{ - pix.fill( cg.background().light(105) ); -} - -void PlastikStyle::renderTab(TQPainter *p, - const TQRect &r, - const TQColorGroup &g, - bool mouseOver, - const bool selected, - const bool bottom, - const TabPosition pos, - const bool triangular, - const bool cornerWidget) const -{ - const bool reverseLayout = TQApplication::reverseLayout(); - - const bool isFirst = (pos == First) || (pos == Single); - const bool isLast = (pos == Last); - const bool isSingle = (pos == Single); - - if (selected) { - // is selected - - // the top part of the tab which is nearly the same for all positions - TQRect Rc; // contour - if (!bottom) { - if (isFirst && !cornerWidget && !reverseLayout) { - Rc = TQRect(r.x(), r.y(), r.width()-1, r.height()-3); - } else if (isFirst && !cornerWidget && reverseLayout) { - Rc = TQRect(r.x()+1, r.y(), r.width()-1, r.height()-3); - } else { - Rc = TQRect(r.x()+1, r.y(), r.width()-2, r.height()-3); - } - } else { - if (isFirst && !cornerWidget && !reverseLayout) { - Rc = TQRect(r.x(), r.y()+3, r.width()-1, r.height()-3); - } else if (isFirst && !cornerWidget && reverseLayout) { - Rc = TQRect(r.x()+1, r.y()+3, r.width()-1, r.height()-3); - } else { - Rc = TQRect(r.x()+1, r.y()+3, r.width()-2, r.height()-3); - } - } - const TQRect Rs(Rc.x()+1, bottom?Rc.y():Rc.y()+1, Rc.width()-2, Rc.height()-1); // the resulting surface - // the area where the fake border shoudl appear - const TQRect Rb(r.x(), bottom?r.top():Rc.bottom()+1, r.width(), r.height()-Rc.height() ); - - uint contourFlags = Draw_Left|Draw_Right; - if(!bottom) { - contourFlags |= Draw_Top|Round_UpperLeft|Round_UpperRight; - } else { - contourFlags |= Draw_Bottom|Round_BottomLeft|Round_BottomRight; - } - renderContour(p, Rc, - g.background(), getColor(g,PanelContour), - contourFlags); - - // surface - if(!bottom) { - p->setPen(getColor(g,PanelLight) ); - p->drawLine(Rs.x()+1, Rs.y(), Rs.right()-1, Rs.y() ); - renderGradient(p, TQRect(Rs.x(), Rs.y()+1, 1, Rs.height()-1), - getColor(g,PanelLight), getColor(g,PanelLight2)); - renderGradient(p, TQRect(Rs.right(), Rs.y()+1, 1, Rs.height()-1), - getColor(g,PanelDark), getColor(g,PanelDark2)); - } else { - p->setPen(alphaBlendColors(g.background(), g.background().dark(160), 100) ); - p->drawLine(Rs.x()+1, Rs.bottom(), Rs.right()-1, Rs.bottom() ); - renderGradient(p, TQRect(Rs.x(), Rs.y(), 1, Rs.height()-1), - getColor(g,PanelLight), getColor(g,PanelLight2)); - renderGradient(p, TQRect(Rs.right(), Rs.y(), 1, Rs.height()-1), - getColor(g,PanelDark), getColor(g,PanelDark2)); - } - - // some "position specific" paintings... - // draw parts of the inactive tabs around... - if(!isSingle) { - p->setPen(alphaBlendColors(g.background(), getColor(g, ButtonContour), 50) ); - if( (!isFirst&&!reverseLayout) || (!isLast&&reverseLayout) ) { - p->drawPoint(r.left(), bottom?(triangular?r.bottom()-2:r.bottom()-3):(triangular?r.top()+2:r.top()+3) ); - renderSurface(p, TQRect(r.left(), bottom?r.top()+3:(triangular?r.top()+3:r.top()+4), 1, (triangular?r.height()-6:r.height()-7) ), - g.background(), g.button(), getColor(g,MouseOverHighlight), _contrast, - Draw_Top|Draw_Bottom|Is_Horizontal); - } - if( (!isLast&&!reverseLayout) || (!isFirst&&reverseLayout) ) { - p->drawPoint(r.right(), bottom?(triangular?r.bottom()-2:r.bottom()-3):(triangular?r.top()+2:r.top()+3) ); - renderSurface(p, TQRect(r.right(), bottom?r.top()+3:(triangular?r.top()+3:r.top()+4), 1, (triangular?r.height()-6:r.height()-7) ), - g.background(), g.button(), getColor(g,MouseOverHighlight), _contrast, - Draw_Top|Draw_Bottom|Is_Horizontal); - } - } - // left connection from the panel border to the tab. :) - if(isFirst && !reverseLayout && !cornerWidget) { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawLine(Rb.x(), Rb.y(), Rb.x(), Rb.bottom() ); - p->setPen(getColor(g,PanelLight) ); - p->drawLine(Rb.x()+1, Rb.y(), Rb.x()+1, Rb.bottom() ); - } else if(isFirst && reverseLayout && !cornerWidget) { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawLine(Rb.right(), Rb.y(), Rb.right(), Rb.bottom() ); - p->setPen(getColor(g,PanelDark) ); - p->drawLine(Rb.right()-1, Rb.y(), Rb.right()-1, Rb.bottom() ); - } - // rounded connections to the panel... - if(!bottom) { - // left - if( (!isFirst && !reverseLayout) || (reverseLayout) || (isFirst && !reverseLayout && cornerWidget) ) { - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.x(), Rb.y()); - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x(), Rb.y()+1); - p->drawPoint(Rb.x()+1, Rb.y()); - } - // right - if( (!reverseLayout) || (!isFirst && reverseLayout) || (isFirst && reverseLayout && cornerWidget) ) { - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.right(), Rb.y()); - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right(), Rb.y()+1); - p->drawPoint(Rb.right()-1, Rb.y()); - } - } else { - // left - if( (!isFirst && !reverseLayout) || (reverseLayout) || (isFirst && !reverseLayout && cornerWidget) ) { - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.x(), Rb.bottom()); - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x(), Rb.bottom()-1); - p->drawPoint(Rb.x()+1, Rb.bottom()); - } - // right - if( (!reverseLayout) || (!isFirst && reverseLayout) || (isFirst && reverseLayout && cornerWidget) ) { - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.right(), Rb.bottom()); - p->setPen( alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right(), Rb.bottom()-1); - p->drawPoint(Rb.right()-1, Rb.bottom()); - } - } - - } else { - // inactive tabs - - // the top part of the tab which is nearly the same for all positions - TQRect Rc; // contour - if (isFirst&&reverseLayout ) { - Rc = TQRect(r.x()+1, (bottom?r.y()+2:(triangular?r.y()+2:r.y()+3)), r.width()-2, (triangular?r.height()-4:r.height()-5) ); - } else { - Rc = TQRect(r.x()+1, (bottom?r.y()+2:(triangular?r.y()+2:r.y()+3)), r.width()-1, (triangular?r.height()-4:r.height()-5) ); - } - TQRect Rs; // the resulting surface - if ( (isFirst&&!reverseLayout) || (isLast&&reverseLayout) ) { - Rs = TQRect(Rc.x()+1, bottom?Rc.y():Rc.y()+1, Rc.width()-2, Rc.height()-1); - } else { - Rs = TQRect(Rc.x(), bottom?Rc.y():Rc.y()+1, Rc.width()-1, Rc.height()-1); - } - // the area where the fake border shoudl appear - const TQRect Rb(r.x(), bottom?r.y():Rc.bottom()+1, r.width(), 2 ); - - uint contourFlags; - if(!bottom) { - if ( (isFirst&&!reverseLayout) || (isLast&&reverseLayout) ) { - contourFlags = Draw_Left|Draw_Right|Draw_Top|Round_UpperLeft; - } else if ( (isLast&&!reverseLayout) || (isFirst&&reverseLayout) ) { - contourFlags = Draw_Right|Draw_Top|Round_UpperRight; - } else { - contourFlags = Draw_Right|Draw_Top; - } - } else { - if ( (isFirst&&!reverseLayout) || (isLast&&reverseLayout) ) { - contourFlags = Draw_Left|Draw_Right|Draw_Bottom|Round_BottomLeft; - } else if ( (isLast&&!reverseLayout) || (isFirst&&reverseLayout) ) { - contourFlags = Draw_Right|Draw_Bottom|Round_BottomRight; - } else { - contourFlags = Draw_Right|Draw_Bottom; - } - } - renderContour(p, Rc, - g.background(), getColor(g, ButtonContour), - contourFlags); - - uint surfaceFlags = Is_Horizontal; - if(mouseOver) { - surfaceFlags |= (bottom?Highlight_Bottom:Highlight_Top); - surfaceFlags |= Is_Highlight; - } - if ( (isFirst&&!reverseLayout) || (isLast&&reverseLayout) ) { - if(!bottom) - surfaceFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft; - else - surfaceFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_BottomLeft; - } else if ( (isLast&&!reverseLayout) || (isFirst&&reverseLayout) ) { - if(!bottom) - surfaceFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight; - else - surfaceFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_BottomRight; - } else { - surfaceFlags |= Draw_Top|Draw_Bottom; - } - renderSurface(p, Rs, - g.background(), g.button(), getColor(g,MouseOverHighlight), _contrast, - surfaceFlags); - - // some "position specific" paintings... - // fake parts of the panel border - if(!bottom) { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawLine(Rb.x(), Rb.y(), ((isLast&&!reverseLayout)||(isFirst&&reverseLayout&&cornerWidget))?Rb.right():Rb.right()-1, Rb.y()); - p->setPen(getColor(g,PanelLight) ); - p->drawLine(Rb.x(), Rb.y()+1, ((isLast&&!reverseLayout)||(isFirst&&reverseLayout&&cornerWidget))?Rb.right():Rb.right()-1, Rb.y()+1 ); - } else { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawLine(Rb.x(), Rb.bottom(), ((isLast&&!reverseLayout)||(isFirst&&reverseLayout&&cornerWidget))?Rb.right():Rb.right()-1, Rb.bottom()); - p->setPen(getColor(g,PanelDark) ); - p->drawLine(Rb.x(), Rb.bottom()-1, ((isLast&&!reverseLayout)||(isFirst&&reverseLayout&&cornerWidget))?Rb.right():Rb.right()-1, Rb.bottom()-1 ); - } - // fake the panel border edge for tabs which are aligned left-most - // (i.e. only if there is no widget in the corner of the tabwidget!) - if(isFirst&&!reverseLayout&&!cornerWidget) - // normal layout - { - if (!bottom) { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.x()+1, Rb.y()+1 ); - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x(), Rb.y()+1 ); - p->setPen(g.background() ); - p->drawPoint(Rb.x(), Rb.y() ); - p->setPen(alphaBlendColors( alphaBlendColors(g.background(), getColor(g, ButtonContour), 50), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x()+1, Rb.y() ); - } else { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.x()+1, Rb.bottom()-1 ); - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x(), Rb.bottom()-1 ); - p->setPen(g.background() ); - p->drawPoint(Rb.x(), Rb.bottom() ); - p->setPen(alphaBlendColors( alphaBlendColors(g.background(), getColor(g, ButtonContour), 50), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.x()+1, Rb.bottom() ); - } - } else if(isFirst&&reverseLayout&&!cornerWidget) - // reverse layout - { - if (!bottom) { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.right()-1, Rb.y()+1 ); - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right(), Rb.y()+1 ); - p->setPen(g.background() ); - p->drawPoint(Rb.right(), Rb.y() ); - p->setPen(alphaBlendColors( alphaBlendColors(g.background(), getColor(g, ButtonContour), 50), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right()-1, Rb.y() ); - } else { - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 50) ); - p->drawPoint(Rb.right()-1, Rb.bottom()-1 ); - p->setPen(alphaBlendColors(g.background(), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right(), Rb.bottom()-1 ); - p->setPen(g.background() ); - p->drawPoint(Rb.right(), Rb.bottom() ); - p->setPen(alphaBlendColors( alphaBlendColors(g.background(), getColor(g, ButtonContour), 50), getColor(g,PanelContour), 150) ); - p->drawPoint(Rb.right()-1, Rb.bottom() ); - } - } - } -} - -void PlastikStyle::drawTDEStylePrimitive(TDEStylePrimitive kpe, - TQPainter *p, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQRect &r, - const TQColorGroup &cg, - SFlags flags, - const TQStyleOption& opt, - const TQWidget* widget) const -{ - // some "global" vars... - const bool enabled = (flags & Style_Enabled); - -// SLIDER -// ------ - switch( kpe ) { - case KPE_SliderGroove: { - bool horizontal = ceData.orientation == TQt::Horizontal; - - if (horizontal) { - int center = r.y()+r.height()/2; - renderContour(p, TQRect(r.left(), center-2, r.width(), 4), - cg.background(), cg.background().dark(enabled?150:130), - Draw_Left|Draw_Right|Draw_Top|Draw_Bottom); - } else { - int center = r.x()+r.width()/2; - renderContour(p, TQRect(center-2, r.top(), 4, r.height()), - cg.background(), cg.background().dark(enabled?150:130), - Draw_Left|Draw_Right|Draw_Top|Draw_Bottom); - } - break; - } - - case KPE_SliderHandle: { - bool horizontal = ceData.orientation == TQt::Horizontal; - - const bool pressed = (flags&Style_Active); - const WidgetState s = enabled?(pressed?IsPressed:IsEnabled):IsDisabled; - const TQColor contour = getColor(cg,DragButtonContour,s), - surface = getColor(cg,DragButtonSurface,s); - - int xcenter = (r.left()+r.right()) / 2; - int ycenter = (r.top()+r.bottom()) / 2; - - if (horizontal) { - renderContour(p, TQRect(xcenter-5, ycenter-6, 11, 10), - cg.background(), contour, - Draw_Left|Draw_Right|Draw_Top|Round_UpperLeft|Round_UpperRight); - - // manual contour: vertex - p->setPen(alphaBlendColors(cg.background(), contour, 50) ); - p->drawPoint(xcenter-5+1, ycenter+4); - p->drawPoint(xcenter+5-1, ycenter+4); - p->drawPoint(xcenter-5+2, ycenter+5); - p->drawPoint(xcenter+5-2, ycenter+5); - p->drawPoint(xcenter-5+3, ycenter+6); - p->drawPoint(xcenter+5-3, ycenter+6); - p->drawPoint(xcenter-5+4, ycenter+7); - p->drawPoint(xcenter+5-4, ycenter+7); - // anti-aliasing of the contour... sort of. :) - p->setPen(alphaBlendColors(cg.background(), contour, 80) ); - p->drawPoint(xcenter, ycenter+8); - p->setPen(alphaBlendColors(cg.background(), contour, 150) ); - p->drawPoint(xcenter-5, ycenter+4); - p->drawPoint(xcenter+5, ycenter+4); - p->drawPoint(xcenter-5+1, ycenter+5); - p->drawPoint(xcenter+5-1, ycenter+5); - p->drawPoint(xcenter-5+2, ycenter+6); - p->drawPoint(xcenter+5-2, ycenter+6); - p->drawPoint(xcenter-5+3, ycenter+7); - p->drawPoint(xcenter+5-3, ycenter+7); - p->setPen(alphaBlendColors(cg.background(), contour, 190) ); - p->drawPoint(xcenter-5+4, ycenter+8); - p->drawPoint(xcenter+5-4, ycenter+8); - - - TQRegion mask(xcenter-4, ycenter-5, 9, 13); - mask -= TQRegion(xcenter-4, ycenter+4, 1, 4); - mask -= TQRegion(xcenter-3, ycenter+5, 1, 3); - mask -= TQRegion(xcenter-2, ycenter+6, 1, 2); - mask -= TQRegion(xcenter-1, ycenter+7, 1, 1); - mask -= TQRegion(xcenter+1, ycenter+7, 1, 1); - mask -= TQRegion(xcenter+2, ycenter+6, 1, 2); - mask -= TQRegion(xcenter+3, ycenter+5, 1, 3); - mask -= TQRegion(xcenter+4, ycenter+4, 1, 4); - p->setClipRegion(mask); - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Round_UpperLeft|Round_UpperRight|Is_Horizontal; - if(!enabled) - surfaceFlags |= Is_Disabled; - renderSurface(p, TQRect(xcenter-4, ycenter-5, 9, 13), - cg.background(), surface, getColor(cg,MouseOverHighlight), - _contrast+3, surfaceFlags); - renderDot(p, TQPoint(xcenter-3, ycenter-3), surface, false, true ); - renderDot(p, TQPoint(xcenter+2, ycenter-3), surface, false, true ); - p->setClipping(false); - } else { - renderContour(p, TQRect(xcenter-6, ycenter-5, 10, 11), - cg.background(), contour, - Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft); - - // manual contour: vertex - p->setPen(alphaBlendColors(cg.background(), contour, 50) ); - p->drawPoint(xcenter+4, ycenter-5+1); - p->drawPoint(xcenter+4, ycenter+5-1); - p->drawPoint(xcenter+5, ycenter-5+2); - p->drawPoint(xcenter+5, ycenter+5-2); - p->drawPoint(xcenter+6, ycenter-5+3); - p->drawPoint(xcenter+6, ycenter+5-3); - p->drawPoint(xcenter+7, ycenter-5+4); - p->drawPoint(xcenter+7, ycenter+5-4); - // anti-aliasing. ...sort of :) - p->setPen(alphaBlendColors(cg.background(), contour, 80) ); - p->drawPoint(xcenter+8, ycenter); - p->setPen(alphaBlendColors(cg.background(), contour, 150) ); - p->drawPoint(xcenter+4, ycenter-5); - p->drawPoint(xcenter+4, ycenter+5); - p->drawPoint(xcenter+5, ycenter-5+1); - p->drawPoint(xcenter+5, ycenter+5-1); - p->drawPoint(xcenter+6, ycenter-5+2); - p->drawPoint(xcenter+6, ycenter+5-2); - p->drawPoint(xcenter+7, ycenter-5+3); - p->drawPoint(xcenter+7, ycenter+5-3); - p->setPen(alphaBlendColors(cg.background(), contour, 190) ); - p->drawPoint(xcenter+8, ycenter-5+4); - p->drawPoint(xcenter+8, ycenter+5-4); - - TQRegion mask(xcenter-5, ycenter-4, 13, 9); - mask -= TQRegion(xcenter+4, ycenter-4, 4, 1); - mask -= TQRegion(xcenter+5, ycenter-3, 3, 1); - mask -= TQRegion(xcenter+6, ycenter-2, 2, 1); - mask -= TQRegion(xcenter+7, ycenter-1, 1, 1); - mask -= TQRegion(xcenter+7, ycenter+1, 1, 1); - mask -= TQRegion(xcenter+6, ycenter+2, 2, 1); - mask -= TQRegion(xcenter+5, ycenter+3, 3, 1); - mask -= TQRegion(xcenter+4, ycenter+4, 4, 1); - p->setClipRegion(mask); - uint surfaceFlags = Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft| - Round_UpperRight|Is_Horizontal; - if(!enabled) - surfaceFlags |= Is_Disabled; - renderSurface(p, TQRect(xcenter-5, ycenter-4, 13, 9), - cg.background(), surface, getColor(cg,MouseOverHighlight), - _contrast+3, surfaceFlags); - renderDot(p, TQPoint(xcenter-3, ycenter-3), surface, false, true ); - renderDot(p, TQPoint(xcenter-3, ycenter+2), surface, false, true ); - p->setClipping(false); - } - - break; - } - - case KPE_ListViewExpander: { - int radius = (r.width() - 4) / 2; - int centerx = r.x() + r.width()/2; - int centery = r.y() + r.height()/2; - - renderContour(p, r, cg.base(), cg.dark(), Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight ); - - p->setPen( cg.text() ); - if(!_drawTriangularExpander) - { - // plus or minus - p->drawLine( centerx - radius, centery, centerx + radius, centery ); - if ( flags & Style_On ) // Collapsed = On - p->drawLine( centerx, centery - radius, centerx, centery + radius ); - } else if(_drawTriangularExpander) { - if( flags & Style_On ) - drawPrimitive(PE_ArrowRight, p, ceData, elementFlags, TQRect(r.x()+1,r.y()+1,r.width(),r.height()), cg,ButtonContour, flags); - if( flags & Style_Off ) - drawPrimitive(PE_ArrowDown, p, ceData, elementFlags, TQRect(r.x()+1,r.y()+1,r.width(),r.height()), cg,ButtonContour, flags); - } - - break; - } - - // copied and slightly modified from TDEStyle. - case KPE_ListViewBranch: { - // Typical Windows style listview branch element (dotted line). - - // Create the dotline pixmaps if not already created - if ( !verticalLine ) - { - // make 128*1 and 1*128 bitmaps that can be used for - // drawing the right sort of lines. - verticalLine = new TQBitmap( 1, 129, true ); - horizontalLine = new TQBitmap( 128, 1, true ); - TQPointArray a( 64 ); - TQPainter p2; - p2.begin( verticalLine ); - - int i; - for( i=0; i < 64; i++ ) - a.setPoint( i, 0, i*2+1 ); - p2.setPen( color1 ); - p2.drawPoints( a ); - p2.end(); - TQApplication::flushX(); - verticalLine->setMask( *verticalLine ); - - p2.begin( horizontalLine ); - for( i=0; i < 64; i++ ) - a.setPoint( i, i*2+1, 0 ); - p2.setPen( color1 ); - p2.drawPoints( a ); - p2.end(); - TQApplication::flushX(); - horizontalLine->setMask( *horizontalLine ); - } - - p->setPen( cg.mid() ); - - if (flags & Style_Horizontal) - { - int point = r.x(); - int other = r.y(); - int end = r.x()+r.width(); - int thickness = r.height(); - - while( point < end ) - { - int i = 128; - if ( i+point > end ) - i = end-point; - p->drawPixmap( point, other, *horizontalLine, 0, 0, i, thickness ); - point += i; - } - - } else { - int point = r.y(); - int other = r.x(); - int end = r.y()+r.height(); - int thickness = r.width(); - int pixmapoffset = (flags & Style_NoChange) ? 0 : 1; // ### Hackish - - while( point < end ) - { - int i = 128; - if ( i+point > end ) - i = end-point; - p->drawPixmap( other, point, *verticalLine, 0, pixmapoffset, thickness, i ); - point += i; - } - } - - break; - } - - default: - TDEStyle::drawTDEStylePrimitive(kpe, p, ceData, elementFlags, r, cg, flags, opt, widget); - } -} - - -void PlastikStyle::drawPrimitive(TQ_PrimitiveElement pe, - TQPainter *p, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQRect &r, - const TQColorGroup &cg, - SFlags flags, - const TQStyleOption &opt ) const -{ - bool down = flags & Style_Down; - bool on = flags & Style_On; - bool sunken = flags & Style_Sunken; - bool horiz = flags & Style_Horizontal; - const bool enabled = flags & Style_Enabled; - const bool mouseOver = flags & Style_MouseOver; - - bool hasFocus = flags & Style_HasFocus; - - int x = r.x(); - int y = r.y(); - int w = r.width(); - int h = r.height(); - - int x2, y2; - r.coords(&x, &y, &x2, &y2); - - switch(pe) { - // BUTTONS - // ------- - case PE_FocusRect: { - if(_drawFocusRect) - p->drawWinFocusRect( r ); - break; - } - - case PE_HeaderSectionMenu: - case PE_HeaderSection: { - // the taskbar buttons seems to be painted with PE_HeaderSection but I - // want them look like normal buttons (at least for now. :) ) - if(!kickerMode) { - // detect if this is the left most header item - bool isFirst = false; - TQHeader *header = dynamic_cast<TQHeader*>(p->device() ); - if (header) { - isFirst = header->mapToIndex(header->sectionAt(r.x() ) ) == 0; - } - - uint contourFlags = Draw_Right|Draw_Top|Draw_Bottom; - if (isFirst) - contourFlags |= Draw_Left; - if(!enabled) contourFlags|=Is_Disabled; - renderContour(p, r, cg.background(), getColor(cg,ButtonContour), - contourFlags); - - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(!enabled) surfaceFlags|=Is_Disabled; - else { - if(on||down) surfaceFlags|=Is_Sunken; - else { - if(mouseOver) { - surfaceFlags|=Is_Highlight|Highlight_Top|Highlight_Bottom; - } - } - } - renderSurface(p, TQRect(isFirst?r.left()+1:r.left(), r.top()+1, isFirst?r.width()-2:r.width()-1, r.height()-2), - cg.background(), cg.button(), getColor(cg,MouseOverHighlight), _contrast, - surfaceFlags); - - break; - } - } - case PE_ButtonBevel: - case PE_ButtonTool: - case PE_ButtonDropDown: - case PE_ButtonCommand: { - bool tdehtmlMode = opt.isDefault() ? false : tdehtmlWidgets.contains(opt.widget()); - renderButton(p, r, cg, (on||down), mouseOver, true, enabled, tdehtmlMode ); - break; - } - - case PE_ButtonDefault: { - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight; - if(!enabled) contourFlags|=Is_Disabled; - renderContour(p, r, cg.background(), cg.background().dark(120), - contourFlags); - break; - } - - case PE_SpinWidgetPlus: - case PE_SpinWidgetMinus: { - p->setPen( cg.buttonText() ); - - int l = QMIN( w-2, h-2 ); - // make the length even so that we get a nice symmetric plus... - if(l%2 != 0) - --l; - TQPoint c = r.center(); - - p->drawLine( c.x()-l/2, c.y(), c.x()+l/2, c.y() ); - if ( pe == PE_SpinWidgetPlus ) { - p->drawLine( c.x(), c.y()-l/2, c.x(), c.y()+l/2 ); - } - break; - } - - case PE_ScrollBarSlider: { - const WidgetState s = enabled?(down?IsPressed:IsEnabled):IsDisabled; - const TQColor surface = getColor(cg, DragButtonSurface, s); - - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(!enabled) contourFlags|=Is_Disabled; - renderContour(p, r, cg.background(), getColor(cg, DragButtonContour, s), - contourFlags); - - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(horiz) surfaceFlags|=Is_Horizontal; - if(!enabled) surfaceFlags|=Is_Disabled; - if(r.height() >= 4) - renderSurface(p, TQRect(r.left()+1, r.top()+1, r.width()-2, r.height()-2), - cg.background(), surface, cg.background(), - _contrast+3, surfaceFlags); - - // set contour-like color for the case _scrollBarLines is set and we paint lines instead of dots. - p->setPen(alphaBlendColors(cg.background(), surface.dark(enabled?140:120), 50) ); - - const int d = 4; - int n = ((horiz?r.width():r.height())-8)/d; - if(n>5) n=5; - if(!horiz) { - for(int j = 0; j < n; j++) { - int yPos = r.center().y()-(n*d)/2+d*j+1; - if(_scrollBarLines) - p->drawLine(r.x()+1, yPos, r.right()-1, yPos); - else - { - for(int k = 3; k <= 13; k+=4) { - renderDot(p, TQPoint(k, yPos), surface, false, true ); - } - } - } - } else { - for(int j = 0; j < n; j++) { - int xPos = r.center().x()-(n*d)/2+d*j+1; - if(_scrollBarLines) - p->drawLine(xPos, r.y()+1, xPos, r.bottom()-1); - else - { - for(int k = 3; k <= 13; k+=4) { - renderDot(p, TQPoint(xPos, k), surface, false, true ); - } - } - } - } - - break; - } - - case PE_ScrollBarAddPage: - case PE_ScrollBarSubPage: { - // draw double buffered to avoid flicker... - TQPixmap buffer; - if(flags & Style_Horizontal) { - buffer.resize(2, r.height() ); - } else { - buffer.resize(r.width(), 2 ); - } - TQRect br(buffer.rect() ); - TQPainter bp(&buffer); - - if (on || down) { - bp.fillRect(br, TQBrush(cg.mid().dark())); - } else { - if(flags & Style_Horizontal) { - bp.setPen(cg.background().dark(106)); - bp.drawLine(br.left(), br.top(), br.right(), br.top()); - bp.setPen(cg.background().light(106)); - bp.drawLine(br.left(), br.bottom(), br.right(), br.bottom()); - bp.fillRect(br.left(), br.top()+1, br.width(), br.height()-2,cg.background()); - } else { - bp.setPen(cg.background().dark(106)); - bp.drawLine(br.left(), br.top(), br.left(), br.bottom()); - bp.setPen(cg.background().light(106)); - bp.drawLine(br.right(), br.top(), br.right(), br.bottom()); - bp.fillRect(br.left()+1, br.top(), br.width()-2, br.height(),cg.background()); - } - } - - bp.fillRect(br, TQBrush(cg.background().light(), Dense4Pattern)); - - bp.end(); - - p->drawTiledPixmap(r, buffer, TQPoint(0, r.top()%2) ); - break; - } - - // SCROLLBAR BUTTONS - // ----------------- - case PE_ScrollBarSubLine: { - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(down) surfaceFlags|=Is_Sunken; - if(!enabled) { - contourFlags|=Is_Disabled; - surfaceFlags|=Is_Disabled; - } - if(horiz) { - contourFlags |= Round_UpperLeft|Round_BottomLeft|Is_Horizontal; - surfaceFlags |= Round_UpperLeft|Round_BottomLeft|Is_Horizontal; - } else { - contourFlags |= Round_UpperLeft|Round_UpperRight; - surfaceFlags |= Round_UpperLeft|Round_UpperRight; - } - renderContour(p, r, cg.background(), getColor(cg, ButtonContour), - contourFlags); - renderSurface(p, TQRect(r.left()+1, r.top()+1, r.width()-2, r.height()-2), - cg.background(), cg.button(), getColor(cg,MouseOverHighlight), _contrast+3, - surfaceFlags); - - p->setPen(cg.foreground()); - drawPrimitive((horiz ? PE_ArrowLeft : PE_ArrowUp), p, ceData, elementFlags, r, cg, flags); - break; - } - - case PE_ScrollBarAddLine: { - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(down) surfaceFlags|=Is_Sunken; - if(!enabled) { - contourFlags|=Is_Disabled; - surfaceFlags|=Is_Disabled; - } - if(horiz) { - contourFlags |= Round_UpperRight|Round_BottomRight|Is_Horizontal; - surfaceFlags |= Round_UpperRight|Round_BottomRight|Is_Horizontal; - } else { - contourFlags |= Round_BottomLeft|Round_BottomRight; - surfaceFlags |= Round_BottomLeft|Round_BottomRight; - } - renderContour(p, r, cg.background(), getColor(cg, ButtonContour), - contourFlags); - renderSurface(p, TQRect(r.left()+1, r.top()+1, r.width()-2, r.height()-2), - cg.background(), cg.button(), getColor(cg,MouseOverHighlight), _contrast+3, - surfaceFlags); - - p->setPen(cg.foreground()); - drawPrimitive((horiz ? PE_ArrowRight : PE_ArrowDown), p, ceData, elementFlags, r, cg, flags); - break; - } - - // CHECKBOXES - // ---------- - case PE_Indicator: { - TQColor contentColor = enabled?cg.base():cg.background(); - - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom; - if(!enabled) { - contourFlags |= Is_Disabled; - } - renderContour(p, r, cg.background(), getColor(cg, ButtonContour), - contourFlags); - - // surface - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(!enabled) { - surfaceFlags |= Is_Disabled; - } else if(mouseOver) { - contentColor = alphaBlendColors(contentColor, getColor(cg,MouseOverHighlight), 240); - surfaceFlags |= Is_Highlight; - surfaceFlags |= Highlight_Left|Highlight_Right| - Highlight_Top|Highlight_Bottom; - } - renderSurface(p, TQRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2), - cg.background(), contentColor, getColor(cg,MouseOverHighlight), enabled?_contrast+3:(_contrast/2), surfaceFlags); - - drawPrimitive(PE_CheckMark, p, ceData, elementFlags, r, cg, flags); - - break; - } - - case PE_IndicatorMask: { - p->fillRect (r, color1); - break; - } - - // RADIOBUTTONS - // ------------ - case PE_ExclusiveIndicator: { - const TQColor contourColor = getColor(cg, ButtonContour, enabled); - TQColor contentColor = enabled?cg.base():cg.background(); - - TQBitmap bmp; - bmp = TQBitmap(13, 13, radiobutton_mask_bits, true); - // first the surface... - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(!enabled) { - surfaceFlags |= Is_Disabled; - } else if (mouseOver) { - contentColor = alphaBlendColors(contentColor, getColor(cg,MouseOverHighlight), 240); - } - p->setClipRegion(bmp); - renderSurface(p, r, - cg.background(), contentColor, getColor(cg,MouseOverHighlight), enabled?_contrast+3:(_contrast/2), surfaceFlags); - p->setClipping(false); - - // ...then contour, anti-alias, mouseOver... - // contour - bmp = TQBitmap(13, 13, radiobutton_contour_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(cg.background(), contourColor, 50) ); - p->drawPixmap(x, y, bmp); - // anti-alias outside - bmp = TQBitmap(13, 13, radiobutton_aa_outside_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(cg.background(), contourColor, 150) ); - p->drawPixmap(x, y, bmp); - // highlighting... - if(mouseOver) { - bmp = TQBitmap(13, 13, radiobutton_highlight1_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, getColor(cg,MouseOverHighlight), 80) ); - p->drawPixmap(x, y, bmp); - bmp = TQBitmap(13, 13, radiobutton_highlight2_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, getColor(cg,MouseOverHighlight), 150) ); - p->drawPixmap(x, y, bmp); - } - // anti-alias inside, "above" the higlighting! - bmp = TQBitmap(13, 13, radiobutton_aa_inside_bits, true); - bmp.setMask(bmp); - if(mouseOver) { - p->setPen(alphaBlendColors(getColor(cg,MouseOverHighlight), contourColor, 180) ); - } else { - p->setPen(alphaBlendColors(contentColor, contourColor, 180) ); - } - p->drawPixmap(x, y, bmp); - - - TQColor checkmarkColor = enabled?getColor(cg,CheckMark):cg.background(); - if(flags & Style_Down) { - checkmarkColor = alphaBlendColors(contentColor, checkmarkColor, 150); - } - - // draw the radio mark - if (flags & Style_On || flags & Style_Down) { - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, radiomark_dark_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(150), 50) ); - p->drawPixmap(x+2, y+2, bmp); - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, radiomark_light_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(125), 50) ); - p->drawPixmap(x+2, y+2, bmp); - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, radiomark_aa_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(150), 150) ); - p->drawPixmap(x+2, y+2, bmp); - } - - break; - } - - case PE_ExclusiveIndicatorMask: { - p->fillRect(r, color0); - - TQBitmap bmp; - bmp = TQBitmap(13, 13, radiobutton_mask_bits, true); - bmp.setMask(bmp); - p->setPen(color1); - p->drawPixmap(x, y, bmp); - - break; - } - - // GENERAL PANELS - // -------------- - case PE_Splitter: { - // highlight on mouse over - TQColor color = (mouseOver)?TQColor(cg.background().light(100+_contrast)):cg.background(); - p->fillRect(r, color); - if (w > h) { - if (h > 4) { - int ycenter = r.height()/2; - for(int k = 2*r.width()/10; k < 8*r.width()/10; k+=5) { - renderDot(p, TQPoint(k, ycenter-1), color, false, true); - } - } - } else { - if (w > 4) { - int xcenter = r.width()/2; - for(int k = 2*r.height()/10; k < 8*r.height()/10; k+=5) { - renderDot(p, TQPoint(xcenter-1, k), color, false, true); - } - } - } - - break; - } - - case PE_PanelGroupBox: - case PE_GroupBoxFrame: { - if ( opt.isDefault() || opt.lineWidth() <= 0 ) - break; - renderPanel(p, r, cg, false); - - break; - } - - case PE_WindowFrame: - case PE_Panel: { - if ( opt.isDefault() || opt.lineWidth() <= 0 ) - break; - renderPanel(p, r, cg, true, sunken); - break; - } - - case PE_PanelLineEdit: { - bool isReadOnly = false; - bool 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 (p->device() && dynamic_cast<TQLineEdit*>(p->device())) - { - TQLineEdit* lineEdit = dynamic_cast<TQLineEdit*>(p->device()); - isReadOnly = lineEdit->isReadOnly(); - isEnabled = lineEdit->isEnabled(); - } - - uint contourFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight; - - // HACK!! - // - // In order to draw nice edges in tdehtml, we need to paint alpha-blended. - // On the other hand, we can't paint alpha-blended in normal widgets. - // - // In this place there is no reliable way to detect if we are in tdehtml; the - // only thing we know is that tdehtml buffers its widgets into a pixmap. So - // when the paint device is a TQPixmap, chances are high that we are in tdehtml. - // It's possible that this breaks other things, so let's see how it works... - if (p->device() && dynamic_cast<TQPixmap*>(p->device() ) ) { - contourFlags += Draw_AlphaBlend; - } - - if ( _inputFocusHighlight && hasFocus && !isReadOnly && isEnabled) - { - renderContour(p, r, cg.background(), - getColor(cg,FocusHighlight,enabled), contourFlags ); - } - else - { - renderContour(p, r, cg.background(), - getColor(cg, ButtonContour, enabled), contourFlags ); - } - const TQColor contentColor = enabled?cg.base():cg.background(); - if (_inputFocusHighlight && hasFocus && !isReadOnly && isEnabled) - { - p->setPen( getColor(cg,FocusHighlight).dark(130) ); - } - else - { - p->setPen(contentColor.dark(130) ); - } - p->drawLine(r.left()+1, r.top()+2, r.left()+1, r.bottom()-2 ); - p->drawLine(r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); - if (_inputFocusHighlight && hasFocus && !isReadOnly && isEnabled) - { - p->setPen( getColor(cg,FocusHighlight).light(130) ); - } - else - { - p->setPen(contentColor.light(130) ); - } - p->drawLine(r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); - p->drawLine(r.right()-1, r.top()+2, r.right()-1, r.bottom()-2 ); - break; - } - - case PE_StatusBarSection: { - renderContour(p, r, cg.background(), cg.background().dark(160), - Draw_Left|Draw_Right|Draw_Top|Draw_Bottom); - break; - } - - case PE_TabBarBase: // Still not sure what this one does - case PE_PanelTabWidget: { - renderPanel(p, r, cg, true, sunken); - break; - } - - case PE_PanelPopup: { - renderContour(p, r, cg.background(), cg.background().dark(200), - Draw_Left|Draw_Right|Draw_Top|Draw_Bottom); - break; - } - - // MENU / TOOLBAR PANEL - // -------------------- - case PE_PanelMenuBar: - case PE_PanelDockWindow: { - // fix for toolbar lag (from Mosfet Liquid) - TQWidget* w = dynamic_cast<TQWidget*>(p->device()); - if(w && w->backgroundMode() == PaletteButton) - w->setBackgroundMode(PaletteBackground); - p->fillRect(r, cg.brush(TQColorGroup::Background)); - - if ( _drawToolBarSeparator ) { - if ( r.width() > r.height() ) { - p->setPen( getColor(cg, PanelLight) ); - p->drawLine( r.left(), r.top(), r.right(), r.top() ); - p->setPen( getColor(cg, PanelDark) ); - p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); - } - else { - p->setPen( getColor(cg, PanelLight) ); - p->drawLine( r.left(), r.top(), r.left(), r.bottom() ); - p->setPen( getColor(cg, PanelDark) ); - p->drawLine( r.right(), r.top(), r.right(), r.bottom() ); - } - } - - break; - } - - // TOOLBAR/DOCK WINDOW HANDLE - // -------------------------- - case PE_DockWindowResizeHandle: { - renderButton(p, r, cg); - break; - } - - case PE_DockWindowHandle: { - - int counter = 1; - - if(horiz) { - int center = r.left()+r.width()/2; - for(int j = r.top()+2; j <= r.bottom()-3; j+=3) { - if(counter%2 == 0) { - renderDot(p, TQPoint(center+1, j), cg.background(), true, true); - } else { - renderDot(p, TQPoint(center-2, j), cg.background(), true, true); - } - counter++; - } - } else { - int center = r.top()+r.height()/2; - for(int j = r.left()+2; j <= r.right()-3; j+=3) { - if(counter%2 == 0) { - renderDot(p, TQPoint(j, center+1), cg.background(), true, true); - } else { - renderDot(p, TQPoint(j, center-2), cg.background(), true, true); - } - counter++; - } - } - - break; - } - - // TOOLBAR SEPARATOR - // ----------------- - case PE_DockWindowSeparator: { - p->fillRect(r, cg.background()); - - if(_drawToolBarItemSeparator) { - if(horiz) { - int center = r.left()+r.width()/2; - p->setPen( getColor(cg, PanelDark) ); - p->drawLine( center-1, r.top()+3, center-1, r.bottom()-3 ); - p->setPen( getColor(cg, PanelLight) ); - p->drawLine( center, r.top()+3, center, r.bottom()-3 ); - } else { - int center = r.top()+r.height()/2; - p->setPen( getColor(cg, PanelDark) ); - p->drawLine( r.x()+3, center-1, r.right()-3, center-1 ); - p->setPen( getColor(cg, PanelLight) ); - p->drawLine( r.x()+3, center, r.right()-3, center ); - } - } - break; - } - - case PE_CheckMark: { - const TQColor contentColor = enabled?cg.base():cg.background(); - TQColor checkmarkColor = enabled?getColor(cg,CheckMark):cg.background(); - if(flags & Style_Down) { - checkmarkColor = alphaBlendColors(contentColor, checkmarkColor, 150); - } - - int x = r.center().x() - 4, y = r.center().y() - 4; - TQBitmap bmp; - if( flags & Style_On ) { - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, checkmark_dark_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(150), 50) ); - p->drawPixmap(x, y, bmp); - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, checkmark_light_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(125), 50) ); - p->drawPixmap(x, y, bmp); - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, checkmark_aa_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(150), 150) ); - p->drawPixmap(x, y, bmp); - } else if ( flags & Style_Off ) { - // empty - } else { // tristate - bmp = TQBitmap(CHECKMARKSIZE, CHECKMARKSIZE, checkmark_tristate_bits, true); - bmp.setMask(bmp); - p->setPen(alphaBlendColors(contentColor, checkmarkColor.dark(150), 50) ); - p->drawPixmap(x, y, bmp); - } - - break; - } - - case PE_MenuItemIndicatorFrame: - { - int x, y, w, h; - r.rect( &x, &y, &w, &h ); - int checkcol = styleHint(SH_MenuIndicatorColumnWidth, ceData, elementFlags, opt, NULL, NULL); - TQRect cr = visualRect( TQRect( x + 2, y + 2, checkcol - 1, h - 4 ), r ); - qDrawShadePanel( p, cr.x(), cr.y(), cr.width(), cr.height(), cg, true, 1, &cg.brush(TQColorGroup::Midlight) ); - break; - } - case PE_MenuItemIndicatorIconFrame: - { - int x, y, w, h; - r.rect( &x, &y, &w, &h ); - int checkcol = styleHint(SH_MenuIndicatorColumnWidth, ceData, elementFlags, opt, NULL, NULL); - TQRect cr = visualRect( TQRect( x + 2, y + 2, checkcol - 1, h - 4 ), r ); - qDrawShadePanel( p, cr.x(), cr.y(), cr.width(), cr.height(), cg, true, 1, &cg.brush(TQColorGroup::Midlight) ); - break; - } - case PE_MenuItemIndicatorCheck: - { - int x, y, w, h; - r.rect( &x, &y, &w, &h ); - int checkcol = styleHint(SH_MenuIndicatorColumnWidth, ceData, elementFlags, opt, NULL, NULL); - TQRect cr = visualRect( TQRect( x + 2, y + 2, checkcol - 1, h - 4 ), r ); - // Draw the checkmark - SFlags cflags = Style_On; - if (enabled) - cflags |= Style_Enabled; - drawPrimitive( PE_CheckMark, p, ceData, elementFlags, cr, cg, cflags ); - break; - } - - case PE_SpinWidgetUp: - case PE_SpinWidgetDown: - case PE_HeaderArrow: - case PE_ArrowUp: - case PE_ArrowDown: - case PE_ArrowLeft: - case PE_ArrowRight: { - TQPointArray a; - - switch (pe) { - case PE_SpinWidgetUp: - case PE_ArrowUp: { - a.setPoints(7, u_arrow); - break; - } - case PE_SpinWidgetDown: - case PE_ArrowDown: { - a.setPoints(7, d_arrow); - break; - } - case PE_ArrowLeft: { - a.setPoints(7, l_arrow); - break; - } - case PE_ArrowRight: { - a.setPoints(7, r_arrow); - break; - } - default: { - if (flags & Style_Up) { - a.setPoints(7, u_arrow); - } else { - a.setPoints(7, d_arrow); - } - } - } - - const TQWMatrix oldMatrix( p->worldMatrix() ); - - if (flags & Style_Down) { - p->translate(pixelMetric(PM_ButtonShiftHorizontal, ceData, elementFlags), - pixelMetric(PM_ButtonShiftVertical, ceData, elementFlags)); - } - - a.translate((r.x()+r.width()/2), (r.y()+r.height()/2)); - // extra-pixel-shift, correcting some visual tics... - switch(pe) { - case PE_ArrowLeft: - case PE_ArrowRight: - a.translate(0, -1); - break; - case PE_SpinWidgetUp: - case PE_SpinWidgetDown: - a.translate(+1, 0); - break; - default: - a.translate(0, 0); - } - - if (p->pen() == Qt::NoPen) { - if (flags & Style_Enabled) { - p->setPen(cg.buttonText()); - } else { - p->setPen(cg.highlightedText()); - } - } - p->drawLineSegments(a, 0, 3); - p->drawPoint(a[6]); - - p->setWorldMatrix( oldMatrix ); - - break; - } - - default: { - return TDEStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, opt); - } - } -} - - -void PlastikStyle::drawControl(TQ_ControlElement element, - TQPainter *p, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQRect &r, - const TQColorGroup &cg, - SFlags flags, - const TQStyleOption& opt, - const TQWidget *widget) const -{ - const bool reverseLayout = TQApplication::reverseLayout(); - - const bool enabled = (flags & Style_Enabled); - - switch (element) { - - // PROGRESSBAR - // ----------- - case CE_ProgressBarGroove: { - const TQColor content = enabled?cg.base():cg.background(); - renderContour(p, r, cg.background(), getColor(cg, ButtonContour, enabled) ); - p->setPen(content.dark(105) ); - p->drawLine(r.left()+2, r.top()+1, r.right()-2, r.top()+1 ); - p->drawLine(r.left()+1, r.top()+2, r.left()+1, r.bottom()-2); - p->setPen(content.light(105) ); - p->drawLine(r.left()+2, r.bottom()-1, r.right()-2, r.bottom()-1 ); - p->drawLine(r.right()-1, r.top()+2, r.right()-1, r.bottom()-2); - break; - } - - case CE_ProgressBarContents: { - int steps = ceData.totalSteps; - - const TQColor bg = enabled?cg.base():cg.background(); // background - const TQColor fg = enabled?cg.highlight():TQColor(cg.background().dark(110)); // foreground - - if( steps == 0 ) { // Busy indicator - static const int barWidth = 10; - int progress = ceData.currentStep % (2*(r.width()-barWidth)); - if( progress < 0) - progress = 0; - if( progress > r.width()-barWidth ) - progress = (r.width()-barWidth)-(progress-(r.width()-barWidth)); - p->fillRect( TQRect( r.x(), r.y(), r.width(), r.height() ), bg ); - renderContour( p, TQRect( r.x()+progress, r.y(), barWidth, r.height() ), - bg, fg.dark(160), - Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight| - Round_BottomRight|Round_UpperLeft|Round_BottomLeft ); - renderSurface(p, TQRect( r.x()+progress+1, r.y()+1, barWidth-2, r.height()-2 ), - bg, fg, cg.highlight(), - 2*(_contrast/3), - Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperRight|Round_BottomRight| - Round_UpperLeft|Round_BottomLeft|Is_Horizontal); - } else { - double percent = static_cast<double>(ceData.currentStep) / static_cast<double>(steps); - - int w = static_cast<int>(r.width() * percent); - // renderContour/renderSurface handle small sizes not very well, so set a minimal - // progressbar width... - if(w<4) w = 4; - int w2 = r.width()-(r.width()-w); - - TQRect Rempty(reverseLayout?r.left():r.left()+w-1, r.top(), r.width()-w+1, r.height() ); - TQRect Rcontour(reverseLayout?r.right()-w2+1:r.left(), r.top(), w2, r.height() ); - TQRect Rsurface(Rcontour.left()+1, Rcontour.top()+1, w2-2, Rcontour.height()-2); - - p->fillRect(Rempty, bg); - - renderContour(p, Rcontour, - bg, fg.dark(160), - reverseLayout ? Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft - : Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight|Round_BottomRight); - - TQRegion mask(Rsurface); - if(reverseLayout) { - mask -= TQRegion(Rsurface.left(), Rsurface.top(), 1, 1); - mask -= TQRegion(Rsurface.left(), Rsurface.bottom(), 1, 1); - } else { - mask -= TQRegion(Rsurface.right(), Rsurface.top(), 1, 1); - mask -= TQRegion(Rsurface.right(), Rsurface.bottom(), 1, 1); - } - p->setClipRegion(mask); - int counter = 0; - TQPixmap surfaceTile(21, r.height()-2); - TQPainter surfacePainter(&surfaceTile); - // - 21 pixel - - // __________ - // | ` `| <- 3 - // | 1 | 2 | - // |____,____,| <- 3 - // 1 = light, 11 pixel, 1 pixel overlapping with 2 - // 2 = dark, 11 pixel, 1 pixel overlapping with 3 - // 3 = light edges - const int tileHeight = surfaceTile.height(); - // 3 - renderSurface(&surfacePainter, - TQRect(20, 0, 11, tileHeight), - fg.light(105), fg, cg.highlight(), 2*(_contrast/3), - reverseLayout ? Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_BottomLeft|Is_Horizontal - : Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperRight|Round_BottomRight|Is_Horizontal); - // 2 - renderSurface(&surfacePainter, - TQRect(10, 0, 11, tileHeight), - fg, fg.light(105), cg.highlight(), 2*(_contrast/3), - reverseLayout ? Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_BottomLeft|Is_Horizontal - : Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperRight|Round_BottomRight|Is_Horizontal); - // 1 - renderSurface(&surfacePainter, - TQRect(0, 0, 11, tileHeight), - fg.light(105), fg, cg.highlight(), 2*(_contrast/3), - reverseLayout ? Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_BottomLeft|Is_Horizontal - : Draw_Right|Draw_Left|Draw_Top|Draw_Bottom| - Round_UpperRight|Round_BottomRight|Is_Horizontal); - - surfacePainter.end(); - int staticShift = 0; - int animShift = 0; - if (!_animateProgressBar) { - staticShift = (reverseLayout ? Rsurface.left() : Rsurface.right()) % 40 - 40; - } else { - // find the animation Offset for the current Widget - TQWidget* nonConstWidget = const_cast<TQWidget*>(widget); - TQMapConstIterator<TQWidget*, int> iter = progAnimWidgets.find(nonConstWidget); - if (iter != progAnimWidgets.end()) - animShift = iter.data(); - } - while((counter*10) < (Rsurface.width()+20)) { - counter++; - if (reverseLayout) { - // from right to left, overlap 1 pixel with the previously drawn tile - p->drawPixmap(Rsurface.right()-counter*20-animShift+40+staticShift, r.top()+1, - surfaceTile); - } else { - // from left to right, overlap 1 pixel with the previously drawn tile - p->drawPixmap(Rsurface.left()+counter*20+animShift-40+staticShift, r.top()+1, - surfaceTile); - } - } - - p->setClipping(false); - } - - break; - } - - // TABS - // ---- - case CE_TabBarTab: { - bool cornerWidget = false; - if (!ceData.tabBarData.cornerWidgets[TQStyleControlElementTabBarData::CWL_TopLeft].widgetObjectTypes.isEmpty()) { - cornerWidget = true; - } - TQTabBar::Shape tbs = ceData.tabBarData.shape; - bool selected = false; - if (flags & Style_Selected) selected = true; - TabPosition pos; - if (ceData.tabBarData.tabCount == 1) { - pos = Single; - } else if (ceData.tabBarData.identIndexMap[opt.tab()->identifier()] == 0) { - pos = First; - } else if (ceData.tabBarData.identIndexMap[opt.tab()->identifier()] == (ceData.tabBarData.tabCount - 1)) { - pos = Last; - } else { - pos = Middle; - } - - bool mouseOver = false; - if (opt.tab() == opt.hoverTab()) { - mouseOver = true; - flags |= Style_MouseOver; - } - - switch (tbs) { - case TQTabBar::TriangularAbove: -// renderTriangularTab(p, r, cg, (flags & Style_MouseOver), selected, false, pos); - renderTab(p, r, cg, mouseOver, selected, false, pos, true, cornerWidget); - break; - case TQTabBar::RoundedAbove: - renderTab(p, r, cg, mouseOver, selected, false, pos, false, cornerWidget); - break; - case TQTabBar::TriangularBelow: -// renderTriangularTab(p, r, cg, (flags & Style_MouseOver), selected, true, pos); - renderTab(p, r, cg, mouseOver, selected, true, pos, true, cornerWidget); - break; - case TQTabBar::RoundedBelow: - renderTab(p, r, cg, mouseOver, selected, true, pos, false, cornerWidget); - break; - default: - TDEStyle::drawControl(element, p, ceData, elementFlags, r, cg, flags, opt, widget); - } - - break; - } - - case CE_PushButton: { - TQPushButton *button = (TQPushButton *)widget; - - const bool isDefault = enabled && (elementFlags & CEF_IsDefault); - - if ( elementFlags & CEF_IsFlat ) - flatMode = true; - - TQColorGroup g2 = cg; - if (isDefault) - g2.setColor(TQColorGroup::Background, cg.background().dark(120) ); - drawPrimitive(PE_ButtonBevel, p, ceData, elementFlags, - isDefault?TQRect(r.x()+1,r.y()+1,r.width()-2,r.height()-2):r, - g2, flags, TQStyleOption(button) ); - - if (isDefault ) { - drawPrimitive(PE_ButtonDefault, p, ceData, elementFlags, r, cg, flags); - } - - break; - } - - case CE_PushButtonLabel: - { - int x, y, w, h; - r.rect( &x, &y, &w, &h ); - - const TQPushButton* button = static_cast<const TQPushButton *>( widget ); - bool active = (elementFlags & CEF_IsOn) || (elementFlags & CEF_IsDown); - bool cornArrow = false; - - // Shift button contents if pushed. - if ( active ) - { - x += pixelMetric(PM_ButtonShiftHorizontal, ceData, elementFlags, widget); - y += pixelMetric(PM_ButtonShiftVertical, ceData, elementFlags, widget); - flags |= Style_Sunken; - } - - // Does the button have a popup menu? - if ( elementFlags & CEF_IsMenuWidget ) - { - int dx = pixelMetric( PM_MenuButtonIndicator, ceData, elementFlags, widget ); - if ( !ceData.iconSet.isNull() && - (dx + ceData.iconSet.pixmap (TQIconSet::Small, TQIconSet::Normal, TQIconSet::Off ).width()) >= w ) - { - cornArrow = true; //To little room. Draw the arrow in the corner, don't adjust the widget - } - else - { - p->setPen(cg.buttonText()); - drawPrimitive( PE_ArrowDown, p, ceData, elementFlags, visualRect( TQRect(x + w - dx - 8, y + 2, dx, h - 4), r ), - cg, flags, opt ); - w -= dx; - } - } - - // Draw the icon if there is one - if ( !ceData.iconSet.isNull() ) - { - TQIconSet::Mode mode = TQIconSet::Disabled; - TQIconSet::State state = TQIconSet::Off; - - if (elementFlags & CEF_IsEnabled) - mode = (elementFlags & CEF_HasFocus) ? TQIconSet::Active : TQIconSet::Normal; - if ((elementFlags & CEF_BiState) && (elementFlags & CEF_IsOn)) - state = TQIconSet::On; - - TQPixmap pixmap = ceData.iconSet.pixmap( TQIconSet::Small, mode, state ); - - if (ceData.text.isEmpty() && ceData.fgPixmap.isNull()) - p->drawPixmap( x + w/2 - pixmap.width()/2, y + h / 2 - pixmap.height() / 2, - pixmap ); - else - p->drawPixmap( x + 4, y + h / 2 - pixmap.height() / 2, pixmap ); - - if (cornArrow) //Draw over the icon - drawPrimitive( PE_ArrowDown, p, ceData, elementFlags, visualRect( TQRect(x + w - 6, x + h - 6, 7, 7), r ), - cg, flags, opt ); - - - int pw = pixmap.width(); - x += pw + 4; - w -= pw + 4; - } - - // Make the label indicate if the button is a default button or not - drawItem( p, TQRect(x, y, w, h), AlignCenter|ShowPrefix, ceData.colorGroup, - (elementFlags & CEF_IsEnabled), (ceData.fgPixmap.isNull())?NULL:&ceData.fgPixmap, ceData.text, -1, - &ceData.colorGroup.buttonText() ); - - - if ( flags & Style_HasFocus ) - drawPrimitive( PE_FocusRect, p, ceData, elementFlags, - visualRect( subRect( SR_PushButtonFocusRect, ceData, elementFlags, widget ), ceData, elementFlags ), - cg, flags ); - break; - } - - // MENUBAR ITEM (sunken panel on mouse over) - // ----------------------------------------- - case CE_MenuBarItem: { - TQMenuItem *mi = opt.menuItem(); - bool active = flags & Style_Active; - bool focused = flags & Style_HasFocus; - bool down = flags & Style_Down; - const int text_flags = - AlignVCenter | AlignHCenter | ShowPrefix | DontClip | SingleLine; - - p->fillRect(r, cg.background()); - - if (active && focused) { - if (down) { - drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, r, cg, flags|Style_Down, opt); - } else { - drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, r, cg, flags, opt); - } - } - - p->setPen(cg.foreground() ); - p->drawText(r, text_flags, mi->text()); - break; - } - - // POPUPMENU ITEM (highlighted on mouseover) - // ------------------------------------------ - case CE_PopupMenuItem: { - TQMenuItem *mi = opt.menuItem(); - - if ( !mi ) - { - // Don't leave blank holes if we set NoBackground for the TQPopupMenu. - // This only happens when the popupMenu spans more than one column. - if ( ceData.bgPixmap.isNull() ) - p->fillRect( r, cg.background().light( 105 ) ); - - break; - } - int tab = opt.tabWidth(); - int checkcol = opt.maxIconWidth(); - bool enabled = mi->isEnabled(); - bool checkable = (elementFlags & CEF_IsCheckable); - bool active = flags & Style_Active; - bool etchtext = styleHint( SH_EtchDisabledText, ceData, elementFlags ); - bool reverse = TQApplication::reverseLayout(); - if ( checkable ) - checkcol = QMAX( checkcol, 20 ); - - // Draw the menu item background - if (active) { - if (enabled) { - renderSurface(p, r, cg.background(), cg.highlight(), cg.highlight(), - _contrast+3, Draw_Top|Draw_Bottom|Is_Horizontal); - } - else { - if ( ceData.bgPixmap.isNull() ) - p->drawPixmap( r.topLeft(), ceData.bgPixmap, r ); - else p->fillRect( r, cg.background().light(105) ); - if(_drawFocusRect) - p->drawWinFocusRect( r ); - } - } - // Draw the transparency pixmap - else if ( !ceData.bgPixmap.isNull() ) - p->drawPixmap( r.topLeft(), ceData.bgPixmap, r ); - // Draw a solid background - else - p->fillRect( r, cg.background().light( 105 ) ); - // Are we a menu item separator? - if ( mi->isSeparator() ) - { - p->setPen( cg.mid() ); - p->drawLine( r.x()+5, r.y() + 1, r.right()-5, r.y() + 1 ); - p->setPen( cg.light() ); - p->drawLine( r.x()+5, r.y() + 2, r.right()-5 , r.y() + 2 ); - break; - } - - TQRect cr = visualRect( TQRect( r.x() + 2, r.y() + 2, checkcol - 1, r.height() - 4 ), r ); - // Do we have an icon? - if ( mi->iconSet() ) - { - TQIconSet::Mode mode; - - // Select the correct icon from the iconset - if (active) - mode = enabled?TQIconSet::Active:TQIconSet::Disabled; - else - mode = enabled?TQIconSet::Normal:TQIconSet::Disabled; - - // Do we have an icon and are checked at the same time? - // Then draw a "pressed" background behind the icon - if ( checkable && /*!active &&*/ mi->isChecked() ) - drawPrimitive(PE_MenuItemIndicatorIconFrame, p, ceData, elementFlags, r, cg, flags, opt); - // Draw the icon - TQPixmap pixmap = mi->iconSet()->pixmap(TQIconSet::Small, mode); - TQRect pmr( 0, 0, pixmap.width(), pixmap.height() ); - pmr.moveCenter( cr.center() ); - p->drawPixmap( pmr.topLeft(), pixmap ); - } - - // Are we checked? (This time without an icon) - else if ( checkable && mi->isChecked() ) - { - // We only have to draw the background if the menu item is inactive - - // if it's active the "pressed" background is already drawn - // if ( ! active ) - drawPrimitive(PE_MenuItemIndicatorFrame, p, ceData, elementFlags, r, cg, flags, opt); - - drawPrimitive(PE_MenuItemIndicatorCheck, p, ceData, elementFlags, r, cg, flags, opt); - } - - // Time to draw the menu item label... - int xm = 2 + checkcol + 2; // X position margin - - int xp = reverse ? // X position - r.x() + tab + rightBorder + itemHMargin + itemFrame - 1 : - r.x() + xm; - - int offset = reverse ? -1 : 1; // Shadow offset for etched text - - // Label width (minus the width of the accelerator portion) - int tw = r.width() - xm - tab - arrowHMargin - itemHMargin * 3 - itemFrame + 1; - - // Set the color for enabled and disabled text - // (used for both active and inactive menu items) - p->setPen( enabled ? cg.buttonText() : cg.mid() ); - - // This color will be used instead of the above if the menu item - // is active and disabled at the same time. (etched text) - TQColor discol = cg.mid(); - - // Does the menu item draw it's own label? - if ( mi->custom() ) { - int m = 2; - // Save the painter state in case the custom - // paint method changes it in some way - p->save(); - - // Draw etched text if we're inactive and the menu item is disabled - if ( etchtext && !enabled && !active ) { - p->setPen( cg.light() ); - mi->custom()->paint( p, cg, active, enabled, xp+offset, r.y()+m+1, tw, r.height()-2*m ); - p->setPen( discol ); - } - mi->custom()->paint( p, cg, active, enabled, xp, r.y()+m, tw, r.height()-2*m ); - p->restore(); - } - else { - // The menu item doesn't draw it's own label - TQString s = mi->text(); - // Does the menu item have a text label? - if ( !s.isNull() ) { - int t = s.find( '\t' ); - int m = 2; - int text_flags = AlignVCenter | ShowPrefix | DontClip | SingleLine; - text_flags |= reverse ? AlignRight : AlignLeft; - - //TQColor draw = cg.text(); - TQColor draw = (active && enabled) ? cg.highlightedText () : cg.foreground(); - p->setPen(draw); - - - // Does the menu item have a tabstop? (for the accelerator text) - if ( t >= 0 ) { - int tabx = reverse ? r.x() + rightBorder + itemHMargin + itemFrame : - r.x() + r.width() - tab - rightBorder - itemHMargin - itemFrame; - - // Draw the right part of the label (accelerator text) - if ( etchtext && !enabled ) { - // Draw etched text if we're inactive and the menu item is disabled - p->setPen( cg.light() ); - p->drawText( tabx+offset, r.y()+m+1, tab, r.height()-2*m, text_flags, s.mid( t+1 ) ); - p->setPen( discol ); - } - p->drawText( tabx, r.y()+m, tab, r.height()-2*m, text_flags, s.mid( t+1 ) ); - s = s.left( t ); - } - - // Draw the left part of the label (or the whole label - // if there's no accelerator) - if ( etchtext && !enabled ) { - // Etched text again for inactive disabled menu items... - p->setPen( cg.light() ); - p->drawText( xp+offset, r.y()+m+1, tw, r.height()-2*m, text_flags, s, t ); - p->setPen( discol ); - } - - - p->drawText( xp, r.y()+m, tw, r.height()-2*m, text_flags, s, t ); - - p->setPen(cg.text()); - - } - - // The menu item doesn't have a text label - // Check if it has a pixmap instead - else if ( mi->pixmap() ) { - TQPixmap *pixmap = mi->pixmap(); - - // Draw the pixmap - if ( pixmap->depth() == 1 ) - p->setBackgroundMode( Qt::OpaqueMode ); - - int diffw = ( ( r.width() - pixmap->width() ) / 2 ) - + ( ( r.width() - pixmap->width() ) % 2 ); - p->drawPixmap( r.x()+diffw, r.y()+1, *pixmap ); - - if ( pixmap->depth() == 1 ) - p->setBackgroundMode( Qt::TransparentMode ); - } - } - - // Does the menu item have a submenu? - if ( mi->popup() ) { - TQ_PrimitiveElement arrow = reverse ? PE_ArrowLeft : PE_ArrowRight; - int dim = pixelMetric(PM_MenuButtonIndicator, ceData, elementFlags) - 1; - TQRect vr = visualRect( TQRect( r.x() + r.width() - 5 - 1 - dim, - r.y() + r.height() / 2 - dim / 2, dim, dim), r ); - - // Draw an arrow at the far end of the menu item - if ( active ) { - if ( enabled ) - discol = cg.buttonText(); - - TQColorGroup g2( discol, cg.highlight(), white, white, - enabled ? white : discol, discol, white ); - - drawPrimitive( arrow, p, ceData, elementFlags, vr, g2, Style_Enabled ); - } else - drawPrimitive( arrow, p, ceData, elementFlags, vr, cg, - enabled ? Style_Enabled : Style_Default ); - } - break; - } - - // Menu and dockwindow empty space - // - case CE_DockWindowEmptyArea: - p->fillRect(r, cg.background()); - break; - - case CE_MenuBarEmptyArea: - p->fillRect(r, cg.background()); - -// if ( _drawToolBarSeparator ) { -// p->setPen( getColor(cg, PanelDark) ); -// p->drawLine( r.left(), r.bottom(), r.right(), r.bottom() ); -// } - - break; - - default: - TDEStyle::drawControl(element, p, ceData, elementFlags, r, cg, flags, opt, widget); - } -} - -void PlastikStyle::drawControlMask(TQ_ControlElement element, - TQPainter *p, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQRect &r, - const TQStyleOption &opt, - const TQWidget *w) const -{ - switch (element) { - case CE_PushButton: { - p->fillRect (r, color0); - renderMask(p, r, color1, - Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight); - break; - } - - default: { - TDEStyle::drawControlMask (element, p, ceData, elementFlags, r, opt, w); - } - } -} - -void PlastikStyle::drawComplexControlMask(TQ_ComplexControl c, - TQPainter *p, - const TQStyleControlElementData &ceData, - const ControlElementFlags elementFlags, - const TQRect &r, - const TQStyleOption &o, - const TQWidget *w) const -{ - switch (c) { - case CC_SpinWidget: - case CC_ListView: - case CC_ComboBox: { - p->fillRect (r, color0); - renderMask(p, r, color1, - Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight); - break; - } - default: { - TDEStyle::drawComplexControlMask (c, p, ceData, elementFlags, r, o, w); - } - } -} - -void PlastikStyle::drawComplexControl(TQ_ComplexControl control, - TQPainter *p, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQRect &r, - const TQColorGroup &cg, - SFlags flags, - SCFlags controls, - SCFlags active, - const TQStyleOption& opt, - const TQWidget *widget) const -{ - const bool reverseLayout = TQApplication::reverseLayout(); - - const bool enabled = (flags & Style_Enabled); - - switch(control) { - // COMBOBOX - // -------- - case CC_ComboBox: { - static const unsigned int handleWidth = 15; - - const TQComboBox *cb = dynamic_cast<const TQComboBox *>(widget); - bool editable = false; - bool hasFocus = false; - editable = (elementFlags & CEF_IsEditable); - hasFocus = (elementFlags & CEF_HasFocus); - - const TQColor buttonColor = enabled?cg.button():cg.background(); - const TQColor inputColor = enabled?(editable?cg.base():cg.button()) - :cg.background(); - - uint contourFlags = 0; - if( tdehtmlWidgets.contains(cb) ) - contourFlags |= Draw_AlphaBlend; - - if (_inputFocusHighlight && hasFocus && editable && enabled) - { - TQRect editField = querySubControlMetrics(control, ceData, elementFlags, SC_ComboBoxEditField, TQStyleOption::Default, widget); - TQRect editFrame = r; - TQRect buttonFrame = r; - - uint editFlags = contourFlags; - uint buttonFlags = contourFlags; - - // Hightlight only the part of the contour next to the control button - if (reverseLayout) - { - // querySubControlMetrics doesn't work right for reverse Layout - int dx = r.right() - editField.right(); - editFrame.setLeft(editFrame.left() + dx); - buttonFrame.setRight(editFrame.left() - 1); - editFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight|Round_BottomRight; - buttonFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft; - } - else - { - editFrame.setRight(editField.right()); - buttonFrame.setLeft(editField.right() + 1); - - editFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft; - buttonFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight|Round_BottomRight; - } - renderContour(p, editFrame, cg.background(), getColor(cg,FocusHighlight,enabled), editFlags); - renderContour(p, buttonFrame, cg.background(), - getColor(cg, ButtonContour, enabled), buttonFlags); - } - else - { - contourFlags |= Draw_Left|Draw_Right|Draw_Top|Draw_Bottom| - Round_UpperLeft|Round_UpperRight|Round_BottomLeft|Round_BottomRight; - renderContour(p, r, cg.background(), getColor(cg, ButtonContour, enabled), contourFlags); - } - //extend the contour: between input and handler... - p->setPen(alphaBlendColors(cg.background(), getColor(cg, ButtonContour, enabled), 50) ); - if(reverseLayout) { - p->drawLine(r.left()+1+handleWidth, r.top()+1, r.left()+1+handleWidth, r.bottom()-1); - } else { - p->drawLine(r.right()-handleWidth-1, r.top()+1, r.right()-handleWidth-1, r.bottom()-1); - } - - const TQRect RbuttonSurface(reverseLayout?r.left()+1:r.right()-handleWidth, r.top()+1, - handleWidth, r.height()-2); - const TQRect RcontentSurface(reverseLayout?r.left()+1+handleWidth+1:r.left()+1, r.top()+1, - r.width()-handleWidth-3, r.height()-2); - - // handler - - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(reverseLayout) { - surfaceFlags |= Round_UpperLeft|Round_BottomLeft; - } else { - surfaceFlags |= Round_UpperRight|Round_BottomRight; - } - - if (flags & Style_MouseOver) { - surfaceFlags |= Is_Highlight; - if(editable) surfaceFlags |= Highlight_Left|Highlight_Right; - surfaceFlags |= Highlight_Top|Highlight_Bottom; - } - renderSurface(p, RbuttonSurface, - cg.background(), buttonColor, getColor(cg,MouseOverHighlight), enabled?_contrast+3:(_contrast/2), - surfaceFlags); - - if(!editable) { - surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(reverseLayout) { - surfaceFlags |= Round_UpperRight|Round_BottomRight; - } else { - surfaceFlags |= Round_UpperLeft|Round_BottomLeft; - } - - if (flags & Style_MouseOver) { - surfaceFlags |= Is_Highlight; - surfaceFlags |= Highlight_Top|Highlight_Bottom; - } - renderSurface(p, RcontentSurface, - cg.background(), buttonColor, getColor(cg,MouseOverHighlight), enabled?_contrast+3:(_contrast/2), - surfaceFlags); - if (hasFocus) { - drawPrimitive(PE_FocusRect, p, ceData, elementFlags, - TQRect(RcontentSurface.x() + 2, - RcontentSurface.y() + 2, - RcontentSurface.width() - 4, - RcontentSurface.height() - 4), cg); - } - } else { - // thin frame around the input area - if (_inputFocusHighlight && hasFocus && editable && enabled) - { - p->setPen( getColor(cg,FocusHighlight).dark(130) ); - } - else - { - p->setPen(inputColor.dark(130) ); - } - p->drawLine(RcontentSurface.x(), reverseLayout?RcontentSurface.y():RcontentSurface.y()+1, - RcontentSurface.x(), reverseLayout?RcontentSurface.bottom():RcontentSurface.bottom()-1); - p->drawLine(RcontentSurface.x()+1, RcontentSurface.y(), - reverseLayout?RcontentSurface.right()-1:RcontentSurface.right(), RcontentSurface.y() ); - if (_inputFocusHighlight && hasFocus && editable && enabled) - { - p->setPen( getColor(cg,FocusHighlight).light(130) ); - } - else - { - p->setPen(inputColor.light(130) ); - } - p->drawLine(reverseLayout?RcontentSurface.x():RcontentSurface.x()+1, RcontentSurface.bottom(), - reverseLayout?RcontentSurface.right()-1:RcontentSurface.right(), RcontentSurface.bottom() ); - p->drawLine(RcontentSurface.right(), RcontentSurface.top()+1, - RcontentSurface.right(), RcontentSurface.bottom()-1 ); - - // input area - p->fillRect(RcontentSurface.x()+1, RcontentSurface.y()+1, - RcontentSurface.width()-2, RcontentSurface.height()-2, inputColor ); - } - - p->setPen(cg.foreground()); - drawPrimitive(PE_SpinWidgetDown, p, ceData, elementFlags, RbuttonSurface, cg, Style_Default|Style_Enabled|Style_Raised); - - // TQComboBox draws the text using cg.text(), we can override this - // from here - p->setPen( cg.buttonText() ); - p->setBackgroundColor( cg.button() ); - break; - } - - // TOOLBUTTON - // ---------- - case CC_ToolButton: { - TQRect button, menuarea; - button = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButton, opt, widget); - menuarea = querySubControlMetrics(control, ceData, elementFlags, SC_ToolButtonMenu, opt, widget); - - SFlags bflags = flags, - mflags = flags; - - if (kornMode) { - drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, button, cg, bflags, opt); - break; - } else { - // don't want to have the buttoncolor as the background... - p->fillRect(r, cg.background()); - bflags &= ~Style_MouseOver; - } - - if (active & SC_ToolButton) - bflags |= Style_Down; - - if (active & SC_ToolButtonMenu) - mflags |= Style_Down; - - if (controls & SC_ToolButton) { - // If we're pressed, on, or raised... - if (bflags & (Style_Down | Style_On | Style_Raised) || (flags & Style_MouseOver) ) { - drawPrimitive(PE_ButtonTool, p, ceData, elementFlags, button, cg, bflags, opt); - } else if ((elementFlags & CEF_HasParentWidget) && - !ceData.parentWidgetData.bgPixmap.isNull()) { - TQPixmap pixmap = ceData.parentWidgetData.bgPixmap; - p->drawTiledPixmap( r, pixmap, ceData.pos ); - } - } - - // Draw a toolbutton menu indicator if required - if (controls & SC_ToolButtonMenu) { - if (mflags & (Style_Down | Style_On | Style_Raised)) { - drawPrimitive(PE_ButtonDropDown, p, ceData, elementFlags, menuarea, cg, mflags, opt); - } - drawPrimitive(PE_ArrowDown, p, ceData, elementFlags, menuarea, cg, mflags, opt); - } - - if ((elementFlags & CEF_HasFocus) && !(elementFlags & CEF_HasFocusProxy)) { - TQRect fr = ceData.rect; - fr.addCoords(2, 2, -2, -2); - drawPrimitive(PE_FocusRect, p, ceData, elementFlags, fr, cg); - } - - // Set the color for the ToolButton menu indicator - p->setPen(cg.buttonText() ); - - break; - } - - // SPINWIDGETS - // ----------- - case CC_SpinWidget: { - static const unsigned int handleWidth = 15; - - const TQSpinWidget *sw = dynamic_cast<const TQSpinWidget *>(widget); - SFlags sflags = flags; - TQ_PrimitiveElement pe; - - bool hasFocus = false; - if (sw) - hasFocus = sw->hasFocus(); - - const TQColor buttonColor = enabled?cg.button():cg.background(); - const TQColor inputColor = enabled?cg.base():cg.background(); - - // contour - const bool heightDividable = ((r.height()%2) == 0); - if (_inputFocusHighlight && hasFocus && enabled) - { - TQRect editField = querySubControlMetrics(control, ceData, elementFlags, SC_SpinWidgetEditField, TQStyleOption::Default, widget); - TQRect editFrame = r; - TQRect buttonFrame = r; - - uint editFlags = 0; - uint buttonFlags = 0; - - // Hightlight only the part of the contour next to the control buttons - if (reverseLayout) - { - // querySubControlMetrics doesn't work right for reverse Layout - int dx = r.right() - editField.right(); - editFrame.setLeft(editFrame.left() + dx); - buttonFrame.setRight(editFrame.left() - 1); - editFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight|Round_BottomRight; - buttonFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft; - } - else - { - editFrame.setRight(editField.right()); - buttonFrame.setLeft(editField.right() + 1); - - editFlags |= Draw_Left|Draw_Top|Draw_Bottom|Round_UpperLeft|Round_BottomLeft; - buttonFlags |= Draw_Right|Draw_Top|Draw_Bottom|Round_UpperRight|Round_BottomRight; - } - renderContour(p, editFrame, cg.background(), cg.highlight(), editFlags); - renderContour(p, buttonFrame, cg.background(), - getColor(cg, ButtonContour, enabled), buttonFlags); - } - else - { - renderContour(p, querySubControlMetrics(control, ceData, elementFlags, SC_SpinWidgetFrame, TQStyleOption::Default, widget), - cg.background(), getColor(cg, ButtonContour, enabled) ); - } - p->setPen(alphaBlendColors(cg.background(), getColor(cg, ButtonContour, enabled), 50) ); - p->drawLine(reverseLayout?r.left()+1+handleWidth:r.right()-handleWidth-1, r.top()+1, - reverseLayout?r.left()+1+handleWidth:r.right()-handleWidth-1, r.bottom()-1); - p->drawLine(reverseLayout?r.left()+1:r.right()-handleWidth, r.top()+1+(r.height()-2)/2, - reverseLayout?r.left()+handleWidth:r.right()-1, r.top()+1+(r.height()-2)/2); - if(heightDividable) - p->drawLine(reverseLayout?r.left()+1:r.right()-handleWidth, r.top()+1+(r.height()-2)/2-1, - reverseLayout?r.left()+handleWidth:r.right()-1, r.top()+1+(r.height()-2)/2-1); - - // surface - TQRect upRect = TQRect(reverseLayout?r.left()+1:r.right()-handleWidth, r.top()+1, - handleWidth, (r.height()-2)/2); - TQRect downRect = TQRect(reverseLayout?r.left()+1:r.right()-handleWidth, - heightDividable?r.top()+1+((r.height()-2)/2):r.top()+1+((r.height()-2)/2)+1, - handleWidth, ((r.height()-2)/2) ); - if(heightDividable) { - upRect = TQRect(upRect.left(), upRect.top(), upRect.width(), upRect.height()-1 ); - downRect = TQRect(downRect.left(), downRect.top()+1, downRect.width(), downRect.height()-1 ); - } - - uint surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(reverseLayout) { - surfaceFlags |= Round_UpperLeft; - } else { - surfaceFlags |= Round_UpperRight; - } - if (sflags & Style_MouseOver) { - surfaceFlags |= Is_Highlight; - surfaceFlags |= Highlight_Top|Highlight_Left|Highlight_Right; - } - if (active==SC_SpinWidgetUp) surfaceFlags|=Is_Sunken; - if(!enabled) surfaceFlags|=Is_Disabled; - renderSurface(p, upRect, cg.background(), buttonColor, getColor(cg,MouseOverHighlight), - _contrast, surfaceFlags); - surfaceFlags = Draw_Left|Draw_Right|Draw_Top|Draw_Bottom|Is_Horizontal; - if(reverseLayout) { - surfaceFlags |= Round_BottomLeft; - } else { - surfaceFlags |= Round_BottomRight; - } - if (sflags & Style_MouseOver) { - surfaceFlags |= Is_Highlight; - surfaceFlags |= Highlight_Bottom|Highlight_Left|Highlight_Right; - } - if (active==SC_SpinWidgetDown) surfaceFlags|=Is_Sunken; - if(!enabled) surfaceFlags|=Is_Disabled; - renderSurface(p, downRect, cg.background(), buttonColor, getColor(cg,MouseOverHighlight), - _contrast, surfaceFlags); - - // icons... - sflags = Style_Default | Style_Enabled; - if (active == SC_SpinWidgetUp) { - sflags |= Style_On; - sflags |= Style_Sunken; - } else - sflags |= Style_Raised; - if (sw->buttonSymbols() == TQSpinWidget::PlusMinus) - pe = PE_SpinWidgetPlus; - else - pe = PE_SpinWidgetUp; - p->setPen(cg.foreground()); - drawPrimitive(pe, p, ceData, elementFlags, upRect, cg, sflags); - - sflags = Style_Default | Style_Enabled; - if (active == SC_SpinWidgetDown) { - sflags |= Style_On; - sflags |= Style_Sunken; - } else - sflags |= Style_Raised; - if (sw->buttonSymbols() == TQSpinWidget::PlusMinus) - pe = PE_SpinWidgetMinus; - else - pe = PE_SpinWidgetDown; - p->setPen(cg.foreground()); - drawPrimitive(pe, p, ceData, elementFlags, downRect, cg, sflags); - - // thin frame around the input area - const TQRect Rcontent = TQRect(reverseLayout?r.left()+1+handleWidth+1:r.left()+1, r.top()+1, - r.width()-1-2-handleWidth, r.height()-2); - if (_inputFocusHighlight && hasFocus && enabled) - { - p->setPen( getColor(cg,FocusHighlight).dark(130) ); - } - else - { - p->setPen(inputColor.dark(130) ); - } - p->drawLine(Rcontent.left(), reverseLayout?Rcontent.top():Rcontent.top()+1, - Rcontent.left(), reverseLayout?Rcontent.bottom():Rcontent.bottom()-1 ); - p->drawLine(Rcontent.left()+1, Rcontent.top(), - reverseLayout?Rcontent.right()-1:Rcontent.right(), Rcontent.top() ); - if (_inputFocusHighlight && hasFocus && enabled) - { - p->setPen( getColor(cg,FocusHighlight).light(130) ); - } - else - { - p->setPen(inputColor.light(130) ); - } - p->drawLine(Rcontent.left()+1, Rcontent.bottom(), Rcontent.right()-1, Rcontent.bottom() ); - p->drawLine(Rcontent.right(), Rcontent.top()+1, - Rcontent.right(), reverseLayout?Rcontent.bottom()-1:Rcontent.bottom() ); - - break; - } - - default: - TDEStyle::drawComplexControl(control, p, ceData, elementFlags, - r, cg, flags, controls, - active, opt, widget); - break; - } -} - - -TQRect PlastikStyle::subRect(SubRect r, const TQStyleControlElementData &ceData, const ControlElementFlags elementFlags, const TQWidget *widget) const -{ - switch (r) { - case SR_ComboBoxFocusRect: { - return querySubControlMetrics( CC_ComboBox, ceData, elementFlags, SC_ComboBoxEditField, TQStyleOption::Default, widget ); - } - - // Don't use TDEStyles progressbar subrect - // TODO: - case SR_ProgressBarGroove: { - return TQRect(ceData.rect); - } - case SR_ProgressBarContents: - case SR_ProgressBarLabel: { - TQRect rw = ceData.rect; - return TQRect(rw.left()+2, rw.top()+2, rw.width()-4, rw.height()-4 ); - } - - default: { - return TDEStyle::subRect(r, ceData, elementFlags, widget); - } - } -} - -TQRect PlastikStyle::querySubControlMetrics(TQ_ComplexControl control, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - SubControl subcontrol, - const TQStyleOption &opt, - const TQWidget *widget) const -{ - TQRect r(ceData.rect); - switch (control) { - case CC_ComboBox: { - switch (subcontrol) { - case SC_ComboBoxEditField: { - // TODO: is the handler width in pixelmetric? - return TQRect(r.left()+2, r.top()+2, r.width()-4-15-1, r.height()-4); - } - default: { - return TDEStyle::querySubControlMetrics(control, ceData, elementFlags, subcontrol, opt, widget); - } - } - break; - } - case CC_SpinWidget: { - const int fw = 2; // Frame width... - - const bool heightDividable = ((r.height()%2) == 0); - - TQSize bs; - if(heightDividable) { - bs.setHeight(QMAX(8, (r.height()-2)/2)); - } else { - bs.setHeight(QMAX(8, (r.height()-2-1)/2)); - } - bs.setWidth(15); - - const int buttonsLeft = /*reverseLayout?r.left()+1:*/r.right()-bs.width(); - - switch (subcontrol) { - case SC_SpinWidgetUp: { - return TQRect(buttonsLeft, r.top()+1, bs.width(), bs.height() ); - } - case SC_SpinWidgetDown: { - if(heightDividable) { - return TQRect(buttonsLeft, r.top()+1+bs.height(), - bs.width(), r.height()-(bs.height()+2) ); - } else { - return TQRect(buttonsLeft, r.top()+1+bs.height()+1, - bs.width(), r.height()-(bs.height()+2+1) ); - } - } - case SC_SpinWidgetFrame: { - return TQRect(r.left(), r.top(), r.width(), r.height() ); - } - case SC_SpinWidgetEditField: { - return TQRect(r.left()+fw, r.top()+fw, - r.width()-(bs.width()+1+2*fw), r.height()-2*fw); - } - case SC_SpinWidgetButtonField: { - return TQRect(buttonsLeft, r.top()+1, bs.width(), r.height()-2); - } - default: { - return TDEStyle::querySubControlMetrics(control, ceData, elementFlags, subcontrol, opt, widget); - } - } - break; - } - default: { - return TDEStyle::querySubControlMetrics(control, ceData, elementFlags, subcontrol, opt, widget); - } - } -} - -int PlastikStyle::pixelMetric(PixelMetric m, const TQStyleControlElementData &ceData, ControlElementFlags elementFlags, const TQWidget *widget) const -{ - switch(m) { - // TABS - // ---- - case PM_TabBarTabVSpace: { - if (ceData.tabBarData.shape == TQTabBar::RoundedAbove || - ceData.tabBarData.shape == TQTabBar::RoundedBelow) - return 12; - else - return 4; - } - - case PM_TabBarTabOverlap: { - return 1; - } - - // extra space between menubar items - case PM_MenuBarItemSpacing: { - return 6; - } - -// // extra space between toolbar items -// case PM_ToolBarItemSpacing: { -// return 4; -// } - - // SCROLL BAR - case PM_ScrollBarSliderMin: { - return 21; - } - case PM_ScrollBarExtent: { - return 16; - } - - case PM_DockWindowSeparatorExtent: - return 6; - - // SPLITTERS - // --------- - case PM_SplitterWidth: { - return 6; - } - - // PROGRESSBARS - // ------------ - case PM_ProgressBarChunkWidth: - return 10; - - // SLIDER - // ------ - case PM_SliderLength: - return 11; - - // MENU INDICATOR - // -------------- - case PM_MenuButtonIndicator: - return 8; - - // CHECKBOXES / RADIO BUTTONS - // -------------------------- - case PM_ExclusiveIndicatorWidth: // Radiobutton size - case PM_ExclusiveIndicatorHeight: // 13x13 - case PM_IndicatorWidth: // Checkbox size - case PM_IndicatorHeight: // 13x13 - return 13; - - // FRAMES - // ------ - case PM_SpinBoxFrameWidth: - return 1; - - case PM_MenuBarFrameWidth: - return 1; - - case PM_DefaultFrameWidth: { - if(widget && ::tqqt_cast<TQPopupMenu*>(widget)) - return 1; - else - return 2; - } - - case PM_ButtonDefaultIndicator: { - return 0; - } - - case PM_ButtonMargin: { - return 2; - } - - case PM_ButtonShiftVertical: - case PM_ButtonShiftHorizontal: { - return 1; - } - - case PM_MenuIndicatorFrameHBorder: - case PM_MenuIndicatorFrameVBorder: - case PM_MenuIconIndicatorFrameHBorder: - case PM_MenuIconIndicatorFrameVBorder: - return 2; - - default: - return TDEStyle::pixelMetric(m, ceData, elementFlags, widget); - } -} - - -TQSize PlastikStyle::sizeFromContents(ContentsType t, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQSize &s, - const TQStyleOption &opt, - const TQWidget *widget) const -{ - switch (t) { - case CT_PopupMenuItem: { - if (!widget || opt.isDefault()) - return s; - - const TQPopupMenu *popup = dynamic_cast<const TQPopupMenu *>(widget); - TQMenuItem *mi = opt.menuItem(); - int maxpmw = opt.maxIconWidth(); - int w = s.width(), h = s.height(); - bool checkable = popup->isCheckable(); - - if (mi->custom()) { - w = mi->custom()->sizeHint().width(); - h = mi->custom()->sizeHint().height(); - if (!mi->custom()->fullSpan() ) - h += 4; - } else if (mi->widget()) { - // don't change the size in this case. - } else if (mi->isSeparator()) { - w = 20; - h = 2; - } else { - if (mi->pixmap()) { - h = QMAX(h, mi->pixmap()->height() + 2); - } else { - h = QMAX(h, 16 + 2 ); - h = QMAX(h, popup->fontMetrics().height() + 4 ); - } - - if (mi->iconSet()) { - h = QMAX(h, mi->iconSet()->pixmap(TQIconSet::Small, TQIconSet::Normal).height() + 2); - } - } - - if (!mi->text().isNull() && (mi->text().find('\t') >= 0)) { - w += itemHMargin + itemFrame*2 + 7; - } else if (mi->popup()) { - w += 2 * arrowHMargin; - } - - if (maxpmw) { - w += maxpmw + 6; - } - if (checkable && maxpmw < 20) { - w += 20 - maxpmw; - } - if (checkable || maxpmw > 0) { - w += 12; - } - - w += rightBorder; - - return TQSize(w, h); - } - - case CT_PushButton: - { - const TQPushButton* btn = static_cast<const TQPushButton*>(widget); - - int w = s.width() + 2 * pixelMetric(PM_ButtonMargin, ceData, elementFlags, widget); - int h = s.height() + 2 * pixelMetric(PM_ButtonMargin, ceData, elementFlags, widget); - if ( btn->text().isEmpty() && s.width() < 32 ) return TQSize(w, h); - - return TQSize( w+25, h+5 ); - } - - case CT_ToolButton: - { - if(widget->parent() && ::tqqt_cast<TQToolBar*>(widget->parent()) ) - return TQSize( s.width()+2*4, s.height()+2*4 ); - else - return TDEStyle::sizeFromContents (t, ceData, elementFlags, s, opt, widget); - } - - default: - return TDEStyle::sizeFromContents (t, ceData, elementFlags, s, opt, widget); - } - - return TDEStyle::sizeFromContents (t, ceData, elementFlags, s, opt, widget); -} - -int PlastikStyle::styleHint( TQ_StyleHint stylehint, - const TQStyleControlElementData &ceData, - ControlElementFlags elementFlags, - const TQStyleOption &option, - TQStyleHintReturn* returnData, - const TQWidget *widget ) const -{ - switch (stylehint) { - case SH_PopupMenu_SubMenuPopupDelay: - return 96; // Motif-like delay... - - case SH_MenuIndicatorColumnWidth: - { - int checkcol = option.maxIconWidth(); - bool checkable = (elementFlags & CEF_IsCheckable); - - if ( checkable ) - checkcol = QMAX( checkcol, 20 ); - - return checkcol; - } - - default: - return TDEStyle::styleHint(stylehint, ceData, elementFlags, option, returnData, widget); - } -} - -bool PlastikStyle::objectEventHandler( const TQStyleControlElementData &ceData, ControlElementFlags elementFlags, void* source, TQEvent *ev ) -{ - if (TDEStyle::objectEventHandler(ceData, elementFlags, source, ev) ) - return true; - - if (ceData.widgetObjectTypes.contains(TQOBJECT_OBJECT_NAME_STRING)) { - TQObject* obj = reinterpret_cast<TQObject*>(source); - - if (!obj->isWidgetType() ) return false; - - // Track show events for progress bars - if ( _animateProgressBar && ::tqqt_cast<TQProgressBar*>(obj) ) - { - if ((ev->type() == TQEvent::Show) && !animationTimer->isActive()) - { - animationTimer->start( 50, false ); - } - } - if ( !qstrcmp(obj->name(), "kde toolbar widget") ) - { - TQWidget* lb = TQT_TQWIDGET(obj); - if (lb->backgroundMode() == TQt::PaletteButton) - lb->setBackgroundMode(TQt::PaletteBackground); - removeObjectEventHandler(ceData, elementFlags, source, this); - } - } - - return false; -} - -TQColor PlastikStyle::getColor(const TQColorGroup &cg, const ColorType t, const bool enabled)const -{ - return getColor(cg, t, enabled?IsEnabled:IsDisabled); -} - -TQColor PlastikStyle::getColor(const TQColorGroup &cg, const ColorType t, const WidgetState s)const -{ - const bool enabled = (s != IsDisabled) && - ((s == IsEnabled) || (s == IsPressed) || (s == IsHighlighted)); - const bool pressed = (s == IsPressed); - const bool highlighted = (s == IsHighlighted); - switch(t) { - case ButtonContour: - return enabled ? cg.button().dark(130+_contrast*8) - : cg.background().dark(120+_contrast*8); - case DragButtonContour: { - if(enabled) { - if(pressed) - return cg.button().dark(130+_contrast*6); // bright - else if(highlighted) - return cg.button().dark(130+_contrast*9); // dark - else - return cg.button().dark(130+_contrast*8); // normal - } else { - return cg.background().dark(120+_contrast*8); - } - } - case DragButtonSurface: { - if(enabled) { - if(pressed) - return cg.button().dark(100-_contrast); // bright - else if(highlighted) - return cg.button().light(100+_contrast); // dark - else - return cg.button(); // normal - } else { - return cg.background(); - } - } - case PanelContour: - return cg.background().dark(160+_contrast*8); - case PanelDark: - return alphaBlendColors(cg.background(), cg.background().dark(120+_contrast*5), 110); - case PanelDark2: - return alphaBlendColors(cg.background(), cg.background().dark(110+_contrast*5), 110); - case PanelLight: - return alphaBlendColors(cg.background(), cg.background().light(120+_contrast*5), 110); - case PanelLight2: - return alphaBlendColors(cg.background(), cg.background().light(110+_contrast*5), 110); - case MouseOverHighlight: - if( _customOverHighlightColor ) - return _overHighlightColor; - else - return cg.highlight(); - case FocusHighlight: - if( _customFocusHighlightColor ) - return _focusHighlightColor; - else - return cg.highlight(); - case CheckMark: - if( _customCheckMarkColor ) - return _checkMarkColor; - else - return cg.foreground(); - default: - return cg.background(); - } -} |