Merge branch 'slider-react-to-mouse'

This commit is contained in:
Marianne Gagnon 2015-03-10 19:43:06 -04:00
commit 26914e60e3
2 changed files with 38 additions and 0 deletions

View File

@ -432,3 +432,38 @@ void SpinnerWidget::setCustomText(const core::stringw& text)
} }
} }
// -----------------------------------------------------------------------------
void SpinnerWidget::onClick()
{
if (m_children[1].m_deactivated ||
m_children[1].m_properties[PROP_ID] != "spinnerbody" ||
!isGauge())
{
return;
}
const core::position2di mouse_position
= irr_driver->getDevice()->getCursorControl()->getPosition();
core::recti body_rect
= m_children[1].getIrrlichtElement()->getAbsolutePosition();
if (body_rect.isPointInside(mouse_position))
{
float exact_hover = (float)((mouse_position.X -
body_rect.UpperLeftCorner.X) /
(float)body_rect.getWidth()) * (m_max-m_min);
float new_value_f = ((exact_hover * (m_max - m_min)) /
(m_max - m_min)) + m_min;
int new_value = (int)roundf(new_value_f);
if (new_value > m_max) new_value = m_max;
if (new_value < m_min) new_value = m_min;
setValue(new_value);
}
}
// -----------------------------------------------------------------------------

View File

@ -92,6 +92,9 @@ namespace GUIEngine
/** \brief implementing method from base class Widget */ /** \brief implementing method from base class Widget */
virtual EventPropagation leftPressed(const int playerID); virtual EventPropagation leftPressed(const int playerID);
/** \brief implementing method from base class Widget */
virtual void onClick();
/** When inferring widget size from its label length, this method will be called to /** When inferring widget size from its label length, this method will be called to
* if/how much space must be added to the raw label's size for the widget to be large enough */ * if/how much space must be added to the raw label's size for the widget to be large enough */
virtual int getWidthNeededAroundLabel() const { return 25; } virtual int getWidthNeededAroundLabel() const { return 25; }