/*
  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, 2nd revision:
  Copyright(c)2000-2001 Trolltech AS (info@trolltech.com). The light style
  license is as follows:

  Permission is hereby granted, free of charge, to any person obtaining a
  copy of this software and associated documentation files(the "Software"),
  to deal in the Software without restriction, including without limitation
  the rights to use, copy, modify, merge, publish, distribute, sublicense,
  and/or sell copies of the Software, and to permit persons to whom the
  Software is furnished to do so, subject to the following conditions:

  The above copyright notice and this permission notice shall be included in
  all copies or substantial portions of the Software.

  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
  THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  DEALINGS IN THE SOFTWARE.
*/

/*
TDEHTML
-----
Srollbars:

For some reason Scrollbars in TDEHTML seem to lose the bottom/left pixels. As if TDEHTML 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"
#include "shortcuthandler.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"

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);
        unsigned long prop=((APPEARANCE_STRIPED==app || APPEARANCE_FILE==app ? app : APPEARANCE_FLAT)&0xFF) |
                           (widget->palette().active().background().rgb()&0x00FFFFFF)<<8;

        XChangeProperty(tqt_xdisplay(), w->parentWidget() ? w->parentWidget()->winId() : w->winId(),
                        constAtom, XA_CARDINAL, 32, PropModeReplace, (unsigned char *)&prop, 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 void adjustToolbarButtons(const TQWidget *widget, const TQToolBar *toolbar, int &leftAdjust, int &topAdjust,
                                 int &rightAdjust, int &bottomAdjust, int &round)
{
    const int constAdjust=4;
    const int d = 1;
    TQRect geo(widget->geometry());

    if (TQt::Horizontal==toolbar->orientation())
    {
        bool haveLeft=::tqqt_cast<TQToolButton*>(toolbar->childAt(geo.x()-d, geo.y())),
             haveRight=::tqqt_cast<TQToolButton*>(toolbar->childAt(geo.right()+d, geo.y()));

        if(haveLeft && haveRight)
            leftAdjust=-constAdjust, rightAdjust=constAdjust, round=ROUNDED_NONE;
        else if(haveLeft)
            leftAdjust=-constAdjust, round=ROUNDED_RIGHT;
        else if(haveRight)
            rightAdjust=constAdjust, round=ROUNDED_LEFT;
    }
    else
    {
        bool haveTop=::tqqt_cast<TQToolButton*>(toolbar->childAt(geo.x(), geo.y()-d)),
             haveBot=::tqqt_cast<TQToolButton*>(toolbar->childAt(geo.x(), geo.bottom()+d));

        if(haveTop && haveBot)
            topAdjust=-constAdjust, bottomAdjust=constAdjust, round=ROUNDED_NONE;
        else if(haveTop)
            topAdjust=-constAdjust, round=ROUNDED_BOTTOM;
        else if(haveBot)
            bottomAdjust=constAdjust, round=ROUNDED_TOP;
    }
}

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 && (
                    ::tqqt_cast<TQRadioButton *>(w) ||
                    ::tqqt_cast<TQCheckBox *>(w) ||
                    ::tqqt_cast<TQScrollBar *>(w) ||
                    ::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(), "__tdehtml")) ||
                 (level && isKhtmlWidget(w->parentWidget(), --level)));
}

static bool isKhtmlFormWidget(const TQWidget *widget)
{
    if(isKhtmlWidget(widget))
        return true;

    // Copied from Keramik...

    //Form widgets are in the TDEHTMLView, 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 *potentialTDEHTML(potentialViewPort->parentWidget());

    if (!potentialTDEHTML || potentialTDEHTML->isTopLevel() ||
        qstrcmp(potentialTDEHTML->className(), "TDEHTMLView"))
        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 bool isOnToolbar(const TQWidget *widget, TQPainter *p)
{
    const TQWidget *wid=widget ? widget->parentWidget() : (p && p->device() ? dynamic_cast<TQWidget *>(p->device()) : 0L);

    while(wid)
    {
        if(::tqqt_cast<const TQToolBar *>(wid))
            return true;
        wid=wid->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, TQRgb bgnd, bool horiz, int app, ECacheFlags flags)
{
    TQString key;

    TQTextOStream(&key) << size << '-' << color << '-' << bgnd << '-' << 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),
              itsPopupMenuCols(0L),
              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),
              itsShortcutHandler(new ShortcutHandler(this))
{
#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 ((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(itsPopupMenuCols && itsPopupMenuCols!=itsMenubarCols && itsPopupMenuCols!=itsBackgroundCols && itsPopupMenuCols!=itsActiveMdiColors)
        delete [] itsPopupMenuCols;
    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;
}

inline void addEventFilter(TQObject *object, TQObject *filter)
{
    object->removeEventFilter(filter);
    object->installEventFilter(filter);
}

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
//	BASE_STYLE::polish(app);
	if(opts.hideShortcutUnderline)
		addEventFilter(app, itsShortcutHandler);
    }
}

void QtCurveStyle::applicationUnPolish(const TQStyleControlElementData &ceData, ControlElementFlags elementFlags, void *ptr)
{
    if (ceData.widgetObjectTypes.contains(TQAPPLICATION_OBJECT_NAME_STRING)) {
	TQApplication *app = reinterpret_cast<TQApplication*>(ptr);
	if(opts.hideShortcutUnderline)
		app->removeEventFilter(itsShortcutHandler);
//	BASE_STYLE::unPolish(app);
    }
}

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(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)));
    else if(APPEARANCE_FILE==opts.bgndAppearance)
    {
        TQPixmap       pix(opts.bgndPixmap.img.width(), opts.bgndPixmap.img.height());
        TQPainter      p(&pix);
        WindowBorders borders=qtcGetWindowBorderSize();
        int           xadjust=borders.sides>0 && borders.sides!=opts.bgndPixmap.img.width()
                        ? borders.sides>opts.bgndPixmap.img.width()
                            ? borders.sides%opts.bgndPixmap.img.width()
                            : borders.sides
                        :0,
                      yadjust=borders.titleHeight>0 && borders.titleHeight!=opts.bgndPixmap.img.height()
                        ? borders.titleHeight>opts.bgndPixmap.img.height()
                            ? borders.titleHeight%opts.bgndPixmap.img.height()
                            : borders.titleHeight
                        :0;

        p.fillRect(0, 0, opts.bgndPixmap.img.width(), opts.bgndPixmap.img.height(), pal.active().background());

        p.drawPixmap(-xadjust, -yadjust, opts.bgndPixmap.img);
        if(xadjust>0)
            p.drawPixmap(opts.bgndPixmap.img.width()-xadjust, -yadjust, opts.bgndPixmap.img);
        if(yadjust>0)
            p.drawPixmap(-xadjust, opts.bgndPixmap.img.height()-yadjust, opts.bgndPixmap.img);
        if(xadjust>0 && yadjust>0)
            p.drawPixmap(opts.bgndPixmap.img.width()-xadjust,  opts.bgndPixmap.img.height()-yadjust, opts.bgndPixmap.img);

        p.end();
        pal.setBrush(TQColorGroup::Background, TQBrush(pal.active().background(), pix));
    }
}

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="tde 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(tdehtmlWidgetDestroyed(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(::tqqt_cast<TQDialog *>(widget) || ::tqqt_cast<TQMainWindow *>(widget))
	{
		setBgndProp(widget, opts.bgndAppearance);
		installObjectEventHandler(ceData, elementFlags, ptr, this); // To trap palette change
	}

	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 (!DRAW_MENU_BORDER && !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(!isFormWidget(widget))
			widget->setMouseTracking(true);
		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);
		}
	}
	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());
		setMenuTextColors(widget, true);
	}
	else if(::tqqt_cast<TQToolBar *>(widget))
	{
		if(NoBackground!=widget->backgroundMode())
		widget->setBackgroundMode(PaletteBackground);
	}
	else if(::tqqt_cast<TQPopupMenu *>(widget))
	{
		widget->setBackgroundMode(NoBackground); // PaletteBackground);
		setMenuTextColors(widget, true);
	}
	else if (ceData.widgetObjectTypes.contains("TDEToolBarSeparator") ||
		(ceData.widgetObjectTypes.contains("TDEListViewSearchLineWidget") &&
		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("TDEIO::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(),
						"TDEListViewSearchLineWidget") ||
		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 || APPEARANCE_FILE==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))
	{
		widget->setMouseTracking(false);
		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);
	}
	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("TDEToolBarSeparator"))
	{
		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
		// "tde 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);
			const TQColor *pc(popupMenuCols(widget->palette().active()));
			TQColor   col(pc[ORIGINAL_SHADE]);

			if(APPEARANCE_STRIPED==opts.menuBgndAppearance)
			{
				painter.drawTiledPixmap(ceData.rect, *createStripePixmap(col, false));
			}
			else if(APPEARANCE_FILE==opts.menuBgndAppearance)
			{
				painter.fillRect(widget->rect(), col);
				painter.drawTiledPixmap(widget->rect(), opts.menuBgndPixmap.img);
			}
			else
			{
				drawBevelGradientReal(col, col, &painter, ceData.rect, GT_HORIZ==opts.menuBgndGrad, false,
						opts.menuBgndAppearance, WIDGET_OTHER);
			}
			return false;
		}
		else if (object->inherits("TDEToolBarSeparator"))
		{
			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 recolouring 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;
		}
	if(TQEvent::PaletteChange==event->type() && (::tqqt_cast<TQDialog *>(object) || ::tqqt_cast<TQMainWindow *>(object)))
		setBgndProp(static_cast<TQWidget *>(object), opts.bgndAppearance);
#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 if(opts.highlightScrollViews && ::tqqt_cast<TQScrollView *>(itsHoverWidget))
					itsHoverWidget->repaint(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 TQWidget *widget) const
{
    EAppearance   app(widgetApp(APPEARANCE_NONE!=opts.tbarBtnAppearance &&
                               (WIDGET_TOOLBAR_BUTTON==w || (WIDGET_BUTTON(w) && isOnToolbar(widget, p)))
                                ? WIDGET_TOOLBAR_BUTTON : 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, bgnd, 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], bgnd, p, TQRect(r.x()+so, r.y(), len, r.height()),
                                      horiz, sunken, app, w);
                    drawBevelGradient(itsMouseOverCols[col], bgnd, p, TQRect(r.x()+r.width()-eo, r.y(), len, r.height()),
                                      horiz, sunken, app, w);
                }
                else
                {
                    drawBevelGradient(itsMouseOverCols[col], bgnd, p, TQRect(r.x(), r.y()+so, r.width(), len),
                                      horiz, sunken, app, w);
                    drawBevelGradient(itsMouseOverCols[col], bgnd, 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) && !(opts.thin&THIN_FRAMES) &&
            ((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, w);
    }

    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, EWidget w) const
{
    square=square || ROUND_NONE==opts.round;

    int mod(square ? 0 : 2);

    if(WIDGET_TOOLBAR_BUTTON==w && EFFECT_ETCH==opts.tbarBtnEffect)
        raised=false;

    {
        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;

    if(!(opts.thin&THIN_FRAMES))
        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 (TDEHTML) 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 TDEHTML) 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
                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 && (ceData.widgetObjectTypes.count() > 0) && 0==qstrcmp(ceData.widgetObjectTypes[ceData.widgetObjectTypes.count()-1].ascii(), "TDEPopupTitle"));
                    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), cg.background(), 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, 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)), cg.background(), 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, 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)), cg.background(), 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"))));

//                 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 && opts.highlightScrollViews
                                                            ? flags&Style_MouseOver
                                                                ? ENTRY_MOUSE_OVER
                                                                : flags&Style_HasFocus
                                                                    ? ENTRY_FOCUS
                                                                    : ENTRY_NONE
                                                            : ENTRY_NONE, square ? ROUNDED_NONE : ROUNDED_ALL, WIDGET_SCROLLVIEW);
                    }
                    else
                    {
                        const TQColor *use(sv && opts.highlightScrollViews
                                            ? widget==itsHoverWidget
                                                ? itsMouseOverCols
                                                : flags&Style_HasFocus
                                                    ? itsFocusCols
                                                    : backgroundColors(cg)
                                            : backgroundColors(cg));

                        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(popupMenuCols(cg));
            EGradientBorder border=getGradient(opts.menuBgndAppearance, &opts)->border;

            p->setPen(use[STD_BORDER]);
            p->setBrush(NoBrush);
            p->drawRect(r);

            if(USE_BORDER(border) && APPEARANCE_FLAT!=opts.menuBgndAppearance)
            {
                p->setPen(use[0]);
                if(GB_LIGHT==border)
                    p->drawRect(TQRect(r.x()+1, r.y()+1, r.width()-2, r.height()-2));
                else
                {
                    if(GB_3D==border)
                        p->setPen(use[ORIGINAL_SHADE]);
                    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);
                }
            }
            else if(IS_FLAT_BGND(opts.menuBgndAppearance))
            {
                p->setPen(/*USE_LIGHTER_POPUP_MENU ? */use[ORIGINAL_SHADE]/* : cg.background()*/);
                p->drawRect(TQRect(r.x()+1, r.y()+1, r.width()-2, 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], 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 && (ceData.widgetObjectTypes.count() > 0) && 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 || FOCUS_GLOW==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 tdehtml; the
            // only thing we know is that tdehtml buffers its widgets into a pixmap. So
            // when the paint device is a TQPixmap, chances are high that we are in tdehtml.
            // It's possible that this breaks other things, so let's see how it works...
            if (p->device() && dynamic_cast<TQPixmap*>(p->device()))
                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 && (!scrollView || opts.highlightScrollViews)
                                                ? flags&Style_MouseOver
                                                    ? 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::drawTDEStylePrimitive(TDEStylePrimitive kpe, TQPainter *p, const TQStyleControlElementData &ceData, ControlElementFlags elementFlags,
                                       const TQRect &r, const TQColorGroup &cg, SFlags flags,
                                       const TQStyleOption &opt, const TQWidget *widget) const
{
    ELine handles(kpe!=KPE_ToolBarHandle && LINE_DASHES==opts.handles ? LINE_SUNKEN
                                                                      : opts.handles);

    switch(kpe)
    {
        case KPE_ToolBarHandle:
        {
            if(APPEARANCE_STRIPED!=opts.bgndAppearance && APPEARANCE_FILE!=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(), 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 0
            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);
                }
            }
#endif
            ::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::drawTDEStylePrimitive(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()
//                                          ? ((ceData.widgetObjectTypes.count() > 0) && 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),
                          thin(opts.thin&THIN_FRAMES),
                          drawOuterGlow(glowMo && !thin);
            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, cg.background(), 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(drawOuterGlow)
            {
                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);
                    if(!thin)
                    {
                        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
                {
                    if(!thin)
                    {
                        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 && !thin)
                    {
                        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);
                    if(!thin)
                    {
                        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
                {
                    if(!thin)
                    {
                        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;
        }
        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 | (styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget) ? 0 : NoAccel), 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;
        }
        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 && button->isDefault() ? 2 : 1),
                         textFlags(AlignCenter|ShowPrefix|(styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget) ? 0 : NoAccel));
            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), textFlags, 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;

            //const TQPopupMenu *popupmenu((const QPopupMenu *)widget);
            TQMenuItem        *mi(data.menuItem());
            int              tab(data.tabWidth()),
                             maxpmw(data.maxIconWidth()),
                             x, y, w, h;
            bool             reverse(TQApplication::reverseLayout());
            const TQColor    *use(popupMenuCols(cg));

            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[ORIGINAL_SHADE]);

                if(opts.menuStripe)
                    drawBevelGradient(menuStripeCol(cg), use[ORIGINAL_SHADE], 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[ORIGINAL_SHADE],
                             opts.useHighlightForMenu ? itsHighlightCols : itsBackgroundCols);

            if(!mi)
                break;

            if(mi->isSeparator())
            {
                y=r.y()+(r.height()>>1);
                p->setPen(popupMenuCols(cg)[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')),
                    textFlags=AlignVCenter|ShowPrefix|DontClip|SingleLine;

                if (!styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget))
                    textFlags |= NoAccel;

                // draw accelerator/tab-text
                if(t>=0)
                    p->drawText(tr, textFlags|(reverse ? AlignLeft : AlignRight), text.mid(t+1));

                p->drawText(ir, textFlags|(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|(styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget) ? 0 : NoAccel), 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, cg.background(), 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 TDEStyle 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 &&
                   HOVER_CHECK==itsHover && itsHoverWidget && itsHoverWidget==widget &&
                   !isFormWidget(widget))
                {
                    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()));

                    r-=visualRect(subRect(SR_CheckBoxIndicator, ceData, elementFlags, widget), ceData, elementFlags);
                    p->setClipRegion(r);
                    drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.crHighlight)), cg.background(), p, checkbox->rect(), true,
                                      false, opts.selectionAppearance, WIDGET_SELECTION);
                    p->setClipping(false);
                }
                int alignment(TQApplication::reverseLayout() ? AlignRight : AlignLeft);

                drawItem(p, r, alignment|AlignVCenter|ShowPrefix|(styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget) ? 0 : NoAccel), 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 &&
                   HOVER_RADIO==itsHover && itsHoverWidget && itsHoverWidget==widget &&
                   !isFormWidget(widget))
                {
                    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()));
                    r-=visualRect(subRect(SR_RadioButtonIndicator, ceData, elementFlags, widget), ceData, elementFlags);
                    p->setClipRegion(r);
                    drawBevelGradient(shade(cg.background(), TO_FACTOR(opts.crHighlight)), cg.background(), p, ceData.rect, true,
                                      false, opts.selectionAppearance, WIDGET_SELECTION);
                    p->setClipping(false);
                }

                int alignment(TQApplication::reverseLayout() ? AlignRight : AlignLeft);

                drawItem(p, r, alignment|AlignVCenter|ShowPrefix|(styleHint(SH_UnderlineAccelerator, ceData, elementFlags, data, 0, widget) ? 0 : NoAccel),
                         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;

            int  round(ROUNDED_ALL), leftAdjust(0), topAdjust(0), rightAdjust(0), bottomAdjust(0);
            bool horizTBar(true),
                 raised(!onControlButtons && (TBTN_RAISED==opts.tbarBtns || TBTN_JOINED==opts.tbarBtns));

            if(raised)
            {
                if(tb)
                {
                    if(TBTN_JOINED==opts.tbarBtns)
                    {
                        horizTBar=Qt::Horizontal==tb->orientation();
                        adjustToolbarButtons(widget, tb, leftAdjust, topAdjust, rightAdjust, bottomAdjust, round);
                    }
                }
                else
                    raised=false;
            }

            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 || raised)
