Merge branch 'dev' into 3D
This commit is contained in:
commit
9905cc803f
22 changed files with 501 additions and 447 deletions
|
@ -185,7 +185,8 @@
|
||||||
<roll-offset-deg archive="y">0</roll-offset-deg>
|
<roll-offset-deg archive="y">0</roll-offset-deg>
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
<view n="110">
|
<!-- Walker is 110 and 111 -->
|
||||||
|
<view n="112">
|
||||||
<name>Right Aft View</name>
|
<name>Right Aft View</name>
|
||||||
<type>lookfrom</type>
|
<type>lookfrom</type>
|
||||||
<internal archive="y">false</internal>
|
<internal archive="y">false</internal>
|
||||||
|
|
|
@ -185,7 +185,8 @@
|
||||||
<roll-offset-deg archive="y">0</roll-offset-deg>
|
<roll-offset-deg archive="y">0</roll-offset-deg>
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
<view n="110">
|
<!-- Walker is 110 and 111 -->
|
||||||
|
<view n="112">
|
||||||
<name>Right Aft View</name>
|
<name>Right Aft View</name>
|
||||||
<type>lookfrom</type>
|
<type>lookfrom</type>
|
||||||
<internal archive="y">false</internal>
|
<internal archive="y">false</internal>
|
||||||
|
@ -201,6 +202,15 @@
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
|
<systems n="0">
|
||||||
|
<autopilot n="0">
|
||||||
|
<path>Aircraft/A320-family/Systems/fadec-cfm.xml</path>
|
||||||
|
</autopilot>
|
||||||
|
<autopilot n="10">
|
||||||
|
<path>Aircraft/A320-family/Systems/cfm56-sound.xml</path>
|
||||||
|
</autopilot>
|
||||||
|
</systems>
|
||||||
|
|
||||||
</sim>
|
</sim>
|
||||||
|
|
||||||
<limits>
|
<limits>
|
||||||
|
|
|
@ -185,7 +185,8 @@
|
||||||
<roll-offset-deg archive="y">0</roll-offset-deg>
|
<roll-offset-deg archive="y">0</roll-offset-deg>
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
<view n="110">
|
<!-- Walker is 110 and 111 -->
|
||||||
|
<view n="112">
|
||||||
<name>Right Aft View</name>
|
<name>Right Aft View</name>
|
||||||
<type>lookfrom</type>
|
<type>lookfrom</type>
|
||||||
<internal archive="y">false</internal>
|
<internal archive="y">false</internal>
|
||||||
|
|
|
@ -4432,9 +4432,11 @@
|
||||||
<libraries>
|
<libraries>
|
||||||
<file>Aircraft/A320-family/Nasal/Libraries/libraries.nas</file>
|
<file>Aircraft/A320-family/Nasal/Libraries/libraries.nas</file>
|
||||||
<file>Aircraft/A320-family/Nasal/Libraries/buttons.nas</file>
|
<file>Aircraft/A320-family/Nasal/Libraries/buttons.nas</file>
|
||||||
<file>Aircraft/A320-family/Nasal/Libraries/shake.nas</file>
|
<file>Aircraft/A320-family/Nasal/Libraries/controls-override.nas</file>
|
||||||
<file>Aircraft/A320-family/Nasal/Libraries/zoom-views.nas</file>
|
|
||||||
<file>Aircraft/A320-family/Nasal/Libraries/custom-views.nas</file>
|
<file>Aircraft/A320-family/Nasal/Libraries/custom-views.nas</file>
|
||||||
|
<file>Aircraft/A320-family/Nasal/Libraries/shake.nas</file>
|
||||||
|
<file>Aircraft/A320-family/Nasal/Libraries/sounds.nas</file>
|
||||||
|
<file>Aircraft/A320-family/Nasal/Libraries/zoom-views.nas</file>
|
||||||
</libraries>
|
</libraries>
|
||||||
<acconfig>
|
<acconfig>
|
||||||
<file>Aircraft/A320-family/AircraftConfig/acconfig.nas</file>
|
<file>Aircraft/A320-family/AircraftConfig/acconfig.nas</file>
|
||||||
|
|
|
@ -185,7 +185,8 @@
|
||||||
<roll-offset-deg archive="y">0</roll-offset-deg>
|
<roll-offset-deg archive="y">0</roll-offset-deg>
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
<view n="110">
|
<!-- Walker is 110 and 111 -->
|
||||||
|
<view n="112">
|
||||||
<name>Right Aft View</name>
|
<name>Right Aft View</name>
|
||||||
<type>lookfrom</type>
|
<type>lookfrom</type>
|
||||||
<internal archive="y">false</internal>
|
<internal archive="y">false</internal>
|
||||||
|
|
|
@ -185,7 +185,8 @@
|
||||||
<roll-offset-deg archive="y">0</roll-offset-deg>
|
<roll-offset-deg archive="y">0</roll-offset-deg>
|
||||||
</config>
|
</config>
|
||||||
</view>
|
</view>
|
||||||
<view n="110">
|
<!-- Walker is 110 and 111 -->
|
||||||
|
<view n="112">
|
||||||
<name>Right Aft View</name>
|
<name>Right Aft View</name>
|
||||||
<type>lookfrom</type>
|
<type>lookfrom</type>
|
||||||
<internal archive="y">false</internal>
|
<internal archive="y">false</internal>
|
||||||
|
|
|
@ -124,16 +124,10 @@
|
||||||
<value>0</value>
|
<value>0</value>
|
||||||
</binding>
|
</binding>
|
||||||
<enable>
|
<enable>
|
||||||
<and>
|
<less-than>
|
||||||
<or>
|
<property>/velocities/groundspeed-kt</property>
|
||||||
<property>/controls/gear/brake-parking</property>
|
<value>2</value>
|
||||||
<property>/services/chocks/enable</property>
|
</less-than>
|
||||||
</or>
|
|
||||||
<less-than>
|
|
||||||
<property>/velocities/groundspeed-kt</property>
|
|
||||||
<value>2</value>
|
|
||||||
</less-than>
|
|
||||||
</and>
|
|
||||||
</enable>
|
</enable>
|
||||||
<binding>
|
<binding>
|
||||||
<command>dialog-apply</command>
|
<command>dialog-apply</command>
|
||||||
|
@ -150,50 +144,10 @@
|
||||||
<property>/controls/pneumatics/switches/groundair</property>
|
<property>/controls/pneumatics/switches/groundair</property>
|
||||||
</binding>
|
</binding>
|
||||||
<enable>
|
<enable>
|
||||||
<and>
|
<less-than>
|
||||||
<or>
|
<property>/velocities/groundspeed-kt</property>
|
||||||
<property>/controls/gear/brake-parking</property>
|
<value>2</value>
|
||||||
<property>/services/chocks/enable</property>
|
</less-than>
|
||||||
</or>
|
|
||||||
<less-than>
|
|
||||||
<property>/velocities/groundspeed-kt</property>
|
|
||||||
<value>2</value>
|
|
||||||
</less-than>
|
|
||||||
</and>
|
|
||||||
</enable>
|
|
||||||
<binding>
|
|
||||||
<command>dialog-apply</command>
|
|
||||||
</binding>
|
|
||||||
<live>true</live>
|
|
||||||
</checkbox>
|
|
||||||
|
|
||||||
<checkbox>
|
|
||||||
<label>Yellow HYD Hand Pump</label>
|
|
||||||
<halign>left</halign>
|
|
||||||
<property>/controls/hydraulic/hand-pump-yellow</property>
|
|
||||||
<binding>
|
|
||||||
<command>property-toggle</command>
|
|
||||||
<property>/controls/hydraulic/hand-pump-yellow</property>
|
|
||||||
</binding>
|
|
||||||
<enable>
|
|
||||||
<and>
|
|
||||||
<or>
|
|
||||||
<property>/controls/gear/brake-parking</property>
|
|
||||||
<property>/services/chocks/enable</property>
|
|
||||||
</or>
|
|
||||||
<less-than>
|
|
||||||
<property>/velocities/groundspeed-kt</property>
|
|
||||||
<value>2</value>
|
|
||||||
</less-than>
|
|
||||||
<less-than>
|
|
||||||
<property>/systems/electrical/bus/ac-2</property>
|
|
||||||
<value>115</value>
|
|
||||||
</less-than>
|
|
||||||
<equals>
|
|
||||||
<property>/controls/electrical/switches/ext-pwr</property>
|
|
||||||
<value>0</value>
|
|
||||||
</equals>
|
|
||||||
</and>
|
|
||||||
</enable>
|
</enable>
|
||||||
<binding>
|
<binding>
|
||||||
<command>dialog-apply</command>
|
<command>dialog-apply</command>
|
||||||
|
|
|
@ -74,6 +74,7 @@ var MAGENTA = [0.6902,0.3333,0.7541];
|
||||||
var mcdu_keyboard_left = props.globals.getNode("/FMGC/keyboard-left", 0);
|
var mcdu_keyboard_left = props.globals.getNode("/FMGC/keyboard-left", 0);
|
||||||
var mcdu_keyboard_right = props.globals.getNode("/FMGC/keyboard-right", 0);
|
var mcdu_keyboard_right = props.globals.getNode("/FMGC/keyboard-right", 0);
|
||||||
var acconfig_weight_kgs = props.globals.getNode("/systems/acconfig/options/weight-kgs", 1);
|
var acconfig_weight_kgs = props.globals.getNode("/systems/acconfig/options/weight-kgs", 1);
|
||||||
|
var engRdy = props.globals.getNode("/engines/ready");
|
||||||
|
|
||||||
#ACCONFIG
|
#ACCONFIG
|
||||||
var mcdu1_lgt = props.globals.getNode("/controls/lighting/DU/mcdu1", 1);
|
var mcdu1_lgt = props.globals.getNode("/controls/lighting/DU/mcdu1", 1);
|
||||||
|
@ -117,7 +118,6 @@ var align_set = props.globals.getNode("/FMGC/internal/align-set", 1);
|
||||||
# FUELPRED
|
# FUELPRED
|
||||||
var state1 = props.globals.getNode("/engines/engine[0]/state", 1);
|
var state1 = props.globals.getNode("/engines/engine[0]/state", 1);
|
||||||
var state2 = props.globals.getNode("/engines/engine[1]/state", 1);
|
var state2 = props.globals.getNode("/engines/engine[1]/state", 1);
|
||||||
var engrdy = props.globals.getNode("/engines/ready", 1);
|
|
||||||
|
|
||||||
# PERF
|
# PERF
|
||||||
var altitude = props.globals.getNode("/instrumentation/altimeter/indicated-altitude-ft", 1);
|
var altitude = props.globals.getNode("/instrumentation/altimeter/indicated-altitude-ft", 1);
|
||||||
|
@ -3011,12 +3011,12 @@ var canvas_MCDU_base = {
|
||||||
pageSwitch[i].setBoolValue(1);
|
pageSwitch[i].setBoolValue(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!engrdy.getBoolValue() or !fmgc.FMGCInternal.toFromSet) {
|
if (!engRdy.getBoolValue() or !fmgc.FMGCInternal.toFromSet) {
|
||||||
me["Simple_L1"].setText("NONE");
|
me["Simple_L1"].setText("NONE");
|
||||||
} else {
|
} else {
|
||||||
me["Simple_L1"].setText(fmgc.FMGCInternal.arrApt);
|
me["Simple_L1"].setText(fmgc.FMGCInternal.arrApt);
|
||||||
}
|
}
|
||||||
if (!engrdy.getBoolValue() or !fmgc.FMGCInternal.altAirportSet) {
|
if (!engRdy.getBoolValue() or !fmgc.FMGCInternal.altAirportSet) {
|
||||||
me["Simple_L2"].setText("NONE");
|
me["Simple_L2"].setText("NONE");
|
||||||
} else {
|
} else {
|
||||||
me["Simple_L2"].setText(fmgc.FMGCInternal.altAirport);
|
me["Simple_L2"].setText(fmgc.FMGCInternal.altAirport);
|
||||||
|
|
|
@ -58,7 +58,7 @@ var FCU = {
|
||||||
var FCUController = {
|
var FCUController = {
|
||||||
FCU1: nil,
|
FCU1: nil,
|
||||||
FCU2: nil,
|
FCU2: nil,
|
||||||
activeFMGC: props.globals.getNode("FMGC/active-fmgc-channel"),
|
activeFMGC: props.globals.getNode("/FMGC/active-fmgc-channel"),
|
||||||
FCUworking: 0,
|
FCUworking: 0,
|
||||||
_init: 0,
|
_init: 0,
|
||||||
init: func() {
|
init: func() {
|
||||||
|
@ -81,9 +81,8 @@ var FCUController = {
|
||||||
FCUworkingNode.setValue(0);
|
FCUworkingNode.setValue(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
notification = nil;
|
|
||||||
foreach (var update_item; me.update_items) {
|
foreach (var update_item; me.update_items) {
|
||||||
update_item.update(notification);
|
update_item.update(nil);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
update_items: [
|
update_items: [
|
||||||
|
@ -99,8 +98,8 @@ var FCUController = {
|
||||||
me.FCU2.restore();
|
me.FCU2.restore();
|
||||||
},
|
},
|
||||||
AP1: func() {
|
AP1: func() {
|
||||||
if (me.FCUworking and fbw.FBW.activeLaw.getValue() == 0) {
|
if (me.FCUworking) {
|
||||||
if (!ap1.getBoolValue()) {
|
if (!ap1.getBoolValue() and fbw.FBW.apOff == 0) {
|
||||||
ap1Input.setValue(1);
|
ap1Input.setValue(1);
|
||||||
ecam.apWarnNode.setValue(0);
|
ecam.apWarnNode.setValue(0);
|
||||||
pts.Controls.Flight.rudderTrim.setValue(0);
|
pts.Controls.Flight.rudderTrim.setValue(0);
|
||||||
|
@ -110,9 +109,10 @@ var FCUController = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
AP2: func() {
|
AP2: func() {
|
||||||
if (me.FCUworking and fbw.FBW.activeLaw.getValue() == 0) {
|
if (me.FCUworking) {
|
||||||
if (!ap2.getBoolValue()) {
|
if (!ap2.getBoolValue() and fbw.FBW.apOff == 0) {
|
||||||
ap2Input.setValue(1);
|
ap2Input.setValue(1);
|
||||||
|
ecam.apWarnNode.setValue(0);
|
||||||
pts.Controls.Flight.rudderTrim.setValue(0);
|
pts.Controls.Flight.rudderTrim.setValue(0);
|
||||||
} else {
|
} else {
|
||||||
apOff("hard", 2);
|
apOff("hard", 2);
|
||||||
|
@ -120,8 +120,8 @@ var FCUController = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
ATHR: func() {
|
ATHR: func() {
|
||||||
if (me.FCUworking and !pts.FMGC.CasCompare.casRejectAll.getBoolValue() and fbw.FBW.activeLaw.getValue() == 0) {
|
if (me.FCUworking) {
|
||||||
if (!athr.getBoolValue()) {
|
if (!athr.getBoolValue() and !pts.FMGC.CasCompare.casRejectAll.getBoolValue() and fbw.FBW.apOff == 0) {
|
||||||
athrInput.setValue(1);
|
athrInput.setValue(1);
|
||||||
} else {
|
} else {
|
||||||
athrOff("hard");
|
athrOff("hard");
|
||||||
|
|
|
@ -441,7 +441,7 @@ var ITAF = {
|
||||||
},
|
},
|
||||||
ap1Master: func(s) {
|
ap1Master: func(s) {
|
||||||
if (s == 1) {
|
if (s == 1) {
|
||||||
if (Output.vert.getValue() != 6 and !Gear.wow1.getBoolValue() and !Gear.wow2.getBoolValue() and systems.ELEC.Bus.acEss.getValue() >= 110 and Misc.fbwLaw.getValue() == 0 and Position.gearAglFt.getValue() >= 100) {
|
if (Output.vert.getValue() != 6 and !Gear.wow1.getBoolValue() and !Gear.wow2.getBoolValue() and systems.ELEC.Bus.acEss.getValue() >= 110 and fbw.FBW.apOff == 0 and Position.gearAglFt.getValue() >= 100) {
|
||||||
me.revertBasicMode();
|
me.revertBasicMode();
|
||||||
Output.ap1.setBoolValue(1);
|
Output.ap1.setBoolValue(1);
|
||||||
Output.latTemp = Output.lat.getValue();
|
Output.latTemp = Output.lat.getValue();
|
||||||
|
@ -462,7 +462,7 @@ var ITAF = {
|
||||||
},
|
},
|
||||||
ap2Master: func(s) {
|
ap2Master: func(s) {
|
||||||
if (s == 1) {
|
if (s == 1) {
|
||||||
if (Output.vert.getValue() != 6 and !Gear.wow1.getBoolValue() and !Gear.wow2.getBoolValue() and systems.ELEC.Bus.acEss.getValue() >= 110 and Misc.fbwLaw.getValue() == 0 and Position.gearAglFt.getValue() >= 100) {
|
if (Output.vert.getValue() != 6 and !Gear.wow1.getBoolValue() and !Gear.wow2.getBoolValue() and systems.ELEC.Bus.acEss.getValue() >= 110 and fbw.FBW.apOff == 0 and Position.gearAglFt.getValue() >= 100) {
|
||||||
me.revertBasicMode();
|
me.revertBasicMode();
|
||||||
Output.ap2.setBoolValue(1);
|
Output.ap2.setBoolValue(1);
|
||||||
Output.latTemp = Output.lat.getValue();
|
Output.latTemp = Output.lat.getValue();
|
||||||
|
@ -492,7 +492,7 @@ var ITAF = {
|
||||||
},
|
},
|
||||||
athrMaster: func(s) {
|
athrMaster: func(s) {
|
||||||
if (s == 1) {
|
if (s == 1) {
|
||||||
if (systems.ELEC.Bus.acEss.getValue() >= 110) {
|
if (systems.ELEC.Bus.acEss.getValue() >= 110 and !pts.FMGC.CasCompare.casRejectAll.getBoolValue() and fbw.FBW.apOff == 0) {
|
||||||
Output.athr.setBoolValue(1);
|
Output.athr.setBoolValue(1);
|
||||||
Custom.ThrLock.setValue(0);
|
Custom.ThrLock.setValue(0);
|
||||||
Custom.Sound.enableAthrOff = 1;
|
Custom.Sound.enableAthrOff = 1;
|
||||||
|
|
|
@ -62,6 +62,7 @@ var altsel = 0;
|
||||||
var crzFl = 0;
|
var crzFl = 0;
|
||||||
var windHdg = 0;
|
var windHdg = 0;
|
||||||
var windSpeed = 0;
|
var windSpeed = 0;
|
||||||
|
var windsDidChange = 0;
|
||||||
setprop("position/gear-agl-ft", 0);
|
setprop("position/gear-agl-ft", 0);
|
||||||
setprop("/it-autoflight/settings/accel-agl-ft", 1500); #eventually set to 1500 above runway
|
setprop("/it-autoflight/settings/accel-agl-ft", 1500); #eventually set to 1500 above runway
|
||||||
setprop("/it-autoflight/internal/vert-speed-fpm", 0);
|
setprop("/it-autoflight/internal/vert-speed-fpm", 0);
|
||||||
|
@ -681,7 +682,7 @@ var masterFMGC = maketimer(0.2, func {
|
||||||
windHdg = pts.Environment.windFromHdg.getValue();
|
windHdg = pts.Environment.windFromHdg.getValue();
|
||||||
windSpeed = pts.Environment.windSpeedKt.getValue();
|
windSpeed = pts.Environment.windSpeedKt.getValue();
|
||||||
if (FMGCInternal.phase == 3 or FMGCInternal.phase == 4 or FMGCInternal.phase == 6) {
|
if (FMGCInternal.phase == 3 or FMGCInternal.phase == 4 or FMGCInternal.phase == 6) {
|
||||||
var windsDidChange = 0;
|
windsDidChange = 0;
|
||||||
if (FMGCInternal.crzFt > 5000 and alt > 4980 and alt < 5020) {
|
if (FMGCInternal.crzFt > 5000 and alt > 4980 and alt < 5020) {
|
||||||
if (sprintf("%03d", windHdg) != fmgc.windController.fl50_wind[0] or sprintf("%03d", windSpeed) != fmgc.windController.fl50_wind[1]) {
|
if (sprintf("%03d", windHdg) != fmgc.windController.fl50_wind[0] or sprintf("%03d", windSpeed) != fmgc.windController.fl50_wind[1]) {
|
||||||
fmgc.windController.fl50_wind[0] = sprintf("%03d", windHdg);
|
fmgc.windController.fl50_wind[0] = sprintf("%03d", windHdg);
|
||||||
|
@ -1018,9 +1019,7 @@ var ManagedSPD = maketimer(0.25, func {
|
||||||
|
|
||||||
if (mach > mng_alt_mach and (FMGCInternal.phase == 2 or FMGCInternal.phase == 3)) {
|
if (mach > mng_alt_mach and (FMGCInternal.phase == 2 or FMGCInternal.phase == 3)) {
|
||||||
FMGCInternal.machSwitchover = 1;
|
FMGCInternal.machSwitchover = 1;
|
||||||
}
|
} elsif (ias > mng_alt_spd and (FMGCInternal.phase == 4 or FMGCInternal.phase == 5)) {
|
||||||
|
|
||||||
if (ias > mng_alt_spd and (FMGCInternal.phase == 4 or FMGCInternal.phase == 5)) {
|
|
||||||
FMGCInternal.machSwitchover = 0;
|
FMGCInternal.machSwitchover = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,8 +3,6 @@
|
||||||
|
|
||||||
# Copyright (c) 2020 Josh Davidson (Octal450)
|
# Copyright (c) 2020 Josh Davidson (Octal450)
|
||||||
|
|
||||||
var wow = nil;
|
|
||||||
var wowr = nil;
|
|
||||||
var OnLt = props.globals.getNode("/controls/switches/emerCallLtO");
|
var OnLt = props.globals.getNode("/controls/switches/emerCallLtO");
|
||||||
var CallLt = props.globals.getNode("/controls/switches/emerCallLtC");
|
var CallLt = props.globals.getNode("/controls/switches/emerCallLtC");
|
||||||
var EmerCall = props.globals.getNode("/controls/switches/emerCall");
|
var EmerCall = props.globals.getNode("/controls/switches/emerCall");
|
||||||
|
@ -13,7 +11,7 @@ var MechCall = props.globals.getNode("/controls/switches/mechCall");
|
||||||
var cvr_tone = props.globals.getNode("/controls/CVR/tone");
|
var cvr_tone = props.globals.getNode("/controls/CVR/tone");
|
||||||
|
|
||||||
# Resets buttons to the default values
|
# Resets buttons to the default values
|
||||||
var variousReset = func {
|
var variousReset = func() {
|
||||||
setprop("/modes/cpt-du-xfr", 0);
|
setprop("/modes/cpt-du-xfr", 0);
|
||||||
setprop("/modes/fo-du-xfr", 0);
|
setprop("/modes/fo-du-xfr", 0);
|
||||||
setprop("/controls/fadec/n1mode1", 0);
|
setprop("/controls/fadec/n1mode1", 0);
|
||||||
|
@ -64,72 +62,89 @@ var variousReset = func {
|
||||||
setprop("/modes/fcu/hdg-time", -45);
|
setprop("/modes/fcu/hdg-time", -45);
|
||||||
setprop("/controls/navigation/switching/att-hdg", 0);
|
setprop("/controls/navigation/switching/att-hdg", 0);
|
||||||
setprop("/controls/navigation/switching/air-data", 0);
|
setprop("/controls/navigation/switching/air-data", 0);
|
||||||
setprop("/controls/switches/no-smoking-sign", 1);
|
setprop("/controls/switches/no-smoking-sign", 0.5);
|
||||||
setprop("/controls/switches/seatbelt-sign", 1);
|
setprop("/controls/switches/seatbelt-sign", 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
var BUTTONS = {
|
var BUTTONS = {
|
||||||
|
storeEmerCall: 0,
|
||||||
update: func() {
|
update: func() {
|
||||||
if (EmerCall.getValue()) {
|
me.storeEmerCall = EmerCall.getValue();
|
||||||
EmerCallOnLight();
|
if (me.storeEmerCall) {
|
||||||
EmerCallLight();
|
EmerCallOnLight(me.storeEmerCall);
|
||||||
|
EmerCallLight(me.storeEmerCall);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
var _OnLt = nil;
|
var _OnLt = nil;
|
||||||
var _EmerCall = nil;
|
var EmerCallOnLight = func(emerCallSts) {
|
||||||
|
|
||||||
var EmerCallOnLight = func() {
|
|
||||||
_OnLt = OnLt.getValue();
|
_OnLt = OnLt.getValue();
|
||||||
_EmerCall = EmerCall.getValue();
|
if ((_OnLt and emerCallSts) or !emerCallSts) {
|
||||||
if ((_OnLt and _EmerCall) or !_EmerCall) {
|
|
||||||
OnLt.setValue(0);
|
OnLt.setValue(0);
|
||||||
} else if (!_OnLt and _EmerCall) {
|
} else if (!_OnLt and emerCallSts) {
|
||||||
OnLt.setValue(1);
|
OnLt.setValue(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var _CallLt = nil;
|
var _CallLt = nil;
|
||||||
var _EmerCall2 = nil;
|
var EmerCallLight = func(emerCallSts) {
|
||||||
|
|
||||||
var EmerCallLight = func() {
|
|
||||||
_CallLt = CallLt.getValue();
|
_CallLt = CallLt.getValue();
|
||||||
_EmerCall2 = EmerCall.getValue();
|
_EmerCall2 = emerCallSts;
|
||||||
if ((_CallLt and _EmerCall2) or !_EmerCall2) {
|
if ((_CallLt and emerCallSts) or !emerCallSts) {
|
||||||
CallLt.setValue(0);
|
CallLt.setValue(0);
|
||||||
} else if (!_CallLt and _EmerCall2) {
|
} else if (!_CallLt and emerCallSts) {
|
||||||
CallLt.setValue(1);
|
CallLt.setValue(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var EmerCallFunc = func {
|
var _EmerCallRunning = 0;
|
||||||
EmerCall.setValue(1);
|
var EmerCallFunc = func() {
|
||||||
settimer(func() {
|
if (!_EmerCallRunning) {
|
||||||
EmerCall.setValue(0);
|
_EmerCallRunning = 1;
|
||||||
}, 10);
|
EmerCall.setValue(1);
|
||||||
}
|
|
||||||
|
|
||||||
var CabinCallFunc = func {
|
|
||||||
CabinCall.setValue(1);
|
|
||||||
settimer(func() {
|
|
||||||
CabinCall.setValue(0);
|
|
||||||
}, 15);
|
|
||||||
}
|
|
||||||
|
|
||||||
var MechCallFunc = func {
|
|
||||||
MechCall.setValue(1);
|
|
||||||
settimer(func() {
|
|
||||||
MechCall.setValue(0);
|
|
||||||
}, 15);
|
|
||||||
}
|
|
||||||
|
|
||||||
var CVR_test = func {
|
|
||||||
if (pts.Controls.Gear.parkingBrake.getValue()) {
|
|
||||||
cvr_tone.setValue(1);
|
|
||||||
settimer(func() {
|
settimer(func() {
|
||||||
cvr_tone.setValue(0);
|
EmerCall.setValue(0);
|
||||||
}, 15);
|
_EmerCallRunning = 0;
|
||||||
|
}, 7);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _CabinCallRunning = 0;
|
||||||
|
var CabinCallFunc = func() {
|
||||||
|
if (!_CabinCallRunning) {
|
||||||
|
_CabinCallRunning = 1;
|
||||||
|
CabinCall.setValue(1);
|
||||||
|
settimer(func() {
|
||||||
|
CabinCall.setValue(0);
|
||||||
|
_CabinCallRunning = 0;
|
||||||
|
}, 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _MechCallRunning = 0;
|
||||||
|
var MechCallFunc = func() {
|
||||||
|
if (!_MechCallRunning) {
|
||||||
|
_MechCallRunning = 1;
|
||||||
|
MechCall.setValue(1);
|
||||||
|
settimer(func() {
|
||||||
|
MechCall.setValue(0);
|
||||||
|
_MechCallRunning = 0;
|
||||||
|
}, 6);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _CVRtestRunning = 0;
|
||||||
|
var CVR_test = func() {
|
||||||
|
if (pts.Controls.Gear.parkingBrake.getValue()) {
|
||||||
|
if (!_CVRtestRunning) {
|
||||||
|
_CVRtestRunning = 1;
|
||||||
|
cvr_tone.setValue(1);
|
||||||
|
settimer(func() {
|
||||||
|
_CVRtestRunning = 0;
|
||||||
|
cvr_tone.setValue(0);
|
||||||
|
}, 15);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,7 +155,7 @@ setlistener("/controls/apu/master", func() { # poor mans set-reset latch
|
||||||
}
|
}
|
||||||
}, 0, 0);
|
}, 0, 0);
|
||||||
|
|
||||||
var toggleSTD = func {
|
var toggleSTD = func() {
|
||||||
if (pts.Instrumentation.Altimeter.std.getBoolValue()) {
|
if (pts.Instrumentation.Altimeter.std.getBoolValue()) {
|
||||||
pts.Instrumentation.Altimeter.settingInhg.setValue(pts.Instrumentation.Altimeter.oldQnh.getValue());
|
pts.Instrumentation.Altimeter.settingInhg.setValue(pts.Instrumentation.Altimeter.oldQnh.getValue());
|
||||||
pts.Instrumentation.Altimeter.std.setBoolValue(0);
|
pts.Instrumentation.Altimeter.std.setBoolValue(0);
|
||||||
|
@ -150,9 +165,3 @@ var toggleSTD = func {
|
||||||
pts.Instrumentation.Altimeter.std.setBoolValue(1);
|
pts.Instrumentation.Altimeter.std.setBoolValue(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var pushbuttonSound = props.globals.getNode("/sim/sounde/pushbutton");
|
|
||||||
var pushbutton = func {
|
|
||||||
pushbuttonSound.setValue(1);
|
|
||||||
settimer(func {pushbuttonSound.setValue(0);},0.20);
|
|
||||||
}
|
|
110
Nasal/Libraries/controls-override.nas
Normal file
110
Nasal/Libraries/controls-override.nas
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
# A320 Main Libraries
|
||||||
|
# Joshua Davidson (Octal450)
|
||||||
|
|
||||||
|
# Copyright (c) 2020 Josh Davidson (Octal450)
|
||||||
|
|
||||||
|
############
|
||||||
|
# Controls #
|
||||||
|
############
|
||||||
|
|
||||||
|
controls.stepSpoilers = func(step) {
|
||||||
|
pts.Controls.Flight.speedbrakeArm.setValue(0);
|
||||||
|
if (step == 1) {
|
||||||
|
deploySpeedbrake();
|
||||||
|
} else if (step == -1) {
|
||||||
|
retractSpeedbrake();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var deploySpeedbrake = func() {
|
||||||
|
if (pts.Gear.wow[1].getBoolValue() or pts.Gear.wow[2].getBoolValue()) {
|
||||||
|
if (pts.Controls.Flight.speedbrake.getValue() < 1.0) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(1.0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (pts.Controls.Flight.speedbrake.getValue() < 0.5) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(0.5);
|
||||||
|
} else if (pts.Controls.Flight.speedbrake.getValue() < 1.0) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(1.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var retractSpeedbrake = func() {
|
||||||
|
if (pts.Gear.wow[1].getBoolValue() or pts.Gear.wow[2].getBoolValue()) {
|
||||||
|
if (pts.Controls.Flight.speedbrake.getValue() > 0.0) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(0.0);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (pts.Controls.Flight.speedbrake.getValue() > 0.5) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(0.5);
|
||||||
|
} else if (pts.Controls.Flight.speedbrake.getValue() > 0.0) {
|
||||||
|
pts.Controls.Flight.speedbrake.setValue(0.0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var delta = 0;
|
||||||
|
var output = 0;
|
||||||
|
var slewProp = func(prop, delta) {
|
||||||
|
delta *= pts.Sim.Time.deltaRealtimeSec.getValue();
|
||||||
|
output = props.globals.getNode(prop).getValue() + delta;
|
||||||
|
props.globals.getNode(prop).setValue(output);
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
|
controls.flapsDown = func(step) {
|
||||||
|
pts.Controls.Flight.flapsTemp = pts.Controls.Flight.flaps.getValue();
|
||||||
|
if (step == 1) {
|
||||||
|
if (pts.Controls.Flight.flapsTemp < 0.2) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.2);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp < 0.4) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.4);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp < 0.6) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.6);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp < 0.8) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.8);
|
||||||
|
}
|
||||||
|
} else if (step == -1) {
|
||||||
|
if (pts.Controls.Flight.flapsTemp > 0.6) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.6);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp > 0.4) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.4);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp > 0.2) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0.2);
|
||||||
|
} else if (pts.Controls.Flight.flapsTemp > 0) {
|
||||||
|
pts.Controls.Flight.flaps.setValue(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
controls.elevatorTrim = func(d) {
|
||||||
|
if (systems.HYD.Psi.green.getValue() >= 1500) {
|
||||||
|
slewProp("/controls/flight/elevator-trim", d * 0.0185); # Rate in JSB normalized (0.125 / 13.5)
|
||||||
|
} else {
|
||||||
|
slewProp("/controls/flight/elevator-trim", d * 0.0092) # Rate in JSB normalized (0.125 / 13.5)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
setlistener("/controls/flight/elevator-trim", func() {
|
||||||
|
if (pts.Controls.Flight.elevatorTrim.getValue() > 0.296296) {
|
||||||
|
pts.Controls.Flight.elevatorTrim.setValue(0.296296);
|
||||||
|
}
|
||||||
|
}, 0, 0);
|
||||||
|
|
||||||
|
# For the cockpit rotation and anywhere else you want to use it
|
||||||
|
var cmdDegCalc = 0;
|
||||||
|
var slewPitchWheel = func(d) {
|
||||||
|
cmdDegCalc = math.round(pts.Fdm.JSBsim.Hydraulics.ElevatorTrim.cmdDeg.getValue(), 0.1);
|
||||||
|
if (d > 0) { # DN
|
||||||
|
if (cmdDegCalc < 4) {
|
||||||
|
cmdDegCalc = (cmdDegCalc + 0.1) / 13.5; # Add and normalize, NOT 4! 13.5 = 1 on either polarity
|
||||||
|
pts.Controls.Flight.elevatorTrim.setValue(cmdDegCalc);
|
||||||
|
}
|
||||||
|
} else { # UP
|
||||||
|
if (cmdDegCalc > -13.5) {
|
||||||
|
cmdDegCalc = (cmdDegCalc - 0.1) / 13.5; # Subtract and normalize
|
||||||
|
pts.Controls.Flight.elevatorTrim.setValue(cmdDegCalc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,7 +8,7 @@ var viewNumberRaw = 0;
|
||||||
var shakeFlag = 0;
|
var shakeFlag = 0;
|
||||||
var resetView = func() {
|
var resetView = func() {
|
||||||
viewNumberRaw = pts.Sim.CurrentView.viewNumberRaw.getValue();
|
viewNumberRaw = pts.Sim.CurrentView.viewNumberRaw.getValue();
|
||||||
if (viewNumberRaw == 0 or (viewNumberRaw >= 100 and viewNumberRaw <= 110)) {
|
if (viewNumberRaw == 0 or (viewNumberRaw >= 100 and viewNumberRaw <= 109) or viewNumberRaw == 112) {
|
||||||
if (pts.Sim.Rendering.Headshake.enabled.getBoolValue()) {
|
if (pts.Sim.Rendering.Headshake.enabled.getBoolValue()) {
|
||||||
shakeFlag = 1;
|
shakeFlag = 1;
|
||||||
pts.Sim.Rendering.Headshake.enabled.setBoolValue(0);
|
pts.Sim.Rendering.Headshake.enabled.setBoolValue(0);
|
||||||
|
|
|
@ -7,6 +7,7 @@ print("------------------------------------------------");
|
||||||
print("Copyright (c) 2016-2020 Josh Davidson (Octal450)");
|
print("Copyright (c) 2016-2020 Josh Davidson (Octal450)");
|
||||||
print("------------------------------------------------");
|
print("------------------------------------------------");
|
||||||
|
|
||||||
|
# Disable specific menubar items
|
||||||
setprop("/sim/menubar/default/menu[0]/item[0]/enabled", 0);
|
setprop("/sim/menubar/default/menu[0]/item[0]/enabled", 0);
|
||||||
setprop("/sim/menubar/default/menu[2]/item[0]/enabled", 0);
|
setprop("/sim/menubar/default/menu[2]/item[0]/enabled", 0);
|
||||||
setprop("/sim/menubar/default/menu[2]/item[2]/enabled", 0);
|
setprop("/sim/menubar/default/menu[2]/item[2]/enabled", 0);
|
||||||
|
@ -28,9 +29,6 @@ var beacon = aircraft.light.new("/sim/model/lights/beacon", [0.1, 1], "/controls
|
||||||
var strobe = aircraft.light.new("/sim/model/lights/strobe", [0.05, 0.06, 0.05, 1], "/controls/lighting/strobe");
|
var strobe = aircraft.light.new("/sim/model/lights/strobe", [0.05, 0.06, 0.05, 1], "/controls/lighting/strobe");
|
||||||
var tail_strobe = aircraft.light.new("/sim/model/lights/tailstrobe", [0.1, 1], "/controls/lighting/strobe");
|
var tail_strobe = aircraft.light.new("/sim/model/lights/tailstrobe", [0.1, 1], "/controls/lighting/strobe");
|
||||||
|
|
||||||
var stateL = 0;
|
|
||||||
var stateR = 0;
|
|
||||||
|
|
||||||
###########
|
###########
|
||||||
# Effects #
|
# Effects #
|
||||||
###########
|
###########
|
||||||
|
@ -40,121 +38,6 @@ aircraft.rain.init();
|
||||||
|
|
||||||
aircraft.livery.init(getprop("/sim/model/livery-dir"));
|
aircraft.livery.init(getprop("/sim/model/livery-dir"));
|
||||||
|
|
||||||
##########
|
|
||||||
# Sounds #
|
|
||||||
##########
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/btn1", func {
|
|
||||||
if (!getprop("/sim/sounde/btn1")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/btn1").setBoolValue(0);
|
|
||||||
}, 0.05);
|
|
||||||
});
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/oh-btn", func {
|
|
||||||
if (!getprop("/sim/sounde/oh-btn")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/oh-btn").setBoolValue(0);
|
|
||||||
}, 0.05);
|
|
||||||
});
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/btn3", func {
|
|
||||||
if (!getprop("/sim/sounde/btn3")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/btn3").setBoolValue(0);
|
|
||||||
}, 0.05);
|
|
||||||
});
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/knb1", func {
|
|
||||||
if (!getprop("/sim/sounde/knb1")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/knb1").setBoolValue(0);
|
|
||||||
}, 0.05);
|
|
||||||
});
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/switch1", func {
|
|
||||||
if (!getprop("/sim/sounde/switch1")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/switch1").setBoolValue(0);
|
|
||||||
}, 0.05);
|
|
||||||
});
|
|
||||||
|
|
||||||
setlistener("/controls/lighting/seatbelt-sign", func {
|
|
||||||
props.globals.getNode("/sim/sounde/seatbelt-sign").setBoolValue(1);
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/seatbelt-sign").setBoolValue(0);
|
|
||||||
}, 2);
|
|
||||||
}, 0, 0);
|
|
||||||
|
|
||||||
setlistener("/controls/lighting/no-smoking-sign", func {
|
|
||||||
props.globals.getNode("/sim/sounde/no-smoking-sign").setBoolValue(1);
|
|
||||||
settimer(func {
|
|
||||||
props.globals.getNode("/sim/sounde/no-smoking-sign").setBoolValue(0);
|
|
||||||
}, 1);
|
|
||||||
}, 0, 0);
|
|
||||||
|
|
||||||
var flaps_click = props.globals.getNode("/sim/sounde/flaps-click");
|
|
||||||
|
|
||||||
setlistener("/controls/flight/flaps-input", func {
|
|
||||||
flaps_click.setBoolValue(1);
|
|
||||||
}, 0, 0);
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/flaps-click", func {
|
|
||||||
if (!flaps_click.getValue()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
flaps_click.setBoolValue(0);
|
|
||||||
}, 0.4);
|
|
||||||
});
|
|
||||||
|
|
||||||
var spdbrk_click = props.globals.getNode("/sim/sounde/spdbrk-click");
|
|
||||||
|
|
||||||
setlistener("/controls/flight/speedbrake", func {
|
|
||||||
spdbrk_click.setBoolValue(1);
|
|
||||||
}, 0, 0);
|
|
||||||
|
|
||||||
setlistener("/sim/sounde/spdbrk-click", func {
|
|
||||||
if (!spdbrk_click.getValue()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
settimer(func {
|
|
||||||
spdbrk_click.setBoolValue(0);
|
|
||||||
}, 0.4);
|
|
||||||
});
|
|
||||||
|
|
||||||
var relayBatt1 = func {
|
|
||||||
setprop("/sim/sounde/relay-batt-1",1);
|
|
||||||
settimer(func {setprop("/sim/sounde/relay-batt-1",0);},0.35);
|
|
||||||
}
|
|
||||||
var relayBatt2 = func {
|
|
||||||
setprop("/sim/sounde/relay-batt-2",1);
|
|
||||||
settimer(func {setprop("/sim/sounde/relay-batt-2",0);},0.35);
|
|
||||||
}
|
|
||||||
var relayApu = func {
|
|
||||||
setprop("/sim/sounde/relay-apu",1);
|
|
||||||
settimer(func {setprop("/sim/sounde/relay-apu",0);},0.35);
|
|
||||||
}
|
|
||||||
var relayExt = func {
|
|
||||||
setprop("/sim/sounde/relay-ext",1);
|
|
||||||
settimer(func {setprop("/sim/sounde/relay-ext",0);},0.35);
|
|
||||||
}
|
|
||||||
|
|
||||||
setlistener("/systems/electrical/sources/bat-1/contact", relayBatt1, nil, 0);
|
|
||||||
setlistener("/systems/electrical/sources/bat-2/contact", relayBatt2, nil, 0);
|
|
||||||
setlistener("/systems/electrical/relay/apu-glc/contact-pos", relayApu, nil, 0);
|
|
||||||
setlistener("/systems/electrical/relay/ext-epc/contact-pos", relayExt, nil, 0);
|
|
||||||
|
|
||||||
#########
|
#########
|
||||||
# Doors #
|
# Doors #
|
||||||
#########
|
#########
|
||||||
|
@ -195,7 +78,11 @@ var triggerDoor = func(door, doorName, doorDesc) {
|
||||||
###########
|
###########
|
||||||
# Systems #
|
# Systems #
|
||||||
###########
|
###########
|
||||||
var systemsInit = func {
|
var systemsInitialized = 0;
|
||||||
|
var A320Libraries = nil;
|
||||||
|
|
||||||
|
var systemsInit = func() {
|
||||||
|
systemsInitialized = 0;
|
||||||
fbw.FBW.init();
|
fbw.FBW.init();
|
||||||
effects.light_manager.init();
|
effects.light_manager.init();
|
||||||
systems.ELEC.init();
|
systems.ELEC.init();
|
||||||
|
@ -217,9 +104,7 @@ var systemsInit = func {
|
||||||
mcdu.MCDU_init(1);
|
mcdu.MCDU_init(1);
|
||||||
mcdu_scratchpad.mcduMsgtimer1.start();
|
mcdu_scratchpad.mcduMsgtimer1.start();
|
||||||
mcdu_scratchpad.mcduMsgtimer2.start();
|
mcdu_scratchpad.mcduMsgtimer2.start();
|
||||||
systemsLoop.start();
|
|
||||||
effects.icingInit();
|
effects.icingInit();
|
||||||
lightsLoop.start();
|
|
||||||
ecam.ECAM.init();
|
ecam.ECAM.init();
|
||||||
libraries.variousReset();
|
libraries.variousReset();
|
||||||
rmp.init();
|
rmp.init();
|
||||||
|
@ -231,13 +116,17 @@ var systemsInit = func {
|
||||||
fmgc.flightPlanController.init();
|
fmgc.flightPlanController.init();
|
||||||
fmgc.windController.init();
|
fmgc.windController.init();
|
||||||
atsu.CompanyCall.init();
|
atsu.CompanyCall.init();
|
||||||
|
systemsInitialized = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
setlistener("/sim/signals/fdm-initialized", func {
|
setlistener("/sim/signals/fdm-initialized", func() {
|
||||||
systemsInit();
|
systemsInit();
|
||||||
fmgc.postInit();
|
fmgc.postInit();
|
||||||
fmgc.flightPlanTimer.start();
|
fmgc.flightPlanTimer.start();
|
||||||
fmgc.WaypointDatabase.read();
|
fmgc.WaypointDatabase.read();
|
||||||
|
|
||||||
|
A320Libraries = LibrariesRecipient.new("A320 Libraries");
|
||||||
|
emesary.GlobalTransmitter.Register(A320Libraries);
|
||||||
});
|
});
|
||||||
|
|
||||||
var collectorTankL = props.globals.getNode("/fdm/jsbsim/propulsion/tank[5]/contents-lbs");
|
var collectorTankL = props.globals.getNode("/fdm/jsbsim/propulsion/tank[5]/contents-lbs");
|
||||||
|
@ -245,10 +134,42 @@ var collectorTankR = props.globals.getNode("/fdm/jsbsim/propulsion/tank[6]/conte
|
||||||
var groundAir = props.globals.getNode("/controls/pneumatics/switches/groundair");
|
var groundAir = props.globals.getNode("/controls/pneumatics/switches/groundair");
|
||||||
var groundCart = props.globals.getNode("/controls/electrical/ground-cart");
|
var groundCart = props.globals.getNode("/controls/electrical/ground-cart");
|
||||||
var chocks = props.globals.getNode("/services/chocks/enable");
|
var chocks = props.globals.getNode("/services/chocks/enable");
|
||||||
var engRdy = props.globals.getNode("/engines/ready");
|
|
||||||
var groundspeed = 0;
|
var groundspeed = 0;
|
||||||
|
var stateL = 0;
|
||||||
|
var stateR = 0;
|
||||||
|
|
||||||
var systemsLoop = maketimer(0.1, func {
|
var seatbeltLight = props.globals.getNode("/controls/lighting/seatbelt-sign");
|
||||||
|
var noSmokingLight = props.globals.getNode("/controls/lighting/no-smoking-sign");
|
||||||
|
|
||||||
|
var update_items = [
|
||||||
|
props.UpdateManager.FromHashValue("seatbelt", nil, func(val) {
|
||||||
|
if (val) {
|
||||||
|
if (!seatbeltLight.getBoolValue()) {
|
||||||
|
seatbeltLight.setValue(1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (seatbeltLight.getBoolValue()) {
|
||||||
|
seatbeltLight.setValue(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
props.UpdateManager.FromHashList(["noSmoking","gearPosNorm"], nil, func(val) {
|
||||||
|
if (val.noSmoking == 1) {
|
||||||
|
if (!noSmokingLight.getBoolValue()) {
|
||||||
|
noSmokingLight.setBoolValue(1);
|
||||||
|
}
|
||||||
|
} elsif (val.noSmoking == 0.5 and val.gearPosNorm != 0) { # todo: should be when uplocks not engaged
|
||||||
|
if (!noSmokingLight.getBoolValue()) {
|
||||||
|
noSmokingLight.setBoolValue(1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
noSmokingLight.setBoolValue(0); # sign stays on in cabin but sound still occurs
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
];
|
||||||
|
|
||||||
|
var systemsLoop = func(notification) {
|
||||||
|
if (!systemsInitialized) { return; }
|
||||||
systems.ELEC.loop();
|
systems.ELEC.loop();
|
||||||
systems.PNEU.loop();
|
systems.PNEU.loop();
|
||||||
systems.HYD.loop();
|
systems.HYD.loop();
|
||||||
|
@ -261,36 +182,19 @@ var systemsLoop = maketimer(0.1, func {
|
||||||
dmc.DMController.loop();
|
dmc.DMController.loop();
|
||||||
atsu.ATSU.loop();
|
atsu.ATSU.loop();
|
||||||
libraries.BUTTONS.update();
|
libraries.BUTTONS.update();
|
||||||
systems.HFLoop();
|
systems.HFLoop(notification);
|
||||||
|
|
||||||
groundspeed = pts.Velocities.groundspeed.getValue();
|
if ((notification.engine1State == 2 or notification.engine1State == 3) and collectorTankL.getValue() < 1) {
|
||||||
if ((groundAir.getBoolValue() or groundCart.getBoolValue()) and ((groundspeed > 2) or (!pts.Controls.Gear.parkingBrake.getBoolValue() and !chocks.getBoolValue()))) {
|
|
||||||
groundAir.setBoolValue(0);
|
|
||||||
groundCart.setBoolValue(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (groundspeed > 15) {
|
|
||||||
shakeEffectA3XX.setBoolValue(1);
|
|
||||||
} else {
|
|
||||||
shakeEffectA3XX.setBoolValue(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
stateL = pts.Engines.Engine.state[0].getValue();
|
|
||||||
stateR = pts.Engines.Engine.state[1].getValue();
|
|
||||||
|
|
||||||
if (stateL == 3 and stateR == 3) {
|
|
||||||
engRdy.setBoolValue(1);
|
|
||||||
} else {
|
|
||||||
engRdy.setBoolValue(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((stateL == 2 or stateL == 3) and collectorTankL.getValue() < 1) {
|
|
||||||
systems.cutoff_one();
|
systems.cutoff_one();
|
||||||
}
|
}
|
||||||
if ((stateR == 2 or stateR == 3) and collectorTankR.getValue() < 1) {
|
if ((notification.engine2State == 2 or notification.engine2State == 3) and collectorTankR.getValue() < 1) {
|
||||||
systems.cutoff_two();
|
systems.cutoff_two();
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
foreach (var update_item; update_items) {
|
||||||
|
update_item.update(notification);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# GPWS
|
# GPWS
|
||||||
var GPWS = {
|
var GPWS = {
|
||||||
|
@ -336,7 +240,7 @@ setlistener("/sim/replay/replay-state", func() {
|
||||||
}, 0, 0);
|
}, 0, 0);
|
||||||
|
|
||||||
# Steep ILS
|
# Steep ILS
|
||||||
setlistener("/options/steep-ils", func {
|
setlistener("/options/steep-ils", func() {
|
||||||
if (getprop("/options/steep-ils") == 1) {
|
if (getprop("/options/steep-ils") == 1) {
|
||||||
setprop("/instrumentation/mk-viii/inputs/discretes/steep-approach", 1);
|
setprop("/instrumentation/mk-viii/inputs/discretes/steep-approach", 1);
|
||||||
} else {
|
} else {
|
||||||
|
@ -352,12 +256,12 @@ canvas.Text.setText = func(text) {
|
||||||
me.set("text", typeof(text) == 'scalar' ? text : "");
|
me.set("text", typeof(text) == 'scalar' ? text : "");
|
||||||
};
|
};
|
||||||
canvas.Element._lastVisible = nil;
|
canvas.Element._lastVisible = nil;
|
||||||
canvas.Element.show = func {
|
canvas.Element.show = func() {
|
||||||
if (1 == me._lastVisible) {return me;}
|
if (1 == me._lastVisible) {return me;}
|
||||||
me._lastVisible = 1;
|
me._lastVisible = 1;
|
||||||
me.setBool("visible", 1);
|
me.setBool("visible", 1);
|
||||||
};
|
};
|
||||||
canvas.Element.hide = func {
|
canvas.Element.hide = func() {
|
||||||
if (0 == me._lastVisible) {return me;}
|
if (0 == me._lastVisible) {return me;}
|
||||||
me._lastVisible = 0;
|
me._lastVisible = 0;
|
||||||
me.setBool("visible", 0);
|
me.setBool("visible", 0);
|
||||||
|
@ -368,146 +272,9 @@ canvas.Element.setVisible = func(vis) {
|
||||||
me.setBool("visible", vis);
|
me.setBool("visible", vis);
|
||||||
};
|
};
|
||||||
|
|
||||||
############
|
|
||||||
# Controls #
|
|
||||||
############
|
|
||||||
|
|
||||||
controls.stepSpoilers = func(step) {
|
|
||||||
pts.Controls.Flight.speedbrakeArm.setValue(0);
|
|
||||||
if (step == 1) {
|
|
||||||
deploySpeedbrake();
|
|
||||||
} else if (step == -1) {
|
|
||||||
retractSpeedbrake();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var deploySpeedbrake = func {
|
|
||||||
if (pts.Gear.wow[1].getBoolValue() or pts.Gear.wow[2].getBoolValue()) {
|
|
||||||
if (pts.Controls.Flight.speedbrake.getValue() < 1.0) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(1.0);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (pts.Controls.Flight.speedbrake.getValue() < 0.5) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(0.5);
|
|
||||||
} else if (pts.Controls.Flight.speedbrake.getValue() < 1.0) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(1.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var retractSpeedbrake = func {
|
|
||||||
if (pts.Gear.wow[1].getBoolValue() or pts.Gear.wow[2].getBoolValue()) {
|
|
||||||
if (pts.Controls.Flight.speedbrake.getValue() > 0.0) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(0.0);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (pts.Controls.Flight.speedbrake.getValue() > 0.5) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(0.5);
|
|
||||||
} else if (pts.Controls.Flight.speedbrake.getValue() > 0.0) {
|
|
||||||
pts.Controls.Flight.speedbrake.setValue(0.0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var delta = 0;
|
|
||||||
var output = 0;
|
|
||||||
var slewProp = func(prop, delta) {
|
|
||||||
delta *= pts.Sim.Time.deltaRealtimeSec.getValue();
|
|
||||||
output = props.globals.getNode(prop).getValue() + delta;
|
|
||||||
props.globals.getNode(prop).setValue(output);
|
|
||||||
return output;
|
|
||||||
}
|
|
||||||
|
|
||||||
controls.flapsDown = func(step) {
|
|
||||||
pts.Controls.Flight.flapsTemp = pts.Controls.Flight.flaps.getValue();
|
|
||||||
if (step == 1) {
|
|
||||||
if (pts.Controls.Flight.flapsTemp < 0.2) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.2);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp < 0.4) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.4);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp < 0.6) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.6);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp < 0.8) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.8);
|
|
||||||
}
|
|
||||||
} else if (step == -1) {
|
|
||||||
if (pts.Controls.Flight.flapsTemp > 0.6) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.6);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp > 0.4) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.4);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp > 0.2) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0.2);
|
|
||||||
} else if (pts.Controls.Flight.flapsTemp > 0) {
|
|
||||||
pts.Controls.Flight.flaps.setValue(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
controls.elevatorTrim = func(d) {
|
|
||||||
if (systems.HYD.Psi.green.getValue() >= 1500) {
|
|
||||||
slewProp("/controls/flight/elevator-trim", d * 0.0185); # Rate in JSB normalized (0.125 / 13.5)
|
|
||||||
} else {
|
|
||||||
slewProp("/controls/flight/elevator-trim", d * 0.0092) # Rate in JSB normalized (0.125 / 13.5)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
setlistener("/controls/flight/elevator-trim", func {
|
|
||||||
if (pts.Controls.Flight.elevatorTrim.getValue() > 0.296296) {
|
|
||||||
pts.Controls.Flight.elevatorTrim.setValue(0.296296);
|
|
||||||
}
|
|
||||||
}, 0, 0);
|
|
||||||
|
|
||||||
# For the cockpit rotation and anywhere else you want to use it
|
|
||||||
var cmdDegCalc = 0;
|
|
||||||
var slewPitchWheel = func(d) {
|
|
||||||
cmdDegCalc = math.round(pts.Fdm.JSBsim.Hydraulics.ElevatorTrim.cmdDeg.getValue(), 0.1);
|
|
||||||
if (d > 0) { # DN
|
|
||||||
if (cmdDegCalc < 4) {
|
|
||||||
cmdDegCalc = (cmdDegCalc + 0.1) / 13.5; # Add and normalize, NOT 4! 13.5 = 1 on either polarity
|
|
||||||
pts.Controls.Flight.elevatorTrim.setValue(cmdDegCalc);
|
|
||||||
}
|
|
||||||
} else { # UP
|
|
||||||
if (cmdDegCalc > -13.5) {
|
|
||||||
cmdDegCalc = (cmdDegCalc - 0.1) / 13.5; # Subtract and normalize
|
|
||||||
pts.Controls.Flight.elevatorTrim.setValue(cmdDegCalc);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
##########
|
##########
|
||||||
# Lights #
|
# Misc #
|
||||||
##########
|
##########
|
||||||
|
|
||||||
var lightsLoop = maketimer(0.2, func {
|
|
||||||
# signs
|
|
||||||
if (getprop("/systems/pressurization/cabinalt-norm") > 11300) {
|
|
||||||
setprop("/controls/lighting/seatbelt-sign", 1);
|
|
||||||
setprop("/controls/lighting/no-smoking-sign", 1);
|
|
||||||
} else {
|
|
||||||
if (getprop("/controls/switches/seatbelt-sign") == 1) {
|
|
||||||
if (getprop("/controls/lighting/seatbelt-sign") == 0) {
|
|
||||||
setprop("/controls/lighting/seatbelt-sign", 1);
|
|
||||||
}
|
|
||||||
} elsif (getprop("/controls/switches/seatbelt-sign") == 0) {
|
|
||||||
if (getprop("/controls/lighting/seatbelt-sign") == 1) {
|
|
||||||
setprop("/controls/lighting/seatbelt-sign", 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (getprop("/controls/switches/no-smoking-sign") == 1) {
|
|
||||||
if (getprop("/controls/lighting/no-smoking-sign") == 0) {
|
|
||||||
setprop("/controls/lighting/no-smoking-sign", 1);
|
|
||||||
}
|
|
||||||
} elsif (getprop("/controls/switches/no-smoking-sign") == 0.5 and getprop("/gear/gear[0]/position-norm") != 0) { # todo: should be when uplocks not engaged
|
|
||||||
if (getprop("/controls/lighting/no-smoking-sign") == 0) {
|
|
||||||
setprop("/controls/lighting/no-smoking-sign", 1);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
setprop("/controls/lighting/no-smoking-sign", 0); # sign stays on in cabin but sound still occurs
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var pilotComfortTwoPos = func(prop) {
|
var pilotComfortTwoPos = func(prop) {
|
||||||
var item = getprop(prop);
|
var item = getprop(prop);
|
||||||
if (item < 0.5) {
|
if (item < 0.5) {
|
||||||
|
@ -528,25 +295,24 @@ var pilotComfortOnePos = func(prop) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var lTray = func {
|
var lTray = func() {
|
||||||
pilotComfortTwoPos("/controls/tray/lefttrayext");
|
pilotComfortTwoPos("/controls/tray/lefttrayext");
|
||||||
}
|
}
|
||||||
var rTray = func {
|
var rTray = func() {
|
||||||
pilotComfortTwoPos("/controls/tray/righttrayext");
|
pilotComfortTwoPos("/controls/tray/righttrayext");
|
||||||
}
|
}
|
||||||
|
|
||||||
var l1Pedal = func {
|
var l1Pedal = func() {
|
||||||
pilotComfortOnePos("/controls/footrest-cpt[0]");
|
pilotComfortOnePos("/controls/footrest-cpt[0]");
|
||||||
}
|
}
|
||||||
var l2Pedal = func {
|
var l2Pedal = func() {
|
||||||
pilotComfortOnePos("/controls/footrest-cpt[1]");
|
pilotComfortOnePos("/controls/footrest-cpt[1]");
|
||||||
}
|
}
|
||||||
|
|
||||||
var r1Pedal = func {
|
var r1Pedal = func() {
|
||||||
pilotComfortOnePos("/controls/footrest-fo[0]");
|
pilotComfortOnePos("/controls/footrest-fo[0]");
|
||||||
}
|
}
|
||||||
var r2Pedal = func {
|
var r2Pedal = func() {
|
||||||
var r2PedalCMD = getprop("/controls/footrest-fo[1]");
|
|
||||||
pilotComfortOnePos("/controls/footrest-fo[1]");
|
pilotComfortOnePos("/controls/footrest-fo[1]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -561,7 +327,7 @@ if (pts.Controls.Flight.autoCoordination.getBoolValue()) {
|
||||||
pts.Controls.Flight.aileronDrivesTiller.setBoolValue(0);
|
pts.Controls.Flight.aileronDrivesTiller.setBoolValue(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
setlistener("/controls/flight/auto-coordination", func {
|
setlistener("/controls/flight/auto-coordination", func() {
|
||||||
pts.Controls.Flight.autoCoordination.setBoolValue(0);
|
pts.Controls.Flight.autoCoordination.setBoolValue(0);
|
||||||
print("System: Auto Coordination has been turned off as it is not compatible with the fly-by-wire of this aircraft.");
|
print("System: Auto Coordination has been turned off as it is not compatible with the fly-by-wire of this aircraft.");
|
||||||
screen.log.write("Auto Coordination has been disabled as it is not compatible with the fly-by-wire of this aircraft", 1, 0, 0);
|
screen.log.write("Auto Coordination has been disabled as it is not compatible with the fly-by-wire of this aircraft", 1, 0, 0);
|
||||||
|
@ -579,4 +345,37 @@ var APPanel = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
# Emesary
|
||||||
|
var LibrariesRecipient =
|
||||||
|
{
|
||||||
|
new: func(_ident)
|
||||||
|
{
|
||||||
|
var NewLibrariesRecipient = emesary.Recipient.new(_ident);
|
||||||
|
NewLibrariesRecipient.Receive = func(notification)
|
||||||
|
{
|
||||||
|
if (notification.NotificationType == "FrameNotification")
|
||||||
|
{
|
||||||
|
if (math.mod(notifications.frameNotification.FrameCount,4) == 0) {
|
||||||
|
systemsLoop(notification);
|
||||||
|
}
|
||||||
|
return emesary.Transmitter.ReceiptStatus_OK;
|
||||||
|
}
|
||||||
|
return emesary.Transmitter.ReceiptStatus_NotProcessed;
|
||||||
|
};
|
||||||
|
return NewLibrariesRecipient;
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
var input = {
|
||||||
|
# Libraries
|
||||||
|
"seatbelt": "/controls/switches/seatbelt-sign",
|
||||||
|
"noSmoking": "/controls/switches/no-smoking-sign",
|
||||||
|
"gearPosNorm": "/gear/gear[0]/position-norm",
|
||||||
|
};
|
||||||
|
|
||||||
|
foreach (var name; keys(input)) {
|
||||||
|
emesary.GlobalTransmitter.NotifyAll(notifications.FrameNotificationAddProperty.new("A320 Libraries", name, input[name]));
|
||||||
|
}
|
||||||
|
|
||||||
setprop("/systems/acconfig/libraries-loaded", 1);
|
setprop("/systems/acconfig/libraries-loaded", 1);
|
||||||
|
|
|
@ -249,6 +249,11 @@ var Sim = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Version: props.globals.getNode("/sim/version/flightgear"),
|
Version: props.globals.getNode("/sim/version/flightgear"),
|
||||||
|
View: {
|
||||||
|
Config: {
|
||||||
|
defaultFieldOfViewDeg: props.globals.getNode("/sim/view/config/default-field-of-view-deg", 1),
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
var Systems = {
|
var Systems = {
|
||||||
|
|
|
@ -5,16 +5,9 @@
|
||||||
var shakeEffectA3XX = props.globals.initNode("/systems/shake/effect", 0, "BOOL");
|
var shakeEffectA3XX = props.globals.initNode("/systems/shake/effect", 0, "BOOL");
|
||||||
var shakeA3XX = props.globals.initNode("/systems/shake/shaking", 0, "DOUBLE");
|
var shakeA3XX = props.globals.initNode("/systems/shake/shaking", 0, "DOUBLE");
|
||||||
var sf = 0;
|
var sf = 0;
|
||||||
var n_g_c = 0;
|
|
||||||
var n_g_l = 0;
|
|
||||||
var n_g_r = 0;
|
|
||||||
|
|
||||||
var theShakeEffect = func {
|
var theShakeEffect = func {
|
||||||
n_g_c = pts.Gear.compression[0].getValue() or 0;
|
if (shakeEffectA3XX.getBoolValue()) {
|
||||||
n_g_l = pts.Gear.compression[1].getValue() or 0;
|
|
||||||
n_g_r = pts.Gear.compression[2].getValue() or 0;
|
|
||||||
|
|
||||||
if (shakeEffectA3XX.getBoolValue() and (n_g_c > 0 or n_g_l > 0 or n_g_r > 0)) {
|
|
||||||
sf = pts.Gear.rollspeed[0].getValue() / 94000;
|
sf = pts.Gear.rollspeed[0].getValue() / 94000;
|
||||||
interpolate("/systems/shake/shaking", sf, 0.03);
|
interpolate("/systems/shake/shaking", sf, 0.03);
|
||||||
settimer(func {
|
settimer(func {
|
||||||
|
|
125
Nasal/Libraries/sounds.nas
Normal file
125
Nasal/Libraries/sounds.nas
Normal file
|
@ -0,0 +1,125 @@
|
||||||
|
# A320 Main Libraries
|
||||||
|
# Joshua Davidson (Octal450)
|
||||||
|
|
||||||
|
# Copyright (c) 2020 Josh Davidson (Octal450)
|
||||||
|
|
||||||
|
##########
|
||||||
|
# Sounds #
|
||||||
|
##########
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/btn1", func {
|
||||||
|
if (!getprop("/sim/sounde/btn1")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/btn1").setBoolValue(0);
|
||||||
|
}, 0.05);
|
||||||
|
});
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/oh-btn", func {
|
||||||
|
if (!getprop("/sim/sounde/oh-btn")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/oh-btn").setBoolValue(0);
|
||||||
|
}, 0.05);
|
||||||
|
});
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/btn3", func {
|
||||||
|
if (!getprop("/sim/sounde/btn3")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/btn3").setBoolValue(0);
|
||||||
|
}, 0.05);
|
||||||
|
});
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/knb1", func {
|
||||||
|
if (!getprop("/sim/sounde/knb1")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/knb1").setBoolValue(0);
|
||||||
|
}, 0.05);
|
||||||
|
});
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/switch1", func {
|
||||||
|
if (!getprop("/sim/sounde/switch1")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/switch1").setBoolValue(0);
|
||||||
|
}, 0.05);
|
||||||
|
});
|
||||||
|
|
||||||
|
setlistener("/controls/lighting/seatbelt-sign", func {
|
||||||
|
props.globals.getNode("/sim/sounde/seatbelt-sign").setBoolValue(1);
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/seatbelt-sign").setBoolValue(0);
|
||||||
|
}, 2);
|
||||||
|
}, 0, 0);
|
||||||
|
|
||||||
|
setlistener("/controls/lighting/no-smoking-sign", func {
|
||||||
|
props.globals.getNode("/sim/sounde/no-smoking-sign").setBoolValue(1);
|
||||||
|
settimer(func {
|
||||||
|
props.globals.getNode("/sim/sounde/no-smoking-sign").setBoolValue(0);
|
||||||
|
}, 1);
|
||||||
|
}, 0, 0);
|
||||||
|
|
||||||
|
var flaps_click = props.globals.getNode("/sim/sounde/flaps-click");
|
||||||
|
|
||||||
|
setlistener("/controls/flight/flaps-input", func {
|
||||||
|
flaps_click.setBoolValue(1);
|
||||||
|
}, 0, 0);
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/flaps-click", func {
|
||||||
|
if (!flaps_click.getValue()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
flaps_click.setBoolValue(0);
|
||||||
|
}, 0.4);
|
||||||
|
});
|
||||||
|
|
||||||
|
var spdbrk_click = props.globals.getNode("/sim/sounde/spdbrk-click");
|
||||||
|
|
||||||
|
setlistener("/controls/flight/speedbrake", func {
|
||||||
|
spdbrk_click.setBoolValue(1);
|
||||||
|
}, 0, 0);
|
||||||
|
|
||||||
|
setlistener("/sim/sounde/spdbrk-click", func {
|
||||||
|
if (!spdbrk_click.getValue()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
settimer(func {
|
||||||
|
spdbrk_click.setBoolValue(0);
|
||||||
|
}, 0.4);
|
||||||
|
});
|
||||||
|
|
||||||
|
var relayBatt1 = func {
|
||||||
|
setprop("/sim/sounde/relay-batt-1",1);
|
||||||
|
settimer(func {setprop("/sim/sounde/relay-batt-1",0);},0.35);
|
||||||
|
}
|
||||||
|
var relayBatt2 = func {
|
||||||
|
setprop("/sim/sounde/relay-batt-2",1);
|
||||||
|
settimer(func {setprop("/sim/sounde/relay-batt-2",0);},0.35);
|
||||||
|
}
|
||||||
|
var relayApu = func {
|
||||||
|
setprop("/sim/sounde/relay-apu",1);
|
||||||
|
settimer(func {setprop("/sim/sounde/relay-apu",0);},0.35);
|
||||||
|
}
|
||||||
|
var relayExt = func {
|
||||||
|
setprop("/sim/sounde/relay-ext",1);
|
||||||
|
settimer(func {setprop("/sim/sounde/relay-ext",0);},0.35);
|
||||||
|
}
|
||||||
|
|
||||||
|
setlistener("/systems/electrical/sources/bat-1/contact", relayBatt1, nil, 0);
|
||||||
|
setlistener("/systems/electrical/sources/bat-2/contact", relayBatt2, nil, 0);
|
||||||
|
setlistener("/systems/electrical/relay/apu-glc/contact-pos", relayApu, nil, 0);
|
||||||
|
setlistener("/systems/electrical/relay/ext-epc/contact-pos", relayExt, nil, 0);
|
||||||
|
|
||||||
|
var pushbuttonSound = props.globals.getNode("/sim/sounde/pushbutton");
|
||||||
|
var pushbutton = func() {
|
||||||
|
pushbuttonSound.setValue(1);
|
||||||
|
settimer(func {pushbuttonSound.setValue(0);},0.20);
|
||||||
|
}
|
|
@ -118,9 +118,9 @@ var HFS = [highFrequencyRadio.new(systems.ELEC.Bus.acEssShed, 0), highFrequencyR
|
||||||
# Can't use setlistener on the voltage as it always gets written to by JSB (and changes according to engine rpm)
|
# Can't use setlistener on the voltage as it always gets written to by JSB (and changes according to engine rpm)
|
||||||
|
|
||||||
var update_items_HF_radio = [
|
var update_items_HF_radio = [
|
||||||
props.UpdateManager.FromProperty("/systems/electrical/bus/ac-ess-shed", 0.1, func(notification)
|
props.UpdateManager.FromHashValue("elecACEssShed", 0.1, func(val)
|
||||||
{
|
{
|
||||||
if (systems.ELEC.Bus.acEssShed.getValue() < 110) {
|
if (val < 110) {
|
||||||
HFS[0].transmit = 0;
|
HFS[0].transmit = 0;
|
||||||
HFS[0].receptionProp.setValue(0);
|
HFS[0].receptionProp.setValue(0);
|
||||||
toneTimer1.stop();
|
toneTimer1.stop();
|
||||||
|
@ -133,9 +133,9 @@ var update_items_HF_radio = [
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
props.UpdateManager.FromProperty("/systems/electrical/bus/ac-2", 0.1, func(notification)
|
props.UpdateManager.FromHashValue("elecAC2", 0.1, func(val)
|
||||||
{
|
{
|
||||||
if (systems.ELEC.Bus.ac2.getValue() < 110) {
|
if (val) {
|
||||||
HFS[1].transmit = 0;
|
HFS[1].transmit = 0;
|
||||||
HFS[1].receptionProp.setValue(0);
|
HFS[1].receptionProp.setValue(0);
|
||||||
toneTimer2.stop();
|
toneTimer2.stop();
|
||||||
|
@ -150,9 +150,9 @@ var update_items_HF_radio = [
|
||||||
),
|
),
|
||||||
];
|
];
|
||||||
|
|
||||||
var HFLoop = func() {
|
var HFLoop = func(notification) {
|
||||||
foreach (var update_item_HF; update_items_HF_radio) {
|
foreach (var update_item_HF; update_items_HF_radio) {
|
||||||
update_item_HF.update(nil);
|
update_item_HF.update(notification);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,6 +43,12 @@ input = {
|
||||||
elapsedTime: "/sim/time/elapsed-sec",
|
elapsedTime: "/sim/time/elapsed-sec",
|
||||||
FWCPhase: "/ECAM/warning-phase",
|
FWCPhase: "/ECAM/warning-phase",
|
||||||
gear0Wow: "/gear/gear[0]/wow",
|
gear0Wow: "/gear/gear[0]/wow",
|
||||||
|
|
||||||
|
# Just about everything uses these properties at some stage, lets add them here!
|
||||||
|
elecAC1: "/systems/electrical/bus/ac-1",
|
||||||
|
elecAC2: "/systems/electrical/bus/ac-2",
|
||||||
|
elecACEss: "/systems/electrical/bus/ac-ess",
|
||||||
|
elecACEssShed: "/systems/electrical/bus/ac-ess-shed",
|
||||||
engine1State: "/engines/engine[0]/state",
|
engine1State: "/engines/engine[0]/state",
|
||||||
engine2State: "/engines/engine[1]/state",
|
engine2State: "/engines/engine[1]/state",
|
||||||
};
|
};
|
||||||
|
|
|
@ -39,4 +39,42 @@
|
||||||
|
|
||||||
</channel>
|
</channel>
|
||||||
|
|
||||||
|
<channel name="Shake" execrate="8">
|
||||||
|
|
||||||
|
<switch name="/systems/shake/effect">
|
||||||
|
<default value="0"/>
|
||||||
|
<test logic="AND" value="1">
|
||||||
|
/velocities/groundspeed-kt ge 15
|
||||||
|
<test logic="OR">
|
||||||
|
/gear/gear[0]/compression-norm gt 0
|
||||||
|
/gear/gear[1]/compression-norm gt 0
|
||||||
|
/gear/gear[2]/compression-norm gt 0
|
||||||
|
</test>
|
||||||
|
</test>
|
||||||
|
</switch>
|
||||||
|
|
||||||
|
<switch name="/engines/ready">
|
||||||
|
<default value="0"/>
|
||||||
|
<test logic="AND" value="1">
|
||||||
|
/engines/engine[0]/state eq 3
|
||||||
|
/engines/engine[1]/state eq 3
|
||||||
|
</test>
|
||||||
|
</switch>
|
||||||
|
|
||||||
|
<switch name="/controls/pneumatics/switches/groundair">
|
||||||
|
<default value="/controls/pneumatics/switches/groundair"/>
|
||||||
|
<test logic="AND" value="0">
|
||||||
|
/velocities/groundspeed-kt ge 2
|
||||||
|
</test>
|
||||||
|
</switch>
|
||||||
|
|
||||||
|
<switch name="/controls/electrical/ground-cart">
|
||||||
|
<default value="/controls/electrical/ground-cart"/>
|
||||||
|
<test logic="AND" value="0">
|
||||||
|
/velocities/groundspeed-kt ge 2
|
||||||
|
</test>
|
||||||
|
</switch>
|
||||||
|
|
||||||
|
</channel>
|
||||||
|
|
||||||
</system>
|
</system>
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
43
|
45
|
Loading…
Add table
Reference in a new issue