You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1650 lines
47 KiB
1650 lines
47 KiB
/*
|
|
Copyright (c) 2000-2001 Trolltech AS (info@trolltech.com)
|
|
|
|
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.
|
|
*/
|
|
|
|
#include "lightstyle-v2.h"
|
|
|
|
#include "tqmenubar.h"
|
|
#include "tqapplication.h"
|
|
#include "tqpainter.h"
|
|
#include "tqpalette.h"
|
|
#include "tqframe.h"
|
|
#include "tqpushbutton.h"
|
|
#include "tqdrawutil.h"
|
|
#include "tqprogressbar.h"
|
|
#include "tqscrollbar.h"
|
|
#include "tqtabbar.h"
|
|
#include "tqguardedptr.h"
|
|
#include "tqlayout.h"
|
|
#include "tqlineedit.h"
|
|
#include "tqimage.h"
|
|
#include "tqcombobox.h"
|
|
#include "tqslider.h"
|
|
#include "tqstylefactory.h"
|
|
|
|
|
|
class LightStyleV2Private
|
|
{
|
|
public:
|
|
LightStyleV2Private()
|
|
: ref(1)
|
|
{
|
|
basestyle = TQStyleFactory::create( "Windows" );
|
|
if ( ! basestyle )
|
|
basestyle = TQStyleFactory::create( TQStyleFactory::keys().first() );
|
|
if ( ! basestyle )
|
|
tqFatal( "LightStyle: couldn't find a basestyle!" );
|
|
}
|
|
|
|
~LightStyleV2Private()
|
|
{
|
|
delete basestyle;
|
|
}
|
|
|
|
TQStyle *basestyle;
|
|
int ref;
|
|
};
|
|
|
|
static LightStyleV2Private *singleton = 0;
|
|
|
|
|
|
LightStyleV2::LightStyleV2()
|
|
: KStyle(AllowMenuTransparency)
|
|
{
|
|
if (! singleton)
|
|
singleton = new LightStyleV2Private;
|
|
else
|
|
singleton->ref++;
|
|
}
|
|
|
|
LightStyleV2::~LightStyleV2()
|
|
{
|
|
if (singleton && --singleton->ref <= 0) {
|
|
delete singleton;
|
|
singleton = 0;
|
|
}
|
|
}
|
|
|
|
void LightStyleV2::polishPopupMenu( TQStyleControlElementData ceData, ControlElementFlags elementFlags, void *ptr )
|
|
{
|
|
KStyle::polishPopupMenu(ceData, elementFlags, ptr);
|
|
}
|
|
|
|
static void drawLightBevel(TQPainter *p, const TQRect &r, const TQColorGroup &cg,
|
|
TQStyle::SFlags flags, const TQBrush *fill = 0)
|
|
{
|
|
TQRect br = r;
|
|
bool sunken = (flags & (TQStyle::Style_Down | TQStyle::Style_On |
|
|
TQStyle::Style_Sunken));
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawRect(r);
|
|
|
|
if (flags & (TQStyle::Style_Down | TQStyle::Style_On |
|
|
TQStyle::Style_Sunken | TQStyle::Style_Raised)) {
|
|
// button bevel
|
|
if (sunken)
|
|
p->setPen(cg.mid());
|
|
else
|
|
p->setPen(cg.light());
|
|
|
|
p->drawLine(r.x() + 1, r.y() + 2,
|
|
r.x() + 1, r.y() + r.height() - 3); // left
|
|
p->drawLine(r.x() + 1, r.y() + 1,
|
|
r.x() + r.width() - 2, r.y() + 1); // top
|
|
|
|
if (sunken)
|
|
p->setPen(cg.light());
|
|
else
|
|
p->setPen(cg.mid());
|
|
|
|
p->drawLine(r.x() + r.width() - 2, r.y() + 2,
|
|
r.x() + r.width() - 2, r.y() + r.height() - 3); // right
|
|
p->drawLine(r.x() + 1, r.y() + r.height() - 2,
|
|
r.x() + r.width() - 2, r.y() + r.height() - 2); // bottom
|
|
|
|
br.addCoords(2, 2, -2, -2);
|
|
} else
|
|
br.addCoords(1, 1, -1, -1);
|
|
|
|
// fill
|
|
if (fill) p->fillRect(br, *fill);
|
|
}
|
|
|
|
void LightStyleV2::drawPrimitive( TQ_PrimitiveElement pe,
|
|
TQPainter *p,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQRect &r,
|
|
const TQColorGroup &cg,
|
|
SFlags flags,
|
|
const TQStyleOption &data ) const
|
|
{
|
|
switch (pe) {
|
|
case PE_HeaderSectionMenu:
|
|
case PE_HeaderSection:
|
|
{
|
|
flags = ((flags | Style_Sunken) ^ Style_Sunken) | Style_Raised;
|
|
//Don't show pressed too often (as in light 3)
|
|
TQBrush fill(cg.background());
|
|
if (flags & TQStyle::Style_Enabled)
|
|
fill.setColor(cg.button());
|
|
|
|
drawLightBevel(p, r, cg, flags, &fill);
|
|
p->setPen( cg.buttonText() );
|
|
break;
|
|
}
|
|
|
|
case PE_ButtonCommand:
|
|
case PE_ButtonBevel:
|
|
case PE_ButtonTool:
|
|
{
|
|
const TQBrush *fill;
|
|
if (flags & TQStyle::Style_Enabled) {
|
|
if (flags & (TQStyle::Style_Down |
|
|
TQStyle::Style_On |
|
|
TQStyle::Style_Sunken))
|
|
fill = &cg.brush(TQColorGroup::Midlight);
|
|
else
|
|
fill = &cg.brush(TQColorGroup::Button);
|
|
} else
|
|
fill = &cg.brush(TQColorGroup::Background);
|
|
drawLightBevel(p, r, cg, flags, fill);
|
|
break;
|
|
}
|
|
|
|
case PE_ButtonDropDown:
|
|
{
|
|
TQBrush thefill;
|
|
bool sunken =
|
|
(flags & (TQStyle::Style_Down | TQStyle::Style_On | TQStyle::Style_Sunken));
|
|
|
|
if (flags & TQStyle::Style_Enabled) {
|
|
if (sunken)
|
|
thefill = cg.brush(TQColorGroup::Midlight);
|
|
else
|
|
thefill = cg.brush(TQColorGroup::Button);
|
|
} else
|
|
thefill = cg.brush(TQColorGroup::Background);
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawLine(r.topLeft(), r.topRight());
|
|
p->drawLine(r.topRight(), r.bottomRight());
|
|
p->drawLine(r.bottomRight(), r.bottomLeft());
|
|
|
|
if (flags & (TQStyle::Style_Down | TQStyle::Style_On |
|
|
TQStyle::Style_Sunken | TQStyle::Style_Raised)) {
|
|
// button bevel
|
|
if (sunken)
|
|
p->setPen(cg.mid());
|
|
else
|
|
p->setPen(cg.light());
|
|
|
|
p->drawLine(r.x(), r.y() + 2,
|
|
r.x(), r.y() + r.height() - 3); // left
|
|
p->drawLine(r.x(), r.y() + 1,
|
|
r.x() + r.width() - 2, r.y() + 1); // top
|
|
|
|
if (sunken)
|
|
p->setPen(cg.light());
|
|
else
|
|
p->setPen(cg.mid());
|
|
|
|
p->drawLine(r.x() + r.width() - 2, r.y() + 2,
|
|
r.x() + r.width() - 2, r.y() + r.height() - 3); // right
|
|
p->drawLine(r.x() + 1, r.y() + r.height() - 2,
|
|
r.x() + r.width() - 2, r.y() + r.height() - 2); // bottom
|
|
}
|
|
|
|
p->fillRect(r.x() + 1, r.y() + 2, r.width() - 3, r.height() - 4, thefill);
|
|
break;
|
|
}
|
|
|
|
case PE_ButtonDefault:
|
|
p->setPen(cg.dark());
|
|
p->setBrush(cg.light());
|
|
p->drawRect(r);
|
|
break;
|
|
|
|
case PE_Indicator:
|
|
const TQBrush *fill;
|
|
if (! (flags & Style_Enabled))
|
|
fill = &cg.brush(TQColorGroup::Background);
|
|
else if (flags & Style_Down)
|
|
fill = &cg.brush(TQColorGroup::Mid);
|
|
else
|
|
fill = &cg.brush(TQColorGroup::Base);
|
|
drawLightBevel(p, r, cg, flags | Style_Sunken, fill);
|
|
|
|
p->setPen(cg.text());
|
|
if (flags & Style_NoChange) {
|
|
p->drawLine(r.x() + 3, r.y() + r.height() / 2,
|
|
r.x() + r.width() - 4, r.y() + r.height() / 2);
|
|
p->drawLine(r.x() + 3, r.y() + 1 + r.height() / 2,
|
|
r.x() + r.width() - 4, r.y() + 1 + r.height() / 2);
|
|
p->drawLine(r.x() + 3, r.y() - 1 + r.height() / 2,
|
|
r.x() + r.width() - 4, r.y() - 1 + r.height() / 2);
|
|
} else if (flags & Style_On) {
|
|
p->drawLine(r.x() + 4, r.y() + 3,
|
|
r.x() + r.width() - 4, r.y() + r.height() - 5);
|
|
p->drawLine(r.x() + 3, r.y() + 3,
|
|
r.x() + r.width() - 4, r.y() + r.height() - 4);
|
|
p->drawLine(r.x() + 3, r.y() + 4,
|
|
r.x() + r.width() - 5, r.y() + r.height() - 4);
|
|
p->drawLine(r.x() + 3, r.y() + r.height() - 5,
|
|
r.x() + r.width() - 5, r.y() + 3);
|
|
p->drawLine(r.x() + 3, r.y() + r.height() - 4,
|
|
r.x() + r.width() - 4, r.y() + 3);
|
|
p->drawLine(r.x() + 4, r.y() + r.height() - 4,
|
|
r.x() + r.width() - 4, r.y() + 4);
|
|
}
|
|
|
|
break;
|
|
|
|
case PE_ExclusiveIndicator:
|
|
{
|
|
TQRect br = r, // bevel rect
|
|
cr = r, // contents rect
|
|
ir = r; // indicator rect
|
|
br.addCoords(1, 1, -1, -1);
|
|
cr.addCoords(2, 2, -2, -2);
|
|
ir.addCoords(3, 3, -3, -3);
|
|
|
|
p->fillRect(r, cg.brush(TQColorGroup::Background));
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawArc(r, 0, 16*360);
|
|
p->setPen(cg.mid());
|
|
p->drawArc(br, 45*16, 180*16);
|
|
p->setPen(cg.light());
|
|
p->drawArc(br, 235*16, 180*16);
|
|
|
|
p->setPen(flags & Style_Down ? cg.mid() :
|
|
(flags & Style_Enabled ? cg.base() : cg.background()));
|
|
p->setBrush(flags & Style_Down ? cg.mid() :
|
|
(flags & Style_Enabled ? cg.base() : cg.background()));
|
|
p->drawEllipse(cr);
|
|
|
|
if (flags & Style_On) {
|
|
p->setBrush(cg.text());
|
|
p->drawEllipse(ir);
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case PE_DockWindowHandle:
|
|
{
|
|
TQString title;
|
|
bool drawTitle = false;
|
|
if ( p && p->device()->devType() == TQInternal::Widget ) {
|
|
TQWidget *w = (TQWidget *) p->device();
|
|
TQWidget *p = w->parentWidget();
|
|
if (p->inherits(TQDOCKWINDOW_OBJECT_NAME_STRING) && ! p->inherits(TQTOOLBAR_OBJECT_NAME_STRING)) {
|
|
drawTitle = true;
|
|
title = p->caption();
|
|
}
|
|
}
|
|
|
|
flags |= Style_Raised;
|
|
if (flags & Style_Horizontal) {
|
|
if (drawTitle) {
|
|
TQPixmap pm(r.height(), r.width());
|
|
TQPainter p2(&pm);
|
|
p2.fillRect(0, 0, pm.width(), pm.height(),
|
|
cg.brush(TQColorGroup::Highlight));
|
|
p2.setPen(cg.highlightedText());
|
|
p2.drawText(0, 0, pm.width(), pm.height(), AlignCenter, title);
|
|
p2.end();
|
|
|
|
TQWMatrix m;
|
|
m.rotate(270.0);
|
|
pm = pm.xForm(m);
|
|
p->drawPixmap(r.x(), r.y(), pm);
|
|
} else {
|
|
p->fillRect(r, cg.background());
|
|
p->setPen(cg.mid().dark());
|
|
p->drawLine(r.right() - 6, r.top() + 2,
|
|
r.right() - 6, r.bottom() - 2);
|
|
p->drawLine(r.right() - 3, r.top() + 2,
|
|
r.right() - 3, r.bottom() - 2);
|
|
p->setPen(cg.light());
|
|
p->drawLine(r.right() - 5, r.top() + 2,
|
|
r.right() - 5, r.bottom() - 2);
|
|
p->drawLine(r.right() - 2, r.top() + 2,
|
|
r.right() - 2, r.bottom() - 2);
|
|
}
|
|
} else {
|
|
if (drawTitle) {
|
|
p->fillRect(r, cg.brush(TQColorGroup::Highlight));
|
|
p->setPen(cg.highlightedText());
|
|
p->drawText(r, AlignCenter, title);
|
|
} else {
|
|
p->fillRect(r, cg.background());
|
|
p->setPen(cg.mid().dark());
|
|
p->drawLine(r.left() + 2, r.bottom() - 6,
|
|
r.right() - 2, r.bottom() - 6);
|
|
p->drawLine(r.left() + 2, r.bottom() - 3,
|
|
r.right() - 2, r.bottom() - 3);
|
|
p->setPen(cg.light());
|
|
p->drawLine(r.left() + 2, r.bottom() - 5,
|
|
r.right() - 2, r.bottom() - 5);
|
|
p->drawLine(r.left() + 2, r.bottom() - 2,
|
|
r.right() - 2, r.bottom() - 2);
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
|
|
case PE_DockWindowSeparator:
|
|
{
|
|
if (r.width() > 20 || r.height() > 20) {
|
|
if (flags & Style_Horizontal) {
|
|
p->setPen(cg.mid().dark(120));
|
|
p->drawLine(r.left() + 1, r.top() + 6, r.left() + 1, r.bottom() - 6);
|
|
p->setPen(cg.light());
|
|
p->drawLine(r.left() + 2, r.top() + 6, r.left() + 2, r.bottom() - 6);
|
|
} else {
|
|
p->setPen(cg.mid().dark(120));
|
|
p->drawLine(r.left() + 6, r.top() + 1, r.right() - 6, r.top() + 1);
|
|
p->setPen(cg.light());
|
|
p->drawLine(r.left() + 6, r.top() + 2, r.right() - 6, r.top() + 2);
|
|
}
|
|
} else
|
|
TQCommonStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, data);
|
|
break;
|
|
}
|
|
|
|
case PE_Splitter:
|
|
if (flags & Style_Horizontal)
|
|
flags &= ~Style_Horizontal;
|
|
else
|
|
flags |= Style_Horizontal;
|
|
// fall through intended
|
|
|
|
case PE_DockWindowResizeHandle:
|
|
{
|
|
p->fillRect(r, cg.background());
|
|
if (flags & Style_Horizontal) {
|
|
p->setPen(cg.highlight().light());
|
|
p->drawLine(r.left() + 1, r.top() + 1, r.right() - 1, r.top() + 1);
|
|
p->setPen(cg.highlight());
|
|
p->drawLine(r.left() + 1, r.top() + 2, r.right() - 1, r.top() + 2);
|
|
p->setPen(cg.highlight().dark());
|
|
p->drawLine(r.left() + 1, r.top() + 3, r.right() - 1, r.top() + 3);
|
|
} else {
|
|
p->setPen(cg.highlight().light());
|
|
p->drawLine(r.left() + 1, r.top() + 1, r.left() + 1, r.bottom() - 1);
|
|
p->setPen(cg.highlight());
|
|
p->drawLine(r.left() + 2, r.top() + 1, r.left() + 2, r.bottom() - 1);
|
|
p->setPen(cg.highlight().dark());
|
|
p->drawLine(r.left() + 3, r.top() + 1, r.left() + 3, r.bottom() - 1);
|
|
}
|
|
break;
|
|
}
|
|
|
|
case PE_Panel:
|
|
case PE_PanelPopup:
|
|
case PE_PanelLineEdit:
|
|
case PE_PanelTabWidget:
|
|
case PE_WindowFrame:
|
|
{
|
|
int lw = data.isDefault() ?
|
|
pixelMetric(PM_DefaultFrameWidth, ceData, elementFlags) : data.lineWidth();
|
|
|
|
if ( ! ( flags & Style_Sunken ) )
|
|
flags |= Style_Raised;
|
|
if (lw == 2)
|
|
drawLightBevel(p, r, cg, flags);
|
|
else
|
|
TQCommonStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, data);
|
|
break;
|
|
}
|
|
|
|
case PE_PanelDockWindow:
|
|
{
|
|
int lw = data.isDefault() ?
|
|
pixelMetric(PM_DockWindowFrameWidth, ceData, elementFlags) : data.lineWidth();
|
|
|
|
if (lw == 2)
|
|
drawLightBevel(p, r, cg, flags | Style_Raised,
|
|
&cg.brush(TQColorGroup::Button));
|
|
else
|
|
TQCommonStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, data);
|
|
break;
|
|
}
|
|
|
|
case PE_PanelMenuBar:
|
|
{
|
|
int lw = data.isDefault() ?
|
|
pixelMetric(PM_MenuBarFrameWidth, ceData, elementFlags) : data.lineWidth();
|
|
|
|
if (lw == 2)
|
|
drawLightBevel(p, r, cg, flags, &cg.brush(TQColorGroup::Button));
|
|
else
|
|
TQCommonStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, data);
|
|
break;
|
|
}
|
|
|
|
case PE_ScrollBarSubLine:
|
|
{
|
|
TQRect fr = r, ar = r;
|
|
TQ_PrimitiveElement pe;
|
|
|
|
p->setPen(cg.dark());
|
|
if (flags & Style_Horizontal) {
|
|
p->drawLine(r.topLeft(), r.topRight());
|
|
fr.addCoords(0, 1, 0, 0);
|
|
ar.addCoords(0, 1, 0, 0);
|
|
pe = PE_ArrowLeft;
|
|
} else {
|
|
p->drawLine(r.topLeft(), r.bottomLeft());
|
|
fr.addCoords(1, 0, 0, 0);
|
|
ar.addCoords(2, 0, 0, 0);
|
|
pe = PE_ArrowUp;
|
|
}
|
|
|
|
p->fillRect(fr, cg.brush((flags & Style_Down) ?
|
|
TQColorGroup::Midlight :
|
|
TQColorGroup::Background));
|
|
drawPrimitive(pe, p, ceData, elementFlags, ar, cg, flags);
|
|
break;
|
|
}
|
|
|
|
case PE_ScrollBarAddLine:
|
|
{
|
|
TQRect fr = r, ar = r;
|
|
TQ_PrimitiveElement pe;
|
|
|
|
p->setPen(cg.dark());
|
|
if (flags & Style_Horizontal) {
|
|
p->drawLine(r.topLeft(), r.topRight());
|
|
fr.addCoords(0, 1, 0, 0);
|
|
ar.addCoords(0, 1, 0, 0);
|
|
pe = PE_ArrowRight;
|
|
} else {
|
|
p->drawLine(r.topLeft(), r.bottomLeft());
|
|
fr.addCoords(1, 0, 0, 0);
|
|
ar.addCoords(2, 0, 0, 0);
|
|
pe = PE_ArrowDown;
|
|
}
|
|
|
|
p->fillRect(fr, cg.brush((flags & Style_Down) ?
|
|
TQColorGroup::Midlight :
|
|
TQColorGroup::Background));
|
|
drawPrimitive(pe, p, ceData, elementFlags, ar, cg, flags);
|
|
break;
|
|
}
|
|
|
|
case PE_ScrollBarSubPage:
|
|
case PE_ScrollBarAddPage:
|
|
{
|
|
TQRect fr = r;
|
|
|
|
p->setPen(cg.dark());
|
|
if (flags & Style_Horizontal) {
|
|
p->drawLine(r.topLeft(), r.topRight());
|
|
p->setPen(cg.background());
|
|
p->drawLine(r.left(), r.top() + 1, r.right(), r.top() + 1);
|
|
p->drawLine(r.left(), r.bottom(), r.right(), r.bottom());
|
|
fr.addCoords(0, 2, 0, -1);
|
|
} else {
|
|
p->drawLine(r.topLeft(), r.bottomLeft());
|
|
p->setPen(cg.background());
|
|
p->drawLine(r.left() + 1, r.top(), r.left() + 1, r.bottom());
|
|
fr.addCoords(2, 0, 0, 0);
|
|
}
|
|
|
|
p->fillRect(fr, cg.brush((flags & Style_Down) ?
|
|
TQColorGroup::Midlight :
|
|
TQColorGroup::Mid));
|
|
break;
|
|
}
|
|
|
|
case PE_ScrollBarSlider:
|
|
{
|
|
TQRect fr = r;
|
|
|
|
p->setPen(cg.dark());
|
|
if (flags & Style_Horizontal) {
|
|
p->drawLine(r.topLeft(), r.topRight());
|
|
p->setPen(cg.background());
|
|
p->drawLine(r.left(), r.bottom(), r.right(), r.bottom());
|
|
p->drawLine(r.left(), r.top() + 1, r.right(), r.top() + 1);
|
|
fr.addCoords(0, 2, 0, -1);
|
|
} else {
|
|
p->drawLine(r.topLeft(), r.bottomLeft());
|
|
p->setPen(cg.background());
|
|
p->drawLine(r.right(), r.top(), r.right(), r.bottom());
|
|
p->drawLine(r.left() + 1, r.top(), r.left() + 1, r.bottom());
|
|
fr.addCoords(2, 0, -1, 0);
|
|
}
|
|
|
|
drawLightBevel(p, fr, cg, ((flags | Style_Down) ^ Style_Down) |
|
|
((flags & Style_Enabled) ? Style_Raised : Style_Default),
|
|
&cg.brush(TQColorGroup::Button));
|
|
break;
|
|
}
|
|
|
|
case PE_FocusRect:
|
|
{
|
|
p->setBrush(NoBrush);
|
|
if (flags & Style_FocusAtBorder)
|
|
p->setPen(cg.shadow());
|
|
else
|
|
p->setPen(cg.dark());
|
|
p->drawRect(r);
|
|
break;
|
|
}
|
|
|
|
case PE_ProgressBarChunk:
|
|
p->fillRect(r.x(), r.y() + 2, r.width(), r.height() - 4, cg.highlight());
|
|
break;
|
|
|
|
default:
|
|
if (pe == PE_HeaderArrow) {
|
|
if (flags & Style_Down)
|
|
pe = PE_ArrowDown;
|
|
else
|
|
pe = PE_ArrowUp;
|
|
}
|
|
|
|
|
|
if (pe >= PE_ArrowUp && pe <= PE_ArrowLeft) {
|
|
TQPointArray a;
|
|
|
|
switch ( pe ) {
|
|
case PE_ArrowUp:
|
|
a.setPoints( 7, -4,1, 2,1, -3,0, 1,0, -2,-1, 0,-1, -1,-2 );
|
|
break;
|
|
|
|
case PE_ArrowDown:
|
|
a.setPoints( 7, -4,-2, 2,-2, -3,-1, 1,-1, -2,0, 0,0, -1,1 );
|
|
break;
|
|
|
|
case PE_ArrowRight:
|
|
a.setPoints( 7, -2,-3, -2,3, -1,-2, -1,2, 0,-1, 0,1, 1,0 );
|
|
break;
|
|
|
|
case PE_ArrowLeft:
|
|
a.setPoints( 7, 0,-3, 0,3, -1,-2, -1,2, -2,-1, -2,1, -3,0 );
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (a.isNull())
|
|
return;
|
|
|
|
p->save();
|
|
if ( flags & Style_Enabled ) {
|
|
a.translate( r.x() + r.width() / 2, r.y() + r.height() / 2 );
|
|
p->setPen( cg.buttonText() );
|
|
p->drawLineSegments( a, 0, 3 ); // draw arrow
|
|
p->drawPoint( a[6] );
|
|
} else {
|
|
a.translate( r.x() + r.width() / 2 + 1, r.y() + r.height() / 2 + 1 );
|
|
p->setPen( cg.light() );
|
|
p->drawLineSegments( a, 0, 3 ); // draw arrow
|
|
p->drawPoint( a[6] );
|
|
a.translate( -1, -1 );
|
|
p->setPen( cg.mid() );
|
|
p->drawLineSegments( a, 0, 3 ); // draw arrow
|
|
p->drawPoint( a[6] );
|
|
}
|
|
p->restore();
|
|
} else
|
|
TQCommonStyle::drawPrimitive(pe, p, ceData, elementFlags, r, cg, flags, data);
|
|
break;
|
|
}
|
|
}
|
|
|
|
void LightStyleV2::drawControl( TQ_ControlElement control,
|
|
TQPainter *p,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQRect &r,
|
|
const TQColorGroup &cg,
|
|
SFlags flags,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
switch (control) {
|
|
case CE_TabBarTab:
|
|
{
|
|
const TQTabBar* tb = static_cast<const TQTabBar*>(widget);
|
|
bool below = false;
|
|
TQRect tr(r);
|
|
TQRect fr(r);
|
|
|
|
tr.addCoords(0, 0, 0, -1);
|
|
fr.addCoords(2, 2, -2, -2);
|
|
|
|
if ( tb->shape() == TQTabBar::RoundedBelow || tb->shape() == TQTabBar::TriangularBelow) {
|
|
tr = r; tr.addCoords(0, 1, 0, 0);
|
|
fr = r; fr.addCoords(2, 2,-2, -4);
|
|
below = true;
|
|
}
|
|
|
|
if (! (flags & Style_Selected)) {
|
|
if (below) {
|
|
tr.addCoords(0, 0, 0, -1);
|
|
tr.addCoords(0, 0, 0, -1);
|
|
} else {
|
|
tr.addCoords(0, 1, 0, 0);
|
|
fr.addCoords(0, 1, 0, 0);
|
|
}
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawRect(tr);
|
|
|
|
if (tr.left() == 0)
|
|
if (below)
|
|
p->drawPoint(tr.left(), tr.top() - 1);
|
|
else
|
|
p->drawPoint(tr.left(), tr.bottom() + 1);
|
|
|
|
p->setPen(cg.light());
|
|
if (below) {
|
|
p->drawLine(tr.left() + 1, tr.top() + 1,
|
|
tr.left() + 1, tr.bottom() - 2);
|
|
p->drawLine(tr.left() + 1, tr.bottom() - 1,
|
|
tr.right() - 1, tr.bottom() - 1);
|
|
} else {
|
|
p->drawLine(tr.left() + 1, tr.bottom() - 1,
|
|
tr.left() + 1, tr.top() + 2);
|
|
p->drawLine(tr.left() + 1, tr.top() + 1,
|
|
tr.right() - 1, tr.top() + 1);
|
|
}
|
|
|
|
if (below) {
|
|
if (tr.left() == 0)
|
|
p->drawLine(tr.left() + 1, tr.top() - 1,
|
|
tr.right(), tr.top() - 1);
|
|
else
|
|
{
|
|
p->setPen(cg.mid()); //To match lower border of the frame
|
|
p->drawLine(tr.left(), tr.top() - 1,
|
|
tr.right(), tr.top() - 1);
|
|
}
|
|
} else {
|
|
if (tr.left() == 0)
|
|
p->drawLine(tr.left() + 1, tr.bottom() + 1,
|
|
tr.right(), tr.bottom() + 1);
|
|
else
|
|
p->drawLine(tr.left(), tr.bottom() + 1,
|
|
tr.right(), tr.bottom() + 1);
|
|
}
|
|
|
|
p->setPen(cg.mid());
|
|
|
|
if (below) {
|
|
p->drawLine(tr.right() - 1, tr.bottom() - 2,
|
|
tr.right() - 1, tr.top() + 1);
|
|
} else {
|
|
p->drawLine(tr.right() - 1, tr.top() + 2,
|
|
tr.right() - 1, tr.bottom() - 1);
|
|
}
|
|
} else {
|
|
p->setPen(cg.dark());
|
|
if (tr.left() == 0)
|
|
if (below)
|
|
p->drawLine(tr.left(), tr.top() - 1,
|
|
tr.left(), tr.bottom() - 1);
|
|
else
|
|
p->drawLine(tr.left(), tr.bottom() + 1,
|
|
tr.left(), tr.top() + 1);
|
|
else
|
|
if (below)
|
|
p->drawLine(tr.left(), tr.bottom(),
|
|
tr.left(), tr.top() + 1);
|
|
else
|
|
p->drawLine(tr.left(), tr.bottom(),
|
|
tr.left(), tr.top() + 1);
|
|
|
|
if (below) {
|
|
p->drawLine(tr.left(), tr.bottom(),
|
|
tr.right(), tr.bottom());
|
|
p->drawLine(tr.right(), tr.bottom() - 1,
|
|
tr.right(), tr.top());
|
|
|
|
} else {
|
|
p->drawLine(tr.left(), tr.top(),
|
|
tr.right(), tr.top());
|
|
p->drawLine(tr.right(), tr.top() + 1,
|
|
tr.right(), tr.bottom());
|
|
}
|
|
|
|
p->setPen(cg.light());
|
|
if (tr.left() == 0)
|
|
if (below)
|
|
p->drawLine(tr.left() + 1, tr.top() - 2,
|
|
tr.left() + 1, tr.bottom() - 2);
|
|
else
|
|
p->drawLine(tr.left() + 1, tr.bottom() + 2,
|
|
tr.left() + 1, tr.top() + 2);
|
|
else {
|
|
if (below) {
|
|
p->drawLine(tr.left() + 1, tr.top(),
|
|
tr.left() + 1, tr.bottom() - 2);
|
|
p->drawPoint(tr.left(), tr.top() - 1);
|
|
|
|
} else {
|
|
p->drawLine(tr.left() + 1, tr.bottom(),
|
|
tr.left() + 1, tr.top() + 2);
|
|
p->drawPoint(tr.left(), tr.bottom() + 1);
|
|
}
|
|
}
|
|
|
|
if (below) {
|
|
p->drawLine(tr.left() + 1, tr.bottom() - 1,
|
|
tr.right() - 1, tr.bottom() - 1);
|
|
p->drawPoint(tr.right(), tr.top() - 1);
|
|
|
|
p->setPen(cg.mid());
|
|
p->drawLine(tr.right() - 1, tr.bottom() - 2,
|
|
tr.right() - 1, tr.top());
|
|
} else {
|
|
p->drawLine(tr.left() + 1, tr.top() + 1,
|
|
tr.right() - 1, tr.top() + 1);
|
|
p->drawPoint(tr.right(), tr.bottom() + 1);
|
|
|
|
p->setPen(cg.mid());
|
|
p->drawLine(tr.right() - 1, tr.top() + 2,
|
|
tr.right() - 1, tr.bottom());
|
|
}
|
|
}
|
|
|
|
p->fillRect(fr, ((flags & Style_Selected) ?
|
|
cg.background() : cg.mid()));
|
|
break;
|
|
}
|
|
|
|
case CE_PopupMenuItem:
|
|
{
|
|
if (! widget || data.isDefault())
|
|
break;
|
|
|
|
const TQPopupMenu *popupmenu = (const TQPopupMenu *) widget;
|
|
TQMenuItem *mi = data.menuItem();
|
|
int tab = data.tabWidth();
|
|
int maxpmw = data.maxIconWidth();
|
|
|
|
if ( mi && mi->isSeparator() ) {
|
|
// draw separator (bg first, though)
|
|
if ( widget->erasePixmap() && !widget->erasePixmap()->isNull() )
|
|
p->drawPixmap( r.topLeft(), *widget->erasePixmap(), r );
|
|
else
|
|
p->fillRect(r, cg.brush(TQColorGroup::Button));
|
|
|
|
p->setPen(cg.mid().dark(120));
|
|
p->drawLine(r.left() + 12, r.top() + 1,
|
|
r.right() - 12, r.top() + 1);
|
|
p->setPen(cg.light());
|
|
p->drawLine(r.left() + 12, r.top() + 2,
|
|
r.right() - 12, r.top() + 2);
|
|
break;
|
|
}
|
|
|
|
if (flags & Style_Active)
|
|
qDrawShadePanel(p, r, cg, true, 1,
|
|
&cg.brush(TQColorGroup::Midlight));
|
|
else if ( widget->erasePixmap() && !widget->erasePixmap()->isNull() )
|
|
p->drawPixmap( r.topLeft(), *widget->erasePixmap(), r );
|
|
else
|
|
p->fillRect(r, cg.brush(TQColorGroup::Button));
|
|
|
|
if ( !mi )
|
|
break;
|
|
|
|
maxpmw = QMAX(maxpmw, 16);
|
|
|
|
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());
|
|
|
|
bool reverse = TQApplication::reverseLayout();
|
|
if ( reverse ) {
|
|
cr = visualRect( cr, r );
|
|
sr = visualRect( sr, r );
|
|
tr = visualRect( tr, r );
|
|
ir = visualRect( ir, r );
|
|
}
|
|
|
|
if (mi->isChecked() &&
|
|
! (flags & Style_Active) &
|
|
(flags & Style_Enabled))
|
|
qDrawShadePanel(p, cr, cg, true, 1, &cg.brush(TQColorGroup::Midlight));
|
|
|
|
if (mi->iconSet()) {
|
|
TQIconSet::Mode mode =
|
|
(flags & Style_Enabled) ? TQIconSet::Normal : TQIconSet::Disabled;
|
|
if ((flags & Style_Active) && (flags & Style_Enabled))
|
|
mode = TQIconSet::Active;
|
|
TQPixmap pixmap;
|
|
if (popupmenu->isCheckable() && mi->isChecked())
|
|
pixmap =
|
|
mi->iconSet()->pixmap( TQIconSet::Small, mode, TQIconSet::On );
|
|
else
|
|
pixmap =
|
|
mi->iconSet()->pixmap( TQIconSet::Small, mode );
|
|
TQRect pmr(TQPoint(0, 0), pixmap.size());
|
|
pmr.moveCenter(cr.center());
|
|
p->setPen(cg.text());
|
|
p->drawPixmap(pmr.topLeft(), pixmap);
|
|
} else if (popupmenu->isCheckable() && mi->isChecked())
|
|
drawPrimitive(PE_CheckMark, p, ceData, elementFlags, cr, cg,
|
|
(flags & Style_Enabled) | Style_On);
|
|
|
|
TQColor textcolor;
|
|
TQColor embosscolor;
|
|
if (flags & Style_Active) {
|
|
if (! (flags & Style_Enabled))
|
|
textcolor = cg.midlight().dark();
|
|
else
|
|
textcolor = cg.buttonText();
|
|
embosscolor = cg.midlight().light();
|
|
} else if (! (flags & Style_Enabled)) {
|
|
textcolor = cg.text();
|
|
embosscolor = cg.light();
|
|
} else
|
|
textcolor = embosscolor = cg.buttonText();
|
|
p->setPen(textcolor);
|
|
|
|
if (mi->custom()) {
|
|
p->save();
|
|
if (! (flags & Style_Enabled)) {
|
|
p->setPen(cg.light());
|
|
mi->custom()->paint(p, cg, flags & Style_Active,
|
|
flags & Style_Enabled,
|
|
ir.x() + 1, ir.y() + 1,
|
|
ir.width() - 1, ir.height() - 1);
|
|
p->setPen(textcolor);
|
|
}
|
|
mi->custom()->paint(p, cg, flags & Style_Active,
|
|
flags & Style_Enabled,
|
|
ir.x(), ir.y(),
|
|
ir.width(), ir.height());
|
|
p->restore();
|
|
}
|
|
|
|
TQString text = mi->text();
|
|
if (! text.isNull()) {
|
|
int t = text.find('\t');
|
|
|
|
// draw accelerator/tab-text
|
|
if (t >= 0) {
|
|
int alignFlag = AlignVCenter | ShowPrefix | DontClip | SingleLine;
|
|
alignFlag |= ( reverse ? AlignLeft : AlignRight );
|
|
if (! (flags & Style_Enabled)) {
|
|
p->setPen(embosscolor);
|
|
tr.moveBy(1, 1);
|
|
p->drawText(tr, alignFlag, text.mid(t + 1));
|
|
tr.moveBy(-1, -1);
|
|
p->setPen(textcolor);
|
|
}
|
|
|
|
p->drawText(tr, alignFlag, text.mid(t + 1));
|
|
}
|
|
|
|
int alignFlag = AlignVCenter | ShowPrefix | DontClip | SingleLine;
|
|
alignFlag |= ( reverse ? AlignRight : AlignLeft );
|
|
|
|
if (! (flags & Style_Enabled)) {
|
|
p->setPen(embosscolor);
|
|
ir.moveBy(1, 1);
|
|
p->drawText(ir, alignFlag, text, t);
|
|
ir.moveBy(-1, -1);
|
|
p->setPen(textcolor);
|
|
}
|
|
|
|
p->drawText(ir, alignFlag, text, t);
|
|
} else if (mi->pixmap()) {
|
|
TQPixmap pixmap = *mi->pixmap();
|
|
if (pixmap.depth() == 1)
|
|
p->setBackgroundMode(Qt::OpaqueMode);
|
|
p->drawPixmap(ir.x(), ir.y() + (ir.height() - pixmap.height()) / 2, pixmap);
|
|
if (pixmap.depth() == 1)
|
|
p->setBackgroundMode(Qt::TransparentMode);
|
|
}
|
|
|
|
if (mi->popup())
|
|
drawPrimitive( (reverse ? PE_ArrowLeft : PE_ArrowRight), p, ceData, elementFlags, sr, cg, flags);
|
|
break;
|
|
}
|
|
|
|
case CE_MenuBarEmptyArea:
|
|
{
|
|
p->fillRect(r, cg.brush(TQColorGroup::Button));
|
|
break;
|
|
}
|
|
|
|
case CE_DockWindowEmptyArea:
|
|
{
|
|
p->fillRect(r, cg.brush(TQColorGroup::Button));
|
|
break;
|
|
}
|
|
|
|
|
|
case CE_MenuBarItem:
|
|
{
|
|
if (flags & Style_Active)
|
|
qDrawShadePanel(p, r, cg, true, 1, &cg.brush(TQColorGroup::Midlight));
|
|
else
|
|
p->fillRect(r, cg.brush(TQColorGroup::Button));
|
|
|
|
if (data.isDefault())
|
|
break;
|
|
|
|
TQMenuItem *mi = data.menuItem();
|
|
drawItem(p, r, AlignCenter | ShowPrefix | DontClip | SingleLine, cg,
|
|
flags & Style_Enabled, mi->pixmap(), mi->text(), -1,
|
|
&cg.buttonText());
|
|
break;
|
|
}
|
|
|
|
case CE_ProgressBarGroove:
|
|
drawLightBevel(p, r, cg, Style_Sunken, &cg.brush(TQColorGroup::Background));
|
|
break;
|
|
|
|
default:
|
|
TQCommonStyle::drawControl(control, p, ceData, elementFlags, r, cg, flags, data, widget);
|
|
break;
|
|
}
|
|
}
|
|
|
|
void LightStyleV2::drawControlMask( TQ_ControlElement control,
|
|
TQPainter *p,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQRect &r,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
switch (control) {
|
|
case CE_PushButton:
|
|
p->fillRect(r, color1);
|
|
break;
|
|
|
|
default:
|
|
TQCommonStyle::drawControlMask(control, p, ceData, elementFlags, r, data, widget);
|
|
break;
|
|
}
|
|
}
|
|
|
|
TQRect LightStyleV2::subRect(SubRect subrect, const TQStyleControlElementData ceData, const ControlElementFlags elementFlags, const TQWidget *widget) const
|
|
{
|
|
TQRect rect, wrect(widget->rect());
|
|
|
|
switch (subrect) {
|
|
case SR_PushButtonFocusRect:
|
|
{
|
|
const TQPushButton *button = (const TQPushButton *) widget;
|
|
int dbw1 = 0, dbw2 = 0;
|
|
if (button->isDefault() || button->autoDefault()) {
|
|
dbw1 = pixelMetric(PM_ButtonDefaultIndicator, ceData, elementFlags, widget);
|
|
dbw2 = dbw1 * 2;
|
|
}
|
|
|
|
rect.setRect(wrect.x() + 3 + dbw1,
|
|
wrect.y() + 3 + dbw1,
|
|
wrect.width() - 6 - dbw2,
|
|
wrect.height() - 6 - dbw2);
|
|
break;
|
|
}
|
|
|
|
default:
|
|
rect = TQCommonStyle::subRect(subrect, ceData, elementFlags, widget);
|
|
}
|
|
|
|
return rect;
|
|
}
|
|
|
|
void LightStyleV2::drawComplexControl( TQ_ComplexControl control,
|
|
TQPainter* p,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQRect& r,
|
|
const TQColorGroup& cg,
|
|
SFlags flags,
|
|
SCFlags controls,
|
|
SCFlags active,
|
|
const TQStyleOption &data,
|
|
const TQWidget* widget ) const
|
|
{
|
|
switch (control) {
|
|
case CC_ComboBox:
|
|
{
|
|
const TQComboBox *combobox = (const TQComboBox *) widget;
|
|
TQRect frame, arrow, field;
|
|
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);
|
|
|
|
if ((controls & SC_ComboBoxFrame) && frame.isValid())
|
|
drawLightBevel(p, frame, cg, flags | Style_Raised,
|
|
&cg.brush(TQColorGroup::Button));
|
|
|
|
if ((controls & SC_ComboBoxArrow) && arrow.isValid()) {
|
|
if (active == SC_ComboBoxArrow)
|
|
p->fillRect(arrow, cg.brush(TQColorGroup::Mid));
|
|
arrow.addCoords(4, 2, -2, -2);
|
|
drawPrimitive(PE_ArrowDown, p, ceData, elementFlags, arrow, cg, flags);
|
|
}
|
|
|
|
if ((controls & SC_ComboBoxEditField) && field.isValid()) {
|
|
p->setPen(cg.dark());
|
|
if (combobox->editable()) {
|
|
field.addCoords(-1, -1, 1, 1);
|
|
p->drawRect(field);
|
|
} else
|
|
p->drawLine(field.right() + 1, field.top(),
|
|
field.right() + 1, field.bottom());
|
|
|
|
if (flags & Style_HasFocus) {
|
|
if (! combobox->editable()) {
|
|
p->fillRect( field, cg.brush( TQColorGroup::Highlight ) );
|
|
TQRect fr =
|
|
TQStyle::visualRect( subRect( SR_ComboBoxFocusRect, ceData, elementFlags, widget ),
|
|
ceData, elementFlags );
|
|
drawPrimitive( PE_FocusRect, p, ceData, elementFlags, fr, cg,
|
|
flags | Style_FocusAtBorder,
|
|
TQStyleOption(cg.highlight()));
|
|
}
|
|
|
|
p->setPen(cg.highlightedText());
|
|
} else
|
|
p->setPen(cg.buttonText());
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case CC_SpinWidget:
|
|
{
|
|
const TQSpinWidget *spinwidget = (const TQSpinWidget *) widget;
|
|
TQRect frame, up, down;
|
|
|
|
frame = querySubControlMetrics((TQ_ComplexControl)CC_SpinWidget, ceData, elementFlags,
|
|
SC_SpinWidgetFrame, data, widget);
|
|
up = spinwidget->upRect();
|
|
down = spinwidget->downRect();
|
|
|
|
if ((controls & SC_SpinWidgetFrame) && frame.isValid())
|
|
drawLightBevel(p, frame, cg, flags | Style_Sunken,
|
|
&cg.brush(TQColorGroup::Base));
|
|
|
|
if ((controls & SC_SpinWidgetUp) && up.isValid()) {
|
|
TQ_PrimitiveElement pe = PE_SpinWidgetUp;
|
|
if ( spinwidget->buttonSymbols() == TQSpinWidget::PlusMinus )
|
|
pe = PE_SpinWidgetPlus;
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawLine(up.topLeft(), up.bottomLeft());
|
|
|
|
up.addCoords(1, 0, 0, 0);
|
|
p->fillRect(up, cg.brush(TQColorGroup::Button));
|
|
if (active == SC_SpinWidgetUp)
|
|
p->setPen(cg.mid());
|
|
else
|
|
p->setPen(cg.light());
|
|
p->drawLine(up.left(), up.top(),
|
|
up.right() - 1, up.top());
|
|
p->drawLine(up.left(), up.top() + 1,
|
|
up.left(), up.bottom() - 1);
|
|
if (active == SC_SpinWidgetUp)
|
|
p->setPen(cg.light());
|
|
else
|
|
p->setPen(cg.mid());
|
|
p->drawLine(up.right(), up.top(),
|
|
up.right(), up.bottom());
|
|
p->drawLine(up.left(), up.bottom(),
|
|
up.right() - 1, up.bottom());
|
|
|
|
up.addCoords(1, 0, 0, 0);
|
|
drawPrimitive(pe, p, ceData, elementFlags, up, cg, flags |
|
|
((active == SC_SpinWidgetUp) ?
|
|
Style_On | Style_Sunken : Style_Raised));
|
|
}
|
|
|
|
if ((controls & SC_SpinWidgetDown) && down.isValid()) {
|
|
TQ_PrimitiveElement pe = PE_SpinWidgetDown;
|
|
if ( spinwidget->buttonSymbols() == TQSpinWidget::PlusMinus )
|
|
pe = PE_SpinWidgetMinus;
|
|
|
|
p->setPen(cg.dark());
|
|
p->drawLine(down.topLeft(), down.bottomLeft());
|
|
|
|
down.addCoords(1, 0, 0, 0);
|
|
p->fillRect(down, cg.brush(TQColorGroup::Button));
|
|
if (active == SC_SpinWidgetDown)
|
|
p->setPen(cg.mid());
|
|
else
|
|
p->setPen(cg.light());
|
|
p->drawLine(down.left(), down.top(),
|
|
down.right() - 1, down.top());
|
|
p->drawLine(down.left(), down.top() + 1,
|
|
down.left(), down.bottom() - 1);
|
|
if (active == SC_SpinWidgetDown)
|
|
p->setPen(cg.light());
|
|
else
|
|
p->setPen(cg.mid());
|
|
p->drawLine(down.right(), down.top(),
|
|
down.right(), down.bottom());
|
|
p->drawLine(down.left(), down.bottom(),
|
|
down.right() - 1, down.bottom());
|
|
|
|
down.addCoords(1, 0, 0, 0);
|
|
drawPrimitive(pe, p, ceData, elementFlags, down, cg, flags |
|
|
((active == SC_SpinWidgetDown) ?
|
|
Style_On | Style_Sunken : Style_Raised));
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case CC_ScrollBar:
|
|
{
|
|
const TQScrollBar *scrollbar = (const TQScrollBar *) widget;
|
|
TQRect addline, subline, subline2, addpage, subpage, slider, first, last;
|
|
bool maxedOut = (scrollbar->minValue() == scrollbar->maxValue());
|
|
|
|
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;
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
subline2.moveBy(-addline.width(), 0);
|
|
else
|
|
subline2.moveBy(0, -addline.height());
|
|
|
|
if ((controls & SC_ScrollBarSubLine) && subline.isValid()) {
|
|
drawPrimitive(PE_ScrollBarSubLine, p, ceData, elementFlags, subline, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarSubLine) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
|
|
if (subline2.isValid())
|
|
drawPrimitive(PE_ScrollBarSubLine, p, ceData, elementFlags, subline2, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarSubLine) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
}
|
|
if ((controls & SC_ScrollBarAddLine) && addline.isValid())
|
|
drawPrimitive(PE_ScrollBarAddLine, p, ceData, elementFlags, addline, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarAddLine) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
if ((controls & SC_ScrollBarSubPage) && subpage.isValid())
|
|
drawPrimitive(PE_ScrollBarSubPage, p, ceData, elementFlags, subpage, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarSubPage) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
if ((controls & SC_ScrollBarAddPage) && addpage.isValid())
|
|
drawPrimitive(PE_ScrollBarAddPage, p, ceData, elementFlags, addpage, cg,
|
|
((maxedOut) ? Style_Default : Style_Enabled) |
|
|
((active == SC_ScrollBarAddPage) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
if ((controls & SC_ScrollBarFirst) && first.isValid())
|
|
drawPrimitive(PE_ScrollBarFirst, p, ceData, elementFlags, first, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarFirst) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
if ((controls & SC_ScrollBarLast) && last.isValid())
|
|
drawPrimitive(PE_ScrollBarLast, p, ceData, elementFlags, last, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarLast) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
if ((controls & SC_ScrollBarSlider) && slider.isValid()) {
|
|
drawPrimitive(PE_ScrollBarSlider, p, ceData, elementFlags, slider, cg,
|
|
Style_Enabled | ((active == SC_ScrollBarSlider) ?
|
|
Style_Down : Style_Default) |
|
|
((scrollbar->orientation() == Qt::Horizontal) ?
|
|
Style_Horizontal : 0));
|
|
|
|
// ### perhaps this should not be able to accept focus if maxedOut?
|
|
if (scrollbar->hasFocus()) {
|
|
TQRect fr(slider.x() + 2, slider.y() + 2,
|
|
slider.width() - 5, slider.height() - 5);
|
|
drawPrimitive(PE_FocusRect, p, ceData, elementFlags, fr, cg, Style_Default);
|
|
}
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case CC_Slider:
|
|
{
|
|
const TQSlider *slider = (const TQSlider *) widget;
|
|
TQRect groove = querySubControlMetrics(CC_Slider, ceData, elementFlags, SC_SliderGroove,
|
|
data, widget),
|
|
handle = querySubControlMetrics(CC_Slider, ceData, elementFlags, SC_SliderHandle,
|
|
data, widget);
|
|
|
|
if ((controls & SC_SliderGroove) && groove.isValid()) {
|
|
if (flags & Style_HasFocus)
|
|
drawPrimitive( PE_FocusRect, p, ceData, elementFlags, groove, cg );
|
|
|
|
if (slider->orientation() == Qt::Horizontal) {
|
|
int dh = (groove.height() - 5) / 2;
|
|
groove.addCoords(0, dh, 0, -dh);
|
|
} else {
|
|
int dw = (groove.width() - 5) / 2;
|
|
groove.addCoords(dw, 0, -dw, 0);
|
|
}
|
|
|
|
drawLightBevel(p, groove, cg, ((flags | Style_Raised) ^ Style_Raised) |
|
|
((flags & Style_Enabled) ? Style_Sunken : Style_Default),
|
|
&cg.brush(TQColorGroup::Midlight));
|
|
}
|
|
|
|
if ((controls & SC_SliderHandle) && handle.isValid()) {
|
|
drawLightBevel(p, handle, cg, ((flags | Style_Down) ^ Style_Down) |
|
|
((flags & Style_Enabled) ? Style_Raised : Style_Default),
|
|
&cg.brush(TQColorGroup::Button));
|
|
|
|
}
|
|
|
|
if (controls & SC_SliderTickmarks)
|
|
TQCommonStyle::drawComplexControl(control, p, ceData, elementFlags, r, cg, flags,
|
|
SC_SliderTickmarks, active, data, widget );
|
|
break;
|
|
}
|
|
|
|
case CC_ListView:
|
|
// use the base style for CC_ListView
|
|
singleton->basestyle->drawComplexControl(control, p, ceData, elementFlags, r, cg, flags,
|
|
controls, active, data, widget);
|
|
break;
|
|
|
|
default:
|
|
TQCommonStyle::drawComplexControl(control, p, ceData, elementFlags, r, cg, flags,
|
|
controls, active, data, widget);
|
|
break;
|
|
}
|
|
}
|
|
|
|
TQRect LightStyleV2::querySubControlMetrics( TQ_ComplexControl control,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
SubControl sc,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
TQRect ret;
|
|
|
|
switch (control) {
|
|
case CC_ScrollBar:
|
|
{
|
|
const TQScrollBar *scrollbar = (const TQScrollBar *) widget;
|
|
int sliderstart = scrollbar->sliderStart();
|
|
int sbextent = pixelMetric(PM_ScrollBarExtent, ceData, elementFlags, widget);
|
|
int maxlen = ((scrollbar->orientation() == Qt::Horizontal) ?
|
|
scrollbar->width() : scrollbar->height()) - (sbextent * 3);
|
|
int sliderlen;
|
|
|
|
// calculate slider length
|
|
if (scrollbar->maxValue() != scrollbar->minValue()) {
|
|
uint range = scrollbar->maxValue() - scrollbar->minValue();
|
|
sliderlen = (scrollbar->pageStep() * maxlen) /
|
|
(range + scrollbar->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;
|
|
|
|
switch (sc) {
|
|
case SC_ScrollBarSubLine:
|
|
// top/left button
|
|
ret.setRect(0, 0, sbextent, sbextent);
|
|
break;
|
|
|
|
case SC_ScrollBarAddLine:
|
|
// bottom/right button
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
ret.setRect(scrollbar->width() - sbextent, 0, sbextent, sbextent);
|
|
else
|
|
ret.setRect(0, scrollbar->height() - sbextent, sbextent, sbextent);
|
|
break;
|
|
|
|
case SC_ScrollBarSubPage:
|
|
// between top/left button and slider
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
ret.setRect(sbextent, 0, sliderstart - sbextent, sbextent);
|
|
else
|
|
ret.setRect(0, sbextent, sbextent, sliderstart - sbextent);
|
|
break;
|
|
|
|
case SC_ScrollBarAddPage:
|
|
// between bottom/right button and slider
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
ret.setRect(sliderstart + sliderlen, 0,
|
|
maxlen - sliderstart - sliderlen + sbextent, sbextent);
|
|
else
|
|
ret.setRect(0, sliderstart + sliderlen,
|
|
sbextent, maxlen - sliderstart - sliderlen + sbextent);
|
|
break;
|
|
|
|
case SC_ScrollBarGroove:
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
ret.setRect(sbextent, 0, scrollbar->width() - sbextent * 3,
|
|
scrollbar->height());
|
|
else
|
|
ret.setRect(0, sbextent, scrollbar->width(),
|
|
scrollbar->height() - sbextent * 3);
|
|
break;
|
|
|
|
case SC_ScrollBarSlider:
|
|
if (scrollbar->orientation() == Qt::Horizontal)
|
|
ret.setRect(sliderstart, 0, sliderlen, sbextent);
|
|
else
|
|
ret.setRect(0, sliderstart, sbextent, sliderlen);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
default:
|
|
ret = TQCommonStyle::querySubControlMetrics(control, ceData, elementFlags, sc, data, widget);
|
|
break;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
TQStyle::SubControl LightStyleV2::querySubControl( TQ_ComplexControl control,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQPoint &pos,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
TQStyle::SubControl ret = TQCommonStyle::querySubControl(control, ceData, elementFlags, pos, data, widget);
|
|
|
|
// this is an ugly hack, but i really don't care, it's the quickest way to
|
|
// enabled the third button
|
|
if (control == CC_ScrollBar &&
|
|
ret == SC_None)
|
|
ret = SC_ScrollBarSubLine;
|
|
|
|
return ret;
|
|
}
|
|
|
|
int LightStyleV2::pixelMetric( PixelMetric metric, TQStyleControlElementData ceData, ControlElementFlags elementFlags,
|
|
const TQWidget *widget ) const
|
|
{
|
|
int ret;
|
|
|
|
switch (metric) {
|
|
case PM_ButtonMargin:
|
|
ret = 4;
|
|
break;
|
|
|
|
case PM_ButtonShiftHorizontal:
|
|
case PM_ButtonShiftVertical:
|
|
ret = 0;
|
|
break;
|
|
|
|
case PM_ButtonDefaultIndicator:
|
|
case PM_DefaultFrameWidth:
|
|
ret = 2;
|
|
break;
|
|
|
|
case PM_IndicatorWidth:
|
|
case PM_IndicatorHeight:
|
|
case PM_ExclusiveIndicatorWidth:
|
|
case PM_ExclusiveIndicatorHeight:
|
|
ret = 13;
|
|
break;
|
|
|
|
case PM_TabBarTabOverlap:
|
|
ret = 0;
|
|
break;
|
|
|
|
case PM_ScrollBarExtent:
|
|
case PM_ScrollBarSliderMin:
|
|
ret = 14;
|
|
break;
|
|
|
|
case PM_MenuBarFrameWidth:
|
|
ret = 1;
|
|
break;
|
|
|
|
case PM_ProgressBarChunkWidth:
|
|
ret = 1;
|
|
break;
|
|
|
|
case PM_DockWindowSeparatorExtent:
|
|
ret = 4;
|
|
break;
|
|
|
|
case PM_SplitterWidth:
|
|
ret = 6;
|
|
break;
|
|
|
|
|
|
case PM_SliderLength:
|
|
case PM_SliderControlThickness:
|
|
ret = singleton->basestyle->pixelMetric( metric, ceData, elementFlags, widget );
|
|
break;
|
|
|
|
case PM_MaximumDragDistance:
|
|
ret = -1;
|
|
break;
|
|
|
|
default:
|
|
ret = TQCommonStyle::pixelMetric(metric, ceData, elementFlags, widget);
|
|
break;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
TQSize LightStyleV2::sizeFromContents( ContentsType contents,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQSize &contentsSize,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
TQSize ret;
|
|
|
|
switch (contents) {
|
|
case CT_PushButton:
|
|
{
|
|
const TQPushButton *button = (const TQPushButton *) widget;
|
|
ret = TQCommonStyle::sizeFromContents( contents, ceData, elementFlags, contentsSize, data, widget );
|
|
int w = ret.width(), h = ret.height();
|
|
|
|
// only expand the button if we are displaying text...
|
|
if ( ! button->text().isEmpty() ) {
|
|
if ( button->isDefault() || button->autoDefault() ) {
|
|
// default button minimum size
|
|
if ( w < 80 )
|
|
w = 80;
|
|
if ( h < 25 )
|
|
h = 25;
|
|
} else {
|
|
// regular button minimum size
|
|
if ( w < 76 )
|
|
w = 76;
|
|
if ( h < 21 )
|
|
h = 21;
|
|
}
|
|
}
|
|
|
|
ret = TQSize( w, h );
|
|
break;
|
|
}
|
|
|
|
case CT_PopupMenuItem:
|
|
{
|
|
if (! widget || data.isDefault())
|
|
break;
|
|
|
|
TQMenuItem *mi = data.menuItem();
|
|
const TQPopupMenu *popupmenu = (const TQPopupMenu *) widget;
|
|
int maxpmw = data.maxIconWidth();
|
|
int w = contentsSize.width(), h = contentsSize.height();
|
|
|
|
if (mi->custom()) {
|
|
w = mi->custom()->sizeHint().width();
|
|
h = mi->custom()->sizeHint().height();
|
|
if (! mi->custom()->fullSpan() && h < 22)
|
|
h = 22;
|
|
} else if(mi->widget()) {
|
|
} else if (mi->isSeparator()) {
|
|
w = 10;
|
|
h = 4;
|
|
} else {
|
|
// check is at least 16x16
|
|
if (h < 16)
|
|
h = 16;
|
|
if (mi->pixmap())
|
|
h = QMAX(h, mi->pixmap()->height());
|
|
else if (! mi->text().isNull())
|
|
h = QMAX(h, popupmenu->fontMetrics().height() + 2);
|
|
if (mi->iconSet() != 0)
|
|
h = QMAX(h, mi->iconSet()->pixmap(TQIconSet::Small,
|
|
TQIconSet::Normal).height());
|
|
h += 2;
|
|
}
|
|
|
|
// check | 4 pixels | item | 8 pixels | accel | 4 pixels | check
|
|
|
|
// check is at least 16x16
|
|
maxpmw = QMAX(maxpmw, 16);
|
|
w += (maxpmw * 2) + 8;
|
|
|
|
if (! mi->text().isNull() && mi->text().find('\t') >= 0)
|
|
w += 8;
|
|
|
|
ret = TQSize(w, h);
|
|
break;
|
|
}
|
|
case CT_ProgressBar:
|
|
{
|
|
const TQProgressBar* pb = static_cast<const TQProgressBar*>(widget);
|
|
|
|
//If we have to display the indicator, and we do it on RHS, give some more room
|
|
//for it. This tries to match the logic and the spacing in SR_ProgressBarGroove/Contents
|
|
//sizing in TQCommonStyle.
|
|
if (pb->percentageVisible() &&
|
|
(pb->indicatorFollowsStyle() || ! pb->centerIndicator()))
|
|
{
|
|
int addw = pb->fontMetrics().width("100%") + 6;
|
|
return TQSize(contentsSize.width() + addw, contentsSize.height());
|
|
}
|
|
else
|
|
return contentsSize; //Otherwise leave unchanged
|
|
|
|
break;
|
|
}
|
|
|
|
default:
|
|
ret = TQCommonStyle::sizeFromContents(contents, ceData, elementFlags, contentsSize, data, widget);
|
|
break;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
int LightStyleV2::styleHint( TQ_StyleHint stylehint,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQStyleOption &option,
|
|
TQStyleHintReturn* returnData,
|
|
const TQWidget *widget ) const
|
|
{
|
|
int ret;
|
|
|
|
switch (stylehint) {
|
|
case SH_EtchDisabledText:
|
|
case SH_Slider_SnapToValue:
|
|
case SH_PrintDialog_RightAlignButtons:
|
|
case SH_FontDialog_SelectAssociatedText:
|
|
case SH_MenuBar_AltKeyNavigation:
|
|
case SH_MenuBar_MouseTracking:
|
|
case SH_PopupMenu_MouseTracking:
|
|
case SH_ComboBox_ListMouseTracking:
|
|
case SH_ScrollBar_MiddleClickAbsolutePosition:
|
|
ret = 1;
|
|
break;
|
|
|
|
case SH_MainWindow_SpaceBelowMenuBar:
|
|
ret = 0;
|
|
break;
|
|
|
|
default:
|
|
ret = TQCommonStyle::styleHint(stylehint, ceData, elementFlags, option, returnData, widget);
|
|
break;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
TQPixmap LightStyleV2::stylePixmap( StylePixmap stylepixmap,
|
|
TQStyleControlElementData ceData,
|
|
ControlElementFlags elementFlags,
|
|
const TQStyleOption &data,
|
|
const TQWidget *widget ) const
|
|
{
|
|
return singleton->basestyle->stylePixmap( stylepixmap, ceData, elementFlags, data, widget );
|
|
}
|
|
#include "lightstyle-v2.moc"
|