]> Dogcows Code - chaz/openbox/blobdiff - otk/button.cc
updated wrappers around the new otk widget system and style system
[chaz/openbox] / otk / button.cc
index 04906fe517306f1e06baa4d5a0dbdf28c7934a2c..8d63ed0c3b71a6268b353904d31040a668907ddd 100644 (file)
@@ -9,73 +9,73 @@
 namespace otk {
 
 Button::Button(Widget *parent)
-  : FocusLabel(parent), _pressed(false), _pressed_focus_tx(0),
-    _pressed_unfocus_tx(0), _unpr_focus_tx(0), _unpr_unfocus_tx(0)
+  : Label(parent), _default(false), _pressed(false)
 {
+  setHorizontalJustify(RenderStyle::CenterJustify);
+  setVerticalJustify(RenderStyle::CenterJustify);
+  styleChanged(*RenderStyle::style(screen()));
 }
 
 Button::~Button()
 {
 }
 
-
-void Button::setStyle(Style *style)
-{
-  FocusLabel::setStyle(style);
-
-  // XXX: do this again
-  //setTexture(style->getButtonFocus());
-  //setUnfocusTexture(style->getButtonUnfocus());
-  //_pressed_focus_tx = style->getButtonPressedFocus();
-  //_pressed_unfocus_tx = style->getButtonPressedUnfocus();
-}
-
-
 void Button::press(unsigned int mouse_button)
 {
   if (_pressed) return;
 
-  if (_pressed_focus_tx)
-    FocusWidget::setTexture(_pressed_focus_tx);
-  if (_pressed_unfocus_tx)
-    FocusWidget::setUnfocusTexture(_pressed_unfocus_tx);
   _pressed = true;
   _mouse_button = mouse_button;
+
+  styleChanged(*RenderStyle::style(screen()));
+  refresh();
 }
 
 void Button::release(unsigned int mouse_button)
 {
-  if (_mouse_button != mouse_button) return; // wrong button
+  if (!_pressed || _mouse_button != mouse_button) return; // wrong button
 
-  FocusWidget::setTexture(_unpr_focus_tx);
-  FocusWidget::setUnfocusTexture(_unpr_unfocus_tx);
   _pressed = false;
+
+  styleChanged(*RenderStyle::style(screen()));
+  refresh();
 }
 
-void Button::setTexture(RenderTexture *texture)
+void Button::buttonPressHandler(const XButtonEvent &e)
 {
-  FocusWidget::setTexture(texture);
-  _unpr_focus_tx = texture;
+  Widget::buttonPressHandler(e);
+  press(e.button);
 }
 
-void Button::setUnfocusTexture(RenderTexture *texture)
+void Button::buttonReleaseHandler(const XButtonEvent &e)
 {
-  FocusWidget::setUnfocusTexture(texture);
-  _unpr_unfocus_tx = texture;
+  Widget::buttonReleaseHandler(e);
+  release(e.button);
 }
 
-void Button::buttonPressHandler(const XButtonEvent &e)
+void Button::setDefault(bool d)
 {
-  press(e.button);
-  update();
-  FocusWidget::buttonPressHandler(e);
+  _default = d;
+  styleChanged(*RenderStyle::style(screen()));
+  refresh();
 }
 
-void Button::buttonReleaseHandler(const XButtonEvent &e)
+void Button::styleChanged(const RenderStyle &style)
 {
-  release(e.button);
-  update();
-  FocusWidget::buttonReleaseHandler(e);
+  if (_default) {
+    if (_pressed)
+      _texture = style.buttonPressFocusBackground();
+    else
+      _texture = style.buttonUnpressFocusBackground();
+    _forecolor = style.buttonFocusColor();
+  } else {
+    if (_pressed)
+      _texture = style.buttonPressUnfocusBackground();
+    else
+      _texture = style.buttonUnpressUnfocusBackground();
+    _forecolor = style.buttonUnfocusColor();
+  }
+  Widget::styleChanged(style);
 }
 
 }
This page took 0.025289 seconds and 4 git commands to generate.