Merge branch 'slider-react-to-mouse'
This commit is contained in:
commit
26914e60e3
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// -----------------------------------------------------------------------------
|
||||||
|
@ -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; }
|
||||||
|
Loading…
Reference in New Issue
Block a user