257 lines
6.8 KiB
C++
257 lines
6.8 KiB
C++
/**
|
|
* @author Edouard DUPIN
|
|
*
|
|
* @copyright 2011, Edouard DUPIN, all right reserved
|
|
*
|
|
* @license BSD v3 (see license file)
|
|
*/
|
|
|
|
|
|
#include <ewol/widget/ButtonColor.h>
|
|
|
|
#include <ewol/compositing/Drawing.h>
|
|
#include <ewol/widget/WidgetManager.h>
|
|
#include <ewol/widget/meta/ColorChooser.h>
|
|
#include <ewol/widget/Windows.h>
|
|
#include <ewol/ewol.h>
|
|
|
|
extern const char * const ewolEventButtonColorChange = "ewol-Button-Color-Change";
|
|
|
|
|
|
// DEFINE for the shader display system :
|
|
#define STATUS_UP (0)
|
|
#define STATUS_HOVER (2)
|
|
#define STATUS_PRESSED (1)
|
|
#define STATUS_DOWN (3)
|
|
|
|
|
|
#undef __class__
|
|
#define __class__ "ButtonColor"
|
|
|
|
|
|
|
|
static ewol::Widget* Create(void) {
|
|
return new ewol::widget::ButtonColor();
|
|
}
|
|
|
|
void ewol::widget::ButtonColor::init(ewol::WidgetManager& _widgetManager) {
|
|
_widgetManager.addWidgetCreator(__class__,&Create);
|
|
}
|
|
|
|
ewol::widget::ButtonColor::ButtonColor(etk::Color<> _baseColor, std::string _shaperName) :
|
|
m_shaper(_shaperName),
|
|
m_textColorFg(_baseColor),
|
|
m_widgetContextMenu(NULL) {
|
|
addObjectType("ewol::widget::ButtonColor");
|
|
addEventId(ewolEventButtonColorChange);
|
|
changeStatusIn(STATUS_UP);
|
|
setCanHaveFocus(true);
|
|
// Limit event at 1:
|
|
setMouseLimit(1);
|
|
}
|
|
|
|
|
|
ewol::widget::ButtonColor::~ButtonColor(void) {
|
|
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::setShaperName(std::string _shaperName) {
|
|
m_shaper.setSource(_shaperName);
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::calculateMinMaxSize(void) {
|
|
vec2 padding = m_shaper.getPadding();
|
|
std::string label = m_textColorFg.getString();
|
|
vec3 minSize = m_text.calculateSize(label);
|
|
m_minSize.setX(padding.x()*2 + minSize.x() + 7);
|
|
m_minSize.setY(padding.y()*2 + minSize.y() );
|
|
markToRedraw();
|
|
}
|
|
|
|
|
|
|
|
void ewol::widget::ButtonColor::onDraw(void) {
|
|
m_shaper.draw();
|
|
m_text.draw();
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::onRegenerateDisplay(void) {
|
|
if (needRedraw() == false) {
|
|
return;
|
|
}
|
|
EWOL_DEBUG("redraw");
|
|
m_text.clear();
|
|
m_shaper.clear();
|
|
|
|
vec2 padding = m_shaper.getPadding();
|
|
|
|
std::string label = m_textColorFg.getString();
|
|
|
|
ivec2 localSize = m_minSize;
|
|
|
|
vec3 tmpOrigin((m_size.x() - m_minSize.x()) / 2.0,
|
|
(m_size.y() - m_minSize.y()) / 2.0,
|
|
0);
|
|
// no change for the text orogin :
|
|
vec3 tmpTextOrigin((m_size.x() - m_minSize.x()) / 2.0,
|
|
(m_size.y() - m_minSize.y()) / 2.0,
|
|
0);
|
|
|
|
if (true == m_userFill.x()) {
|
|
localSize.setX(m_size.x());
|
|
tmpOrigin.setX(0);
|
|
tmpTextOrigin.setX(0);
|
|
}
|
|
if (true == m_userFill.y()) {
|
|
localSize.setY(m_size.y());
|
|
}
|
|
tmpOrigin += vec3(padding.x(), padding.y(), 0);
|
|
tmpTextOrigin += vec3(padding.x(), padding.y(), 0);
|
|
localSize -= ivec2(2*padding.x(), 2*padding.y());
|
|
|
|
// clean the element
|
|
m_text.reset();
|
|
if( m_textColorFg.r() < 100
|
|
|| m_textColorFg.g() < 100
|
|
|| m_textColorFg.b() < 100) {
|
|
m_text.setColor(etk::color::white);
|
|
} else {
|
|
m_text.setColor(etk::color::black);
|
|
}
|
|
m_text.setPos(tmpTextOrigin);
|
|
m_text.setColorBg(m_textColorFg);
|
|
m_text.setTextAlignement(tmpTextOrigin.x(), tmpTextOrigin.x()+localSize.x(), ewol::Text::alignCenter);
|
|
m_text.print(label);
|
|
|
|
|
|
if (true == m_userFill.y()) {
|
|
tmpOrigin.setY(padding.y());
|
|
}
|
|
|
|
// selection area :
|
|
m_selectableAreaPos = vec2(tmpOrigin.x()-padding.x(), tmpOrigin.y()-padding.y());
|
|
m_selectableAreaSize = localSize + vec2(2,2)*padding;
|
|
m_shaper.setOrigin(m_selectableAreaPos );
|
|
m_shaper.setSize(m_selectableAreaSize);
|
|
m_shaper.setInsidePos(vec2(tmpTextOrigin.x(), tmpTextOrigin.y()) );
|
|
vec3 tmpp = m_text.calculateSize(label);
|
|
vec2 tmpp2(tmpp.x(), tmpp.y());
|
|
m_shaper.setInsideSize(tmpp2);
|
|
}
|
|
|
|
|
|
bool ewol::widget::ButtonColor::onEventInput(const ewol::EventInput& _event) {
|
|
bool previousHoverState = m_mouseHover;
|
|
if(ewol::keyEvent::statusLeave == _event.getStatus()) {
|
|
m_mouseHover = false;
|
|
m_buttonPressed = false;
|
|
} else {
|
|
vec2 relativePos = relativePosition(_event.getPos());
|
|
// prevent error from ouside the button
|
|
if( relativePos.x() < m_selectableAreaPos.x()
|
|
|| relativePos.y() < m_selectableAreaPos.y()
|
|
|| relativePos.x() > m_selectableAreaPos.x() + m_selectableAreaSize.x()
|
|
|| relativePos.y() > m_selectableAreaPos.y() + m_selectableAreaSize.y() ) {
|
|
m_mouseHover = false;
|
|
m_buttonPressed = false;
|
|
} else {
|
|
m_mouseHover = true;
|
|
}
|
|
}
|
|
bool previousPressed = m_buttonPressed;
|
|
//EWOL_DEBUG("Event on BT ... mouse position : " << m_mouseHover);
|
|
if (true == m_mouseHover) {
|
|
if (1 == _event.getId()) {
|
|
if(ewol::keyEvent::statusDown == _event.getStatus()) {
|
|
m_buttonPressed = true;
|
|
markToRedraw();
|
|
}
|
|
if(ewol::keyEvent::statusUp == _event.getStatus()) {
|
|
m_buttonPressed = false;
|
|
markToRedraw();
|
|
}
|
|
if(ewol::keyEvent::statusSingle == _event.getStatus()) {
|
|
m_buttonPressed = false;
|
|
m_mouseHover = false;
|
|
// create a context menu :
|
|
m_widgetContextMenu = new widget::ContextMenu();
|
|
if (NULL == m_widgetContextMenu) {
|
|
EWOL_ERROR("Allocation Error");
|
|
return true;
|
|
}
|
|
vec2 tmpPos = m_origin + m_selectableAreaPos + m_selectableAreaSize;
|
|
tmpPos.setX( tmpPos.x() - m_minSize.x()/2.0);
|
|
m_widgetContextMenu->setPositionMark(widget::ContextMenu::markButtom, tmpPos );
|
|
|
|
widget::ColorChooser * myColorChooser = new widget::ColorChooser();
|
|
myColorChooser->setColor(m_textColorFg);
|
|
// set it in the pop-up-system :
|
|
m_widgetContextMenu->setSubWidget(myColorChooser);
|
|
myColorChooser->registerOnEvent(this, ewolEventColorChooserChange, ewolEventColorChooserChange);
|
|
ewol::Windows* currentWindows = getWindows();
|
|
if (NULL == currentWindows) {
|
|
EWOL_ERROR("Can not get the curent Windows...");
|
|
delete(m_widgetContextMenu);
|
|
m_widgetContextMenu=NULL;
|
|
} else {
|
|
currentWindows->popUpWidgetPush(m_widgetContextMenu);
|
|
}
|
|
markToRedraw();
|
|
}
|
|
}
|
|
}
|
|
if( m_mouseHover != previousHoverState
|
|
|| m_buttonPressed != previousPressed) {
|
|
if (true == m_buttonPressed) {
|
|
changeStatusIn(STATUS_PRESSED);
|
|
} else {
|
|
if (true == m_mouseHover) {
|
|
changeStatusIn(STATUS_HOVER);
|
|
} else {
|
|
changeStatusIn(STATUS_UP);
|
|
}
|
|
}
|
|
}
|
|
return m_mouseHover;
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::setValue(etk::Color<> _color) {
|
|
m_textColorFg = _color;
|
|
markToRedraw();
|
|
}
|
|
|
|
etk::Color<> ewol::widget::ButtonColor::getValue(void) {
|
|
return m_textColorFg;
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::onReceiveMessage(const ewol::EMessage& _msg) {
|
|
EWOL_INFO("Receive MSG : " << _msg.getData());
|
|
if (_msg.getMessage() == ewolEventColorChooserChange) {
|
|
m_textColorFg = _msg.getData();
|
|
generateEventId(ewolEventButtonColorChange, _msg.getData());
|
|
markToRedraw();
|
|
}
|
|
}
|
|
|
|
|
|
void ewol::widget::ButtonColor::changeStatusIn(int32_t _newStatusId) {
|
|
if (true == m_shaper.changeStatusIn(_newStatusId) ) {
|
|
periodicCallEnable();
|
|
markToRedraw();
|
|
}
|
|
}
|
|
|
|
|
|
|
|
void ewol::widget::ButtonColor::periodicCall(const ewol::EventTime& _event) {
|
|
if (false == m_shaper.periodicCall(_event) ) {
|
|
periodicCallDisable();
|
|
}
|
|
markToRedraw();
|
|
}
|