diff options
-rw-r--r-- | gui/mapping-window.cpp | 20 | ||||
-rw-r--r-- | logic/main-settings.hpp | 1 | ||||
-rw-r--r-- | logic/mappings.cpp | 6 |
3 files changed, 15 insertions, 12 deletions
diff --git a/gui/mapping-window.cpp b/gui/mapping-window.cpp index 5f61d31f..71282d84 100644 --- a/gui/mapping-window.cpp +++ b/gui/mapping-window.cpp @@ -65,7 +65,7 @@ void MapWidget::load() x->addItem(QString::number(y) + "°", y); for (QComboBox* x : { ui.max_x_translation, ui.max_y_translation, ui.max_z_translation }) - for (a y : { a::t30, a::t20, a::t15, a::t10 }) + for (a y : { a::t30, a::t20, a::t15, a::t10, a::t100 }) x->addItem(QStringLiteral("%1 cm").arg(int(y)), y); for (int i = 0; qfcs[i].qfc; i++) @@ -87,20 +87,22 @@ void MapWidget::load() } connect(&axis.opts.clamp, static_cast<void(base_value::*)(int) const>(&base_value::valueChanged), - &qfc, [&conf, &qfc](int value) { + &qfc, [i, &conf, &qfc](int value) { conf.set_max_input(value); qfc.reload_spline(); qfc.set_x_step(value + 1e-2 >= 90 ? 10 : 5); + + if (i >= 3) + qfc.set_snap(1, 2.5); + else + { + const double x_snap = std::max(.5, conf.max_input() / 100.); + qfc.set_snap(x_snap, 1); + } }); // force signal to avoid duplicating the slot's logic - axis.opts.clamp.valueChanged(axis.opts.clamp); - - if (qfcs[i].axis >= 3) - qfcs[i].qfc->set_snap(1, 2.5); - else - qfcs[i].qfc->set_snap(.5, 1); - qfcs[i].qfc->setConfig(&conf); + axis.opts.clamp.valueChanged(axis.opts.clamp); } } diff --git a/logic/main-settings.hpp b/logic/main-settings.hpp index 20805059..51b729e3 100644 --- a/logic/main-settings.hpp +++ b/logic/main-settings.hpp @@ -35,6 +35,7 @@ struct OTR_LOGIC_EXPORT axis_opts final r15 = 15, r10 = 10, + t100 = 100, t30 = 30, t20 = 20, t15 = 15, diff --git a/logic/mappings.cpp b/logic/mappings.cpp index f9a149e3..d7764375 100644 --- a/logic/mappings.cpp +++ b/logic/mappings.cpp @@ -25,9 +25,9 @@ void Map::load() Mappings::Mappings(std::vector<axis_opts*> opts) : axes { - Map("spline-X", "alt-spline-X", 30, 75, *opts[TX]), - Map("spline-Y", "alt-spline-Y", 30, 75, *opts[TY]), - Map("spline-Z", "alt-spline-Z", 30, 75, *opts[TZ]), + Map("spline-X", "alt-spline-X", 100, 75, *opts[TX]), + Map("spline-Y", "alt-spline-Y", 100, 75, *opts[TY]), + Map("spline-Z", "alt-spline-Z", 100, 75, *opts[TZ]), Map("spline-yaw", "alt-spline-yaw", 180, 180, *opts[Yaw]), Map("spline-pitch", "alt-spline-pitch", 180, 180, *opts[Pitch]), Map("spline-roll", "alt-spline-roll", 180, 180, *opts[Roll]) |