Menus: When pressing left or right on a slider that has moved by the mouse to a position between the defined intervals, do not round to the nearest interval and then increment or decrement. Instead, check if rounding will satisfy the movement before moving further.

git-svn-id: https://svn.eduke32.com/eduke32@4865 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2014-12-28 21:35:07 +00:00
parent 571a44cd8d
commit a74317a104

View file

@ -4607,11 +4607,14 @@ static void M_RunMenuInput_MenuEntryRangeInt32_MovementVerify(MenuEntry_t *entry
static void M_RunMenuInput_MenuEntryRangeInt32_Movement(MenuEntry_t *entry, MenuRangeInt32_t *object, MenuMovement_t direction)
{
const float interval = ((float) (object->max - object->min)) / (object->steps - 1);
int32_t newValueIndex = Blrintf((float) (*object->variable - object->min) / interval);
const float currentPos = (float) (*object->variable - object->min) / interval;
int32_t newValueIndex = Blrintf(currentPos);
const int32_t newValueProjected = Blrintf(interval * newValueIndex + object->min);
switch (direction)
{
case MM_Left:
if (newValueIndex >= currentPos || *object->variable == newValueProjected)
--newValueIndex;
if (newValueIndex >= 0)
break;
@ -4620,6 +4623,7 @@ static void M_RunMenuInput_MenuEntryRangeInt32_Movement(MenuEntry_t *entry, Menu
break;
case MM_Right:
if (newValueIndex <= currentPos || *object->variable == newValueProjected)
++newValueIndex;
if (newValueIndex < object->steps)
break;
@ -4631,7 +4635,7 @@ static void M_RunMenuInput_MenuEntryRangeInt32_Movement(MenuEntry_t *entry, Menu
break;
}
M_RunMenuInput_MenuEntryRangeInt32_MovementVerify(entry, object, Blrintf(interval * newValueIndex + (object->min)));
M_RunMenuInput_MenuEntryRangeInt32_MovementVerify(entry, object, Blrintf(interval * newValueIndex + object->min));
}
static void M_RunMenuInput_MenuEntryRangeFloat_MovementVerify(MenuEntry_t *entry, MenuRangeFloat_t *object, float newValue)
@ -4646,11 +4650,14 @@ static void M_RunMenuInput_MenuEntryRangeFloat_MovementVerify(MenuEntry_t *entry
static void M_RunMenuInput_MenuEntryRangeFloat_Movement(MenuEntry_t *entry, MenuRangeFloat_t *object, MenuMovement_t direction)
{
const float interval = (object->max - object->min) / (object->steps - 1);
int32_t newValueIndex = Blrintf((*object->variable - object->min) / interval);
const float currentPos = (*object->variable - object->min) / interval;
int32_t newValueIndex = Blrintf(currentPos);
const float newValueProjected = interval * newValueIndex + object->min;
switch (direction)
{
case MM_Left:
if (newValueIndex >= currentPos || *object->variable == newValueProjected)
--newValueIndex;
if (newValueIndex >= 0)
break;
@ -4659,6 +4666,7 @@ static void M_RunMenuInput_MenuEntryRangeFloat_Movement(MenuEntry_t *entry, Menu
break;
case MM_Right:
if (newValueIndex <= currentPos || *object->variable == newValueProjected)
++newValueIndex;
if (newValueIndex < object->steps)
break;
@ -4682,11 +4690,14 @@ static void M_RunMenuInput_MenuEntryRangeDouble_MovementVerify(/*MenuEntry_t *en
static void M_RunMenuInput_MenuEntryRangeDouble_Movement(/*MenuEntry_t *entry, */MenuRangeDouble_t *object, MenuMovement_t direction)
{
const double interval = (object->max - object->min) / (object->steps - 1);
int32_t newValueIndex = Blrintf((*object->variable - object->min) / interval);
const double currentPos = (*object->variable - object->min) / interval;
int32_t newValueIndex = Blrintf(currentPos);
const double newValueProjected = interval * newValueIndex + object->min;
switch (direction)
{
case MM_Left:
if (newValueIndex >= currentPos || *object->variable == newValueProjected)
--newValueIndex;
if (newValueIndex >= 0)
break;
@ -4695,6 +4706,7 @@ static void M_RunMenuInput_MenuEntryRangeDouble_Movement(/*MenuEntry_t *entry, *
break;
case MM_Right:
if (newValueIndex <= currentPos || *object->variable == newValueProjected)
++newValueIndex;
if (newValueIndex < object->steps)
break;