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