1
0
Fork 0

Disable the autopilot menu item if any of

KAP140
CENTURYIIB
CENTURYIII
autopilot is detected or the property
/autopilot/hide-menu
is present
This commit is contained in:
torsten 2010-01-04 14:06:30 +00:00
parent 079c8493a5
commit a18db246f0

View file

@ -92,6 +92,12 @@ var cursor_types = { none: 0, pointer: 1, wait: 2, crosshair: 3, leftright: 4,
var fdm = getprop("/sim/flight-model"); var fdm = getprop("/sim/flight-model");
var screenHProp = nil; var screenHProp = nil;
var tipArg = nil; var tipArg = nil;
var autopilotDisableProps = [
"/autopilot/hide-menu",
"/autopilot/KAP140/locks",
"/autopilot/CENTURYIIB/locks",
"/autopilot/CENTURYIII/locks"
];
_setlistener("/sim/signals/nasal-dir-initialized", func { _setlistener("/sim/signals/nasal-dir-initialized", func {
screenHProp = props.globals.getNode("/sim/startup/ysize"); screenHProp = props.globals.getNode("/sim/startup/ysize");
@ -103,7 +109,14 @@ _setlistener("/sim/signals/nasal-dir-initialized", func {
# enable/disable menu entries # enable/disable menu entries
menuEnable("fuel-and-payload", fdm == "yasim" or fdm == "jsb"); menuEnable("fuel-and-payload", fdm == "yasim" or fdm == "jsb");
menuEnable("autopilot", props.globals.getNode("/autopilot/KAP140/locks") == nil); var isAutopilotMenuEnabled = func {
foreach( var apdp; autopilotDisableProps ) {
if( props.globals.getNode( apdp ) != nil )
return 0;
}
return 1;
}
menuEnable("autopilot", isAutopilotMenuEnabled() );
menuEnable("multiplayer", multiplayer.is_active()); menuEnable("multiplayer", multiplayer.is_active());
menuEnable("tutorial-start", size(props.globals.getNode("/sim/tutorials", 1).getChildren("tutorial"))); menuEnable("tutorial-start", size(props.globals.getNode("/sim/tutorials", 1).getChildren("tutorial")));
menuEnable("joystick-info", size(props.globals.getNode("/input/joysticks").getChildren("js"))); menuEnable("joystick-info", size(props.globals.getNode("/input/joysticks").getChildren("js")));
@ -731,11 +744,13 @@ var showWeightDialog = func {
var fdmdata = { var fdmdata = {
grosswgt : "/yasim/gross-weight-lbs", grosswgt : "/yasim/gross-weight-lbs",
payload : "/sim", payload : "/sim",
cg : nil,
}; };
} elsif(fdm == "jsb") { } elsif(fdm == "jsb") {
var fdmdata = { var fdmdata = {
grosswgt : "/fdm/jsbsim/inertia/weight-lbs", grosswgt : "/fdm/jsbsim/inertia/weight-lbs",
payload : "/payload", payload : "/payload",
cg : "/fdm/jsbsim/inertia/cg-x-in",
}; };
} }
@ -756,6 +771,34 @@ var showWeightDialog = func {
gwg.addChild("empty").set("stretch", 1); gwg.addChild("empty").set("stretch", 1);
} }
var massLimits = props.globals.getNode("/limits/mass-and-balance");
if(massLimits != nil ) {
var weightitem = func( group, name, node, format ) {
group.set("layout", "hbox");
var n = isa( node, props.Node ) ? node : massLimits.getNode( node );
if( n == nil ) return;
group.addChild("empty").set("stretch", 1);
group.addChild("text").set("label", name ~ ":" );
var txt = group.addChild("text");
txt.set("label", "");
txt.set("format", format );
txt.set("property", n.getPath() );
txt.set("live", 1);
group.addChild("empty").set("stretch", 1);
}
weightitem( dialog[name].addChild("group"), "Max. Ramp Weight", "maximum-ramp-mass-lbs", "%.0f lb" );
weightitem( dialog[name].addChild("group"), "Max. Takeoff Weight", "maximum-takeoff-mass-lbs", "%.0f lb" );
weightitem( dialog[name].addChild("group"), "Max. Landing Weight", "maximum-landing-mass-lbs", "%.0f lb" );
weightitem( dialog[name].addChild("group"), "Max. Zero Fuel Weight", "maximum-zero-fuel-mass-lbs", "%.0f lb" );
if( fdmdata.cg != nil ) {
var n = massLimits.getNode("cg/dimension");
weightitem( dialog[name].addChild("group"), "CG", fdmdata.cg, "%.1f " ~ (n == nil ? "in" : n.getValue()));
}
weightitem = nil;
}
var buttonBar = dialog[name].addChild("group"); var buttonBar = dialog[name].addChild("group");
buttonBar.set("layout", "hbox"); buttonBar.set("layout", "hbox");
buttonBar.set("default-padding", 10); buttonBar.set("default-padding", 10);
@ -827,13 +870,13 @@ var showWeightDialog = func {
var lbs = tcell(fuelTable, "text", i+1, 3); var lbs = tcell(fuelTable, "text", i+1, 3);
lbs.set("property", tankprop ~ "/level-lbs"); lbs.set("property", tankprop ~ "/level-lbs");
lbs.set("label", "0123456"); lbs.set("label", "0123456");
lbs.set("format", "%.3f"); lbs.set("format", cap < 1 ? "%.3f" : cap < 10 ? "%.2f" : "%.1f" );
lbs.set("live", 1); lbs.set("live", 1);
var gals = tcell(fuelTable, "text", i+1, 4); var gals = tcell(fuelTable, "text", i+1, 4);
gals.set("property", tankprop ~ "/level-gal_us"); gals.set("property", tankprop ~ "/level-gal_us");
gals.set("label", "0123456"); gals.set("label", "0123456");
gals.set("format", "%.3f"); gals.set("format", cap < 1 ? "%.3f" : cap < 10 ? "%.2f" : "%.1f" );
gals.set("live", 1); gals.set("live", 1);
} }