397 lines
12 KiB
Text
397 lines
12 KiB
Text
# A320 Main Libraries
|
|
# Joshua Davidson (Octal450)
|
|
|
|
# Copyright (c) 2020 Josh Davidson (Octal450)
|
|
|
|
print("------------------------------------------------");
|
|
print("Copyright (c) 2016-2020 Josh Davidson (Octal450)");
|
|
print("------------------------------------------------");
|
|
|
|
setprop("/autopilot/route-manager/disable-route-manager", 1);
|
|
setprop("/autopilot/route-manager/disable-fms", 1);
|
|
|
|
# Disable specific menubar items
|
|
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[2]/enabled", 0);
|
|
setprop("/sim/menubar/default/menu[5]/item[9]/enabled", 0);
|
|
setprop("/sim/menubar/default/menu[5]/item[10]/enabled", 0);
|
|
setprop("/sim/menubar/default/menu[5]/item[11]/enabled", 0);
|
|
|
|
# Oil Qty
|
|
var qty1 = math.round((rand() * 5 ) + 20, 0.1);
|
|
var qty2 = math.round((rand() * 5 ) + 20, 0.1);
|
|
setprop("/engines/engine[0]/oil-qt-actual", qty1);
|
|
setprop("/engines/engine[1]/oil-qt-actual", qty2);
|
|
|
|
##########
|
|
# Lights #
|
|
##########
|
|
var beacon = aircraft.light.new("/sim/model/lights/beacon", [0.1, 1], "/controls/lighting/beacon");
|
|
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");
|
|
|
|
###########
|
|
# Effects #
|
|
###########
|
|
|
|
var tiresmoke_system = aircraft.tyresmoke_system.new(0, 1, 2);
|
|
aircraft.rain.init();
|
|
|
|
aircraft.livery.init(getprop("/sim/model/livery-dir"));
|
|
|
|
#########
|
|
# Doors #
|
|
#########
|
|
|
|
# Front doors
|
|
var doorl1 = aircraft.door.new("/sim/model/door-positions/doorl1", 4);
|
|
var doorr1 = aircraft.door.new("/sim/model/door-positions/doorr1", 4);
|
|
|
|
# Middle doors (A321 only)
|
|
var doorl2 = aircraft.door.new("/sim/model/door-positions/doorl2", 4);
|
|
var doorr2 = aircraft.door.new("/sim/model/door-positions/doorr2", 4);
|
|
var doorl3 = aircraft.door.new("/sim/model/door-positions/doorl3", 4);
|
|
var doorr3 = aircraft.door.new("/sim/model/door-positions/doorr3", 4);
|
|
|
|
# Rear doors
|
|
var doorl4 = aircraft.door.new("/sim/model/door-positions/doorl4", 4);
|
|
var doorr4 = aircraft.door.new("/sim/model/door-positions/doorr4", 4);
|
|
|
|
# Cargo holds
|
|
var cargobulk = aircraft.door.new("/sim/model/door-positions/cargobulk", 3);
|
|
var cargoaft = aircraft.door.new("/sim/model/door-positions/cargoaft", 10);
|
|
var cargofwd = aircraft.door.new("/sim/model/door-positions/cargofwd", 10);
|
|
|
|
# Seat armrests in the flight deck (unused)
|
|
var armrests = aircraft.door.new("/sim/model/door-positions/armrests", 2);
|
|
|
|
# Cockpit door - TODO animation
|
|
var cockpitdoor = aircraft.door.new("/sim/model/door-positions/doorc", 1);
|
|
setprop("/sim/model/door-positions/doorc/lock-status",0);
|
|
|
|
# door opener/closer
|
|
var triggerDoor = func(door, doorName, doorDesc) {
|
|
if (getprop("/sim/model/door-positions/" ~ doorName ~ "/position-norm") > 0) {
|
|
gui.popupTip("Closing " ~ doorDesc ~ " door");
|
|
door.toggle();
|
|
} else {
|
|
if (pts.Velocities.groundspeed.getValue() > 5) {
|
|
gui.popupTip("You cannot open the doors while the aircraft is moving!");
|
|
} else {
|
|
gui.popupTip("Opening " ~ doorDesc ~ " door");
|
|
door.toggle();
|
|
}
|
|
}
|
|
};
|
|
|
|
setlistener("/controls/doors/doorc-switch",func(a){
|
|
setprop("sim/sounde/switch1", 1);
|
|
if (systems.ELEC.Bus.dc1.getValue() > 25 or systems.ELEC.Bus.dc2.getValue() > 25) {
|
|
var pos = a.getValue();
|
|
var current = getprop("/sim/model/door-positions/doorc/lock-status");
|
|
if (pos == 1 and current == 0) { ## LOCK
|
|
settimer( func {
|
|
if (a.getValue() == pos) setprop("/sim/model/door-positions/doorc/lock-status",1);
|
|
},0.4);
|
|
}
|
|
else if (pos == -1 and current == 1) { ## UNLOCK
|
|
settimer( func {
|
|
if (a.getValue() == pos) setprop("/sim/model/door-positions/doorc/lock-status",0);
|
|
},0.3);
|
|
}
|
|
#setprop("/sim/model/door-positions/doorc/lock-status",-9); ## FAULT
|
|
}
|
|
},0,0);
|
|
|
|
###########
|
|
# Systems #
|
|
###########
|
|
var systemsInitialized = 0;
|
|
var A320Libraries = nil;
|
|
|
|
var systemsInit = func() {
|
|
systemsInitialized = 0;
|
|
fbw.FBW.init();
|
|
effects.lightManager.init();
|
|
systems.ELEC.init();
|
|
systems.PNEU.init();
|
|
systems.HYD.init();
|
|
systems.FUEL.init();
|
|
systems.ADIRS.init();
|
|
systems.eng_init();
|
|
systems.APUController.init();
|
|
systems.BrakeSys.reset();
|
|
systems.Autobrake.init();
|
|
systems.fire_init();
|
|
fmgc.flightPlanController.reset();
|
|
fmgc.windController.reset();
|
|
fadec.FADEC.init();
|
|
fmgc.ITAF.init();
|
|
fmgc.FMGCinit();
|
|
mcdu.MCDU_init(0);
|
|
mcdu.MCDU_init(1);
|
|
mcdu_scratchpad.mcduMsgtimer1.start();
|
|
mcdu_scratchpad.mcduMsgtimer2.start();
|
|
effects.icingInit();
|
|
ecam.ECAM.init();
|
|
libraries.variousReset();
|
|
rmp.init();
|
|
acp.init();
|
|
ecam.ECAM_controller.init();
|
|
atc.init();
|
|
fcu.FCUController.init();
|
|
dmc.DMController.init();
|
|
fmgc.flightPlanController.init();
|
|
fmgc.windController.init();
|
|
atsu.CompanyCall.init();
|
|
systemsInitialized = 1;
|
|
}
|
|
|
|
setlistener("/sim/signals/fdm-initialized", func() {
|
|
systemsInit();
|
|
fmgc.postInit();
|
|
fmgc.flightPlanTimer.start();
|
|
fmgc.WaypointDatabase.read();
|
|
|
|
A320Libraries = LibrariesRecipient.new("A320 Libraries");
|
|
emesary.GlobalTransmitter.Register(A320Libraries);
|
|
});
|
|
|
|
var systemsLoop = func(notification) {
|
|
if (!systemsInitialized and getprop("/systems/acconfig/mismatch-code") != "0x000") { return; }
|
|
systems.PNEU.loop(notification);
|
|
systems.ADIRS.loop(notification);
|
|
systems.BrakeSys.update(notification);
|
|
systems.HFLoop(notification);
|
|
systems.APUController.loop();
|
|
fadec.FADEC.loop();
|
|
rmp.rmpUpdate();
|
|
fcu.FCUController.loop(notification);
|
|
atc.Transponders.vector[atc.transponderPanel.atcSel - 1].update(notification);
|
|
dmc.DMController.loop();
|
|
atsu.ATSU.loop();
|
|
libraries.BUTTONS.update();
|
|
|
|
if (notification.engine1State >= 2 and pts.Fdm.JSBsim.Propulsion.Tank.contentsLbs[5].getValue() < 1) {
|
|
systems.cutoff_one();
|
|
}
|
|
|
|
if (notification.engine2State >= 2 and pts.Fdm.JSBsim.Propulsion.Tank.contentsLbs[6].getValue() < 1) {
|
|
systems.cutoff_two();
|
|
}
|
|
}
|
|
|
|
# GPWS
|
|
var GPWS = {
|
|
alertMode: props.globals.initNode("/instrumentation/mk-viii/outputs/alert-mode", 0, "INT"),
|
|
alert: props.globals.getNode("instrumentation/mk-viii/outputs/discretes/gpws-alert"),
|
|
warning: props.globals.getNode("instrumentation/mk-viii/outputs/discretes/gpws-warning"),
|
|
};
|
|
|
|
# GPWS alert pooling for get mode change - a little esoteric way but it works
|
|
var GPWSAlertStatus = 0;
|
|
var gpws_alert_watch = maketimer(0.8, func() {
|
|
if (GPWS.warning.getValue()) {
|
|
GPWSAlertStatus = 2; # MODE2 - warning - RED
|
|
|
|
# Turn on Terr on ND after a GPWS warning
|
|
setprop("/controls/switches/terr_on_nd_l", 1);
|
|
setprop("/instrumentation/efis/inputs/terr", 1);
|
|
setprop("/controls/switches/terr_on_nd_r", 1);
|
|
setprop("/instrumentation/efis[1]/inputs/terr", 1);
|
|
|
|
} else if (GPWS.alert.getValue()) {
|
|
GPWSAlertStatus = 1; # MODE1 - caution - YELLOW
|
|
} else {
|
|
GPWSAlertStatus = 0;
|
|
}
|
|
|
|
if (GPWS.alertMode.getValue() != GPWSAlertStatus) {
|
|
GPWS.alertMode.setValue(GPWSAlertStatus);
|
|
}
|
|
});
|
|
|
|
# detect GPWS switch status
|
|
setlistener("/instrumentation/mk-viii/inputs/discretes/ta-tcf-inhibit", func (val) {
|
|
if (!val.getBoolValue()) {
|
|
gpws_alert_watch.start();
|
|
} else {
|
|
gpws_alert_watch.stop();
|
|
}
|
|
}, 1, 0);
|
|
|
|
# Steep ILS
|
|
setlistener("/options/steep-ils", func(val) {
|
|
if (val.getValue()) {
|
|
pts.Instrumentation.MKVII.Inputs.Discretes.steepApproach.setValue(1);
|
|
} else {
|
|
pts.Instrumentation.MKVII.Inputs.Discretes.steepApproach.setValue(0);
|
|
}
|
|
}, 0, 0);
|
|
|
|
# Replay
|
|
var replayState = props.globals.getNode("/sim/replay/replay-state");
|
|
setlistener(replayState, func(v) {
|
|
if (v.getBoolValue()) {
|
|
} else {
|
|
acconfig.colddark();
|
|
gui.popupTip("Replay Ended: Setting Cold and Dark state...");
|
|
}
|
|
}, 0, 0);
|
|
|
|
# hackCanvas
|
|
canvas.Text._lastText = canvas.Text["_lastText"];
|
|
canvas.Text.setText = func(text) {
|
|
if (text == me._lastText and text != nil and size(text) == size(me._lastText)) {return me;}
|
|
me._lastText = text;
|
|
me.set("text", typeof(text) == 'scalar' ? text : "");
|
|
};
|
|
canvas.Element._lastVisible = nil;
|
|
canvas.Element.show = func() {
|
|
if (1 == me._lastVisible) {return me;}
|
|
me._lastVisible = 1;
|
|
me.setBool("visible", 1);
|
|
};
|
|
canvas.Element.hide = func() {
|
|
if (0 == me._lastVisible) {return me;}
|
|
me._lastVisible = 0;
|
|
me.setBool("visible", 0);
|
|
};
|
|
canvas.Element.setVisible = func(vis) {
|
|
if (vis == me._lastVisible) {return me;}
|
|
me._lastVisible = vis;
|
|
me.setBool("visible", vis);
|
|
};
|
|
|
|
##########
|
|
# Misc #
|
|
##########
|
|
|
|
var pilotComfortTwoPos = func(prop) {
|
|
var item = getprop(prop);
|
|
if (item < 0.5) {
|
|
interpolate(prop, 0.5, 0.5);
|
|
} elsif (item == 0.5) {
|
|
interpolate(prop, 1.0, 0.5);
|
|
} else {
|
|
interpolate(prop, 0.0, 1.0);
|
|
}
|
|
}
|
|
|
|
var pilotComfortOnePos = func(prop) {
|
|
var item = getprop(prop);
|
|
if (item < 1.0) {
|
|
interpolate(prop, 1.0, 1.0);
|
|
} else {
|
|
interpolate(prop, 0.0, 1.0);
|
|
}
|
|
}
|
|
|
|
var lTray = func() {
|
|
pilotComfortTwoPos("/controls/tray/lefttrayext");
|
|
}
|
|
var rTray = func() {
|
|
pilotComfortTwoPos("/controls/tray/righttrayext");
|
|
}
|
|
|
|
var l1Pedal = func() {
|
|
pilotComfortOnePos("/controls/footrest-cpt[0]");
|
|
}
|
|
var l2Pedal = func() {
|
|
pilotComfortOnePos("/controls/footrest-cpt[1]");
|
|
}
|
|
|
|
var r1Pedal = func() {
|
|
pilotComfortOnePos("/controls/footrest-fo[0]");
|
|
}
|
|
var r2Pedal = func() {
|
|
pilotComfortOnePos("/controls/footrest-fo[1]");
|
|
}
|
|
|
|
#####################
|
|
# Auto-coordination #
|
|
#####################
|
|
|
|
if (pts.Controls.Flight.autoCoordination.getBoolValue()) {
|
|
pts.Controls.Flight.autoCoordination.setBoolValue(0);
|
|
pts.Controls.Flight.aileronDrivesTiller.setBoolValue(1);
|
|
} else {
|
|
pts.Controls.Flight.aileronDrivesTiller.setBoolValue(0);
|
|
}
|
|
|
|
setlistener("/controls/flight/auto-coordination", func() {
|
|
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.");
|
|
screen.log.write("Auto Coordination has been disabled as it is not compatible with the fly-by-wire of this aircraft", 1, 0, 0);
|
|
}, 0, 0);
|
|
|
|
##############
|
|
# Legacy FCU #
|
|
##############
|
|
var APPanel = {
|
|
APDisc: func() {
|
|
fcu.FCUController.APDisc();
|
|
},
|
|
ATDisc: func() {
|
|
fcu.FCUController.ATDisc();
|
|
},
|
|
};
|
|
|
|
|
|
# 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
|
|
"gearPosNorm": "/gear/gear[0]/position-norm",
|
|
"gearPosNorm1": "/gear/gear[1]/position-norm",
|
|
"gearPosNorm2": "/gear/gear[2]/position-norm",
|
|
"engine1Running": "/engines/engine[0]/running",
|
|
"engine2Running": "/engines/engine[1]/running",
|
|
};
|
|
|
|
foreach (var name; keys(input)) {
|
|
emesary.GlobalTransmitter.NotifyAll(notifications.FrameNotificationAddProperty.new("A320 Libraries", name, input[name]));
|
|
}
|
|
|
|
# TODO split EFIS altimeters
|
|
var newinhg = nil;
|
|
setlistener("/instrumentation/altimeter/setting-inhg", func(val) {
|
|
newinhg = val.getValue();
|
|
setprop("/instrumentation/altimeter[1]/setting-inhg", newinhg);
|
|
setprop("/instrumentation/altimeter[2]/setting-inhg", newinhg);
|
|
setprop("/instrumentation/altimeter[3]/setting-inhg", newinhg);
|
|
setprop("/instrumentation/altimeter[4]/setting-inhg", newinhg);
|
|
setprop("/instrumentation/altimeter[5]/setting-inhg", newinhg);
|
|
}, 0, 0);
|
|
|
|
var newhpa = nil;
|
|
setlistener("/instrumentation/altimeter/setting-hpa", func(val) {
|
|
newhpa = val.getValue();
|
|
setprop("/instrumentation/altimeter[1]/setting-hpa", newhpa);
|
|
setprop("/instrumentation/altimeter[2]/setting-hpa", newhpa);
|
|
setprop("/instrumentation/altimeter[3]/setting-hpa", newhpa);
|
|
setprop("/instrumentation/altimeter[4]/setting-hpa", newhpa);
|
|
setprop("/instrumentation/altimeter[5]/setting-hpa", newhpa);
|
|
}, 0, 0);
|
|
|
|
setprop("/systems/acconfig/libraries-loaded", 1);
|