1
0
Fork 0

- reverse longitudinal axis

- add reset button (moves cursor back to origin)
- make Ctrl/Shift scale movements (coarser/finer)
This commit is contained in:
mfranz 2007-03-20 16:17:47 +00:00
parent a7d30fa76e
commit 318c08f9c7

View file

@ -1,4 +1,9 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<!--
Dialog for tutorial marker adjustment.
Can be opened with tutorial.dialog() in Help->Nasal Console.
Use Ctrl for coarser, and Shift for finer movements.
-->
<PropertyList> <PropertyList>
<name>marker-adjust</name> <name>marker-adjust</name>
@ -36,18 +41,22 @@
<open> <open>
var self = cmdarg(); var self = cmdarg();
var dlgname = self.getNode("name").getValue(); var dlgname = self.getNode("name").getValue();
var kbdctrl = props.globals.getNode("/devices/status/keyboard/ctrl");
var kbdshift = props.globals.getNode("/devices/status/keyboard/shift");
var Value = { var Value = {
new : func(name, init = 0) { new : func(name, factor, init = 0) {
var m = { parents: [Value] }; var m = { parents: [Value] };
m.name = name; m.name = name;
m.factor = factor;
m.init = init;
var n = props.globals.getNode("/sim/model/marker/" ~ m.name, 1); var n = props.globals.getNode("/sim/model/marker/" ~ m.name, 1);
m.sliderN = n.getNode("slider", 1); m.sliderN = n.getNode("slider", 1);
m.offsetN = n.getNode("offset", 1); m.offsetN = n.getNode("offset", 1);
m.valueN = n.getNode("value", 1); m.valueN = n.getNode("value", 1);
m.offsetN.setDoubleValue(0); m.offsetN.setDoubleValue(0);
m.sliderN.setDoubleValue(0); m.sliderN.setDoubleValue(0);
m.valueN.setDoubleValue(init); m.valueN.setDoubleValue(m.init);
m.last_slider = 0; m.last_slider = 0;
m.center(); m.center();
m.sliderL = setlistener(m.sliderN, func { m.update() }); m.sliderL = setlistener(m.sliderN, func { m.update() });
@ -56,10 +65,20 @@
del : func { del : func {
removelistener(me.sliderL); removelistener(me.sliderL);
}, },
reset : func {
me.center();
me.valueN.setDoubleValue(me.init);
},
update : func { update : func {
var offs = me.sliderN.getValue(); var offs = me.sliderN.getValue();
var v = me.offsetN.getValue() + me.sliderN.getValue() - me.last_slider; var v = me.offsetN.getValue() + me.sliderN.getValue() - me.last_slider;
me.valueN.setValue(me.valueN.getValue() + v * 0.1); var f = me.factor;
if (kbdctrl.getValue()) {
f *= 5;
} elsif (kbdshift.getValue()) {
f *= 0.1;
}
me.valueN.setValue(me.valueN.getValue() + v * f);
me.offsetN.setDoubleValue(0); me.offsetN.setDoubleValue(0);
me.last_slider = offs; me.last_slider = offs;
}, },
@ -70,10 +89,10 @@
}; };
var values = [ var values = [
Value.new("x"), Value.new("x", 0.1), # aft/fore
Value.new("y"), Value.new("y", 0.1), # left/right
Value.new("z"), Value.new("z", 0.1), # down/up
Value.new("scale", 1), Value.new("scale", 2, 1),
]; ];
var center = func { var center = func {
@ -82,6 +101,12 @@
} }
} }
var reset = func {
foreach (var v; values) {
v.reset();
}
}
var dump = func { var dump = func {
print("&lt;marker>"); print("&lt;marker>");
foreach (var v; values) { foreach (var v; values) {
@ -121,7 +146,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>/sim/model/marker/x/offset</property> <property>/sim/model/marker/x/offset</property>
<step>-10</step> <step>10</step>
</binding> </binding>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
@ -137,7 +162,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>/sim/model/marker/x/offset</property> <property>/sim/model/marker/x/offset</property>
<step>-1</step> <step>1</step>
</binding> </binding>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
@ -148,11 +173,11 @@
<slider> <slider>
<name>x</name> <name>x</name>
<property>/sim/model/marker/x/slider</property> <property>/sim/model/marker/x/slider</property>
<legend>fore/aft</legend> <legend>aft/fore</legend>
<pref-width>250</pref-width> <pref-width>250</pref-width>
<live>1</live> <live>1</live>
<min>-1</min> <min>1</min>
<max>1</max> <max>-1</max>
<color> <color>
<red>1.0</red> <red>1.0</red>
@ -175,7 +200,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>/sim/model/marker/x/offset</property> <property>/sim/model/marker/x/offset</property>
<step>1</step> <step>-1</step>
</binding> </binding>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
@ -191,7 +216,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>/sim/model/marker/x/offset</property> <property>/sim/model/marker/x/offset</property>
<step>10</step> <step>-10</step>
</binding> </binding>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
@ -477,6 +502,17 @@
<layout>hbox</layout> <layout>hbox</layout>
<default-padding>2</default-padding> <default-padding>2</default-padding>
<button>
<halign>left</halign>
<legend>Reset</legend>
<pref-height>22</pref-height>
<pref-width>60</pref-width>
<binding>
<command>nasal</command>
<script>reset()</script>
</binding>
</button>
<empty><stretch>1</stretch></empty> <empty><stretch>1</stretch></empty>
<button> <button>