#else
                if(bflags &(Style_Down | Style_On | Style_Raised | Style_MouseOver) || onControlButtons || raised)
#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(raised && TBTN_JOINED==opts.tbarBtns && !horizTBar)
                        bflags &= ~Style_Horizontal;

                    if(elementFlags & CEF_BiState)
                        bflags|=TOGGLE_BUTTON;

                    const TQColor *use(buttonColors(cg));

                    TQRect btnRect(r);

                    btnRect.addCoords(leftAdjust, topAdjust, rightAdjust, bottomAdjust);
                    drawLightBevel(cg.background(), p, btnRect, cg, bflags, round, getFill(bflags, use), use, true, true, WIDGET_STD_BUTTON);

                    if(raised && TBTN_JOINED==opts.tbarBtns)
                    {
                        const int constSpace=opts.fadeLines ? 7 : 4;

                        p->setPen(use[0]);
                        if(leftAdjust)
                            p->drawLine(r.x(), r.y()+constSpace, r.x(), r.height()-(constSpace+1));
                        if(topAdjust)
                            p->drawLine(r.x()+constSpace, r.y(), r.width()-(constSpace+1), r.y());
                        p->setPen(use[STD_BORDER]);
                        if(rightAdjust)
                            p->drawLine(r.x()+r.width()-1, r.y()+constSpace, r.x()+r.width()-1, r.height()-(constSpace+1));
                        if(bottomAdjust)
                            p->drawLine(r.x()+constSpace, r.y()+r.height()-1, r.width()-(constSpace+1), r.y()+r.height()-1);
                    }
                    //drawPrimitive(PE_ButtonTool, p, 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, widget);
                }
            }

            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, widget);
                    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 && !(opts.thin&THIN_FRAMES) &&
                    ((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);

            //const TQSpinWidget *spinwidget((const QSpinWidget *)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, widget);
                    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, widget);
                        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 TDEHTML 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], 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 TDEStyle'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], cg.background(), 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 tdestyle.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);

                TQPtrList<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;
        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;
        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 TDEHTML 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(TDEStylePixelMetric 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.thin&THIN_BUTTONS) ? 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.thin&THIN_BUTTONS) ? 4 : 2));
        }
        case CT_PopupMenuItem:
        {
            if (!widget || data.isDefault())
                break;

            const int        constMinH((opts.thin&THIN_MENU_ITEMS) ? 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.thin&THIN_MENU_ITEMS) ? 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_UnderlineAccelerator:
            return widget && opts.hideShortcutUnderline ? itsShortcutHandler->showShortcut(widget) : true;
        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);
        const TQColor *pc(popupMenuCols(cg));

        p->fillRect(main, cols[fill]);
        if(ROUNDED)
        {
            main.addCoords(-1, -1, 1, 1);
            drawBorder(pc[ORIGINAL_SHADE], p, main, cg, Style_Horizontal|Style_Raised, reverse ? ROUNDED_RIGHT : ROUNDED_LEFT,
                       pc, WIDGET_MENU_ITEM, false, BORDER_FLAT, false, fill);
        }

        drawGradient(reverse ? pc[ORIGINAL_SHADE] : cols[fill], reverse ? cols[fill] : pc[ORIGINAL_SHADE], 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], cg.background(), 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], cg.background(), 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, const TQColor &bgnd, 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(), bgnd.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, bgnd, &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, const TQColor &bgnd, 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((*it).alpha<0.9999)
                col=tint(bgnd, col, (*it).alpha);
            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((*it).alpha<0.9999)
                col=tint(bgnd, col, (*it).alpha);
            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);

            int rl(rTop << 16);
            int gl(gTop << 16);
            int bl(bTop << 16);
            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, cg.background(), 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], cg.background(), p, TQRect(x+1, y+1, len, size-2),
                                      horiz, false, opts.sliderAppearance);
                    drawBevelGradient(itsMouseOverCols[col], cg.background(), 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], cg.background(), p, TQRect(x+1, y+1, size-2, len),
                                      horiz, false, opts.sliderAppearance);
                    drawBevelGradient(itsMouseOverCols[col], cg.background(), 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 || APPEARANCE_FILE==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, cg.background(), 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::popupMenuCols(const TQColorGroup &cg) const
{
    return opts.shadePopupMenu ? menuColors(cg, true) : backgroundColors(cg);
}

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;
    }

    TQColor *base=opts.shadePopupMenu
                    ? SHADE_WINDOW_BORDER==opts.shadeMenubars
                        ? (TQColor *)getMdiColors(cg, true)
                        : itsMenubarCols
                    : itsBackgroundCols;

    if(USE_LIGHTER_POPUP_MENU)
    {
        if(!itsPopupMenuCols)
            itsPopupMenuCols=new TQColor [TOTAL_SHADES+1];
        shadeColors(shade(base[ORIGINAL_SHADE], TO_FACTOR(opts.lighterPopupMenuBgnd)), itsPopupMenuCols);
    }
    else
        itsPopupMenuCols=base;
}

