+// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*-
+
+#ifdef HAVE_CONFIG_H
+# include "../config.h"
+#endif
+
#include "button.hh"
namespace otk {
OtkButton::OtkButton(OtkWidget *parent)
- : OtkWidget(parent), _text(""), _pressed(false),
- _unfocus_tx(OtkWidget::getStyle()->getButtonUnfocus())
+ : OtkFocusLabel(parent), _pressed(false), _pressed_focus_tx(0),
+ _pressed_unfocus_tx(0), _unpr_focus_tx(0), _unpr_unfocus_tx(0)
{
+ setStyle(getStyle());
}
OtkButton::~OtkButton()
{
+}
+
+void OtkButton::setStyle(Style *style)
+{
+ OtkFocusLabel::setStyle(style);
+
+ setTexture(getStyle()->getButtonFocus());
+ setUnfocusTexture(getStyle()->getButtonUnfocus());
+ _pressed_focus_tx = getStyle()->getButtonPressedFocus();
+ _pressed_unfocus_tx = getStyle()->getButtonPressedUnfocus();
}
-void OtkButton::setText(const std::string &text)
+
+void OtkButton::press(unsigned int mouse_button)
{
- std::string a = text;
+ if (_pressed) return;
+
+ if (_pressed_focus_tx)
+ OtkFocusWidget::setTexture(_pressed_focus_tx);
+ if (_pressed_unfocus_tx)
+ OtkFocusWidget::setUnfocusTexture(_pressed_unfocus_tx);
+ _pressed = true;
+ _mouse_button = mouse_button;
}
-void OtkButton::press(void)
+void OtkButton::release(unsigned int mouse_button)
{
+ if (_mouse_button != mouse_button) return; // wrong button
+ OtkFocusWidget::setTexture(_unpr_focus_tx);
+ OtkFocusWidget::setUnfocusTexture(_unpr_unfocus_tx);
+ _pressed = false;
}
-void OtkButton::release(void)
+void OtkButton::setTexture(BTexture *texture)
{
+ OtkFocusWidget::setTexture(texture);
+ _unpr_focus_tx = texture;
+}
+void OtkButton::setUnfocusTexture(BTexture *texture)
+{
+ OtkFocusWidget::setUnfocusTexture(texture);
+ _unpr_unfocus_tx = texture;
+}
+
+void OtkButton::buttonPressHandler(const XButtonEvent &e)
+{
+ press(e.button);
+ update();
+ OtkFocusWidget::buttonPressHandler(e);
+}
+
+void OtkButton::buttonReleaseHandler(const XButtonEvent &e)
+{
+ release(e.button);
+ update();
+ OtkFocusWidget::buttonReleaseHandler(e);
}
}