summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--gui/mapping-window.cpp20
-rw-r--r--logic/main-settings.hpp1
-rw-r--r--logic/mappings.cpp6
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])