#endif
#include "buttonwidget.hh"
-#include "otk/gccache.hh" // otk::BPen
+#include "client.hh"
namespace ob {
-OBButtonWidget::OBButtonWidget(otk::OtkWidget *parent,
- OBWidget::WidgetType type)
- : otk::OtkWidget(parent),
- OBWidget(type),
+ButtonWidget::ButtonWidget(otk::Widget *parent,
+ WidgetBase::WidgetType type,
+ Client *client)
+ : otk::Widget(parent),
+ WidgetBase(type),
+ _client(client),
_pressed(false),
- _button(0)
+ _button(0),
+ _state(false)
{
}
-OBButtonWidget::~OBButtonWidget()
+ButtonWidget::~ButtonWidget()
{
}
-void OBButtonWidget::setTextures()
+void ButtonWidget::setTextures()
{
+ bool p = _pressed;
+
+ switch (type()) {
+ case Type_AllDesktopsButton:
+ if (_client->desktop() == (signed)0xffffffff)
+ p = true;
+ break;
+ case Type_MaximizeButton:
+ if (_client->maxHorz() || _client->maxVert())
+ p = true;
+ break;
+ default:
+ break;
+ }
+
switch (type()) {
case Type_LeftGrip:
case Type_RightGrip:
if (_focused)
- setTexture(_style->getGripFocus());
+ setTexture(_style->gripFocusBackground());
else
- setTexture(_style->getGripUnfocus());
+ setTexture(_style->gripUnfocusBackground());
break;
- case Type_StickyButton:
- case Type_CloseButton:
+ case Type_AllDesktopsButton:
case Type_MaximizeButton:
+ case Type_CloseButton:
case Type_IconifyButton:
- if (_pressed) {
+ if (p) {
if (_focused)
- setTexture(_style->getButtonPressedFocus());
+ setTexture(_style->buttonPressFocusBackground());
else
- setTexture(_style->getButtonPressedUnfocus());
+ setTexture(_style->buttonPressUnfocusBackground());
} else {
if (_focused)
- setTexture(_style->getButtonFocus());
+ setTexture(_style->buttonUnpressFocusBackground());
else
- setTexture(_style->getButtonUnfocus());
+ setTexture(_style->buttonUnpressUnfocusBackground());
}
break;
default:
}
-void OBButtonWidget::setStyle(otk::Style *style)
+void ButtonWidget::setStyle(otk::RenderStyle *style)
{
- otk::OtkWidget::setStyle(style);
+ otk::Widget::setStyle(style);
setTextures();
switch (type()) {
case Type_LeftGrip:
case Type_RightGrip:
- setBorderColor(_style->getBorderColor());
+ setBorderColor(_style->frameBorderColor());
break;
- case Type_StickyButton:
+ case Type_AllDesktopsButton:
case Type_CloseButton:
case Type_MaximizeButton:
case Type_IconifyButton:
}
-void OBButtonWidget::update()
+void ButtonWidget::update()
+{
+ switch (type()) {
+ case Type_AllDesktopsButton:
+ if ((_client->desktop() == (signed)0xffffffff) != _state) {
+ _state = !_state;
+ setTextures();
+ }
+ break;
+ case Type_MaximizeButton:
+ if ((_client->maxHorz() || _client->maxVert()) != _state) {
+ _state = !_state;
+ setTextures();
+ }
+ break;
+ default:
+ break;
+ }
+
+ otk::Widget::update();
+}
+
+
+void ButtonWidget::renderForeground()
{
otk::PixmapMask *pm;
int width;
bool draw = _dirty;
- otk::OtkWidget::update();
+ otk::Widget::renderForeground();
if (draw) {
switch (type()) {
- case Type_StickyButton:
- pm = _style->getStickyButtonMask();
+ case Type_AllDesktopsButton:
+ pm = _style->alldesktopsMask();
break;
case Type_CloseButton:
- pm = _style->getCloseButtonMask();
+ pm = _style->closeMask();
break;
case Type_MaximizeButton:
- pm = _style->getMaximizeButtonMask();
+ pm = _style->maximizeMask();
break;
case Type_IconifyButton:
- pm = _style->getIconifyButtonMask();
+ pm = _style->iconifyMask();
break;
case Type_LeftGrip:
case Type_RightGrip:
assert(false); // there's no other button widgets!
}
+ assert(pm->mask);
if (pm->mask == None) return; // no mask for the button, leave it empty
width = _rect.width();
-
- otk::BPen pen(_focused ? *_style->getButtonPicFocus() :
- *_style->getButtonPicUnfocus());
+
+ otk::RenderColor *color = (_focused ? _style->buttonFocusColor() :
+ _style->buttonUnfocusColor());
// set the clip region
- XSetClipMask(otk::OBDisplay::display, pen.gc(), pm->mask);
- XSetClipOrigin(otk::OBDisplay::display, pen.gc(),
- (width - pm->w)/2, (width - pm->h)/2);
+ int x = (width - pm->w) / 2, y = (width - pm->h) / 2;
+ XSetClipMask(**otk::display, color->gc(), pm->mask);
+ XSetClipOrigin(**otk::display, color->gc(), x, y);
// fill in the clipped region
- XFillRectangle(otk::OBDisplay::display, _window, pen.gc(),
- (width - pm->w)/2, (width - pm->h)/2,
- (width + pm->w)/2, (width + pm->h)/2);
+ XFillRectangle(**otk::display, _surface->pixmap(), color->gc(), x, y,
+ x + pm->w, y + pm->h);
// unset the clip region
- XSetClipMask(otk::OBDisplay::display, pen.gc(), None);
- XSetClipOrigin(otk::OBDisplay::display, pen.gc(), 0, 0);
+ XSetClipMask(**otk::display, color->gc(), None);
+ XSetClipOrigin(**otk::display, color->gc(), 0, 0);
}
}
-void OBButtonWidget::adjust()
+void ButtonWidget::adjust()
{
// nothing to adjust. no children.
}
-void OBButtonWidget::focus()
+void ButtonWidget::focus()
{
- otk::OtkWidget::focus();
+ otk::Widget::focus();
setTextures();
}
-void OBButtonWidget::unfocus()
+void ButtonWidget::unfocus()
{
- otk::OtkWidget::unfocus();
+ otk::Widget::unfocus();
setTextures();
}
-void OBButtonWidget::buttonPressHandler(const XButtonEvent &e)
+void ButtonWidget::buttonPressHandler(const XButtonEvent &e)
{
- OtkWidget::buttonPressHandler(e);
+ otk::Widget::buttonPressHandler(e);
if (_button) return;
_button = e.button;
_pressed = true;
}
-void OBButtonWidget::buttonReleaseHandler(const XButtonEvent &e)
+void ButtonWidget::buttonReleaseHandler(const XButtonEvent &e)
{
- OtkWidget::buttonPressHandler(e);
+ otk::Widget::buttonPressHandler(e);
if (e.button != _button) return;
_button = 0;
_pressed = false;