analog sticks works better now

This commit is contained in:
georgemoralis 2024-06-17 14:33:03 +03:00
parent e91ea8a0e5
commit 89af3f0845

View file

@ -132,42 +132,74 @@ void WindowSDL::onKeyPress(const SDL_Event* event) {
break; break;
case SDLK_a: case SDLK_a:
axis = Input::Axis::LeftX; axis = Input::Axis::LeftX;
axisvalue += -127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += -127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_d: case SDLK_d:
axis = Input::Axis::LeftX; axis = Input::Axis::LeftX;
axisvalue += 127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += 127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_w: case SDLK_w:
axis = Input::Axis::LeftY; axis = Input::Axis::LeftY;
axisvalue += -127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += -127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_s: case SDLK_s:
axis = Input::Axis::LeftY; axis = Input::Axis::LeftY;
axisvalue += 127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += 127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_j: case SDLK_j:
axis = Input::Axis::RightX; axis = Input::Axis::RightX;
axisvalue += -127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += -127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_l: case SDLK_l:
axis = Input::Axis::RightX; axis = Input::Axis::RightX;
axisvalue += 127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += 127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_i: case SDLK_i:
axis = Input::Axis::RightY; axis = Input::Axis::RightY;
axisvalue += -127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += -127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
case SDLK_k: case SDLK_k:
axis = Input::Axis::RightY; axis = Input::Axis::RightY;
axisvalue += 127; if (event->type == SDL_EVENT_KEY_DOWN) {
axisvalue += 127;
} else {
axisvalue = 0;
}
ax = Input::GetAxis(-0x80, 0x80, axisvalue); ax = Input::GetAxis(-0x80, 0x80, axisvalue);
break; break;
default: default:
@ -176,7 +208,7 @@ void WindowSDL::onKeyPress(const SDL_Event* event) {
if (button != 0) { if (button != 0) {
controller->CheckButton(0, button, event->type == SDL_EVENT_KEY_DOWN); controller->CheckButton(0, button, event->type == SDL_EVENT_KEY_DOWN);
} }
if (axis != Input::Axis::AxisMax&& event->type == SDL_EVENT_KEY_DOWN) { if (axis != Input::Axis::AxisMax) {
controller->Axis(0, axis, ax); controller->Axis(0, axis, ax);
} }
} }