Merge branch 'dev' into 3D
This commit is contained in:
commit
990f2ed349
11 changed files with 90 additions and 101 deletions
|
@ -739,6 +739,11 @@
|
||||||
<max-athr-thrust type="double">0.94</max-athr-thrust>
|
<max-athr-thrust type="double">0.94</max-athr-thrust>
|
||||||
<throttle-output type="double">0</throttle-output>
|
<throttle-output type="double">0</throttle-output>
|
||||||
<throttle-fdm type="double">0</throttle-fdm>
|
<throttle-fdm type="double">0</throttle-fdm>
|
||||||
|
<throttle-rev type="double">0</throttle-rev>
|
||||||
|
<reverser type="double">0</reverser>
|
||||||
|
<igniter-a type="bool">0</igniter-a>
|
||||||
|
<igniter-b type="bool">0</igniter-b>
|
||||||
|
<last-igniter type="string">B</last-igniter>
|
||||||
</engine>
|
</engine>
|
||||||
<engine n="1">
|
<engine n="1">
|
||||||
<cutoff type="bool">true</cutoff>
|
<cutoff type="bool">true</cutoff>
|
||||||
|
@ -752,6 +757,11 @@
|
||||||
<max-athr-thrust type="double">0.94</max-athr-thrust>
|
<max-athr-thrust type="double">0.94</max-athr-thrust>
|
||||||
<throttle-output type="double">0</throttle-output>
|
<throttle-output type="double">0</throttle-output>
|
||||||
<throttle-fdm type="double">0</throttle-fdm>
|
<throttle-fdm type="double">0</throttle-fdm>
|
||||||
|
<throttle-rev type="double">0</throttle-rev>
|
||||||
|
<reverser type="double">0</reverser>
|
||||||
|
<igniter-a type="bool">0</igniter-a>
|
||||||
|
<igniter-b type="bool">0</igniter-b>
|
||||||
|
<last-igniter type="string">B</last-igniter>
|
||||||
</engine>
|
</engine>
|
||||||
<engine n="2">
|
<engine n="2">
|
||||||
<cutoff type="bool">true</cutoff>
|
<cutoff type="bool">true</cutoff>
|
||||||
|
|
|
@ -241,7 +241,7 @@ var ECAM_controller = {
|
||||||
me.reset();
|
me.reset();
|
||||||
},
|
},
|
||||||
loop: func() {
|
loop: func() {
|
||||||
if ((systems.ELEC.Bus.acEss.getValue() >= 110 or systems.ELEC.Bus.ac2.getValue() >= 110) and !getprop("systems/acconfig/acconfig-running")) {
|
if ((systems.ELEC.Bus.acEss.getValue() >= 110 or systems.ELEC.Bus.ac2.getValue() >= 110) and !pts.Acconfig.running.getBoolValue()) {
|
||||||
# update FWC phases
|
# update FWC phases
|
||||||
phaseLoop();
|
phaseLoop();
|
||||||
|
|
||||||
|
@ -274,7 +274,7 @@ var ECAM_controller = {
|
||||||
# write to ECAM
|
# write to ECAM
|
||||||
var counter = 0;
|
var counter = 0;
|
||||||
|
|
||||||
if (!getprop("systems/acconfig/autoconfig-running")) {
|
if (!pts.Acconfig.running.getBoolValue()) {
|
||||||
foreach (var w; warnings.vector) {
|
foreach (var w; warnings.vector) {
|
||||||
if (w.active == 1) {
|
if (w.active == 1) {
|
||||||
if (counter < 9) {
|
if (counter < 9) {
|
||||||
|
|
|
@ -116,14 +116,14 @@ var phaseLoop = func() {
|
||||||
|
|
||||||
if (eng == "IAE") {
|
if (eng == "IAE") {
|
||||||
eprlim = getprop("controls/engines/epr-limit");
|
eprlim = getprop("controls/engines/epr-limit");
|
||||||
if ((!getprop("controls/engines/engine[0]/reverser") and !getprop("controls/engines/engine[1]/reverser")) and (((pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.78 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.779) and fadec.Output.limFlex.getBoolValue()) or (pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.99 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.99))) {
|
if ((!pts.Controls.Engines.Engine.reverser[0].getBoolValue() and !pts.Controls.Engines.Engine.reverser[1].getBoolValue()) and (((pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.78 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.779) and fadec.Output.limFlex.getBoolValue()) or (pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.99 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.99))) {
|
||||||
FWC.toPower.setBoolValue(1);
|
FWC.toPower.setBoolValue(1);
|
||||||
} else {
|
} else {
|
||||||
FWC.toPower.setBoolValue(0);
|
FWC.toPower.setBoolValue(0);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
n1lim = getprop("controls/engines/n1-limit");
|
n1lim = getprop("controls/engines/n1-limit");
|
||||||
if ((!getprop("controls/engines/engine[0]/reverser") and !getprop("controls/engines/engine[1]/reverser")) and (((pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.78 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.779) and fadec.Output.limFlex.getBoolValue()) or (pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.99 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.99))) {
|
if ((!pts.Controls.Engines.Engine.reverser[0].getBoolValue() and !pts.Controls.Engines.Engine.reverser[1].getBoolValue()) and (((pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.78 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.779) and fadec.Output.limFlex.getBoolValue()) or (pts.Controls.Engines.Engine.throttle[0].getValue() >= 0.99 or pts.Controls.Engines.Engine.throttle[1].getValue() >= 0.99))) {
|
||||||
FWC.toPower.setBoolValue(1);
|
FWC.toPower.setBoolValue(1);
|
||||||
} else {
|
} else {
|
||||||
FWC.toPower.setBoolValue(0);
|
FWC.toPower.setBoolValue(0);
|
||||||
|
|
|
@ -157,13 +157,13 @@ var FCUController = {
|
||||||
if (ap1.getBoolValue() or ap2.getBoolValue()) {
|
if (ap1.getBoolValue() or ap2.getBoolValue()) {
|
||||||
apOff("soft", 0);
|
apOff("soft", 0);
|
||||||
} else {
|
} else {
|
||||||
if (getprop("it-autoflight/sound/apoffsound") == 1 or getprop("it-autoflight/sound/apoffsound2") == 1) {
|
if (getprop("/it-autoflight/sound/apoffsound") == 1 or getprop("/it-autoflight/sound/apoffsound2") == 1) {
|
||||||
setprop("it-autoflight/sound/apoffsound", 0);
|
setprop("/it-autoflight/sound/apoffsound", 0);
|
||||||
setprop("it-autoflight/sound/apoffsound2", 0);
|
setprop("/it-autoflight/sound/apoffsound2", 0);
|
||||||
}
|
}
|
||||||
if (getprop("it-autoflight/output/ap-warning") != 0) {
|
if (getprop("/it-autoflight/output/ap-warning") != 0) {
|
||||||
setprop("it-autoflight/output/ap-warning", 0);
|
setprop("/it-autoflight/output/ap-warning", 0);
|
||||||
setprop("ECAM/warnings/master-warning-light", 0);
|
ecam.lights[0].setValue(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -178,11 +178,11 @@ var FCUController = {
|
||||||
if (me.FCUworking) {
|
if (me.FCUworking) {
|
||||||
if (athr.getBoolValue()) {
|
if (athr.getBoolValue()) {
|
||||||
athrOff("soft");
|
athrOff("soft");
|
||||||
setprop("ECAM/warnings/master-caution-light", 1);
|
ecam.lights[1].setValue(1);
|
||||||
} else {
|
} else {
|
||||||
if (getprop("it-autoflight/output/athr-warning") == 1) {
|
if (getprop("/it-autoflight/output/athr-warning") == 1) {
|
||||||
setprop("it-autoflight/output/athr-warning", 0);
|
setprop("/it-autoflight/output/athr-warning", 0);
|
||||||
setprop("ECAM/warnings/master-caution-light", 0);
|
ecam.lights[1].setValue(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -349,7 +349,7 @@ var FCUController = {
|
||||||
},
|
},
|
||||||
ALTPush: func() {
|
ALTPush: func() {
|
||||||
if (me.FCUworking) {
|
if (me.FCUworking) {
|
||||||
# setprop("it-autoflight/input/vert", 8); # He don't work yet m8
|
# setprop("/it-autoflight/input/vert", 8); # He don't work yet m8
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ALTPull: func() {
|
ALTPull: func() {
|
||||||
|
@ -523,7 +523,7 @@ var athrOff = func(type) {
|
||||||
var hdgInput = func {
|
var hdgInput = func {
|
||||||
if (latMode.getValue() != 0) {
|
if (latMode.getValue() != 0) {
|
||||||
showHDG.setBoolValue(1);
|
showHDG.setBoolValue(1);
|
||||||
var hdgnow = getprop("it-autoflight/input/hdg");
|
var hdgnow = getprop("/it-autoflight/input/hdg");
|
||||||
setprop("modes/fcu/hdg-time", getprop("sim/time/elapsed-sec"));
|
setprop("/modes/fcu/hdg-time", pts.Sim.Time.elapsedSec.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,8 @@ var Controls = {
|
||||||
cutoffSw: [props.globals.getNode("/controls/engines/engine[0]/cutoff-switch"), props.globals.getNode("/controls/engines/engine[1]/cutoff-switch")],
|
cutoffSw: [props.globals.getNode("/controls/engines/engine[0]/cutoff-switch"), props.globals.getNode("/controls/engines/engine[1]/cutoff-switch")],
|
||||||
firePb: [props.globals.getNode("/controls/engines/engine[0]/fire-btn"), props.globals.getNode("/controls/engines/engine[1]/fire-btn")],
|
firePb: [props.globals.getNode("/controls/engines/engine[0]/fire-btn"), props.globals.getNode("/controls/engines/engine[1]/fire-btn")],
|
||||||
throttle: [props.globals.getNode("/controls/engines/engine[0]/throttle"), props.globals.getNode("/controls/engines/engine[1]/throttle")],
|
throttle: [props.globals.getNode("/controls/engines/engine[0]/throttle"), props.globals.getNode("/controls/engines/engine[1]/throttle")],
|
||||||
|
throttleRev: [props.globals.getNode("/controls/engines/engine[0]/throttle-rev"), props.globals.getNode("/controls/engines/engine[1]/throttle-rev")],
|
||||||
|
reverser: [props.globals.getNode("/controls/engines/engine[0]/reverser"), props.globals.getNode("/controls/engines/engine[1]/reverser")],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Flight: {
|
Flight: {
|
||||||
|
@ -79,6 +81,7 @@ var Fdm = {
|
||||||
Propulsion: {
|
Propulsion: {
|
||||||
Engine: {
|
Engine: {
|
||||||
fuelUsed: [props.globals.getNode("/fdm/jsbsim/propulsion/engine[0]/fuel-used-lbs"), props.globals.getNode("/fdm/jsbsim/propulsion/engine[1]/fuel-used-lbs")],
|
fuelUsed: [props.globals.getNode("/fdm/jsbsim/propulsion/engine[0]/fuel-used-lbs"), props.globals.getNode("/fdm/jsbsim/propulsion/engine[1]/fuel-used-lbs")],
|
||||||
|
reverserAngle: [props.globals.getNode("/fdm/jsbsim/propulsion/engine[0]/reverser-angle-rad"), props.globals.getNode("/fdm/jsbsim/propulsion/engine[1]/reverser-angle-rad")],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -92,9 +95,9 @@ var FMGC = {
|
||||||
|
|
||||||
var Gear = {
|
var Gear = {
|
||||||
compression: [props.globals.getNode("/gear/gear[0]/compression-norm"), props.globals.getNode("/gear/gear[1]/compression-norm"), props.globals.getNode("/gear/gear[2]/compression-norm")],
|
compression: [props.globals.getNode("/gear/gear[0]/compression-norm"), props.globals.getNode("/gear/gear[1]/compression-norm"), props.globals.getNode("/gear/gear[2]/compression-norm")],
|
||||||
wow: [props.globals.getNode("/gear/gear[0]/wow"), props.globals.getNode("/gear/gear[1]/wow"), props.globals.getNode("/gear/gear[2]/wow")],
|
|
||||||
position: [props.globals.getNode("/gear/gear[0]/position-norm"), props.globals.getNode("/gear/gear[1]/position-norm"), props.globals.getNode("/gear/gear[2]/position-norm")],
|
position: [props.globals.getNode("/gear/gear[0]/position-norm"), props.globals.getNode("/gear/gear[1]/position-norm"), props.globals.getNode("/gear/gear[2]/position-norm")],
|
||||||
rollspeed: [props.globals.getNode("/gear/gear[0]/rollspeed-ms"), props.globals.getNode("/gear/gear[1]/rollspeed-ms"), props.globals.getNode("/gear/gear[2]/rollspeed-ms")],
|
rollspeed: [props.globals.getNode("/gear/gear[0]/rollspeed-ms"), props.globals.getNode("/gear/gear[1]/rollspeed-ms"), props.globals.getNode("/gear/gear[2]/rollspeed-ms")],
|
||||||
|
wow: [props.globals.getNode("/gear/gear[0]/wow"), props.globals.getNode("/gear/gear[1]/wow"), props.globals.getNode("/gear/gear[2]/wow")],
|
||||||
};
|
};
|
||||||
|
|
||||||
var Instrumentation = {
|
var Instrumentation = {
|
||||||
|
@ -169,6 +172,12 @@ var Sim = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var Systems = {
|
||||||
|
Thrust: {
|
||||||
|
state: [props.globals.getNode("/systems/thrust/state1"), props.globals.getNode("/systems/thrust/state2")],
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
var Velocities = {
|
var Velocities = {
|
||||||
groundspeed: props.globals.getNode("/velocities/groundspeed-kt"),
|
groundspeed: props.globals.getNode("/velocities/groundspeed-kt"),
|
||||||
};
|
};
|
||||||
|
|
|
@ -17,15 +17,6 @@ var egt_lightdn_time = 10;
|
||||||
var shutdown_time = 20;
|
var shutdown_time = 20;
|
||||||
var egt_shutdown_time = 20;
|
var egt_shutdown_time = 20;
|
||||||
|
|
||||||
setprop("/controls/engines/engine[0]/reverser", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/reverser", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/igniter-a", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/igniter-a", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/igniter-b", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/igniter-b", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/last-igniter", "B");
|
|
||||||
setprop("/controls/engines/engine[1]/last-igniter", "B");
|
|
||||||
|
|
||||||
var eng_init = func {
|
var eng_init = func {
|
||||||
setprop("/controls/engines/engine[0]/man-start", 0);
|
setprop("/controls/engines/engine[0]/man-start", 0);
|
||||||
setprop("/controls/engines/engine[1]/man-start", 0);
|
setprop("/controls/engines/engine[1]/man-start", 0);
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
# Copyright (c) 2020 Josh Davidson (Octal450)
|
# Copyright (c) 2020 Josh Davidson (Octal450)
|
||||||
|
|
||||||
if (getprop("/options/eng") == "IAE") {
|
if (pts.Options.eng.getValue() == "IAE") {
|
||||||
io.include("engines-iae.nas");
|
io.include("engines-iae.nas");
|
||||||
} else {
|
} else {
|
||||||
io.include("engines-cfm.nas");
|
io.include("engines-cfm.nas");
|
||||||
|
@ -50,87 +50,84 @@ var doTOGAThrust = func {
|
||||||
|
|
||||||
# Reverse Thrust System
|
# Reverse Thrust System
|
||||||
var toggleFastRevThrust = func {
|
var toggleFastRevThrust = func {
|
||||||
var state1 = getprop("/systems/thrust/state1");
|
if (pts.Systems.Thrust.state[0].getValue() == "IDLE" and pts.Systems.Thrust.state[1].getValue() == "IDLE" and pts.Controls.Engines.Engine.reverser[0].getValue() == 0 and pts.Controls.Engines.Engine.reverser[1].getValue() == 0 and pts.Gear.wow[1].getValue() == 1 and pts.Gear.wow[2].getValue() == 1) {
|
||||||
var state2 = getprop("/systems/thrust/state2");
|
if (pts.Sim.Input.Selected.engine[0].getBoolValue()) {
|
||||||
if (state1 == "IDLE" and state2 == "IDLE" and getprop("/controls/engines/engine[0]/reverser") == "0" and getprop("/controls/engines/engine[1]/reverser") == "0" and getprop("/gear/gear[1]/wow") == 1 and getprop("/gear/gear[2]/wow") == 1) {
|
|
||||||
if (getprop("/sim/input/selected/engine[0]") == 1) {
|
|
||||||
interpolate("/engines/engine[0]/reverser-pos-norm", 1, 1.4);
|
interpolate("/engines/engine[0]/reverser-pos-norm", 1, 1.4);
|
||||||
setprop("/controls/engines/engine[0]/reverser", 1);
|
pts.Controls.Engines.Engine.reverser[0].setValue(1);
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", 0.65);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(0.65);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[0]/reverser-angle-rad", 3.14);
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[0].setValue(3.14);
|
||||||
}
|
}
|
||||||
if (getprop("/sim/input/selected/engine[1]") == 1) {
|
if (pts.Sim.Input.Selected.engine[1].getBoolValue()) {
|
||||||
interpolate("/engines/engine[1]/reverser-pos-norm", 1, 1.4);
|
interpolate("/engines/engine[1]/reverser-pos-norm", 1, 1.4);
|
||||||
setprop("/controls/engines/engine[1]/reverser", 1);
|
pts.Controls.Engines.Engine.reverser[1].setValue(1);
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", 0.65);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(0.65);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[1]/reverser-angle-rad", 3.14);
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[1].setValue(3.14);
|
||||||
}
|
}
|
||||||
} else if ((getprop("/controls/engines/engine[0]/reverser") == "1") or (getprop("/controls/engines/engine[1]/reverser") == "1")) {
|
} else if (pts.Controls.Engines.Engine.reverser[0].getValue() == 1 or pts.Controls.Engines.Engine.reverser[1].getValue() == 1) {
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", 0);
|
|
||||||
interpolate("/engines/engine[0]/reverser-pos-norm", 0, 1.0);
|
interpolate("/engines/engine[0]/reverser-pos-norm", 0, 1.0);
|
||||||
interpolate("/engines/engine[1]/reverser-pos-norm", 0, 1.0);
|
interpolate("/engines/engine[1]/reverser-pos-norm", 0, 1.0);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[0]/reverser-angle-rad", 0);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(0);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[1]/reverser-angle-rad", 0);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(0);
|
||||||
setprop("/controls/engines/engine[0]/reverser", 0);
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[0].setValue(0);
|
||||||
setprop("/controls/engines/engine[1]/reverser", 0);
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[1].setValue(0);
|
||||||
|
pts.Controls.Engines.Engine.reverser[0].setValue(0);
|
||||||
|
pts.Controls.Engines.Engine.reverser[1].setValue(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var doRevThrust = func {
|
var doRevThrust = func {
|
||||||
if (getprop("/gear/gear[1]/wow") != 1 and getprop("/gear/gear[2]/wow") != 1) {
|
if (pts.Gear.wow[1].getValue() != 1 and pts.Gear.wow[2].getValue() != 1) {
|
||||||
# Can't select reverse if not on the ground
|
# Can't select reverse if not on the ground
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (getprop("/sim/input/selected/engine[0]") == 1 and getprop("/controls/engines/engine[0]/reverser") == "1") {
|
if (pts.Sim.Input.Selected.engine[0].getBoolValue() and pts.Controls.Engines.Engine.reverser[0].getValue() == 1) {
|
||||||
var pos = getprop("/controls/engines/engine[0]/throttle-rev");
|
var pos = pts.Controls.Engines.Engine.throttleRev[0].getValue();
|
||||||
if (pos < 0.649) {
|
if (pos < 0.649) {
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", pos + 0.15);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(pos + 0.15);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (getprop("/sim/input/selected/engine[1]") == 1 and getprop("/controls/engines/engine[1]/reverser") == "1") {
|
if (pts.Sim.Input.Selected.engine[1].getBoolValue() and pts.Controls.Engines.Engine.reverser[1].getValue() == 1) {
|
||||||
var pos = getprop("/controls/engines/engine[1]/throttle-rev");
|
var pos = pts.Controls.Engines.Engine.throttleRev[1].getValue();
|
||||||
if (pos < 0.649) {
|
if (pos < 0.649) {
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", pos + 0.15);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(pos + 0.15);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var state1 = getprop("/systems/thrust/state1");
|
|
||||||
var state2 = getprop("/systems/thrust/state2");
|
if (pts.Sim.Input.Selected.engine[0].getBoolValue() and pts.Systems.Thrust.state[0].getValue() == "IDLE" and pts.Controls.Engines.Engine.reverser[0].getValue() == 0) {
|
||||||
if (getprop("/sim/input/selected/engine[0]") == 1 and state1 == "IDLE" and getprop("/controls/engines/engine[0]/reverser") == "0") {
|
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", 0.05);
|
|
||||||
interpolate("/engines/engine[0]/reverser-pos-norm", 1, 1.4);
|
interpolate("/engines/engine[0]/reverser-pos-norm", 1, 1.4);
|
||||||
setprop("/controls/engines/engine[0]/reverser", 1);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(0.05);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[0]/reverser-angle-rad", 3.14);
|
pts.Controls.Engines.Engine.reverser[0].setValue(1);
|
||||||
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[0].setValue(3.14);
|
||||||
}
|
}
|
||||||
if (getprop("/sim/input/selected/engine[1]") == 1 and state2 == "IDLE" and getprop("/controls/engines/engine[1]/reverser") == "0") {
|
if (pts.Sim.Input.Selected.engine[1].getBoolValue() and pts.Systems.Thrust.state[1].getValue() == "IDLE" and pts.Controls.Engines.Engine.reverser[1].getValue() == 0) {
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", 0.05);
|
|
||||||
interpolate("/engines/engine[1]/reverser-pos-norm", 1, 1.4);
|
interpolate("/engines/engine[1]/reverser-pos-norm", 1, 1.4);
|
||||||
setprop("/controls/engines/engine[1]/reverser", 1);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(0.05);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[1]/reverser-angle-rad", 3.14);
|
pts.Controls.Engines.Engine.reverser[1].setValue(1);
|
||||||
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[1].setValue(3.14);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var unRevThrust = func {
|
var unRevThrust = func {
|
||||||
if (getprop("/sim/input/selected/engine[0]") == 1 and getprop("/controls/engines/engine[0]/reverser") == "1") {
|
if (pts.Sim.Input.Selected.engine[0].getBoolValue() and pts.Controls.Engines.Engine.reverser[0].getValue() == 1) {
|
||||||
var pos = getprop("/controls/engines/engine[0]/throttle-rev");
|
var pos = pts.Controls.Engines.Engine.throttleRev[0].getValue();
|
||||||
if (pos > 0.051) {
|
if (pos > 0.051) {
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", pos - 0.15);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(pos - 0.15);
|
||||||
} else {
|
} else {
|
||||||
setprop("/controls/engines/engine[0]/throttle-rev", 0);
|
|
||||||
interpolate("/engines/engine[0]/reverser-pos-norm", 0, 1.0);
|
interpolate("/engines/engine[0]/reverser-pos-norm", 0, 1.0);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[0]/reverser-angle-rad", 0);
|
pts.Controls.Engines.Engine.throttleRev[0].setValue(0);
|
||||||
setprop("/controls/engines/engine[0]/reverser", 0);
|
pts.Controls.Engines.Engine.reverser[0].setValue(0);
|
||||||
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[0].setValue(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (getprop("/sim/input/selected/engine[1]") == 1 and getprop("/controls/engines/engine[1]/reverser") == "1") {
|
if (pts.Sim.Input.Selected.engine[1].getBoolValue() and pts.Controls.Engines.Engine.reverser[1].getValue() == 1) {
|
||||||
var pos = getprop("/controls/engines/engine[1]/throttle-rev");
|
var pos = pts.Controls.Engines.Engine.throttleRev[1].getValue();
|
||||||
if (pos > 0.051) {
|
if (pos > 0.051) {
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", pos - 0.15);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(pos - 0.15);
|
||||||
} else {
|
} else {
|
||||||
setprop("/controls/engines/engine[1]/throttle-rev", 0);
|
|
||||||
interpolate("/engines/engine[1]/reverser-pos-norm", 0, 1.0);
|
interpolate("/engines/engine[1]/reverser-pos-norm", 0, 1.0);
|
||||||
setprop("/fdm/jsbsim/propulsion/engine[1]/reverser-angle-rad", 0);
|
pts.Controls.Engines.Engine.throttleRev[1].setValue(0);
|
||||||
setprop("/controls/engines/engine[1]/reverser", 0);
|
pts.Controls.Engines.Engine.reverser[1].setValue(0);
|
||||||
|
pts.Fdm.JSBsim.Propulsion.Engine.reverserAngle[1].setValue(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,15 +17,6 @@ var egt_lightdn_time = 10;
|
||||||
var shutdown_time = 20;
|
var shutdown_time = 20;
|
||||||
var egt_shutdown_time = 20;
|
var egt_shutdown_time = 20;
|
||||||
|
|
||||||
setprop("/controls/engines/engine[0]/reverser", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/reverser", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/igniter-a", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/igniter-a", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/igniter-b", 0);
|
|
||||||
setprop("/controls/engines/engine[1]/igniter-b", 0);
|
|
||||||
setprop("/controls/engines/engine[0]/last-igniter", "B");
|
|
||||||
setprop("/controls/engines/engine[1]/last-igniter", "B");
|
|
||||||
|
|
||||||
var eng_init = func {
|
var eng_init = func {
|
||||||
setprop("/controls/engines/engine[0]/man-start", 0);
|
setprop("/controls/engines/engine[0]/man-start", 0);
|
||||||
setprop("/controls/engines/engine[1]/man-start", 0);
|
setprop("/controls/engines/engine[1]/man-start", 0);
|
||||||
|
|
|
@ -162,7 +162,7 @@ var ELEC = {
|
||||||
loop: func() {
|
loop: func() {
|
||||||
# Autopilot Disconnection routines
|
# Autopilot Disconnection routines
|
||||||
if (me.Bus.dcEssShed.getValue() < 25) {
|
if (me.Bus.dcEssShed.getValue() < 25) {
|
||||||
if (getprop("it-autoflight/output/ap1") == 1 and !me._timer1On) {
|
if (fmgc.Output.ap1.getValue() and !me._timer1On) {
|
||||||
me._timer1On = 1;
|
me._timer1On = 1;
|
||||||
settimer(func() {
|
settimer(func() {
|
||||||
if (me.Bus.dcEssShed.getValue() < 25) {
|
if (me.Bus.dcEssShed.getValue() < 25) {
|
||||||
|
@ -177,7 +177,7 @@ var ELEC = {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (me.Bus.dc2.getValue() < 25) {
|
if (me.Bus.dc2.getValue() < 25) {
|
||||||
if (getprop("it-autoflight/output/ap2") == 1 and !me._timer2On) {
|
if (fmgc.Output.ap2.getValue() and !me._timer2On) {
|
||||||
me._timer2On = 1;
|
me._timer2On = 1;
|
||||||
settimer(func() {
|
settimer(func() {
|
||||||
if (me.Bus.dc2.getValue() < 25) {
|
if (me.Bus.dc2.getValue() < 25) {
|
||||||
|
|
|
@ -3,9 +3,6 @@
|
||||||
|
|
||||||
# Copyright (c) 2019 Jonathan Redpath
|
# Copyright (c) 2019 Jonathan Redpath
|
||||||
|
|
||||||
var accum = 0;
|
|
||||||
var down = 0;
|
|
||||||
|
|
||||||
var HYD = {
|
var HYD = {
|
||||||
Brakes: {
|
Brakes: {
|
||||||
accumPressPsi: props.globals.initNode("/systems/hydraulic/brakes/accumulator-pressure-psi", 0, "INT"),
|
accumPressPsi: props.globals.initNode("/systems/hydraulic/brakes/accumulator-pressure-psi", 0, "INT"),
|
||||||
|
@ -82,10 +79,8 @@ var HYD = {
|
||||||
me.Fail.yellowLeak.setBoolValue(0);
|
me.Fail.yellowLeak.setBoolValue(0);
|
||||||
},
|
},
|
||||||
loop: func() {
|
loop: func() {
|
||||||
accum = me.Brakes.accumPressPsi.getValue();
|
|
||||||
|
|
||||||
if (me.Brakes.mode.getValue() == 2) {
|
if (me.Brakes.mode.getValue() == 2) {
|
||||||
if (me.Psi.yellow.getValue() > 2500 and accum < 700) {
|
if (me.Psi.yellow.getValue() > 2500 and me.Brakes.accumPressPsi.getValue() < 700) {
|
||||||
me.Brakes.accumPressPsi.setValue(me.Brakes.accumPressPsi.getValue() + 50);
|
me.Brakes.accumPressPsi.setValue(me.Brakes.accumPressPsi.getValue() + 50);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -93,8 +88,7 @@ var HYD = {
|
||||||
};
|
};
|
||||||
|
|
||||||
setlistener("/controls/gear/gear-down", func {
|
setlistener("/controls/gear/gear-down", func {
|
||||||
down = getprop("/controls/gear/gear-down");
|
if (!pts.Controls.Gear.gearDown.getValue() and (pts.Gear.wow[0].getValue() or pts.Gear.wow[1].getValue() or pts.Gear.wow[2].getValue())) {
|
||||||
if (!down and (getprop("gear/gear[0]/wow") or getprop("gear/gear[1]/wow") or getprop("gear/gear[2]/wow"))) {
|
pts.Controls.Gear.gearDown.setValue(1);
|
||||||
setprop("/controls/gear/gear-down", 1);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -8,8 +8,7 @@ var tyresmoke_2 = aircraft.tyresmoke.new(2, 0, 0.8, 0);
|
||||||
|
|
||||||
# =============================== listeners ===============================
|
# =============================== listeners ===============================
|
||||||
setlistener("gear/gear[0]/position-norm", func {
|
setlistener("gear/gear[0]/position-norm", func {
|
||||||
var gear = getprop("gear/gear[0]/position-norm");
|
if (pts.Gear.position[0].getValue()){
|
||||||
if (gear == 1 ){
|
|
||||||
run_tyresmoke0 = 1;
|
run_tyresmoke0 = 1;
|
||||||
}else{
|
}else{
|
||||||
run_tyresmoke0 = 0;
|
run_tyresmoke0 = 0;
|
||||||
|
@ -17,8 +16,7 @@ setlistener("gear/gear[0]/position-norm", func {
|
||||||
},1,0);
|
},1,0);
|
||||||
|
|
||||||
setlistener("gear/gear[1]/position-norm", func {
|
setlistener("gear/gear[1]/position-norm", func {
|
||||||
var gear = getprop("gear/gear[1]/position-norm");
|
if (pts.Gear.position[1].getValue()){
|
||||||
if (gear == 1 ){
|
|
||||||
run_tyresmoke1 = 1;
|
run_tyresmoke1 = 1;
|
||||||
}else{
|
}else{
|
||||||
run_tyresmoke1 = 0;
|
run_tyresmoke1 = 0;
|
||||||
|
@ -26,8 +24,7 @@ setlistener("gear/gear[1]/position-norm", func {
|
||||||
},1,0);
|
},1,0);
|
||||||
|
|
||||||
setlistener("gear/gear[2]/position-norm", func {
|
setlistener("gear/gear[2]/position-norm", func {
|
||||||
var gear = getprop("gear/gear[2]/position-norm");
|
if (pts.Gear.position[2].getValue()){
|
||||||
if (gear == 1 ){
|
|
||||||
run_tyresmoke2 = 1;
|
run_tyresmoke2 = 1;
|
||||||
}else{
|
}else{
|
||||||
run_tyresmoke2 = 0;
|
run_tyresmoke2 = 0;
|
||||||
|
|
Loading…
Reference in a new issue