From d21546e0447f969ee0b8b515a394069f5e623e23 Mon Sep 17 00:00:00 2001 From: dga711 Date: Sun, 6 Mar 2022 21:25:56 +0100 Subject: [PATCH 1/2] cj4: fix warning/caution tone --- .../SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml | 4 ++-- .../VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js | 1 + 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml b/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml index 128d70e1a..ab08378fb 100644 --- a/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml +++ b/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml @@ -423,8 +423,8 @@ - - + + diff --git a/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js b/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js index 121e7e64b..10c1ebaed 100644 --- a/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js +++ b/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js @@ -3053,6 +3053,7 @@ class CJ4_SystemAnnunciations extends Cabin_Annunciations { super(); this.rootElementName = ""; this.offStart = true; + this.warningTone = true; } init(_root) { super.init(_root); From b8705bc71471a0408db4b32baa1f76cf1596ba1b Mon Sep 17 00:00:00 2001 From: dga711 Date: Sun, 6 Mar 2022 21:30:03 +0100 Subject: [PATCH 2/2] cj4: fix warning/caution tone using wt sounds --- .../Airplanes/Asobo_CJ4/sound/sound.xml | 4 +- .../Airliners/CJ4/Shared/CJ4_Shared.js | 137 +++++++++++++++++- 2 files changed, 135 insertions(+), 6 deletions(-) diff --git a/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml b/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml index ab08378fb..128d70e1a 100644 --- a/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml +++ b/src/workingtitle-aircraft-cj4/SimObjects/Airplanes/Asobo_CJ4/sound/sound.xml @@ -423,8 +423,8 @@ - - + + diff --git a/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js b/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js index 10c1ebaed..ed374a508 100644 --- a/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js +++ b/src/workingtitle-vcockpits-instruments-cj4/html_ui/Pages/VCockpit/Instruments/Airliners/CJ4/Shared/CJ4_Shared.js @@ -3054,16 +3054,145 @@ class CJ4_SystemAnnunciations extends Cabin_Annunciations { this.rootElementName = ""; this.offStart = true; this.warningTone = true; + this.warningToneNameZ = new Name_Z("WT_tone_warning"); + this.cautionToneNameZ = new Name_Z("WT_tone_caution"); } init(_root) { super.init(_root); this.annunciations = _root.querySelector(".SystemAnnunciations"); } - onUpdate(_dTime) { - if (!this.annunciations) - return; - super.onUpdate(_dTime); + onUpdate(_deltaTime) { + this.FrameCounterForAlternation++; + let masterWarningAcknowledged = SimVar.GetSimVarValue("MASTER WARNING ACKNOWLEDGED", "Bool"); + let masterCautionAcknowledged = SimVar.GetSimVarValue("MASTER CAUTION ACKNOWLEDGED", "Bool"); + for (let i = 0; i < this.allMessages.length; i++) { + let message = this.allMessages[i]; + if (message.Visible && !message.Acknowledged) { + if (message.Type == Annunciation_MessageType.CAUTION && masterCautionAcknowledged) { + this.needReload = true; + message.Acknowledged = true; + if (this.firstAcknowledge && this.isAnnunciationsManager) { + if (this.gps.playInstrumentSound("aural_warning_ok")) + this.firstAcknowledge = false; + } + } + else if (message.Type == Annunciation_MessageType.WARNING && masterWarningAcknowledged) { + this.needReload = true; + message.Acknowledged = true; + } + } + } + for (var i = (this.FrameCounterForAlternation & 7); i < this.allMessages.length; i += 8) { + var message = this.allMessages[i]; + var value = false; + if (message.Handler) + value = message.Handler() != 0; + if (value != message.Visible) { + this.needReload = true; + message.Visible = value; + message.Acknowledged = (this.gps.getTimeSinceStart() < 10000 && !this.offStart); + if (value) { + switch (message.Type) { + case Annunciation_MessageType.WARNING: + this.displayWarning.push(message); + break; + case Annunciation_MessageType.CAUTION: + this.displayCaution.push(message); + if (!message.Acknowledged && !this.isPlayingWarningTone && this.isAnnunciationsManager) { + let res = this.gps.playInstrumentSound("WT_tone_caution"); + if (res) + this.isPlayingWarningTone = true; + } + break; + case Annunciation_MessageType.ADVISORY: + this.displayAdvisory.push(message); + break; + } + } + else { + switch (message.Type) { + case Annunciation_MessageType.WARNING: + for (let i = 0; i < this.displayWarning.length; i++) { + if (this.displayWarning[i].Text == message.Text) { + this.displayWarning.splice(i, 1); + break; + } + } + break; + case Annunciation_MessageType.CAUTION: + for (let i = 0; i < this.displayCaution.length; i++) { + if (this.displayCaution[i].Text == message.Text) { + this.displayCaution.splice(i, 1); + break; + } + } + break; + case Annunciation_MessageType.ADVISORY: + for (let i = 0; i < this.displayAdvisory.length; i++) { + if (this.displayAdvisory[i].Text == message.Text) { + this.displayAdvisory.splice(i, 1); + break; + } + } + break; + } + } + } + } + if (this.annunciations) + diffAndSetAttribute(this.annunciations, "state", this.gps.blinkGetState(800, 400) ? "Blink" : "None"); + if (this.needReload) { + let warningOn = 0; + let cautionOn = 0; + let messages = ""; + for (let i = this.displayWarning.length - 1; i >= 0; i--) { + messages += '
' + this.displayWarning[i].Text + "
"; + } + for (let i = this.displayCaution.length - 1; i >= 0; i--) { + messages += '
' + this.displayCaution[i].Text + "
"; + } + for (let i = this.displayAdvisory.length - 1; i >= 0; i--) { + messages += '
' + this.displayAdvisory[i].Text + "
"; + } + this.warningTone = warningOn > 0; + if (this.isAnnunciationsManager) { + let masterWarningActive = SimVar.GetSimVarValue("MASTER WARNING ACTIVE", "Bool"); + if ((this.displayWarning.length > 0) != masterWarningActive || warningOn) { + SimVar.SetSimVarValue("K:MASTER_WARNING_SET", "Bool", (this.displayWarning.length > 0)); + } + if (this.displayWarning.length > 0 && !warningOn) { + SimVar.SetSimVarValue("K:MASTER_WARNING_ACKNOWLEDGE", "Bool", 1); + } + let masterCautionActive = SimVar.GetSimVarValue("MASTER CAUTION ACTIVE", "Bool"); + if ((this.displayCaution.length > 0) != masterCautionActive || cautionOn) { + SimVar.SetSimVarValue("K:MASTER_CAUTION_SET", "Bool", (this.displayCaution.length > 0)); + } + if (this.displayCaution.length > 0 && !cautionOn) { + SimVar.SetSimVarValue("K:MASTER_CAUTION_ACKNOWLEDGE", "Bool", 1); + } + SimVar.SetSimVarValue("L:Generic_Master_Warning_Active", "Bool", warningOn); + SimVar.SetSimVarValue("L:Generic_Master_Caution_Active", "Bool", cautionOn); + } + if (this.annunciations) + diffAndSetHTML(this.annunciations, messages); + this.needReload = false; + } + if (this.warningTone && !this.isPlayingWarningTone && this.isAnnunciationsManager) { + let res = this.gps.playInstrumentSound("WT_tone_warning"); + if (res) + this.isPlayingWarningTone = true; + } } } class CJ4_SystemWarnings extends Cabin_Warnings {