1
0
Fork 0
A320-family/Nasal/Systems/Comm/CPDLC.nas

126 lines
3.2 KiB
Text
Raw Normal View History

2020-08-03 16:50:08 +00:00
# A3XX CPDLC
# Jonathan Redpath
# Copyright (c) 2020 Josh Davidson (Octal450)
var A320CPDLCMessageHandler = cpdlc.CPDLCMessageHandler.new();
2020-08-03 16:50:08 +00:00
var CPDLCmessage = {
new: func(text,responses) {
2020-08-03 16:50:08 +00:00
var cpdlcMessage = {parents: [CPDLCmessage] };
cpdlcMessage.text = text;
cpdlcMessage.responses = responses;
2020-12-28 16:01:09 +00:00
cpdlcMessage._receivedTime = left(getprop("/sim/time/gmt-string"), 5);
cpdlcMessage.receivedTime = split(":", cpdlcMessage._receivedTime)[0] ~ "." ~ split(":", cpdlcMessage._receivedTime)[1] ~ "Z";
2020-08-03 16:50:08 +00:00
return cpdlcMessage;
},
};
2020-12-28 16:01:09 +00:00
var DCDUBuffer = {
buffer: std.Vector.new(),
insertMessage: func(message) {
me.buffer.append(message);
},
popMessage: func() {
return me.buffer.pop(0);
},
};
var CPDLCnewMsgFlag = props.globals.getNode("/network/cpdlc/rx/new-message");
var CPDLCnewMsgAlert = props.globals.initNode("/network/cpdlc/new-message-ringtone", 0, "BOOL");
var CPDLCnewMsgLight = props.globals.initNode("/network/cpdlc/new-message-light", 0, "BOOL");
2020-11-29 16:58:38 +00:00
var ATCMSGRingCancel = 0;
var ATCMsgFlashCancel = 0;
setlistener("/network/cpdlc/rx/new-message", func() {
if (CPDLCnewMsgFlag.getBoolValue()) {
fgcommand("cpdlc-next-message");
# add to DCDU message buffer to display
var message = CPDLCmessage.new(A320CPDLCMessageHandler.getMessage(),A320CPDLCMessageHandler.getReplyOptions());
2020-12-28 16:01:09 +00:00
DCDUBuffer.insertMessage(message);
if (!canvas_dcdu.DCDU.showingMessage) {
canvas_dcdu.DCDU.showNextMessage();
}
ATCMSGRingCancel = 1;
var messageType = 0; # urgent or normal
ATCMSGRing(messageType);
ATCMSGRingCancel = 0;
ATCMsgFlashCancel = 1;
ATCMSGFlash();
ATCMsgFlashCancel = 0;
# ATC MSG pushbutton: flashes, ringtone after 15 secs, therafter every 15 secs
# add DCDU prompts (wilco, etc) associated to message --> so the CPDLC message object must store the correct response for the actual message
}
}, 0, 1);
2020-11-29 16:58:38 +00:00
var ATCMSGRing = func(messageType) {
settimer(func() {
if (!ATCMSGRingCancel) {
CPDLCnewMsgAlert.setBoolValue(0);
settimer(func() {
CPDLCnewMsgAlert.setBoolValue(1);
ATCMSGRing(messageType);
}, 0.1);
}
}, (messageType == 0 ? 15 : 5));
};
var ATCMSGFlash = func() {
CPDLCnewMsgLight.setBoolValue(!CPDLCnewMsgLight.getBoolValue());
settimer(func() {
if (!ATCMsgFlashCancel) {
ATCMSGFlash();
}
}, 0.2);
};
# issue fgcommand with cpdlc message to send
2020-11-29 16:58:38 +00:00
var prefixes = {
acPerf: "DUE TO A/C PERFORMANCE",
weather: "DUE TO WEATHER",
turbulence: "DUE TO TURBULENCE",
medical: "DUE TO MEDICAL",
technical: "DUE TO TECHNICAL",
discretion: "AT PILOTS DISCRETION",
};
var responses = {
w: "WILCO",
u: "UNABLE",
a: "AFFIRM",
n: "NEGATIVE",
r: "ROGER",
s: "STBY",
#o: "none?",
#y: "any?",
};
2020-11-29 16:58:38 +00:00
var freeText = {
new: func() {
return {parents: [freeText]};
2020-11-29 16:58:38 +00:00
},
selection: 9,
changed: 0,
getText: func() {
if (me.selection == 0) {
return prefixes["acPerf"];
} elsif (me.selection == 1) {
return prefixes["weather"];
} elsif (me.selection == 2) {
return prefixes["turbulence"];
} elsif (me.selection == 3) {
return prefixes["medical"];
} elsif (me.selection == 4) {
return prefixes["technical"];
} elsif (me.selection == 5) {
return prefixes["discretion"];
} else {
return "";
}
}
2020-11-29 16:58:38 +00:00
};
var freeTexts = [freeText.new(), freeText.new()];