A32X: Move major systems to classes, temporarily disactive ADIRS
This commit is contained in:
parent
0efbe81dbf
commit
722b8d1109
8 changed files with 1187 additions and 1532 deletions
|
@ -157,29 +157,6 @@
|
|||
|
||||
<instrumentation>
|
||||
<path>Aircraft/IDG-A32X/Systems/instrumentation.xml</path>
|
||||
<adirs n="0">
|
||||
<ir n="0">
|
||||
<aligned type="bool">false</aligned>
|
||||
<display>
|
||||
<status type="string"></status>
|
||||
<ttn type="int">0</ttn>
|
||||
</display>
|
||||
</ir>
|
||||
<ir n="1">
|
||||
<aligned type="bool">false</aligned>
|
||||
<display>
|
||||
<status type="string"></status>
|
||||
<ttn type="int">0</ttn>
|
||||
</display>
|
||||
</ir>
|
||||
<ir n="2">
|
||||
<aligned type="bool">false</aligned>
|
||||
<display>
|
||||
<status type="string"></status>
|
||||
<ttn type="int">0</ttn>
|
||||
</display>
|
||||
</ir>
|
||||
</adirs>
|
||||
</instrumentation>
|
||||
|
||||
<alarms>
|
||||
|
|
|
@ -151,11 +151,11 @@ saveSettings();
|
|||
|
||||
var systemsReset = func {
|
||||
fbw.fctlInit();
|
||||
systems.elec_init();
|
||||
systems.ADIRSreset();
|
||||
systems.pneu_init();
|
||||
systems.hyd_init();
|
||||
systems.fuel_init();
|
||||
systems.ELEC.init();
|
||||
systems.PNEU.init();
|
||||
systems.HYD.init();
|
||||
systems.FUEL.init();
|
||||
systems.ADIRS.init();
|
||||
systems.eng_init();
|
||||
systems.autobrake_init();
|
||||
fmgc.FMGCinit();
|
||||
|
|
258
Nasal/ADIRS.nas
258
Nasal/ADIRS.nas
|
@ -1,23 +1,10 @@
|
|||
# A3XX ADIRS system
|
||||
# Jonathan Redpath and Joshua Davidson
|
||||
# Joshua Davidson
|
||||
|
||||
##############################################
|
||||
# Copyright (c) Joshua Davidson (it0uchpods) #
|
||||
##############################################
|
||||
|
||||
#####################
|
||||
# Initializing Vars #
|
||||
#####################
|
||||
|
||||
setprop("/systems/electrical/bus/dc1", 0);
|
||||
setprop("/systems/electrical/bus/dc2", 0);
|
||||
setprop("/systems/electrical/bus/dc-ess", 0);
|
||||
setprop("/systems/electrical/bus/ac1", 0);
|
||||
setprop("/systems/electrical/bus/ac2", 0);
|
||||
setprop("/systems/electrical/bus/ac-ess", 0);
|
||||
var ttn = 0;
|
||||
var knob = 0;
|
||||
|
||||
setlistener("/sim/signals/fdm-initialized", func {
|
||||
var roll = getprop("/orientation/roll-deg");
|
||||
var pitch = getprop("/orientation/pitch-deg");
|
||||
|
@ -26,12 +13,8 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var selected_ir = getprop("/controls/adirs/display/selected");
|
||||
});
|
||||
|
||||
var adirs_init = func {
|
||||
setprop("/controls/adirs/mcducbtn",0);
|
||||
adirs_timer.start();
|
||||
}
|
||||
|
||||
var ADIRSreset = func {
|
||||
var ADIRS = {
|
||||
init: func() {
|
||||
setprop("/controls/adirs/numm", 0);
|
||||
setprop("/instrumentation/adirs/ir[0]/aligned", 0);
|
||||
setprop("/instrumentation/adirs/ir[1]/aligned", 0);
|
||||
|
@ -39,18 +22,12 @@ var ADIRSreset = func {
|
|||
setprop("/instrumentation/adirs/ir[0]/display/ttn", 0);
|
||||
setprop("/instrumentation/adirs/ir[1]/display/ttn", 0);
|
||||
setprop("/instrumentation/adirs/ir[2]/display/ttn", 0);
|
||||
setprop("/instrumentation/adirs/ir[0]/display/status","- - - - - - - - ");
|
||||
setprop("/instrumentation/adirs/ir[1]/display/status","- - - - - - - - ");
|
||||
setprop("/instrumentation/adirs/ir[2]/display/status","- - - - - - - - ");
|
||||
setprop("/controls/adirs/adr[0]/fault", 0);
|
||||
setprop("/controls/adirs/adr[1]/fault", 0);
|
||||
setprop("/controls/adirs/adr[2]/fault", 0);
|
||||
setprop("/controls/adirs/adr[0]/off", 0);
|
||||
setprop("/controls/adirs/adr[1]/off", 0);
|
||||
setprop("/controls/adirs/adr[2]/off", 0);
|
||||
setprop("/controls/adirs/display/text","");
|
||||
setprop("/controls/adirs/display/dataknob","5");
|
||||
setprop("/controls/adirs/display/selected","1");
|
||||
setprop("/controls/adirs/ir[0]/align", 0);
|
||||
setprop("/controls/adirs/ir[1]/align", 0);
|
||||
setprop("/controls/adirs/ir[2]/align", 0);
|
||||
|
@ -72,225 +49,12 @@ var ADIRSreset = func {
|
|||
setprop("/controls/adirs/mcdu/avgdrift1", "");
|
||||
setprop("/controls/adirs/mcdu/avgdrift2", "");
|
||||
setprop("/controls/adirs/mcdu/avgdrift3", "");
|
||||
adirs_init();
|
||||
}
|
||||
|
||||
var ir_align_loop = func(i) {
|
||||
ttn = getprop("/instrumentation/adirs/ir[" ~ i ~ "]/display/ttn");
|
||||
if ((ttn >= 0) and (ttn < 0.99)) { # Make it less sensitive
|
||||
ir_align_finish(i);
|
||||
} else {
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/display/ttn", ttn - 1);
|
||||
}
|
||||
roll = getprop("/orientation/roll-deg");
|
||||
pitch = getprop("/orientation/pitch-deg");
|
||||
gs = getprop("/velocities/groundspeed-kt");
|
||||
if (gs > 2) {
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/display/status", "STS-XCESS MOTION");
|
||||
ir_align_abort(i);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
var ir0_align_loop_timer = maketimer(1, func{ir_align_loop(0)});
|
||||
var ir1_align_loop_timer = maketimer(1, func{ir_align_loop(1)});
|
||||
var ir2_align_loop_timer = maketimer(1, func{ir_align_loop(2)});
|
||||
|
||||
var ir_align_start = func(i) {
|
||||
if (((i == 0) and !ir0_align_loop_timer.isRunning) or
|
||||
((i == 1) and !ir1_align_loop_timer.isRunning) or
|
||||
((i == 2) and !ir2_align_loop_timer.isRunning)) {
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/display/ttn", (math.sin((getprop("/position/latitude-deg") / 90) * (math.pi / 2)) * 720) + 300);
|
||||
if (i == 0) {
|
||||
ir0_align_loop_timer.start();
|
||||
} else if (i == 1) {
|
||||
ir1_align_loop_timer.start();
|
||||
} else if (i == 2) {
|
||||
ir2_align_loop_timer.start();
|
||||
}
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/align", 1);
|
||||
}
|
||||
}
|
||||
|
||||
var ir_align_finish = func(i) {
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/aligned", 1);
|
||||
if (i == 0) {
|
||||
ir0_align_loop_timer.stop();
|
||||
} else if (i == 1) {
|
||||
ir1_align_loop_timer.stop();
|
||||
} else if (i == 2) {
|
||||
ir2_align_loop_timer.stop();
|
||||
}
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/align", 0);
|
||||
}
|
||||
|
||||
var ir_align_abort = func(i) {
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/fault", 1);
|
||||
if (i == 0) {
|
||||
ir0_align_loop_timer.stop();
|
||||
} else if (i == 1) {
|
||||
ir1_align_loop_timer.stop();
|
||||
} else if (i == 2) {
|
||||
ir2_align_loop_timer.stop();
|
||||
}
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/align", 0);
|
||||
}
|
||||
|
||||
var ir_knob_move = func(i) {
|
||||
knob = getprop("/controls/adirs/ir[" ~ i ~ "]/knob");
|
||||
if (knob == 1) {
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/align", 0);
|
||||
setprop("/controls/adirs/ir[" ~ i ~ "]/fault", 0);
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/aligned", 0);
|
||||
setprop("/instrumentation/adirs/ir[" ~ i ~ "]/display/status", "- - - - - - - - ");
|
||||
if (i == 0) {
|
||||
ir0_align_loop_timer.stop();
|
||||
} else if (i == 1) {
|
||||
ir1_align_loop_timer.stop();
|
||||
} else if (i == 2) {
|
||||
ir2_align_loop_timer.stop();
|
||||
}
|
||||
} else if (knob == 2) {
|
||||
if ( !getprop("/instrumentation/adirs/ir[" ~ i ~ "]/aligned") and
|
||||
(getprop("/systems/electrical/bus/ac-ess") > 9) ) {
|
||||
ir_align_start(i);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
setlistener("/controls/adirs/ir[0]/knob", func {
|
||||
ir_knob_move(0);
|
||||
knobmcducheck();
|
||||
});
|
||||
setlistener("/controls/adirs/ir[1]/knob", func {
|
||||
ir_knob_move(1);
|
||||
knobmcducheck();
|
||||
});
|
||||
setlistener("/controls/adirs/ir[2]/knob", func {
|
||||
ir_knob_move(2);
|
||||
knobmcducheck();
|
||||
});
|
||||
|
||||
var knobmcducheck = func {
|
||||
if (getprop("/controls/adirs/ir[0]/knob") == 1 and getprop("/controls/adirs/ir[1]/knob") == 1 and getprop("/controls/adirs/ir[2]/knob") == 1) {
|
||||
setprop("/controls/adirs/mcducbtn",0);
|
||||
}
|
||||
}
|
||||
|
||||
var onbat_light = func {
|
||||
if (((getprop("/systems/electrical/bus/dc1") > 25) or (getprop("/systems/electrical/bus/dc2") > 25)) and
|
||||
((getprop("/systems/electrical/bus/ac1") < 110) and getprop("/systems/electrical/bus/ac2") < 110) and
|
||||
((getprop("/controls/adirs/ir[0]/knob") > 1) or
|
||||
(getprop("/controls/adirs/ir[1]/knob") > 1) or
|
||||
(getprop("/controls/adirs/ir[2]/knob") > 1))) {
|
||||
setprop("/controls/adirs/onbat", 1);
|
||||
} else {
|
||||
setprop("/controls/adirs/onbat", 0);
|
||||
}
|
||||
}
|
||||
|
||||
var onbat_light_b = func {
|
||||
setprop("/controls/adirs/onbat", 1);
|
||||
settimer(func {
|
||||
onbat_light();
|
||||
}, 4);
|
||||
if (getprop("/controls/adirs/skip") == 1) {
|
||||
skip_ADIRS();
|
||||
}
|
||||
}
|
||||
|
||||
setlistener("/controls/electrical/switches/gen-apu", onbat_light);
|
||||
setlistener("/controls/electrical/switches/gen1", onbat_light);
|
||||
setlistener("/controls/electrical/switches/gen2", onbat_light);
|
||||
setlistener("/controls/electrical/switches/gen-ext", onbat_light);
|
||||
setlistener("/systems/electrical/bus/ac-ess", onbat_light);
|
||||
setlistener("/controls/adirs/ir[0]/knob", onbat_light_b);
|
||||
setlistener("/controls/adirs/ir[1]/knob", onbat_light_b);
|
||||
setlistener("/controls/adirs/ir[2]/knob", onbat_light_b);
|
||||
|
||||
|
||||
var adirs_display = func() {
|
||||
data_knob = getprop("/controls/adirs/display/dataknob");
|
||||
selected_ir = getprop("/controls/adirs/display/selected");
|
||||
if ( selected_ir == 1 ) {
|
||||
setprop("/controls/adirs/display/text", "");
|
||||
} else {
|
||||
if ( data_knob == 1 ) {
|
||||
setprop("/controls/adirs/display/text", "888888888888888");
|
||||
} else if ( data_knob == 2 ) {
|
||||
if ( ((selected_ir == 2) and getprop("/instrumentation/adirs/ir[0]/aligned")) or
|
||||
((selected_ir == 3) and getprop("/instrumentation/adirs/ir[2]/aligned")) or
|
||||
((selected_ir == 4) and getprop("/instrumentation/adirs/ir[1]/aligned")) ) {
|
||||
setprop("/controls/adirs/display/text", sprintf(" %03i", getprop("/orientation/track-magnetic-deg")) ~ sprintf(" %03i", getprop("/velocities/groundspeed-kt")));
|
||||
} else {
|
||||
setprop("/controls/adirs/display/text", "- - - - - - - - ");
|
||||
}
|
||||
} else if ( data_knob == 3 ) {
|
||||
lat = abs(getprop("/position/latitude-deg"));
|
||||
lon = abs(getprop("/position/longitude-deg"));
|
||||
setprop("/controls/adirs/display/text", substr(getprop("/position/latitude-string"), -1, 1) ~
|
||||
sprintf("%2i", lat) ~ "'" ~
|
||||
sprintf("%2.1f", (lat - math.floor(lat)) * 60) ~
|
||||
substr(getprop("/position/longitude-string"), -1, 1) ~
|
||||
sprintf("%3i", lon) ~ "'" ~
|
||||
sprintf("%2.1f", (lon - math.floor(lon)) * 60));
|
||||
} else if ( data_knob == 4 ) {
|
||||
if ( ((selected_ir == 2) and getprop("/instrumentation/adirs/ir[0]/aligned")) or
|
||||
((selected_ir == 3) and getprop("/instrumentation/adirs/ir[2]/aligned")) or
|
||||
((selected_ir == 4) and getprop("/instrumentation/adirs/ir[1]/aligned")) ) {
|
||||
setprop("/controls/adirs/display/text", sprintf(" %03i", getprop("/environment/wind-from-heading-deg")) ~ sprintf(" %03i", getprop("/environment/wind-speed-kt")));
|
||||
} else {
|
||||
setprop("/controls/adirs/display/text", "- - - - - - - - ");
|
||||
}
|
||||
} else if ( data_knob == 5 ) {
|
||||
if ( ((selected_ir == 2) and getprop("/instrumentation/adirs/ir[0]/aligned")) or
|
||||
((selected_ir == 3) and getprop("/instrumentation/adirs/ir[2]/aligned")) or
|
||||
((selected_ir == 4) and getprop("/instrumentation/adirs/ir[1]/aligned")) ) {
|
||||
lat = getprop("/position/latitude-deg");
|
||||
lon = getprop("/position/longitude-deg");
|
||||
if ((lat > 82) or (lat < -60) or (lon < -90 and lon > -120 and lat > 73)) {
|
||||
setprop("/controls/adirs/display/text", sprintf(" %3.1f", getprop("/orientation/heading-deg")) ~ "- - - - "); # this is true heading
|
||||
} else {
|
||||
setprop("/controls/adirs/display/text", sprintf(" %3.1f", getprop("/orientation/heading-magnetic-deg")) ~ "- - - - ");
|
||||
}
|
||||
} else {
|
||||
if ( (selected_ir == 2) and getprop("/controls/adirs/ir[0]/align") ) {
|
||||
setprop("controls/adirs/display/text", "- - - - " ~ sprintf(" TTN %2i", (getprop("/instrumentation/adirs/ir[0]/display/ttn") / 60)));
|
||||
} else if ( (selected_ir == 3) and getprop("/controls/adirs/ir[2]/align") ) {
|
||||
setprop("controls/adirs/display/text", "- - - - " ~ sprintf(" TTN %2i", (getprop("/instrumentation/adirs/ir[2]/display/ttn") / 60)));
|
||||
} else if ( (selected_ir == 4) and getprop("/controls/adirs/ir[1]/align") ) {
|
||||
setprop("controls/adirs/display/text", "- - - - " ~ sprintf(" TTN %2i", (getprop("/instrumentation/adirs/ir[1]/display/ttn") / 60)));
|
||||
} else {
|
||||
setprop("/controls/adirs/display/text", "- - - - - - - - ");
|
||||
}
|
||||
}
|
||||
} else if ( data_knob == 6 ) {
|
||||
if ( selected_ir == 2 ) {
|
||||
setprop("/controls/adirs/display/text","- - - - - - - - ");
|
||||
} else if ( selected_ir == 3 ) {
|
||||
setprop("/controls/adirs/display/text","- - - - - - - - ");
|
||||
} else if ( selected_ir == 4 ) {
|
||||
setprop("/controls/adirs/display/text","- - - - - - - - ");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
var skip_ADIRS = func {
|
||||
if (getprop("/controls/adirs/ir[0]/knob") == 2) {
|
||||
setprop("/instrumentation/adirs/ir[0]/display/ttn",1); # Set it to 1 so it counts down from 1 to 0
|
||||
}
|
||||
if (getprop("/controls/adirs/ir[1]/knob") == 2) {
|
||||
setprop("/instrumentation/adirs/ir[1]/display/ttn",1); # Set it to 1 so it counts down from 1 to 0
|
||||
}
|
||||
if (getprop("/controls/adirs/ir[2]/knob") == 2) {
|
||||
setprop("/instrumentation/adirs/ir[2]/display/ttn",1); # Set it to 1 so it counts down from 1 to 0
|
||||
}
|
||||
}
|
||||
|
||||
var adirs_skip = setlistener("/controls/adirs/skip", func {
|
||||
if (getprop("/controls/adirs/skip") == 1) {
|
||||
skip_ADIRS();
|
||||
}
|
||||
});
|
||||
|
||||
var adirs_timer = maketimer(1, adirs_display);
|
||||
},
|
||||
loop: func() {
|
||||
# Temporary to make instruments work for now
|
||||
setprop("/instrumentation/adirs/ir[0]/aligned", 1);
|
||||
setprop("/instrumentation/adirs/ir[1]/aligned", 1);
|
||||
setprop("/instrumentation/adirs/ir[2]/aligned", 1);
|
||||
},
|
||||
};
|
||||
|
|
|
@ -5,10 +5,6 @@
|
|||
# Copyright (c) Joshua Davidson (it0uchpods) #
|
||||
##############################################
|
||||
|
||||
#############
|
||||
# Init Vars #
|
||||
#############
|
||||
|
||||
var ac_volt_std = 115;
|
||||
var ac_volt_min = 110;
|
||||
var dc_volt_std = 28;
|
||||
|
@ -64,7 +60,8 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var replay = getprop("/sim/replay/replay-state");
|
||||
});
|
||||
|
||||
var elec_init = func {
|
||||
var ELEC = {
|
||||
init: func() {
|
||||
setprop("/controls/switches/annun-test", 0);
|
||||
setprop("/controls/electrical/switches/galley", 1);
|
||||
setprop("/controls/electrical/switches/idg1", 0);
|
||||
|
@ -148,14 +145,8 @@ var elec_init = func {
|
|||
setprop("/systems/electrical/outputs/taxi-lights", 0);
|
||||
setprop("/systems/electrical/outputs/transponder", 0);
|
||||
setprop("/systems/electrical/outputs/turn-coordinator", 0);
|
||||
elec_timer.start();
|
||||
}
|
||||
|
||||
######################
|
||||
# Main Electric Loop #
|
||||
######################
|
||||
|
||||
var master_elec = func {
|
||||
},
|
||||
loop: func() {
|
||||
galley_sw = getprop("/controls/electrical/switches/galley");
|
||||
idg1_sw = getprop("/controls/electrical/switches/idg1");
|
||||
idg2_sw = getprop("/controls/electrical/switches/idg2");
|
||||
|
@ -464,8 +455,6 @@ var master_elec = func {
|
|||
setprop("/it-autoflight/input/ap2", 0);
|
||||
}
|
||||
setprop("systems/electrical/on", 0);
|
||||
# ai_spin.setValue(0.2);
|
||||
# aispin.stop();
|
||||
setprop("/systems/electrical/outputs/adf", 0);
|
||||
setprop("/systems/electrical/outputs/audio-panel", 0);
|
||||
setprop("/systems/electrical/outputs/audio-panel[1]", 0);
|
||||
|
@ -502,7 +491,6 @@ var master_elec = func {
|
|||
setprop("/controls/lighting/overhead-panel-norm", 0);
|
||||
} else {
|
||||
setprop("/systems/electrical/on", 1);
|
||||
# aispin.start();
|
||||
setprop("/systems/electrical/outputs/adf", dc_volt_std);
|
||||
setprop("/systems/electrical/outputs/audio-panel", dc_volt_std);
|
||||
setprop("/systems/electrical/outputs/audio-panel[1]", dc_volt_std);
|
||||
|
@ -584,21 +572,8 @@ var master_elec = func {
|
|||
} else {
|
||||
setprop("/systems/electrical/gen2-fault", 0);
|
||||
}
|
||||
}
|
||||
|
||||
###################
|
||||
# Update Function #
|
||||
###################
|
||||
|
||||
var update_electrical = func {
|
||||
master_elec();
|
||||
}
|
||||
|
||||
##########
|
||||
# Timers #
|
||||
##########
|
||||
|
||||
var elec_timer = maketimer(0.2, update_electrical);
|
||||
},
|
||||
};
|
||||
|
||||
var charge1 = maketimer(6, func {
|
||||
bat1_volts = getprop("/systems/electrical/battery1-volts");
|
||||
|
|
|
@ -5,10 +5,6 @@
|
|||
# Copyright (c) Joshua Davidson (it0uchpods) #
|
||||
##############################################
|
||||
|
||||
#############
|
||||
# Init Vars #
|
||||
#############
|
||||
|
||||
setlistener("/sim/signals/fdm-initialized", func {
|
||||
var xfeed_sw = getprop("/controls/fuel/x-feed");
|
||||
var tank0pump1_sw = getprop("/controls/fuel/tank0pump1");
|
||||
|
@ -39,7 +35,8 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var tank2pump2_fail = getprop("/systems/failures/tank2pump2");
|
||||
});
|
||||
|
||||
var fuel_init = func {
|
||||
var FUEL = {
|
||||
init: func() {
|
||||
setprop("/systems/fuel/gravityfeedL", 0);
|
||||
setprop("/systems/fuel/gravityfeedR", 0);
|
||||
setprop("/systems/fuel/gravityfeedL-output", 0);
|
||||
|
@ -64,13 +61,8 @@ var fuel_init = func {
|
|||
setprop("/systems/fuel/tank2pump1-fault", 0);
|
||||
setprop("/systems/fuel/tank2pump2-fault", 0);
|
||||
setprop("/systems/fuel/mode-fault", 0);
|
||||
fuel_timer.start();
|
||||
}
|
||||
|
||||
##############
|
||||
# Main Loops #
|
||||
##############
|
||||
var master_fuel = func {
|
||||
},
|
||||
loop: func() {
|
||||
xfeed_sw = getprop("/controls/fuel/x-feed");
|
||||
tank0pump1_sw = getprop("/controls/fuel/tank0pump1");
|
||||
tank0pump2_sw = getprop("/controls/fuel/tank0pump2");
|
||||
|
@ -202,14 +194,5 @@ var master_fuel = func {
|
|||
} else {
|
||||
setprop("/systems/fuel/tank2pump2-fault", 0);
|
||||
}
|
||||
}
|
||||
|
||||
###################
|
||||
# Update Function #
|
||||
###################
|
||||
|
||||
var update_fuel = func {
|
||||
master_fuel();
|
||||
}
|
||||
|
||||
var fuel_timer = maketimer(0.2, update_fuel);
|
||||
},
|
||||
};
|
||||
|
|
|
@ -5,10 +5,6 @@
|
|||
# Copyright (c) Joshua Davidson (it0uchpods) #
|
||||
##############################################
|
||||
|
||||
#############
|
||||
# Init Vars #
|
||||
#############
|
||||
|
||||
setlistener("/sim/signals/fdm-initialized", func {
|
||||
var eng1_pump_sw = getprop("/controls/hydraulic/eng1-pump");
|
||||
var eng2_pump_sw = getprop("/controls/hydraulic/eng2-pump");
|
||||
|
@ -51,7 +47,8 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var down = getprop("/controls/gear/gear-down");
|
||||
});
|
||||
|
||||
var hyd_init = func {
|
||||
var HYD = {
|
||||
init: func() {
|
||||
setprop("/controls/hydraulic/eng1-pump", 1);
|
||||
setprop("/controls/hydraulic/eng2-pump", 1);
|
||||
setprop("/controls/hydraulic/elec-pump-blue", 1);
|
||||
|
@ -73,7 +70,7 @@ var hyd_init = func {
|
|||
setprop("/systems/hydraulic/brakes/mode", 0);
|
||||
setprop("/systems/hydraulic/brakes/lbrake", 0);
|
||||
setprop("/systems/hydraulic/brakes/rbrake", 0);
|
||||
setprop("/systems/hydraulic/brakes/nose-rubber", 0); # This stops the nose from spinning when you raise the gear
|
||||
setprop("/systems/hydraulic/brakes/nose-rubber", 0);
|
||||
setprop("/systems/hydraulic/brakes/counter", 0);
|
||||
setprop("/systems/hydraulic/brakes/accumulator-pressure-psi-1", 0);
|
||||
setprop("/systems/hydraulic/eng1-pump-fault", 0);
|
||||
|
@ -81,14 +78,8 @@ var hyd_init = func {
|
|||
setprop("/systems/hydraulic/elec-pump-b-fault", 0);
|
||||
setprop("/systems/hydraulic/elec-pump-y-fault", 0);
|
||||
setprop("/systems/hydraulic/ptu-fault", 0);
|
||||
hyd_timer.start();
|
||||
}
|
||||
|
||||
#######################
|
||||
# Main Hydraulic Loop #
|
||||
#######################
|
||||
|
||||
var master_hyd = func {
|
||||
},
|
||||
loop: func() {
|
||||
eng1_pump_sw = getprop("/controls/hydraulic/eng1-pump");
|
||||
eng2_pump_sw = getprop("/controls/hydraulic/eng2-pump");
|
||||
elec_pump_blue_sw = getprop("/controls/hydraulic/elec-pump-blue");
|
||||
|
@ -134,19 +125,19 @@ var master_hyd = func {
|
|||
|
||||
if ((elec_pump_blue_sw and dc_ess >= 25 and !blue_pump_fail) and (stateL == 3 or stateR == 3) and !blue_leak) {
|
||||
if (blue_psi < 2900) {
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi + 100);
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/blue-psi", 3000);
|
||||
}
|
||||
} else if (gs >= 100 and rat and !blue_leak) {
|
||||
} else if (gs >= 50 and rat and !blue_leak) {
|
||||
if (blue_psi < 2400) {
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi + 100);
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/blue-psi", 2500);
|
||||
setprop("/systems/hydraulic/blue-psi", 2250);
|
||||
}
|
||||
} else {
|
||||
if (blue_psi > 1) {
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi - 50);
|
||||
setprop("/systems/hydraulic/blue-psi", blue_psi - 25);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/blue-psi", 0);
|
||||
}
|
||||
|
@ -154,19 +145,19 @@ var master_hyd = func {
|
|||
|
||||
if ((eng1_pump_sw and stateL == 3 and !green_pump_fail) and !green_leak) {
|
||||
if (green_psi < 2900) {
|
||||
setprop("/systems/hydraulic/green-psi", green_psi + 100);
|
||||
setprop("/systems/hydraulic/green-psi", green_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/green-psi", 3000);
|
||||
}
|
||||
} else if ((ptu_active and stateL != 3 and !ptu_fail) and !green_leak) {
|
||||
if (green_psi < 2900) {
|
||||
setprop("/systems/hydraulic/green-psi", green_psi + 100);
|
||||
setprop("/systems/hydraulic/green-psi", green_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/green-psi", 3000);
|
||||
}
|
||||
} else {
|
||||
if (green_psi > 1) {
|
||||
setprop("/systems/hydraulic/green-psi", green_psi - 50);
|
||||
setprop("/systems/hydraulic/green-psi", green_psi - 25);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/green-psi", 0);
|
||||
}
|
||||
|
@ -174,31 +165,31 @@ var master_hyd = func {
|
|||
|
||||
if ((eng2_pump_sw and stateR == 3 and !yellow_pump_eng_fail) and !yellow_leak) {
|
||||
if (yellow_psi < 2900) {
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 100);
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/yellow-psi", 3000);
|
||||
}
|
||||
} else if ((elec_pump_yellow_sw and dc_ess >= 25 and !yellow_pump_elec_fail) and !yellow_leak) {
|
||||
if (yellow_psi < 2900) {
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 100);
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/yellow-psi", 3000);
|
||||
}
|
||||
} else if ((ptu_active and stateR != 3 and !ptu_fail) and !yellow_leak) {
|
||||
if (yellow_psi < 2900) {
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 100);
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 50);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/yellow-psi", 3000);
|
||||
}
|
||||
} else if (yellow_hand_pump and !yellow_leak and (getprop("/gear/gear[0]/wow") or getprop("/gear/gear[1]/wow") or getprop("/gear/gear[2]/wow"))) {
|
||||
if (yellow_psi < 2900) {
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 50);
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi + 25);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/yellow-psi", 3000);
|
||||
}
|
||||
} else {
|
||||
if (yellow_psi > 1) {
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi - 50);
|
||||
setprop("/systems/hydraulic/yellow-psi", yellow_psi - 25);
|
||||
} else {
|
||||
setprop("/systems/hydraulic/yellow-psi", 0);
|
||||
}
|
||||
|
@ -260,11 +251,8 @@ var master_hyd = func {
|
|||
} else {
|
||||
setprop("/systems/hydraulic/elec-pump-y-fault", 0);
|
||||
}
|
||||
}
|
||||
|
||||
#######################
|
||||
# Various Other Stuff #
|
||||
#######################
|
||||
},
|
||||
};
|
||||
|
||||
setlistener("/controls/gear/gear-down", func {
|
||||
down = getprop("/controls/gear/gear-down");
|
||||
|
@ -272,22 +260,3 @@ setlistener("/controls/gear/gear-down", func {
|
|||
setprop("/controls/gear/gear-down", 1);
|
||||
}
|
||||
});
|
||||
|
||||
###################
|
||||
# Update Function #
|
||||
###################
|
||||
|
||||
var update_hydraulic = func {
|
||||
master_hyd();
|
||||
}
|
||||
|
||||
var hyd_timer = maketimer(0.2, update_hydraulic);
|
||||
|
||||
|
||||
# FIXME:
|
||||
# Josh, please disable braking when:
|
||||
# /systems/hydraulic/brakes/accumulator-pressure-psi is equal to 0 and when /systems/hydraulic/brakes/mode is equal to 2
|
||||
# Thanks!
|
||||
|
||||
# Will do -JD
|
||||
|
||||
|
|
|
@ -199,16 +199,16 @@ var triggerDoor = func(door, doorName, doorDesc) {
|
|||
|
||||
setlistener("/sim/signals/fdm-initialized", func {
|
||||
fbw.fctlInit();
|
||||
systems.elec_init();
|
||||
systems.adirs_init();
|
||||
systems.pneu_init();
|
||||
systems.hyd_init();
|
||||
systems.fuel_init();
|
||||
systems.fire_init();
|
||||
systems.ELEC.init();
|
||||
systems.PNEU.init();
|
||||
systems.HYD.init();
|
||||
systems.FUEL.init();
|
||||
systems.ADIRS.init();
|
||||
systems.eng_init();
|
||||
systems.fire_init();
|
||||
systems.autobrake_init();
|
||||
fmgc.APinit();
|
||||
librariesLoop.start();
|
||||
systemsLoop.start();
|
||||
fmgc.FMGCinit();
|
||||
mcdu1.MCDU_init();
|
||||
mcdu2.MCDU_init();
|
||||
|
@ -217,14 +217,19 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var autopilot = gui.Dialog.new("sim/gui/dialogs/autopilot/dialog", "Aircraft/IDG-A32X/Systems/autopilot-dlg.xml");
|
||||
setprop("/it-autoflight/input/fd1", 1);
|
||||
setprop("/it-autoflight/input/fd2", 1);
|
||||
setprop("/sim/model/lights/floor-light", 0);
|
||||
libraries.ECAMinit();
|
||||
libraries.variousReset();
|
||||
logoTimer.start();
|
||||
noseLoop.start();
|
||||
});
|
||||
|
||||
var librariesLoop = maketimer(0.1, func {
|
||||
var systemsLoop = maketimer(0.1, func {
|
||||
systems.ELEC.loop();
|
||||
systems.PNEU.loop();
|
||||
systems.HYD.loop();
|
||||
systems.FUEL.loop();
|
||||
systems.ADIRS.loop();
|
||||
|
||||
if ((getprop("/controls/pneumatic/switches/groundair") or getprop("/controls/switches/cart")) and ((getprop("/velocities/groundspeed-kt") > 2) or getprop("/controls/gear/brake-parking") == 0)) {
|
||||
setprop("/controls/switches/cart", 0);
|
||||
setprop("/controls/pneumatic/switches/groundair", 0);
|
||||
|
|
|
@ -5,10 +5,6 @@
|
|||
# Copyright (c) Joshua Davidson (it0uchpods) #
|
||||
##############################################
|
||||
|
||||
#############
|
||||
# Init Vars #
|
||||
#############
|
||||
|
||||
setlistener("/sim/signals/fdm-initialized", func {
|
||||
var altitude = getprop("/instrumentation/altimeter/indicated-altitude-ft");
|
||||
var bleed1_sw = getprop("/controls/pneumatic/switches/bleed1");
|
||||
|
@ -78,7 +74,8 @@ setlistener("/sim/signals/fdm-initialized", func {
|
|||
var guard = getprop("/controls/oxygen/masksGuard");
|
||||
});
|
||||
|
||||
var pneu_init = func {
|
||||
var PNEU = {
|
||||
init: func() {
|
||||
setprop("/controls/pneumatic/switches/bleed1", 1);
|
||||
setprop("/controls/pneumatic/switches/bleed2", 1);
|
||||
setprop("/controls/pneumatic/switches/bleedapu", 0);
|
||||
|
@ -142,14 +139,8 @@ var pneu_init = func {
|
|||
setprop("/controls/oxygen/masksDeployMan", 0);
|
||||
setprop("/controls/oxygen/masksReset", 0); # this is the TMR RESET pb on the maintenance panel, needs 3D model
|
||||
setprop("/controls/oxygen/masksSys", 0);
|
||||
pneu_timer.start();
|
||||
}
|
||||
|
||||
#######################
|
||||
# Main Pneumatic Loop #
|
||||
#######################
|
||||
|
||||
var master_pneu = func {
|
||||
},
|
||||
loop: func() {
|
||||
bleed1_sw = getprop("/controls/pneumatic/switches/bleed1");
|
||||
bleed2_sw = getprop("/controls/pneumatic/switches/bleed2");
|
||||
bleedapu_sw = getprop("/controls/pneumatic/switches/bleedapu");
|
||||
|
@ -380,7 +371,8 @@ var master_pneu = func {
|
|||
} else {
|
||||
setprop("/systems/pneumatic/pack2-fault", 0);
|
||||
}
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
setlistener("/controls/pneumatic/switches/pack1", func {
|
||||
pack1_sw = getprop("/controls/pneumatic/switches/pack1");
|
||||
|
@ -456,13 +448,3 @@ var flashfault2 = func {
|
|||
}
|
||||
});
|
||||
}
|
||||
|
||||
###################
|
||||
# Update Function #
|
||||
###################
|
||||
|
||||
var update_pneumatic = func {
|
||||
master_pneu();
|
||||
}
|
||||
|
||||
var pneu_timer = maketimer(0.2, update_pneumatic);
|
||||
|
|
Reference in a new issue