working button class (minus fonts)
This commit is contained in:
parent
b33e8f6612
commit
b169547797
2 changed files with 70 additions and 15 deletions
|
@ -3,29 +3,66 @@
|
||||||
namespace otk {
|
namespace otk {
|
||||||
|
|
||||||
OtkButton::OtkButton(OtkWidget *parent)
|
OtkButton::OtkButton(OtkWidget *parent)
|
||||||
: OtkWidget(parent), _text(""), _pressed(false),
|
: OtkFocusWidget(parent), _text(""), _pressed(false), _dirty(false),
|
||||||
_unfocus_tx(OtkWidget::getStyle()->getButtonUnfocus())
|
_pressed_focus_tx(0), _pressed_unfocus_tx(0), _unpr_focus_tx(0),
|
||||||
|
_unpr_unfocus_tx(0)
|
||||||
{
|
{
|
||||||
|
setTexture(getStyle()->getButtonFocus());
|
||||||
|
setUnfocusTexture(getStyle()->getButtonUnfocus());
|
||||||
|
_pressed_focus_tx = getStyle()->getButtonPressedFocus();
|
||||||
|
_pressed_unfocus_tx = getStyle()->getButtonPressedUnfocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
OtkButton::~OtkButton()
|
OtkButton::~OtkButton()
|
||||||
{
|
{
|
||||||
|
if (_pressed_focus_tx) delete _pressed_focus_tx;
|
||||||
}
|
if (_pressed_unfocus_tx) delete _pressed_unfocus_tx;
|
||||||
|
|
||||||
void OtkButton::setText(const std::string &text)
|
|
||||||
{
|
|
||||||
std::string a = text;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void OtkButton::press(void)
|
void OtkButton::press(void)
|
||||||
{
|
{
|
||||||
|
if (_pressed_focus_tx)
|
||||||
|
OtkFocusWidget::setTexture(_pressed_focus_tx);
|
||||||
|
if (_pressed_unfocus_tx)
|
||||||
|
OtkFocusWidget::setUnfocusTexture(_pressed_unfocus_tx);
|
||||||
|
_pressed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void OtkButton::release(void)
|
void OtkButton::release(void)
|
||||||
{
|
{
|
||||||
|
OtkFocusWidget::setTexture(_unpr_focus_tx);
|
||||||
|
OtkFocusWidget::setUnfocusTexture(_unpr_unfocus_tx);
|
||||||
|
_pressed = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
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::update(void)
|
||||||
|
{
|
||||||
|
if (_dirty) {
|
||||||
|
const BFont ft = getStyle()->getFont();
|
||||||
|
BColor *text_color = (isFocused() ? getStyle()->getTextFocus()
|
||||||
|
: getStyle()->getTextUnfocus());
|
||||||
|
unsigned int bevel = getStyle()->getBevelWidth();
|
||||||
|
|
||||||
|
OtkFocusWidget::resize(ft.measureString(_text) + bevel * 2,
|
||||||
|
ft.height() + bevel * 2);
|
||||||
|
ft.drawString(getWindow(), bevel, bevel, *text_color, _text);
|
||||||
|
|
||||||
|
OtkFocusWidget::update();
|
||||||
|
}
|
||||||
|
|
||||||
|
_dirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +1,30 @@
|
||||||
#include "widget.hh"
|
#include "focuswidget.hh"
|
||||||
#include "style.hh"
|
|
||||||
#include "texture.hh"
|
|
||||||
//#include "pixmap.hh"
|
//#include "pixmap.hh"
|
||||||
|
|
||||||
namespace otk {
|
namespace otk {
|
||||||
|
|
||||||
class OtkButton : public OtkWidget {
|
class OtkButton : public OtkFocusWidget {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
OtkButton(OtkWidget *parent);
|
OtkButton(OtkWidget *parent);
|
||||||
~OtkButton();
|
~OtkButton();
|
||||||
|
|
||||||
|
inline const BTexture *getPressedFocusTexture(void) const
|
||||||
|
{ return _pressed_focus_tx; }
|
||||||
|
void setPressedFocusTexture(BTexture *texture)
|
||||||
|
{ _pressed_focus_tx = texture; }
|
||||||
|
|
||||||
|
inline const BTexture *getPressedUnfocusTexture(void) const
|
||||||
|
{ return _pressed_unfocus_tx; }
|
||||||
|
void setPressedUnfocusTexture(BTexture *texture)
|
||||||
|
{ _pressed_unfocus_tx = texture; }
|
||||||
|
|
||||||
|
void setTexture(BTexture *texture);
|
||||||
|
void setUnfocusTexture(BTexture *texture);
|
||||||
|
|
||||||
inline const std::string &getText(void) const { return _text; }
|
inline const std::string &getText(void) const { return _text; }
|
||||||
void setText(const std::string &text);
|
void setText(const std::string &text) { _text = text; _dirty = true; }
|
||||||
|
|
||||||
//inline const OtkPixmap &getPixmap(void) const { return _pixmap; }
|
//inline const OtkPixmap &getPixmap(void) const { return _pixmap; }
|
||||||
//void setPixmap(const OtkPixmap &pixmap);
|
//void setPixmap(const OtkPixmap &pixmap);
|
||||||
|
@ -22,13 +33,20 @@ public:
|
||||||
void press(void);
|
void press(void);
|
||||||
void release(void);
|
void release(void);
|
||||||
|
|
||||||
|
void update(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
std::string _text;
|
std::string _text;
|
||||||
//OtkPixmap _pixmap;
|
//OtkPixmap _pixmap;
|
||||||
bool _pressed;
|
bool _pressed;
|
||||||
BTexture *_unfocus_tx;
|
bool _dirty;
|
||||||
|
|
||||||
|
BTexture *_pressed_focus_tx;
|
||||||
|
BTexture *_pressed_unfocus_tx;
|
||||||
|
|
||||||
|
BTexture *_unpr_focus_tx;
|
||||||
|
BTexture *_unpr_unfocus_tx;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue