X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Fbuttonwidget.cc;h=810911be4bfccf30694c943c50600d0d97f6ee04;hb=9e6b0d5a8d0226232802bdece77665b167f98dae;hp=534bdc8409f84b35c8aabb091baedcaaa87c09ff;hpb=b99508df011eaf8a264bf5725ac8849f0782ec7b;p=chaz%2Fopenbox diff --git a/src/buttonwidget.cc b/src/buttonwidget.cc index 534bdc84..810911be 100644 --- a/src/buttonwidget.cc +++ b/src/buttonwidget.cc @@ -5,16 +5,19 @@ #endif #include "buttonwidget.hh" -#include "otk/gccache.hh" // otk::BPen +#include "client.hh" namespace ob { ButtonWidget::ButtonWidget(otk::Widget *parent, - WidgetBase::WidgetType type) + WidgetBase::WidgetType type, + Client *client) : otk::Widget(parent), WidgetBase(type), + _client(client), _pressed(false), - _button(0) + _button(0), + _state(false) { } @@ -26,6 +29,21 @@ ButtonWidget::~ButtonWidget() 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: @@ -34,11 +52,11 @@ void ButtonWidget::setTextures() else 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->buttonPressFocusBackground()); else @@ -66,7 +84,7 @@ void ButtonWidget::setStyle(otk::RenderStyle *style) case Type_RightGrip: setBorderColor(_style->frameBorderColor()); break; - case Type_StickyButton: + case Type_AllDesktopsButton: case Type_CloseButton: case Type_MaximizeButton: case Type_IconifyButton: @@ -79,23 +97,39 @@ void ButtonWidget::setStyle(otk::RenderStyle *style) void ButtonWidget::update() { - printf("ButtonWidget::update()\n"); + 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; - printf("ButtonWidget::renderForeground()\n"); otk::Widget::renderForeground(); if (draw) { switch (type()) { - case Type_StickyButton: - pm = _style->stickyMask(); + case Type_AllDesktopsButton: + pm = _style->alldesktopsMask(); break; case Type_CloseButton: pm = _style->closeMask();