Merge branch 'dev' into FMGC
This commit is contained in:
commit
cec616d0d8
8 changed files with 70 additions and 58 deletions
|
@ -462,7 +462,6 @@
|
||||||
<!-- Remove from this animation once you simulate -->
|
<!-- Remove from this animation once you simulate -->
|
||||||
<animation>
|
<animation>
|
||||||
<type>select</type>
|
<type>select</type>
|
||||||
<object-name>alt-text-test</object-name>
|
|
||||||
<object-name>atc-test</object-name>
|
<object-name>atc-test</object-name>
|
||||||
<object-name>audio_att_sgn</object-name>
|
<object-name>audio_att_sgn</object-name>
|
||||||
<object-name>audio_call_hf2_led</object-name>
|
<object-name>audio_call_hf2_led</object-name>
|
||||||
|
@ -478,19 +477,27 @@
|
||||||
<object-name>engine_fault_1</object-name>
|
<object-name>engine_fault_1</object-name>
|
||||||
<object-name>engine_fault_2</object-name>
|
<object-name>engine_fault_2</object-name>
|
||||||
<object-name>exped_led</object-name>
|
<object-name>exped_led</object-name>
|
||||||
<object-name>hdg-text-test</object-name>
|
|
||||||
<object-name>qnh-test</object-name>
|
<object-name>qnh-test</object-name>
|
||||||
<object-name>radio_opt_led</object-name>
|
<object-name>radio_opt_led</object-name>
|
||||||
<object-name>rudder-trim-test</object-name>
|
<object-name>rudder-trim-test</object-name>
|
||||||
<object-name>spd-text-test</object-name>
|
|
||||||
<object-name>terr_on_nd_on</object-name>
|
<object-name>terr_on_nd_on</object-name>
|
||||||
<object-name>ver.fmgc</object-name>
|
<object-name>ver.fmgc</object-name>
|
||||||
|
<condition>
|
||||||
|
<property>controls/switches/annun-test</property>
|
||||||
|
</condition>
|
||||||
|
</animation>
|
||||||
|
|
||||||
|
<animation>
|
||||||
|
<type>select</type>
|
||||||
|
<object-name>alt-text-test</object-name>
|
||||||
|
<object-name>hdg-text-test</object-name>
|
||||||
|
<object-name>spd-text-test</object-name>
|
||||||
<object-name>vs-text-test</object-name>
|
<object-name>vs-text-test</object-name>
|
||||||
<condition>
|
<condition>
|
||||||
<equals>
|
<or>
|
||||||
<property>controls/switches/annun-test</property>
|
<not><property>/FMGC/FCU-working</property></not>
|
||||||
<value>1</value>
|
<property>/controls/switches/annun-test</property>
|
||||||
</equals>
|
</or>
|
||||||
</condition>
|
</condition>
|
||||||
</animation>
|
</animation>
|
||||||
|
|
||||||
|
|
|
@ -3696,21 +3696,8 @@
|
||||||
<object-name>EmerGenInd1F</object-name>
|
<object-name>EmerGenInd1F</object-name>
|
||||||
<condition>
|
<condition>
|
||||||
<and>
|
<and>
|
||||||
<greater-than-equals>
|
|
||||||
<property>systems/electrical/bus/dc-ess</property>
|
|
||||||
<value>25</value>
|
|
||||||
</greater-than-equals>
|
|
||||||
<or>
|
<or>
|
||||||
<and>
|
<property>/systems/electrical/light/rat-emer-gen-fault</property>
|
||||||
<equals>
|
|
||||||
<property>systems/electrical/bus/ac-1</property>
|
|
||||||
<value>0</value>
|
|
||||||
</equals>
|
|
||||||
<equals>
|
|
||||||
<property>systems/electrical/bus/ac-2</property>
|
|
||||||
<value>0</value>
|
|
||||||
</equals>
|
|
||||||
</and>
|
|
||||||
<equals>
|
<equals>
|
||||||
<property>controls/switches/annun-test</property>
|
<property>controls/switches/annun-test</property>
|
||||||
<value>1</value>
|
<value>1</value>
|
||||||
|
|
|
@ -51,19 +51,21 @@ var warning = {
|
||||||
if (me.active == 0) { return; }
|
if (me.active == 0) { return; }
|
||||||
me.wasActive = 1;
|
me.wasActive = 1;
|
||||||
lineIndex = 0;
|
lineIndex = 0;
|
||||||
while (lineIndex < 7 and lines[lineIndex].getValue() != "") {
|
while (lineIndex <= 7 and lines[lineIndex].getValue() != "") {
|
||||||
lineIndex = lineIndex + 1; # go to next line until empty line
|
lineIndex = lineIndex + 1; # go to next line until empty line
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lineIndex == 7) {
|
if (lineIndex == 8) {
|
||||||
leftOverflow.setBoolValue(1);
|
leftOverflow.setBoolValue(1);
|
||||||
} elsif (leftOverflow.getBoolValue()) {
|
} elsif (leftOverflow.getBoolValue()) {
|
||||||
leftOverflow.setBoolValue(0);
|
leftOverflow.setBoolValue(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lines[lineIndex].getValue() == "" and me.msg != "" and lineIndex <= 7) { # at empty line. Also checks if message is not blank to allow for some warnings with no displayed msg, eg stall
|
if (lineIndex <= 7) {
|
||||||
lines[lineIndex].setValue(me.msg);
|
if (lines[lineIndex].getValue() == "" and me.msg != "") { # at empty line. Also checks if message is not blank to allow for some warnings with no displayed msg, eg stall
|
||||||
linesCol[lineIndex].setValue(me.colour);
|
lines[lineIndex].setValue(me.msg);
|
||||||
|
linesCol[lineIndex].setValue(me.colour);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
warnlight: func() {
|
warnlight: func() {
|
||||||
|
@ -309,7 +311,7 @@ var ECAM_controller = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (statusFlag == 1) {
|
if (statusFlag == 1 and lines[0].getValue() == "") {
|
||||||
libraries.SystemDisplay.manCall("sts");
|
libraries.SystemDisplay.manCall("sts");
|
||||||
statusFlag = 0;
|
statusFlag = 0;
|
||||||
}
|
}
|
||||||
|
@ -347,6 +349,7 @@ var ECAM_controller = {
|
||||||
warning.active = 0;
|
warning.active = 0;
|
||||||
warning.noRepeat = 0;
|
warning.noRepeat = 0;
|
||||||
warning.noRepeat2 = 0;
|
warning.noRepeat2 = 0;
|
||||||
|
# don't set .wasActive to 0, warnlight / sound funcs do that
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1058,6 +1058,14 @@ var messages_priority_2 = func {
|
||||||
ECAM_controller.warningReset(acBusEssShedAtc);
|
ECAM_controller.warningReset(acBusEssShedAtc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((athr_offw.clearFlag == 0) and athrWarn.getValue() == 2 and phaseVar != 4 and phaseVar != 8 and phaseVar != 10) {
|
||||||
|
athr_offw.active = 1;
|
||||||
|
athr_offw_1.active = 1;
|
||||||
|
} else {
|
||||||
|
ECAM_controller.warningReset(athr_offw);
|
||||||
|
ECAM_controller.warningReset(athr_offw_1);
|
||||||
|
}
|
||||||
|
|
||||||
if ((athr_lock.clearFlag == 0) and phaseVar >= 5 and phaseVar <= 7 and getprop("/systems/thrust/thr-locked-alert") == 1) {
|
if ((athr_lock.clearFlag == 0) and phaseVar >= 5 and phaseVar <= 7 and getprop("/systems/thrust/thr-locked-alert") == 1) {
|
||||||
if (getprop("/systems/thrust/thr-locked-flash") == 0) {
|
if (getprop("/systems/thrust/thr-locked-flash") == 0) {
|
||||||
athr_lock.msg = " ";
|
athr_lock.msg = " ";
|
||||||
|
@ -1071,18 +1079,6 @@ var messages_priority_2 = func {
|
||||||
ECAM_controller.warningReset(athr_lock_1);
|
ECAM_controller.warningReset(athr_lock_1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((athr_offw.clearFlag == 0) and athrWarn.getValue() == 2 and phaseVar != 4 and phaseVar != 8 and phaseVar != 10) {
|
|
||||||
athr_offw.active = 1;
|
|
||||||
athr_offw_1.active = 1;
|
|
||||||
} else {
|
|
||||||
ECAM_controller.warningReset(athr_offw);
|
|
||||||
ECAM_controller.warningReset(athr_offw_1);
|
|
||||||
if (getprop("/it-autoflight/output/athr-warning") == 2) {
|
|
||||||
setprop("/it-autoflight/output/athr-warning", 0);
|
|
||||||
setprop("/ECAM/Lower/light/clr", 0);
|
|
||||||
setprop("/ECAM/warnings/master-caution-light", 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((athr_lim.clearFlag == 0) and getprop("/it-autoflight/output/athr") == 1 and ((getprop("/systems/thrust/eng-out") != 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN")) or (getprop("/systems/thrust/eng-out") == 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN" or (getprop("/systems/thrust/state1") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83) or (getprop("/systems/thrust/state2") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83)))) and (phaseVar >= 5 and phaseVar <= 7)) {
|
if ((athr_lim.clearFlag == 0) and getprop("/it-autoflight/output/athr") == 1 and ((getprop("/systems/thrust/eng-out") != 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN")) or (getprop("/systems/thrust/eng-out") == 1 and (getprop("/systems/thrust/state1") == "MAN" or getprop("/systems/thrust/state2") == "MAN" or (getprop("/systems/thrust/state1") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83) or (getprop("/systems/thrust/state2") == "MAN THR" and getprop("/controls/engines/engine[0]/throttle-pos") <= 0.83)))) and (phaseVar >= 5 and phaseVar <= 7)) {
|
||||||
athr_lim.active = 1;
|
athr_lim.active = 1;
|
||||||
|
|
|
@ -122,14 +122,8 @@ var warnings = std.Vector.new([
|
||||||
var rud_trim_config_1 = warning.new(msg: " NOT IN T.O. RANGE", colour: "r", aural: 0, light: 0),
|
var rud_trim_config_1 = warning.new(msg: " NOT IN T.O. RANGE", colour: "r", aural: 0, light: 0),
|
||||||
var park_brk_config = warning.new(msg: "CONFIG PARK BRK ON", colour: "r", aural: 0, light: 0),
|
var park_brk_config = warning.new(msg: "CONFIG PARK BRK ON", colour: "r", aural: 0, light: 0),
|
||||||
|
|
||||||
# Autopilot
|
# Autopilot off involuntary
|
||||||
var ap_offw = warning.new(msg: "AUTO FLT AP OFF", colour: "r", light: 0),
|
var ap_offw = warning.new(msg: "AUTO FLT AP OFF", colour: "r", light: 0),
|
||||||
var athr_offw = warning.new(msg: "AUTO FLT A/THR OFF", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
|
||||||
var athr_offw_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
|
||||||
var athr_lock = warning.new(msg: "ENG THRUST LOCKED", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
|
||||||
var athr_lock_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
|
||||||
var athr_lim = warning.new(msg: "AUTO FLT A/THR LIMITED", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
|
||||||
var athr_lim_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
|
||||||
|
|
||||||
# Cargo smoke
|
# Cargo smoke
|
||||||
var cargoSmokeFwd = warning.new(msg: "SMOKE FWD CARGO SMOKE", colour: "r", aural: 0, light: 0, hasSubmsg: 1),
|
var cargoSmokeFwd = warning.new(msg: "SMOKE FWD CARGO SMOKE", colour: "r", aural: 0, light: 0, hasSubmsg: 1),
|
||||||
|
@ -221,6 +215,14 @@ var warnings = std.Vector.new([
|
||||||
var acBusEssShed = warning.new(msg: "ELEC DC ESS BUS SHED", colour: "a", aural: 1, light: 1),
|
var acBusEssShed = warning.new(msg: "ELEC DC ESS BUS SHED", colour: "a", aural: 1, light: 1),
|
||||||
var acBusEssShedAtc = warning.new(msg: " -ATC..............SYS 2", colour: "c"),
|
var acBusEssShedAtc = warning.new(msg: " -ATC..............SYS 2", colour: "c"),
|
||||||
|
|
||||||
|
# Autothrust
|
||||||
|
var athr_offw = warning.new(msg: "AUTO FLT A/THR OFF", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
||||||
|
var athr_offw_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
||||||
|
var athr_lock = warning.new(msg: "ENG THRUST LOCKED", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
||||||
|
var athr_lock_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
||||||
|
var athr_lim = warning.new(msg: "AUTO FLT A/THR LIMITED", colour: "a", aural: 1, light: 1, hasSubmsg: 1),
|
||||||
|
var athr_lim_1 = warning.new(msg: "-THR LEVERS........MOVE", colour: "c"),
|
||||||
|
|
||||||
# TCAS FAULT
|
# TCAS FAULT
|
||||||
var tcasFault = warning.new(msg: "NAV TCAS FAULT", colour: "a", aural: 1, light: 1),
|
var tcasFault = warning.new(msg: "NAV TCAS FAULT", colour: "a", aural: 1, light: 1),
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,7 @@ var vertModeInput = props.globals.getNode("/it-autoflight/input/vert", 1);
|
||||||
var vsModeInput = props.globals.getNode("/it-autoflight/input/vs", 1);
|
var vsModeInput = props.globals.getNode("/it-autoflight/input/vs", 1);
|
||||||
var locArm = props.globals.getNode("/it-autoflight/output/loc-armed", 1);
|
var locArm = props.globals.getNode("/it-autoflight/output/loc-armed", 1);
|
||||||
var apprArm = props.globals.getNode("/it-autoflight/output/appr-armed", 1);
|
var apprArm = props.globals.getNode("/it-autoflight/output/appr-armed", 1);
|
||||||
|
var FCUworkingNode = props.globals.initNode("/FMGC/FCU-working", 0, "BOOL");
|
||||||
|
|
||||||
var FCU = {
|
var FCU = {
|
||||||
elecSupply: "",
|
elecSupply: "",
|
||||||
|
@ -73,10 +74,12 @@ var FCUController = {
|
||||||
me.FCU1.loop();
|
me.FCU1.loop();
|
||||||
me.FCU2.loop();
|
me.FCU2.loop();
|
||||||
|
|
||||||
if (!me.FCU1.failed and !me.FCU2.failed) {
|
if (!me.FCU1.failed or !me.FCU2.failed) {
|
||||||
me.FCUworking = 1;
|
me.FCUworking = 1;
|
||||||
|
FCUworkingNode.setValue(1);
|
||||||
} else {
|
} else {
|
||||||
me.FCUworking = 0;
|
me.FCUworking = 0;
|
||||||
|
FCUworkingNode.setValue(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
notification = nil;
|
notification = nil;
|
||||||
|
|
|
@ -13,6 +13,8 @@ var dc2 = 0;
|
||||||
|
|
||||||
# Main class
|
# Main class
|
||||||
var ELEC = {
|
var ELEC = {
|
||||||
|
_timer1On: 0,
|
||||||
|
_timer2On: 0,
|
||||||
Bus: {
|
Bus: {
|
||||||
acEss: props.globals.getNode("/systems/electrical/bus/ac-ess"),
|
acEss: props.globals.getNode("/systems/electrical/bus/ac-ess"),
|
||||||
acEssShed: props.globals.getNode("/systems/electrical/bus/ac-ess-shed"),
|
acEssShed: props.globals.getNode("/systems/electrical/bus/ac-ess-shed"),
|
||||||
|
@ -227,20 +229,32 @@ var ELEC = {
|
||||||
|
|
||||||
# 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) {
|
if (getprop("/it-autoflight/output/ap1") == 1 and !me._timer1On) {
|
||||||
fcu.apOff("hard", 1);
|
me._timer1On = 1;
|
||||||
if (fcu.FCUController.activeFMGC.getValue() == 1) {
|
settimer(func() {
|
||||||
fcu.athrOff("hard");
|
if (me.Bus.dcEssShed.getValue() < 25) {
|
||||||
}
|
fcu.apOff("hard", 1);
|
||||||
|
if (fcu.FCUController.activeFMGC.getValue() == 1) {
|
||||||
|
fcu.athrOff("hard");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
me._timer1On = 0;
|
||||||
|
}, 0.1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (me.Bus.dc2.getValue() < 25) {
|
if (me.Bus.dc2.getValue() < 25) {
|
||||||
if (getprop("/it-autoflight/output/ap2") == 1) {
|
if (getprop("/it-autoflight/output/ap2") == 1 and !me._timer2On) {
|
||||||
fcu.apOff("hard", 2);
|
me._timer2On = 1;
|
||||||
if (fcu.FCUController.activeFMGC.getValue() == 2) {
|
settimer(func() {
|
||||||
fcu.athrOff("hard");
|
if (me.Bus.dc2.getValue() < 25) {
|
||||||
}
|
fcu.apOff("hard", 2);
|
||||||
|
if (fcu.FCUController.activeFMGC.getValue() == 2) {
|
||||||
|
fcu.athrOff("hard");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
me._timer2On = 0;
|
||||||
|
}, 0.1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -1452,7 +1452,7 @@
|
||||||
|
|
||||||
<switch name="/systems/electrical/light/rat-emer-gen-fault">
|
<switch name="/systems/electrical/light/rat-emer-gen-fault">
|
||||||
<default value="0"/>
|
<default value="0"/>
|
||||||
<test value="1">
|
<test logic="AND" value="1">
|
||||||
/systems/electrical/relay/dc-ess-feed-tr/output eq 0
|
/systems/electrical/relay/dc-ess-feed-tr/output eq 0
|
||||||
/systems/electrical/bus/ac-1 eq 0
|
/systems/electrical/bus/ac-1 eq 0
|
||||||
/systems/electrical/bus/ac-2 eq 0
|
/systems/electrical/bus/ac-2 eq 0
|
||||||
|
|
Loading…
Add table
Reference in a new issue