summaryrefslogtreecommitdiff
path: root/common/rawaccel.hpp
diff options
context:
space:
mode:
authora1xd <[email protected]>2020-10-21 21:03:19 -0400
committera1xd <[email protected]>2020-10-21 21:03:19 -0400
commitf0ec7a278892c0dfed7c39e4efebd57d97cdb46c (patch)
tree633d599336dada1689ce79e177073b7e401a0a35 /common/rawaccel.hpp
parentput autowrite option back in menu (diff)
downloadrawaccel-f0ec7a278892c0dfed7c39e4efebd57d97cdb46c.tar.xz
rawaccel-f0ec7a278892c0dfed7c39e4efebd57d97cdb46c.zip
move speedcap into accelerator
Diffstat (limited to 'common/rawaccel.hpp')
-rw-r--r--common/rawaccel.hpp19
1 files changed, 9 insertions, 10 deletions
diff --git a/common/rawaccel.hpp b/common/rawaccel.hpp
index 3a49aa6..b160a42 100644
--- a/common/rawaccel.hpp
+++ b/common/rawaccel.hpp
@@ -195,12 +195,15 @@ namespace rawaccel {
accel_variant accel;
velocity_gain_cap gain_cap;
accel_scale_clamp clamp;
+ double output_speed_cap = 0;
accelerator(const accel_args& args, accel_mode mode, si_pair* lut = nullptr) :
accel(args, mode, lut), gain_cap(args.gain_cap, accel), clamp(args.scale_cap)
- {}
+ {
+ output_speed_cap = maxsd(args.speed_cap, 0);
+ }
- inline double apply(double speed, double output_speed_cap) const {
+ inline double apply(double speed) const {
double scale;
if (gain_cap.should_apply(speed)) {
@@ -212,9 +215,7 @@ namespace rawaccel {
scale = clamp(scale);
- double output_speed = scale * speed;
-
- if (output_speed_cap > 0 && output_speed > output_speed_cap) {
+ if (output_speed_cap > 0 && (scale * speed) > output_speed_cap) {
scale = output_speed_cap / speed;
}
@@ -230,7 +231,6 @@ namespace rawaccel {
bool apply_accel = false;
bool combine_magnitudes = true;
rotator rotate;
- double output_speed_cap = 0;
vec2<accelerator> accels;
vec2d sensitivity = { 1, 1 };
@@ -251,7 +251,6 @@ namespace rawaccel {
return;
}
- output_speed_cap = maxsd(args.speed_cap, 0);
accels.x = accelerator(args.argsv.x, args.modes.x, luts.x);
accels.y = accelerator(args.argsv.y, args.modes.y, luts.y);
apply_accel = true;
@@ -275,13 +274,13 @@ namespace rawaccel {
if (combine_magnitudes) {
double mag = sqrtsd(movement.x * movement.x + movement.y * movement.y);
double speed = mag / time;
- double scale = accels.x.apply(speed, output_speed_cap);
+ double scale = accels.x.apply(speed);
movement.x *= scale;
movement.y *= scale;
}
else {
- movement.x *= accels.x.apply(fabs(movement.x) / time, output_speed_cap);
- movement.y *= accels.y.apply(fabs(movement.y) / time, output_speed_cap);
+ movement.x *= accels.x.apply(fabs(movement.x) / time);
+ movement.y *= accels.y.apply(fabs(movement.y) / time);
}
}
}