void QtCurveStyle::setMenuTextColors(TQWidget *widget, bool isMenuBar) const
{
    if(SHADE_WINDOW_BORDER==opts.shadeMenubars)
    {
        TQPalette pal(widget->palette());

        getMdiColors(pal.active(), false);

        pal.setBrush(TQPalette::Active, TQColorGroup::Foreground, itsActiveMdiTextColor);
        pal.setBrush(TQPalette::Active, TQColorGroup::Text, pal.brush(TQPalette::Active, TQColorGroup::Foreground));
        if(isMenuBar)
        {
            pal.setBrush(TQPalette::Inactive, TQColorGroup::Foreground,
                            opts.shadeMenubarOnlyWhenActive ? itsMdiTextColor : itsActiveMdiTextColor);
            pal.setBrush(TQPalette::Inactive, TQColorGroup::Text, pal.brush(TQPalette::Inactive, TQColorGroup::Foreground));
        }
        else if(opts.shadePopupMenu)
        {
            pal.setBrush(TQPalette::Disabled, TQColorGroup::Foreground, midColor(itsActiveMdiTextColor,
                                                                                 popupMenuCols(pal.active())[ORIGINAL_SHADE]));
            pal.setBrush(TQPalette::Disabled, TQColorGroup::Text, pal.brush(TQPalette::Disabled, TQColorGroup::Foreground));
        }

        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(widget->palette());

        pal.setBrush(TQPalette::Active, TQColorGroup::Foreground, opts.customMenuTextColor
                                                ? opts.customMenuNormTextColor
                                                : pal.active().highlightedText());
        pal.setBrush(TQPalette::Active, TQColorGroup::Text, pal.brush(TQPalette::Active, TQColorGroup::Foreground));

        if(isMenuBar && !opts.shadeMenubarOnlyWhenActive)
        {
            pal.setBrush(TQPalette::Inactive, TQColorGroup::Foreground, opts.customMenuTextColor
                                                ? opts.customMenuNormTextColor
                                                : pal.active().highlightedText());
            pal.setBrush(TQPalette::Inactive, TQColorGroup::Text, pal.brush(TQPalette::Inactive, TQColorGroup::Foreground));
        }
        else if(!isMenuBar && opts.shadePopupMenu)
        {
            const TQColor *pc(popupMenuCols(pal.active()));
            pal.setBrush(TQPalette::Disabled, TQColorGroup::Foreground,
                         midColor(pal.brush(TQPalette::Active, TQColorGroup::Foreground).color(), pc[ORIGINAL_SHADE]));
            pal.setBrush(TQPalette::Disabled, TQColorGroup::Text, pal.brush(TQPalette::Disabled, TQColorGroup::Foreground));
        }
        widget->setPalette(pal);
    }
}

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 && itsMdiColors && 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;

    const TQStyleControlElementData &ceData = populateControlElementDataFromWidget(itsHoverWidget, TQStyleOption());
    ControlElementFlags elementFlags = getControlElementFlagsForObject(itsHoverWidget, TQStyleOption());

    //
    // 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
        {
            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
            {
                {
                    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);

                            }
                        }
                    }
                }
            }
        }
    }

    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 TQColorGroup &cg) const
{
    const TQColor *pc(popupMenuCols(cg));
    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], pc[ORIGINAL_SHADE]);
            return opts.customMenuStripeColor;
        case SHADE_SELECTED:
            return itsHighlightCols[MENU_STRIPE_SHADE];
        case SHADE_DARKEN:
            return pc[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::tdehtmlWidgetDestroyed(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 TDEHTML 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"