From 2a291eb3a1becc4d36b75efb3627aa2f8849f72e Mon Sep 17 00:00:00 2001 From: Charles Wang Date: Mon, 28 Feb 2022 12:29:53 -0500 Subject: [PATCH] g3000 v0.7.7 (#1492) * updated for SU8 compat * updated docs and manifest * update main readme --- .../workingtitle-g3000-metapackage.xml | 2 +- README.md | 2 +- docs/workingtitle-g3000/CHANGES.md | 4 + docs/workingtitle-g3000/README.md | 14 +- .../NavSystems/Shared/NavSystem.js | 242 ++++++------------ 5 files changed, 92 insertions(+), 172 deletions(-) diff --git a/PackageDefinitions/workingtitle-g3000-metapackage.xml b/PackageDefinitions/workingtitle-g3000-metapackage.xml index bbb572320..eacc38a75 100644 --- a/PackageDefinitions/workingtitle-g3000-metapackage.xml +++ b/PackageDefinitions/workingtitle-g3000-metapackage.xml @@ -1,4 +1,4 @@ - + CUSTOM Working Title G3000 diff --git a/README.md b/README.md index 965621c8e..424a6b663 100644 --- a/README.md +++ b/README.md @@ -13,5 +13,5 @@ You can keep track of Updates and Progress on Discord [https://discord.com/invit Project | Description | Current Version | Documentation --------|-------------|-----------------|-------------- CJ4 | Performance and avionics improvements for the Citation CJ4 | [v0.12.12](https://github.com/Working-Title-MSFS-Mods/fspackages/releases/tag/cj4-v0.12.12) | [docs](https://github.com/Working-Title-MSFS-Mods/fspackages/tree/main/docs/workingtitle-cj4) -G3000 | Fixes and enhancements for the stock G3000 avionics package | [v0.7.6](https://github.com/Working-Title-MSFS-Mods/fspackages/releases/tag/g3000-v0.7.6) | [docs](https://github.com/Working-Title-MSFS-Mods/fspackages/tree/main/docs/workingtitle-g3000) +G3000 | Fixes and enhancements for the stock G3000 avionics package | [v0.7.7](https://github.com/Working-Title-MSFS-Mods/fspackages/releases/tag/g3000-v0.7.7) | [docs](https://github.com/Working-Title-MSFS-Mods/fspackages/tree/main/docs/workingtitle-g3000) GX | Fixes and enhancements for the stock G3X Touch avionics package | [v0.1.0](https://github.com/Working-Title-MSFS-Mods/fspackages/releases/tag/gx-v0.1.0) | [docs](https://github.com/Working-Title-MSFS-Mods/fspackages/tree/main/docs/workingtitle-gx) diff --git a/docs/workingtitle-g3000/CHANGES.md b/docs/workingtitle-g3000/CHANGES.md index 96ab35fa6..d8799ba1a 100644 --- a/docs/workingtitle-g3000/CHANGES.md +++ b/docs/workingtitle-g3000/CHANGES.md @@ -1,5 +1,9 @@ # Changelog +### v0.7.7 +**Fixes** +- \[Compatibility\] Now compatible with game patch 1.23.11.0 (Sim Update 8). + ### v0.7.6 **Fixes** - \[FPL\] Fixed an error when activating a Direct To without an active flight plan that would cause both the PFD and MFD to freeze. diff --git a/docs/workingtitle-g3000/README.md b/docs/workingtitle-g3000/README.md index 3ba18d6bb..7b52f9ca7 100644 --- a/docs/workingtitle-g3000/README.md +++ b/docs/workingtitle-g3000/README.md @@ -1,6 +1,6 @@ # Working Title G3000 -### Latest version: v0.7.6 +### Latest version: v0.7.7 ### Description This is a mod for MSFS2020 that aims to improve the in-game G3000 and G5000. The goal is to bring functionality closer to the real-life units, with a focus on both features and layout/UI. @@ -8,7 +8,7 @@ This is a mod for MSFS2020 that aims to improve the in-game G3000 and G5000. The This mod was created with cross-compatibility in mind. It modifies the minimum number of base files possible to achieve its goals, so it should be compatible with most other mods, including all other WorkingTitle mods. However, because of the nature of the mod, it will conflict with other mods that make changes to the G3000. ### Installation -Download `workingtitle-g3000-v0.7.6.zip` from the Github release page. Do not download the Source code files unless you are sure you want those. +Download `workingtitle-g3000-v0.7.7.zip` from the Github release page. Do not download the Source code files unless you are sure you want those. To install, copy the `workingtitle-g3000` folder from the zip file into your `Community` directory. @@ -29,14 +29,9 @@ This mod enables the G3000/5000 to natively display Navigraph charts. Use of thi During a flight, you can check your Navigraph account link status in the GTC Database Status page. If both the Standby and Active fields display "Available", this means an account has been linked and chart database access is available. If the Standby field displays "Available" and the Active field displays "None", this means an account was linked but access has expired and you need to re-authenticate using the above process to restore chart database access. If both fields display "None", this means no Navigraph account has been linked. -### Release Highlights for v0.7.6 +### Release Highlights for v0.7.7 *Please refer to the changelog for a more detailed description of changes in this release.* -- Now compatible with game patch 1.20.6.0 (Sim Update 6). - -**Fixes** -- \[FPL\] Fixed an error when activating a Direct To without an active flight plan that would cause both the PFD and MFD to freeze. -- \[PFD\] Fixed a bug where the attitude indicator would not update. -- \[PFD\] The flight path marker is now visible when SVT is enabled. +- Now compatible with game patch 1.23.11.0 (Sim Update 8). ### Known Issues - \[General\] The sim's load screen no longer waits for avionics to finish loading before starting a flight. Therefore, you may need to wait a few seconds after entering a flight before the avionics finish loading. @@ -50,7 +45,6 @@ During a flight, you can check your Navigraph account link status in the GTC Dat - \[NavMap\] Airport waypoint symbols will only show around a certain geographic distance from the center of the map (this does not apply to airports that are part of the active flight plan). This is due to the way the game searches for airports (the number of results is limited for performance reasons and there is no option to filter the search e.g. by size to reduce the performance penalty). - \[Weather Radar\] When NEXRAD is enabled for the navigation map in the right MFD pane, the weather radar display in the left MFD pane will have artifacts. This does not occur with the opposite arrangement (i.e. NEXRAD enabled in left MFD pane, weather radar in right MFD pane). The bug also occurs when enabling NEXRAD for the PFD inset map. A workaround for now is to simply disable NEXRAD or to enable it in the left pane instead of the right (and disable it for the PFD inset map) if you wish to use it in conjunction with the weather radar. - \[Misc\] MSFS will take an increased amount of time to fully shut down (up to several minutes) when closing the game after starting a flight that uses the road data package. The game window will still close promptly, but the game process will run in the background and game audio can be heard. The process is not frozen and will eventually shut down on its own, however if you wish to speed up the process, you can manually end-task or end-process MSFS through Task Manager. Disabling world regions for the road data package in the mod configuration file will also speed up the shut down process. -- \[Misc\] TBM 930: the standby airspeed indicator still redlines at lower speeds than it should. If this bothers you, change the `crossover_speed` setting in `asobo-aircraft-tbm930\SimObjects\Airplanes\Asobo_TBM930\flight_model.cfg` to 0. If you use the TBM improvement mod, you should change the value in the `flight_model.cfg` file found in that mod's folder. ### FAQ - **Q**: I copied the mod folder to my Community folder but don't get any of the new features. What do I do? diff --git a/src/workingtitle-vcockpits-instruments-navsystems-g3000/html_ui/WTg3000/Pages/VCockpit/Instruments/NavSystems/Shared/NavSystem.js b/src/workingtitle-vcockpits-instruments-navsystems-g3000/html_ui/WTg3000/Pages/VCockpit/Instruments/NavSystems/Shared/NavSystem.js index 23a98a38d..7f954413f 100644 --- a/src/workingtitle-vcockpits-instruments-navsystems-g3000/html_ui/WTg3000/Pages/VCockpit/Instruments/NavSystems/Shared/NavSystem.js +++ b/src/workingtitle-vcockpits-instruments-navsystems-g3000/html_ui/WTg3000/Pages/VCockpit/Instruments/NavSystems/Shared/NavSystem.js @@ -1,11 +1,3 @@ -var ScreenState; -(function (ScreenState) { - ScreenState[ScreenState["OFF"] = 0] = "OFF"; - ScreenState[ScreenState["INIT"] = 1] = "INIT"; - ScreenState[ScreenState["WAITING_VALIDATION"] = 2] = "WAITING_VALIDATION"; - ScreenState[ScreenState["ON"] = 3] = "ON"; - ScreenState[ScreenState["REVERSIONARY"] = 4] = "REVERSIONARY"; -})(ScreenState || (ScreenState = {})); class NavSystem extends WT_G3x5_BaseInstrument { constructor() { super(...arguments); @@ -37,13 +29,6 @@ class NavSystem extends WT_G3x5_BaseInstrument { this.forcedAspectRatioSet = false; this.forcedAspectRatio = 1; this.forcedScreenRatio = 1; - this.initDuration = 0; - this.hasBeenOff = false; - this.isStarted = false; - this.needValidationAfterInit = false; - this.initAcknowledged = false; - this.screenState = ScreenState.OFF; - this.reversionaryMode = false; } get flightPlanManager() { return this.currFlightPlanManager; } get instrumentAlias() { return null; } @@ -74,10 +59,6 @@ class NavSystem extends WT_G3x5_BaseInstrument { this.soundSourceNode = soundSourceNodeElem[0].textContent; } if (this.instrumentXmlConfig) { - let skipValidationAfterInitElem = this.instrumentXmlConfig.getElementsByTagName("SkipValidationAfterInit"); - if (skipValidationAfterInitElem.length > 0 && this.needValidationAfterInit) { - this.needValidationAfterInit = skipValidationAfterInitElem[0].textContent != "True"; - } let styleNode = this.instrumentXmlConfig.getElementsByTagName("Style"); if (styleNode.length > 0) { diffAndSetAttribute(this.electricity, "displaystyle", styleNode[0].textContent); @@ -331,12 +312,37 @@ class NavSystem extends WT_G3x5_BaseInstrument { } reboot() { super.reboot(); - this.startTime = Date.now(); - this.hasBeenOff = false; - this.isStarted = false; - this.initAcknowledged = false; this.budgetedItemId = 0; } + onShutDown() { + super.onShutDown(); + for (let i = 0; i < this.pageGroups.length; i++) { + for (let j = 0; j < this.pageGroups[i].pages.length; j++) { + this.pageGroups[i].pages[j].onShutDown(); + } + } + for (let i = 0; i < this.IndependentsElements.length; i++) { + this.IndependentsElements[i].onShutDown(); + } + for (let i = 0; i < this.eventLinkedPopUpElements.length; i++) { + this.eventLinkedPopUpElements[i].onShutDown(); + } + } + onPowerOn() { + super.onPowerOn(); + this.budgetedItemId = 0; + for (let i = 0; i < this.pageGroups.length; i++) { + for (let j = 0; j < this.pageGroups[i].pages.length; j++) { + this.pageGroups[i].pages[j].onPowerOn(); + } + } + for (let i = 0; i < this.IndependentsElements.length; i++) { + this.IndependentsElements[i].onPowerOn(); + } + for (let i = 0; i < this.eventLinkedPopUpElements.length; i++) { + this.eventLinkedPopUpElements[i].onPowerOn(); + } + } Update() { super.Update(); if (NavSystem._iterations < 10000) { @@ -392,64 +398,6 @@ class NavSystem extends WT_G3x5_BaseInstrument { NavSystem.mediumTimeUpdate *= (1 - factor); NavSystem.mediumTimeUpdate += factor * t; } - updateElectricity() { - if (this.isElectricityAvailable()) { - if (!this.isStarted) { - this.onPowerOn(); - } - if (this.isBootProcedureComplete()) { - if (this.reversionaryMode) { - if (this.screenState != ScreenState.REVERSIONARY) { - this.screenState = ScreenState.REVERSIONARY; - if (this.electricity) - diffAndSetAttribute(this.electricity, "state", "Backup"); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_ScreenLuminosity", "number", 1); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_State", "number", 3); - } - } - else { - if (this.screenState != ScreenState.ON) { - this.screenState = ScreenState.ON; - if (this.electricity) - diffAndSetAttribute(this.electricity, "state", "on"); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_ScreenLuminosity", "number", 1); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_State", "number", 2); - } - } - } - else if (Date.now() - this.startTime > this.initDuration) { - if (this.screenState != ScreenState.WAITING_VALIDATION) { - this.screenState = ScreenState.WAITING_VALIDATION; - if (this.electricity) - diffAndSetAttribute(this.electricity, "state", "initWaitingValidation"); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_ScreenLuminosity", "number", 0.2); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_State", "number", 1); - } - } - else { - if (this.screenState != ScreenState.INIT) { - this.screenState = ScreenState.INIT; - if (this.electricity) - diffAndSetAttribute(this.electricity, "state", "init"); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_ScreenLuminosity", "number", 0.2); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_State", "number", 1); - } - } - } - else { - this.hasBeenOff = true; - if (this.isStarted) { - this.onShutDown(); - } - if (this.screenState != ScreenState.OFF) { - this.screenState = ScreenState.OFF; - if (this.electricity) - diffAndSetAttribute(this.electricity, "state", "off"); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_ScreenLuminosity", "number", 0); - SimVar.SetSimVarValue("L:" + this.instrumentIdentifier + "_State", "number", 0); - } - } - } updateGroups() { for (let i = 0; i < this.IndependentsElements.length; i++) { this.IndependentsElements[i].onUpdate(this.deltaTime); @@ -897,58 +845,6 @@ class NavSystem extends WT_G3x5_BaseInstrument { this.eventLinkedPopUpElements[i].onSoundEnd(_eventId); } } - onShutDown() { - console.log("System Turned Off"); - this.hasBeenOff = true; - this.isStarted = false; - this.initAcknowledged = false; - for (let i = 0; i < this.pageGroups.length; i++) { - for (let j = 0; j < this.pageGroups[i].pages.length; j++) { - this.pageGroups[i].pages[j].onShutDown(); - } - } - for (let i = 0; i < this.IndependentsElements.length; i++) { - this.IndependentsElements[i].onShutDown(); - } - for (let i = 0; i < this.eventLinkedPopUpElements.length; i++) { - this.eventLinkedPopUpElements[i].onShutDown(); - } - this.clearAlwaysList(); - this.clearPendingCalls(); - } - onPowerOn() { - console.log("System Turned ON"); - this.startTime = Date.now(); - this.isStarted = true; - this.budgetedItemId = 0; - for (let i = 0; i < this.pageGroups.length; i++) { - for (let j = 0; j < this.pageGroups[i].pages.length; j++) { - this.pageGroups[i].pages[j].onPowerOn(); - } - } - for (let i = 0; i < this.IndependentsElements.length; i++) { - this.IndependentsElements[i].onPowerOn(); - } - for (let i = 0; i < this.eventLinkedPopUpElements.length; i++) { - this.eventLinkedPopUpElements[i].onPowerOn(); - } - } - isBootProcedureComplete() { - if (!this.hasBeenOff) - return true; - if ((Date.now() - this.startTime > this.initDuration) && (this.initAcknowledged || !this.needValidationAfterInit)) - return true; - return false; - } - acknowledgeInit() { - this.initAcknowledged = true; - } - isInReversionaryMode() { - return this.reversionaryMode; - } - wasTurnedOff() { - return this.hasBeenOff; - } hasWeatherRadar() { if (this.instrumentXmlConfig) { let elem = this.instrumentXmlConfig.getElementsByTagName("WeatherRadar"); @@ -2154,6 +2050,7 @@ class Annunciations extends NavSystemElement { this.alert = false; this.needReload = true; this.rootElementName = "Annunciations"; + this.isAnnunciationsManager = false; } init(root) { this.engineType = Simplane.getEngineType(); @@ -2168,6 +2065,10 @@ class Annunciations extends NavSystemElement { } } } + if (!SimVar.GetSimVarValue("L:Annunciations_Manager_Initialized", "Bool")) { + SimVar.SetSimVarValue("L:Annunciations_Manager_Initialized", "Bool", true); + this.isAnnunciationsManager = true; + } } onEnter() { } @@ -2202,12 +2103,13 @@ class Annunciations extends NavSystemElement { break; } msg.baseText = _element.getElementsByTagName("Text")[0].textContent; - let conditions = _element.getElementsByTagName("Condition"); - for (let i = 0; i < conditions.length; i++) { - let condition = new XMLCondition(); - condition.logic = new CompositeLogicXMLElement(this.gps, conditions[i]); - condition.suffix = conditions[i].getAttribute("Suffix"); - msg.conditions.push(condition); + for (let i = 0; i < _element.children.length; i++) { + if (_element.children[i].tagName == "Condition") { + let condition = new XMLCondition(); + condition.logic = new CompositeLogicXMLElement(this.gps, _element.children[i]); + condition.suffix = _element.children[i].getAttribute("Suffix"); + msg.conditions.push(condition); + } } this.allMessages.push(msg); } @@ -2280,6 +2182,25 @@ class Cabin_Annunciations extends Annunciations { } 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; @@ -2296,7 +2217,7 @@ class Cabin_Annunciations extends Annunciations { break; case Annunciation_MessageType.CAUTION: this.displayCaution.push(message); - if (!message.Acknowledged && !this.isPlayingWarningTone && this.gps.isPrimary) { + if (!message.Acknowledged && !this.isPlayingWarningTone && this.isAnnunciationsManager) { let res = this.gps.playInstrumentSound("tone_caution"); if (res) this.isPlayingWarningTone = true; @@ -2363,7 +2284,21 @@ class Cabin_Annunciations extends Annunciations { messages += '
' + this.displayAdvisory[i].Text + "
"; } this.warningTone = warningOn > 0; - if (this.gps.isPrimary) { + 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); } @@ -2371,7 +2306,7 @@ class Cabin_Annunciations extends Annunciations { diffAndSetHTML(this.annunciations, messages); this.needReload = false; } - if (this.warningTone && !this.isPlayingWarningTone && this.gps.isPrimary) { + if (this.warningTone && !this.isPlayingWarningTone && this.isAnnunciationsManager) { let res = this.gps.playInstrumentSound("tone_warning"); if (res) this.isPlayingWarningTone = true; @@ -2380,25 +2315,10 @@ class Cabin_Annunciations extends Annunciations { onEvent(_event) { switch (_event) { case "Master_Caution_Push": - for (let i = 0; i < this.allMessages.length; i++) { - if (this.allMessages[i].Type == Annunciation_MessageType.CAUTION && this.allMessages[i].Visible) { - this.allMessages[i].Acknowledged = true; - this.needReload = true; - } - } + SimVar.SetSimVarValue("K:MASTER_CAUTION_ACKNOWLEDGE", "Bool", 1); break; case "Master_Warning_Push": - for (let i = 0; i < this.allMessages.length; i++) { - if (this.allMessages[i].Type == Annunciation_MessageType.WARNING && this.allMessages[i].Visible) { - this.allMessages[i].Acknowledged = true; - this.needReload = true; - } - } - if (this.needReload && this.firstAcknowledge && this.gps.isPrimary) { - let res = this.gps.playInstrumentSound("aural_warning_ok"); - if (res) - this.firstAcknowledge = false; - } + SimVar.SetSimVarValue("K:MASTER_WARNING_ACKNOWLEDGE", "Bool", 1); break; } } @@ -2415,7 +2335,9 @@ class Cabin_Annunciations extends Annunciations { this.displayCaution = []; this.displayWarning = []; this.displayAdvisory = []; - if (!this.gps || this.gps.isPrimary) { + if (this.isAnnunciationsManager) { + SimVar.SetSimVarValue("K:MASTER_WARNING_OFF", "Bool", 1); + SimVar.SetSimVarValue("K:MASTER_CAUTION_OFF", "Bool", 1); SimVar.SetSimVarValue("L:Generic_Master_Warning_Active", "Bool", 0); SimVar.SetSimVarValue("L:Generic_Master_Caution_Active", "Bool", 0); }