1
0
Fork 0

Merge branch 'dev' into 3D

This commit is contained in:
Jonathan Redpath 2021-12-27 12:15:05 +00:00
commit 923b416d84
16 changed files with 1028 additions and 426 deletions

View file

@ -111,6 +111,7 @@
<type>rotate</type> <type>rotate</type>
<object-name>ddrmi_hdg</object-name> <object-name>ddrmi_hdg</object-name>
<property>instrumentation/ddrmi/heading</property> <property>instrumentation/ddrmi/heading</property>
<factor>-1</factor>
<axis> <axis>
<object-name>ddrmi_hdg.axis</object-name> <object-name>ddrmi_hdg.axis</object-name>
</axis> </axis>
@ -121,6 +122,7 @@
<object-name>ddrmi_pointer_1</object-name> <object-name>ddrmi_pointer_1</object-name>
<type>rotate</type> <type>rotate</type>
<property>instrumentation/ddrmi/needle-1</property> <property>instrumentation/ddrmi/needle-1</property>
<factor>-1</factor>
<axis> <axis>
<object-name>ddrmi_hdg.axis</object-name> <object-name>ddrmi_hdg.axis</object-name>
</axis> </axis>
@ -131,6 +133,7 @@
<object-name>ddrmi_pointer_2</object-name> <object-name>ddrmi_pointer_2</object-name>
<type>rotate</type> <type>rotate</type>
<property>instrumentation/ddrmi/needle-2</property> <property>instrumentation/ddrmi/needle-2</property>
<factor>-1</factor>
<axis> <axis>
<object-name>ddrmi_hdg.axis</object-name> <object-name>ddrmi_hdg.axis</object-name>
</axis> </axis>
@ -148,7 +151,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
<min>-1</min> <min>0</min>
<max>1</max> <max>1</max>
</binding> </binding>
</action> </action>
@ -160,8 +163,7 @@
<object-name>ddrmi_vor_adf_select_1</object-name> <object-name>ddrmi_vor_adf_select_1</object-name>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
<interpolation> <interpolation>
<entry><ind>-1</ind><dep>90</dep></entry> <!-- ADF --> <entry><ind> 0</ind><dep>90</dep></entry> <!-- ADF -->
<entry><ind> 0</ind><dep>45</dep></entry> <!-- OFF -->
<entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR --> <entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR -->
</interpolation> </interpolation>
<axis> <axis>
@ -180,7 +182,7 @@
<binding> <binding>
<command>property-adjust</command> <command>property-adjust</command>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>
<min>-1</min> <min>0</min>
<max>1</max> <max>1</max>
</binding> </binding>
</action> </action>
@ -192,8 +194,7 @@
<object-name>ddrmi_vor_adf_select_2</object-name> <object-name>ddrmi_vor_adf_select_2</object-name>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>
<interpolation> <interpolation>
<entry><ind>-1</ind><dep>-90</dep></entry> <!-- ADF --> <entry><ind> 0</ind><dep>-90</dep></entry> <!-- ADF -->
<entry><ind> 0</ind><dep>-45</dep></entry> <!-- OFF -->
<entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR --> <entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR -->
</interpolation> </interpolation>
<axis> <axis>
@ -9096,8 +9097,6 @@
<kerning>default</kerning> <kerning>default</kerning>
</text> </text>
<text> <text>
<name>dme1_0</name> <name>dme1_0</name>
<offsets> <offsets>
@ -9160,14 +9159,74 @@
<kerning>default</kerning> <kerning>default</kerning>
</text> </text>
<text>
<name>dme_flag</name>
<offsets>
<x-m>-0.529</x-m>
<y-m>-0.149</y-m>
<z-m>0.1305</z-m>
<heading-deg>90</heading-deg>
<roll-deg>72.81</roll-deg>
</offsets>
<alignment>right-center</alignment>
<axis-alignment>xy-plane</axis-alignment>
<type type="string">literal</type>
<text type="string">----</text>
<truncate>false</truncate>
<layout>left-to-right</layout>
<draw-text type="bool">true</draw-text> <!-- draw the text itself -->
<draw-alignment type="bool">false</draw-alignment> <!-- draw crosshair at object center -->
<draw-boundingbox type="bool">false</draw-boundingbox> <!-- draw a bounding box -->
<font>led.txf</font> <!-- The font file name, relative to data/Fonts -->
<character-size type="double">0.007</character-size> <!-- size (height) im meters -->
<character-aspect-ratio type="double">1.0</character-aspect-ratio>
<max-height>0.012</max-height> <!-- the maximum height of the text -->
<max-width>0.040</max-width> <!-- the maximum width of the text -->
<font-resolution>
<width type="int">32</width>
<height type="int">32</height>
</font-resolution>
<kerning>default</kerning>
</text>
<text>
<name>dme1_flag</name>
<offsets>
<x-m>-0.529</x-m>
<y-m>-0.116</y-m>
<z-m>0.1305</z-m>
<heading-deg>90</heading-deg>
<roll-deg>72.81</roll-deg>
</offsets>
<alignment>right-center</alignment>
<axis-alignment>xy-plane</axis-alignment>
<type type="string">literal</type>
<text type="string">----</text>
<truncate>false</truncate>
<layout>left-to-right</layout>
<draw-text type="bool">true</draw-text> <!-- draw the text itself -->
<draw-alignment type="bool">false</draw-alignment> <!-- draw crosshair at object center -->
<draw-boundingbox type="bool">false</draw-boundingbox> <!-- draw a bounding box -->
<font>led.txf</font> <!-- The font file name, relative to data/Fonts -->
<character-size type="double">0.007</character-size> <!-- size (height) im meters -->
<character-aspect-ratio type="double">1.0</character-aspect-ratio>
<max-height>0.012</max-height> <!-- the maximum height of the text -->
<max-width>0.040</max-width> <!-- the maximum width of the text -->
<font-resolution>
<width type="int">32</width>
<height type="int">32</height>
</font-resolution>
<kerning>default</kerning>
</text>
<animation> <animation>
<type>material</type> <type>material</type>
<object-name>dme_0</object-name> <object-name>dme_0</object-name>
<object-name>dme</object-name> <object-name>dme</object-name>
<!-- <object-name>dme_20</object-name>--> <object-name>dme_flag</object-name>
<object-name>dme1_0</object-name> <object-name>dme1_0</object-name>
<object-name>dme1</object-name> <object-name>dme1</object-name>
<!-- <object-name>dme1_20</object-name>--> <object-name>dme1_flag</object-name>
<diffuse> <diffuse>
<red>1.00</red> <red>1.00</red>
<green>0.355</green> <green>0.355</green>
@ -9208,8 +9267,8 @@
</greater-than> </greater-than>
</or> </or>
<greater-than-equals> <greater-than-equals>
<property>systems/electrical/bus/dc-ess</property> <property>systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
@ -9235,8 +9294,8 @@
<value>20</value> <value>20</value>
</less-than-equals> </less-than-equals>
<greater-than-equals> <greater-than-equals>
<property>systems/electrical/bus/dc-ess</property> <property>systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
@ -9264,8 +9323,8 @@
</greater-than> </greater-than>
</or> </or>
<greater-than-equals> <greater-than-equals>
<property>systems/electrical/bus/dc-ess</property> <property>systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>
@ -9291,8 +9350,46 @@
<value>20.0</value> <value>20.0</value>
</less-than-equals> </less-than-equals>
<greater-than-equals> <greater-than-equals>
<property>systems/electrical/bus/dc-ess</property> <property>systems/electrical/bus/ac-ess</property>
<value>25.0</value> <value>110.0</value>
</greater-than-equals>
<equals>
<property>instrumentation/ddrmi/vor-adf-2</property>
<value>1</value>
</equals>
</and>
</condition>
</animation>
<animation>
<type>select</type>
<object-name>dme_flag</object-name>
<condition>
<and>
<property>instrumentation/dme[2]/operable</property>
<not><property>instrumentation/dme[2]/in-range</property></not>
<greater-than-equals>
<property>systems/electrical/bus/ac-ess</property>
<value>110.0</value>
</greater-than-equals>
<equals>
<property>instrumentation/ddrmi/vor-adf-1</property>
<value>1</value>
</equals>
</and>
</condition>
</animation>
<animation>
<type>select</type>
<object-name>dme1_flag</object-name>
<condition>
<and>
<property>instrumentation/dme[3]/operable</property>
<not><property>instrumentation/dme[3]/in-range</property></not>
<greater-than-equals>
<property>systems/electrical/bus/ac-ess</property>
<value>110.0</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>

View file

@ -82,23 +82,7 @@ var perfFactor = props.globals.getNode("/options/company-options/perf-factor", 1
var database1 = props.globals.getNode("/FMGC/internal/navdatabase", 1); var database1 = props.globals.getNode("/FMGC/internal/navdatabase", 1);
var database2 = props.globals.getNode("/FMGC/internal/navdatabase2", 1); var database2 = props.globals.getNode("/FMGC/internal/navdatabase2", 1);
var databaseCode = props.globals.getNode("/FMGC/internal/navdatabasecode", 1); var databaseCode = props.globals.getNode("/FMGC/internal/navdatabasecode", 1);
# RADNAV
var vor1 = props.globals.getNode("/FMGC/internal/vor1-mcdu", 1);
var vor2 = props.globals.getNode("/FMGC/internal/vor2-mcdu", 1);
var ils1 = props.globals.getNode("/FMGC/internal/ils1-mcdu", 1);
var adf1 = props.globals.getNode("/FMGC/internal/adf1-mcdu", 1);
var adf2 = props.globals.getNode("/FMGC/internal/adf2-mcdu", 1);
var vor1FreqSet = props.globals.getNode("/FMGC/internal/vor1freq-set", 1);
var vor1CRSSet = props.globals.getNode("/FMGC/internal/vor1crs-set", 1);
var vor2FreqSet = props.globals.getNode("/FMGC/internal/vor2freq-set", 1);
var vor2CRSSet = props.globals.getNode("/FMGC/internal/vor2crs-set", 1);
var ils1FreqSet = props.globals.getNode("/FMGC/internal/ils1freq-set", 1);
var ils1CRSSet = props.globals.getNode("/FMGC/internal/ils1crs-set", 1);
var adf1FreqSet = props.globals.getNode("/FMGC/internal/adf1freq-set", 1);
var adf2FreqSet = props.globals.getNode("/FMGC/internal/adf2freq-set", 1);
var ils1CRS = props.globals.getNode("/instrumentation/nav[0]/radials/selected-deg", 1);
var vor1CRS = props.globals.getNode("/instrumentation/nav[2]/radials/selected-deg", 1);
var vor2CRS = props.globals.getNode("/instrumentation/nav[3]/radials/selected-deg", 1);
# INT-A # INT-A
var ADIRSMCDUBTN = props.globals.getNode("/controls/adirs/mcducbtn", 1); var ADIRSMCDUBTN = props.globals.getNode("/controls/adirs/mcducbtn", 1);
# IRSINIT variables # IRSINIT variables
@ -2865,8 +2849,8 @@ var canvas_MCDU_base = {
me["Simple_L0S"].hide(); me["Simple_L0S"].hide();
showLeftS(me,1, 1, 1, 1, 1, -1); showLeftS(me,1, 1, 1, 1, 1, -1);
showLeftArrow(me,-1, -1, -1, -1, -1, -1); showLeftArrow(me,-1, -1, -1, -1, -1, -1);
showRight(me,1, 1, 1, 1, 1, -1); showRight(me,1, 1, -1, -1, 1, -1);
showRightS(me,1, 1, 1, 1, 1, -1); showRightS(me,1, 1, -1, -1, 1, -1);
showRightArrow(me,-1, -1, -1, -1, -1, -1); showRightArrow(me,-1, -1, -1, -1, -1, -1);
me["Simple_C3B"].hide(); me["Simple_C3B"].hide();
me["Simple_C4B"].hide(); me["Simple_C4B"].hide();
@ -2881,86 +2865,107 @@ var canvas_MCDU_base = {
me.colorLeft("blu", "blu", "blu", "blu", "blu", "blu"); me.colorLeft("blu", "blu", "blu", "blu", "blu", "blu");
me.colorLeftS("wht", "wht", "wht", "wht", "wht", "wht"); me.colorLeftS("wht", "wht", "wht", "wht", "wht", "wht");
me.colorLeftArrow("wht", "wht", "wht", "wht", "wht", "wht"); me.colorLeftArrow("wht", "wht", "wht", "wht", "wht", "blu");
me.colorCenter("wht", "wht", "wht", "wht", "wht", "grn"); me.colorCenter("wht", "wht", "wht", "wht", "wht", "grn");
me.colorCenterS("wht", "wht", "wht", "wht", "wht", "wht"); me.colorCenterS("wht", "wht", "wht", "wht", "wht", "wht");
me.colorRight("blu", "blu", "blu", "blu", "blu", "blu"); me.colorRight("blu", "blu", "blu", "blu", "blu", "blu");
me.colorRightS("wht", "wht", "wht", "wht", "wht", "wht"); me.colorRightS("wht", "wht", "wht", "wht", "wht", "wht");
me.colorRightArrow("wht", "wht", "wht", "wht", "wht", "wht"); me.colorRightArrow("wht", "wht", "wht", "wht", "wht", "blu");
pageSwitch[i].setBoolValue(1); pageSwitch[i].setBoolValue(1);
} }
if (vor1FreqSet.getValue() == 1) { if (fmgc.FMGCInternal.VOR1.freqSet) {
me["Simple_L1"].setFontSize(normal); me["Simple_L1"].setFontSize(normal);
} else { } else {
me["Simple_L1"].setFontSize(small); me["Simple_L1"].setFontSize(small);
} }
if (vor1CRSSet.getValue() == 1) { if (fmgc.FMGCInternal.VOR1.crsSet) {
me["Simple_L2"].setFontSize(normal); me["Simple_L2"].setFontSize(normal);
} else { } else {
me["Simple_L2"].setFontSize(small); me["Simple_L2"].setFontSize(small);
} }
if (ils1FreqSet.getValue() == 1) { if (fmgc.FMGCInternal.ILS.freqSet) {
me["Simple_L3"].setFontSize(normal); me["Simple_L3"].setFontSize(normal);
} else { } else {
me["Simple_L3"].setFontSize(small); me["Simple_L3"].setFontSize(small);
} }
if (ils1CRSSet.getValue() == 1) { if (fmgc.FMGCInternal.ILS.crsSet) {
me["Simple_L4"].setFontSize(normal); me["Simple_L4"].setFontSize(normal);
} else { } else {
me["Simple_L4"].setFontSize(small); me["Simple_L4"].setFontSize(small);
} }
if (adf1FreqSet.getValue() == 1) {
me["Simple_L6"].setText(" ADF1 BFO");
me["Simple_R6"].setText("ADF2 BFO ");
if (fmgc.FMGCInternal.ADF1.freqSet) {
me["Simple_L5"].setFont(default); me["Simple_L5"].setFont(default);
me["Simple_L5"].setFontSize(normal); me["Simple_L5"].setFontSize(normal);
me["Simple_L5"].setText(sprintf("%s", adf1.getValue())); me["Simple_L5"].setText(sprintf(" %s", fmgc.FMGCInternal.ADF1.mcdu));
me["Simple_L6"].show();
if (rmp.BFOActive[0].getValue()) {
# TODO - wrong arrow
me["Simple_L6_Arrow"].hide();
} else {
me["Simple_L6_Arrow"].show();
}
} else { } else {
me["Simple_L5"].setFont(symbol); me["Simple_L5"].setFont(symbol);
me["Simple_L5"].setFontSize(small); me["Simple_L5"].setFontSize(small);
me["Simple_L5"].setText("[ ]/[ ]"); me["Simple_L5"].setText("[ ]/[ .]");
me["Simple_L6"].hide();
me["Simple_L6_Arrow"].hide();
} }
if (vor2FreqSet.getValue() == 1) { if (fmgc.FMGCInternal.VOR2.freqSet) {
me["Simple_R1"].setFontSize(normal); me["Simple_R1"].setFontSize(normal);
} else { } else {
me["Simple_R1"].setFontSize(small); me["Simple_R1"].setFontSize(small);
} }
if (vor2CRSSet.getValue() == 1) { if (fmgc.FMGCInternal.VOR2.crsSet) {
me["Simple_R2"].setFontSize(normal); me["Simple_R2"].setFontSize(normal);
} else { } else {
me["Simple_R2"].setFontSize(small); me["Simple_R2"].setFontSize(small);
} }
if (adf2FreqSet.getValue() == 1) {
if (fmgc.FMGCInternal.ADF2.freqSet) {
me["Simple_R5"].setFont(default); me["Simple_R5"].setFont(default);
me["Simple_R5"].setFontSize(normal); me["Simple_R5"].setFontSize(normal);
me["Simple_R5"].setText(sprintf("%s", adf2.getValue())); me["Simple_R5"].setText(sprintf("%s ", fmgc.FMGCInternal.ADF2.mcdu));
me["Simple_R6"].show();
if (rmp.BFOActive[1].getValue()) {
# TODO - wrong arrow
me["Simple_R6_Arrow"].hide();
} else {
me["Simple_R6_Arrow"].show();
}
} else { } else {
me["Simple_R5"].setFont(symbol); me["Simple_R5"].setFont(symbol);
me["Simple_R5"].setFontSize(small); me["Simple_R5"].setFontSize(small);
me["Simple_R5"].setText("[ ]/[ ]"); me["Simple_R5"].setText("[ .]/[ ]");
me["Simple_R6"].hide();
me["Simple_R6_Arrow"].hide();
} }
me["Simple_L1"].setText(" " ~ vor1.getValue()); me["Simple_L1"].setText(" " ~ fmgc.FMGCInternal.VOR1.mcdu);
me["Simple_L2"].setText(sprintf("%3.0f", vor1CRS.getValue())); me["Simple_L2"].setText(sprintf("%03.0f", pts.Instrumentation.Nav.Radials.selectedDeg[2].getValue()));
me["Simple_L3"].setText(" " ~ ils1.getValue()); me["Simple_L3"].setText(" " ~ fmgc.FMGCInternal.ILS.mcdu);
me["Simple_L4"].setText(sprintf("%3.0f", ils1CRS.getValue())); me["Simple_L4"].setText(sprintf("%03.0f", pts.Instrumentation.Nav.Radials.selectedDeg[0].getValue()));
me["Simple_L1S"].setText("VOR1/FREQ"); me["Simple_L1S"].setText("VOR1/FREQ");
me["Simple_L2S"].setText("CRS"); me["Simple_L2S"].setText("CRS");
me["Simple_L3S"].setText("ILS /FREQ"); me["Simple_L3S"].setText("ILS /FREQ");
me["Simple_L4S"].setText("CRS"); me["Simple_L4S"].setText("CRS");
me["Simple_L5S"].setText("ADF1/FREQ"); me["Simple_L5S"].setText("ADF1/FREQ");
me["Simple_R1"].setText(" " ~ vor2.getValue()); me["Simple_R1"].setText(" " ~ fmgc.FMGCInternal.VOR2.mcdu);
me["Simple_R2"].setText(sprintf("%3.0f", vor2CRS.getValue())); me["Simple_R2"].setText(sprintf("%03.0f", pts.Instrumentation.Nav.Radials.selectedDeg[3].getValue()));
me["Simple_R3"].setText("[ ]/[ ]");
me["Simple_R4"].setText("-.- [ ]");
me["Simple_R1S"].setText("FREQ/VOR2"); me["Simple_R1S"].setText("FREQ/VOR2");
me["Simple_R2S"].setText("CRS"); me["Simple_R2S"].setText("CRS");
me["Simple_R3S"].setText("CHAN/ MLS");
me["Simple_R4S"].setText("SLOPE CRS");
me["Simple_R5S"].setText("FREQ/ADF2"); me["Simple_R5S"].setText("FREQ/ADF2");
if (getprop("systems/radio/rmp[0]/nav") or getprop("systems/radio/rmp[1]/nav")) { if (rmp.rmpNav[0].getValue() or rmp.rmpNav[1].getValue()) {
me["Simple_L1"].hide(); me["Simple_L1"].hide();
me["Simple_L2"].hide(); me["Simple_L2"].hide();
me["Simple_L3"].hide(); me["Simple_L3"].hide();
@ -2968,8 +2973,6 @@ var canvas_MCDU_base = {
me["Simple_L5"].hide(); me["Simple_L5"].hide();
me["Simple_R1"].hide(); me["Simple_R1"].hide();
me["Simple_R2"].hide(); me["Simple_R2"].hide();
me["Simple_R3"].hide();
me["Simple_R4"].hide();
me["Simple_R5"].hide(); me["Simple_R5"].hide();
} else { } else {
me["Simple_L1"].show(); me["Simple_L1"].show();
@ -2979,8 +2982,6 @@ var canvas_MCDU_base = {
me["Simple_L5"].show(); me["Simple_L5"].show();
me["Simple_R1"].show(); me["Simple_R1"].show();
me["Simple_R2"].show(); me["Simple_R2"].show();
me["Simple_R3"].show();
me["Simple_R4"].show();
me["Simple_R5"].show(); me["Simple_R5"].show();
} }
} else if (page == "INITA") { } else if (page == "INITA") {

View file

@ -593,7 +593,7 @@ canvas.NavDisplay.update = func() # FIXME: This stuff is still too aircraft spec
me.symbols.dmeR.setColor(0,0.6,0.85); me.symbols.dmeR.setColor(0,0.6,0.85);
if((var navident=getprop("/instrumentation/adf[1]/ident")) != "") if((var navident=getprop("/instrumentation/adf[1]/ident")) != "")
me.symbols.vorRId.setText(navident); me.symbols.vorRId.setText(navident);
else me.symbols.vorRId.setText(sprintf("%3d",getprop("/instrumentation/adf[1]/frequencies/selected-khz"))); else me.symbols.vorRId.setText(sprintf("%3d",pts.Instrumentation.Adf.Frequencies.selectedKhz[1].getValue()));
me.symbols.vorRId.setColor(0,0.6,0.85); me.symbols.vorRId.setColor(0,0.6,0.85);
me.symbols.dmeRDist.setText(""); me.symbols.dmeRDist.setText("");
me.symbols.dmeRDist.setColor(0,0.6,0.85); me.symbols.dmeRDist.setColor(0,0.6,0.85);

View file

@ -1387,9 +1387,9 @@ canvas.NDStyles["Airbus"] = {
is_true: func(nd) { is_true: func(nd) {
nd.symbols.vorCrsPtr.show(); nd.symbols.vorCrsPtr.show();
if (is_ils) { if (is_ils) {
nd.symbols.vorCrsPtr.setRotation((getprop("/instrumentation/nav[0]/radials/selected-deg")-nd.aircraft_source.get_hdg_mag())*D2R); nd.symbols.vorCrsPtr.setRotation((pts.Instrumentation.Nav.Radials.selectedDeg[0].getValue()-nd.aircraft_source.get_hdg_mag())*D2R);
} else { } else {
nd.symbols.vorCrsPtr.setRotation((getprop("/instrumentation/nav[2]/radials/selected-deg")-nd.aircraft_source.get_hdg_mag())*D2R); nd.symbols.vorCrsPtr.setRotation((pts.Instrumentation.Nav.Radials.selectedDeg[2].getValue()-nd.aircraft_source.get_hdg_mag())*D2R);
} }
}, },
@ -1407,9 +1407,10 @@ canvas.NDStyles["Airbus"] = {
var type = (is_ils ? "ils" : "vor"); var type = (is_ils ? "ils" : "vor");
var path = nd.get_nav_path(type, 0); var path = nd.get_nav_path(type, 0);
if (is_ils) { if (is_ils) {
nd.symbols.vorCrsPtr2.setRotation((getprop("/instrumentation/nav[0]/radials/selected-deg")-nd.aircraft_source.get_hdg_mag())*D2R); nd.symbols.vorCrsPtr2.setRotation((pts.Instrumentation.Nav.Radials.selectedDeg[0].getValue()-nd.aircraft_source.get_hdg_mag())*D2R);
} else { } else {
nd.symbols.vorCrsPtr2.setRotation((getprop("/instrumentation/nav[2]/radials/selected-deg")-nd.aircraft_source.get_hdg_mag())*D2R); # TODO - 3?
nd.symbols.vorCrsPtr2.setRotation((pts.Instrumentation.Nav.Radials.selectedDeg[2].getValue()-nd.aircraft_source.get_hdg_mag())*D2R);
} }
var line = nd.symbols.vorCrsPtr2.getElementById("vorCrsPtr2_line"); var line = nd.symbols.vorCrsPtr2.getElementById("vorCrsPtr2_line");
if(!is_ils){ if(!is_ils){
@ -1499,9 +1500,7 @@ canvas.NDStyles["Airbus"] = {
}, },
is_true: func(nd) { is_true: func(nd) {
nd.symbols.locTrkPointer.show(); nd.symbols.locTrkPointer.show();
var crs = getprop("/instrumentation/nav/radials/selected-deg"); nd.symbols.locTrkPointer.setRotation( (pts.Instrumentation.Nav.Radials.selectedDeg[0].getValue() - nd.aircraft_source.get_hdg_tru()) * D2R);
var rotation = (crs - nd.aircraft_source.get_hdg_tru())*D2R;
nd.symbols.locTrkPointer.setRotation(rotation);
}, },
is_false: func(nd) nd.symbols.locTrkPointer.hide(), is_false: func(nd) nd.symbols.locTrkPointer.hide(),
}, },

View file

@ -515,42 +515,6 @@ var canvas_pfd = {
obj["GS_scale"].hide(); obj["GS_scale"].hide();
} }
}), }),
props.UpdateManager.FromHashList(["pfdILS1","pfdILS2","dmeInRange","dmeDistance","pfdILSMcdu"], nil, func(val) {
if ((obj.number == 0 and val.pfdILS1) or (obj.number == 1 and val.pfdILS2)) {
obj.split_ils = split("/", val.pfdILSMcdu);
if (size(obj.split_ils) < 2) {
obj["ils_freq"].setText(obj.split_ils[0]);
obj["ils_freq"].show();
obj["ils_code"].hide();
obj["dme_dist"].hide();
obj["dme_dist_legend"].hide();
} else {
obj["ils_code"].setText(obj.split_ils[0]);
obj["ils_freq"].setText(obj.split_ils[1]);
obj["ils_code"].show();
obj["ils_freq"].show();
if (val.dmeInRange) {
obj["dme_dist"].show();
obj["dme_dist_legend"].show();
if (val.dmeDistance < 20.0) {
obj["dme_dist"].setText(sprintf("%1.1f", val.dmeDistance));
} else {
obj["dme_dist"].setText(sprintf("%2.0f", val.dmeDistance));
}
} else {
obj["dme_dist"].hide();
obj["dme_dist_legend"].hide();
}
}
} else {
obj["ils_code"].hide();
obj["ils_freq"].hide();
obj["dme_dist"].hide();
obj["dme_dist_legend"].hide();
}
}),
props.UpdateManager.FromHashList(["hasLocalizer","hasGlideslope","signalQuality","localizerInRange","glideslopeInRange","pfdILS1","pfdILS2"], nil, func(val) { props.UpdateManager.FromHashList(["hasLocalizer","hasGlideslope","signalQuality","localizerInRange","glideslopeInRange","pfdILS1","pfdILS2"], nil, func(val) {
if (((obj.number == 0 and val.pfdILS1) or (obj.number == 1 and val.pfdILS2)) and val.localizerInRange and val.hasLocalizer and val.signalQuality > 0.99) { if (((obj.number == 0 and val.pfdILS1) or (obj.number == 1 and val.pfdILS2)) and val.localizerInRange and val.hasLocalizer and val.signalQuality > 0.99) {
obj["LOC_pointer"].show(); obj["LOC_pointer"].show();
@ -625,50 +589,6 @@ var canvas_pfd = {
obj["HDG_target"].hide(); obj["HDG_target"].hide();
} }
}), }),
props.UpdateManager.FromHashList(["pfdILSMcdu","headingPFD","pfdILS1","pfdILS2","ilsCrs"], nil, func(val) {
obj.split_ils = split("/", val.pfdILSMcdu);
if (((obj.number == 0 and val.pfdILS1) or (obj.number == 1 and val.pfdILS2)) and size(obj.split_ils) == 2) {
obj.magnetic_hdg = val.ilsCrs;
obj.magnetic_hdg_dif = geo.normdeg180(obj.magnetic_hdg - val.headingPFD);
if (obj.magnetic_hdg_dif >= -23.62 and obj.magnetic_hdg_dif <= 23.62) {
obj["CRS_pointer"].setTranslation((obj.magnetic_hdg_dif / 10) * 98.5416, 0);
obj["ILS_HDG_R"].hide();
obj["ILS_HDG_L"].hide();
obj["CRS_pointer"].show();
} else if (obj.magnetic_hdg_dif < -23.62 and obj.magnetic_hdg_dif >= -180) {
if (int(obj.magnetic_hdg) < 10) {
obj["ILS_left"].setText(sprintf("00%1.0f", int(obj.magnetic_hdg)));
} else if (int(obj.magnetic_hdg) < 100) {
obj["ILS_left"].setText(sprintf("0%2.0f", int(obj.magnetic_hdg)));
} else {
obj["ILS_left"].setText(sprintf("%3.0f", int(obj.magnetic_hdg)));
}
obj["ILS_HDG_L"].show();
obj["ILS_HDG_R"].hide();
obj["CRS_pointer"].hide();
} else if (obj.magnetic_hdg_dif > 23.62 and obj.magnetic_hdg_dif <= 180) {
if (int(obj.magnetic_hdg) < 10) {
obj["ILS_right"].setText(sprintf("00%1.0f", int(obj.magnetic_hdg)));
} else if (int(obj.magnetic_hdg) < 100) {
obj["ILS_right"].setText(sprintf("0%2.0f", int(obj.magnetic_hdg)));
} else {
obj["ILS_right"].setText(sprintf("%3.0f", int(obj.magnetic_hdg)));
}
obj["ILS_HDG_R"].show();
obj["ILS_HDG_L"].hide();
obj["CRS_pointer"].hide();
} else {
obj["ILS_HDG_R"].hide();
obj["ILS_HDG_L"].hide();
obj["CRS_pointer"].hide();
}
} else {
obj["ILS_HDG_R"].hide();
obj["ILS_HDG_L"].hide();
obj["CRS_pointer"].hide();
}
}),
props.UpdateManager.FromHashList(["altimeterHpa","altimeterInhg","altimeterInhgMode"], nil, func(val) { props.UpdateManager.FromHashList(["altimeterHpa","altimeterInhg","altimeterInhgMode"], nil, func(val) {
if (val.altimeterInhgMode == 0) { if (val.altimeterInhgMode == 0) {
obj["QNH_setting"].setText(sprintf("%4.0f", val.altimeterHpa)); obj["QNH_setting"].setText(sprintf("%4.0f", val.altimeterHpa));
@ -1735,6 +1655,82 @@ var canvas_pfd = {
} }
} }
me.split_ils = split("/", fmgc.FMGCInternal.ILS.mcdu);
if ((me.number == 0 and notification.pfdILS1) or (me.number == 1 and notification.pfdILS2)) {
if (size(me.split_ils) < 2) {
me["ils_freq"].setText(me.split_ils[0]);
me["ils_freq"].show();
me["ils_code"].hide();
me["dme_dist"].hide();
me["dme_dist_legend"].hide();
} else {
me["ils_code"].setText(me.split_ils[0]);
me["ils_freq"].setText(me.split_ils[1]);
me["ils_code"].show();
me["ils_freq"].show();
if (notification.dmeInRange) {
me["dme_dist"].show();
me["dme_dist_legend"].show();
if (notification.dmeDistance < 20.0) {
me["dme_dist"].setText(sprintf("%1.1f", notification.dmeDistance));
} else {
me["dme_dist"].setText(sprintf("%2.0f", notification.dmeDistance));
}
} else {
me["dme_dist"].hide();
me["dme_dist_legend"].hide();
}
}
} else {
me["ils_code"].hide();
me["ils_freq"].hide();
me["dme_dist"].hide();
me["dme_dist_legend"].hide();
}
if (((me.number == 0 and notification.pfdILS1) or (me.number == 1 and notification.pfdILS2)) and size(me.split_ils) == 2) {
me.magnetic_hdg = notification.ilsCrs;
me.magnetic_hdg_dif = geo.normdeg180(me.magnetic_hdg - notification.headingPFD);
if (me.magnetic_hdg_dif >= -23.62 and me.magnetic_hdg_dif <= 23.62) {
me["CRS_pointer"].setTranslation((me.magnetic_hdg_dif / 10) * 98.5416, 0);
me["ILS_HDG_R"].hide();
me["ILS_HDG_L"].hide();
me["CRS_pointer"].show();
} else if (me.magnetic_hdg_dif < -23.62 and me.magnetic_hdg_dif >= -180) {
if (int(me.magnetic_hdg) < 10) {
me["ILS_left"].setText(sprintf("00%1.0f", int(me.magnetic_hdg)));
} else if (int(me.magnetic_hdg) < 100) {
me["ILS_left"].setText(sprintf("0%2.0f", int(me.magnetic_hdg)));
} else {
me["ILS_left"].setText(sprintf("%3.0f", int(me.magnetic_hdg)));
}
me["ILS_HDG_L"].show();
me["ILS_HDG_R"].hide();
me["CRS_pointer"].hide();
} else if (me.magnetic_hdg_dif > 23.62 and me.magnetic_hdg_dif <= 180) {
if (int(me.magnetic_hdg) < 10) {
me["ILS_right"].setText(sprintf("00%1.0f", int(me.magnetic_hdg)));
} else if (int(me.magnetic_hdg) < 100) {
me["ILS_right"].setText(sprintf("0%2.0f", int(me.magnetic_hdg)));
} else {
me["ILS_right"].setText(sprintf("%3.0f", int(me.magnetic_hdg)));
}
me["ILS_HDG_R"].show();
me["ILS_HDG_L"].hide();
me["CRS_pointer"].hide();
} else {
me["ILS_HDG_R"].hide();
me["ILS_HDG_L"].hide();
me["CRS_pointer"].hide();
}
} else {
me["ILS_HDG_R"].hide();
me["ILS_HDG_L"].hide();
me["CRS_pointer"].hide();
}
foreach(var update_item; me.update_items) foreach(var update_item; me.update_items)
{ {
update_item.update(notification); update_item.update(notification);
@ -2000,7 +1996,6 @@ var input = {
pfdILS1: "/modes/pfd/ILS1", pfdILS1: "/modes/pfd/ILS1",
pfdILS2: "/modes/pfd/ILS2", pfdILS2: "/modes/pfd/ILS2",
pfdILSMcdu: "/FMGC/internal/ils1-mcdu",
markerO: "/instrumentation/marker-beacon/outer", markerO: "/instrumentation/marker-beacon/outer",
markerM: "/instrumentation/marker-beacon/middle", markerM: "/instrumentation/marker-beacon/middle",

View file

@ -32,24 +32,6 @@ var alt = 0;
var altitude = 0; var altitude = 0;
var flap = 0; var flap = 0;
var flaps = 0; var flaps = 0;
var freqnav0uf = 0;
var freqnav0 = 0;
var namenav0 = "XX";
var freqnav1uf = 0;
var freqnav1 = 0;
var namenav1 = "XX";
var freqnav2uf = 0;
var freqnav2 = 0;
var namenav2 = "XX";
var freqnav3uf = 0;
var freqnav3 = 0;
var namenav3 = "XX";
var freqadf0uf = 0;
var freqadf0 = 0;
var nameadf0 = "XX";
var freqadf1uf = 0;
var freqadf1 = 0;
var nameadf1 = "XX";
var ias = 0; var ias = 0;
var mach = 0; var mach = 0;
var ktsmach = 0; var ktsmach = 0;
@ -66,18 +48,12 @@ var windSpeed = 0;
var windsDidChange = 0; var windsDidChange = 0;
var tempOverspeed = nil; var tempOverspeed = nil;
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);
setprop("/it-autoflight/output/fma-pwr", 0); setprop("/it-autoflight/output/fma-pwr", 0);
setprop("/instrumentation/nav[0]/nav-id", "XXX"); setprop("/instrumentation/nav[0]/nav-id", "XXX");
setprop("/instrumentation/nav[1]/nav-id", "XXX"); setprop("/instrumentation/nav[1]/nav-id", "XXX");
setprop("/FMGC/internal/ils1-mcdu", "XXX/999.99");
setprop("/FMGC/internal/ils2-mcdu", "XXX/999.99");
setprop("/FMGC/internal/vor1-mcdu", "XXX/999.99");
setprop("/FMGC/internal/vor2-mcdu", "999.99/XXX");
setprop("/FMGC/internal/adf1-mcdu", "XXX/999.99");
setprop("/FMGC/internal/adf2-mcdu", "999.99/XXX");
var FMGCAlignDone = [props.globals.initNode("/FMGC/internal/align1-done", 0, "BOOL"), props.globals.initNode("/FMGC/internal/align2-done", 0, "BOOL"), props.globals.initNode("/FMGC/internal/align3-done", 0, "BOOL")]; var FMGCAlignDone = [props.globals.initNode("/FMGC/internal/align1-done", 0, "BOOL"), props.globals.initNode("/FMGC/internal/align2-done", 0, "BOOL"), props.globals.initNode("/FMGC/internal/align3-done", 0, "BOOL")];
var FMGCAlignTime = [props.globals.initNode("/FMGC/internal/align1-time", 0, "DOUBLE"), props.globals.initNode("/FMGC/internal/align2-time", 0, "DOUBLE"), props.globals.initNode("/FMGC/internal/align3-time", 0, "DOUBLE")]; var FMGCAlignTime = [props.globals.initNode("/FMGC/internal/align1-time", 0, "DOUBLE"), props.globals.initNode("/FMGC/internal/align2-time", 0, "DOUBLE"), props.globals.initNode("/FMGC/internal/align3-time", 0, "DOUBLE")];
@ -243,6 +219,32 @@ var FMGCInternal = {
mngKtsMach: 0, mngKtsMach: 0,
mngSpd: 0, mngSpd: 0,
mngSpdCmd: 0, mngSpdCmd: 0,
# RADNAV
ADF1: {
freqSet: 0,
mcdu: "XXX/999.99"
},
ADF2: {
freqSet: 0,
mcdu: "999.99/XXX"
},
ILS: {
crsSet: 0,
freqCalculated: 0,
freqSet: 0,
mcdu: "XXX/999.99"
},
VOR1: {
crsSet: 0,
freqSet: 0,
mcdu: "XXX/999.99"
},
VOR2: {
crsSet: 0,
freqSet: 0,
mcdu: "999.99/XXX"
},
}; };
var postInit = func() { var postInit = func() {
@ -519,88 +521,53 @@ var updateFuel = func {
############################ ############################
# Flight Phase and Various # # Flight Phase and Various #
############################ ############################
var freqnav0 = nil;
var nav0 = func { var nav0 = func {
var freqnav0uf = getprop("/instrumentation/nav[0]/frequencies/selected-mhz"); freqnav0 = sprintf("%.2f", pts.Instrumentation.Nav.Frequencies.selectedMhz[0].getValue());
var freqnav0 = sprintf("%.2f", freqnav0uf);
var namenav0 = getprop("/instrumentation/nav[0]/nav-id") or "";
if (freqnav0 >= 108.10 and freqnav0 <= 111.95) { if (freqnav0 >= 108.10 and freqnav0 <= 111.95) {
if (namenav0 != "") { var namenav0 = getprop("/instrumentation/nav[0]/nav-id") or " ";
setprop("/FMGC/internal/ils1-mcdu", namenav0 ~ "/" ~ freqnav0); fmgc.FMGCInternal.ILS.mcdu = namenav0 ~ "/" ~ freqnav0;
} else {
setprop("/FMGC/internal/ils1-mcdu", freqnav0);
}
}
}
var nav1 = func {
var freqnav1uf = getprop("/instrumentation/nav[1]/frequencies/selected-mhz");
var freqnav1 = sprintf("%.2f", freqnav1uf);
var namenav1 = getprop("/instrumentation/nav[1]/nav-id") or "";
if (freqnav1 >= 108.10 and freqnav1 <= 111.95) {
if (namenav1 != "") {
setprop("/FMGC/internal/ils2-mcdu", freqnav1 ~ "/" ~ namenav1);
} else {
setprop("/FMGC/internal/ils2-mcdu", freqnav1);
}
} }
} }
var freqnav2 = nil;
var nav2 = func { var nav2 = func {
var freqnav2uf = getprop("/instrumentation/nav[2]/frequencies/selected-mhz"); freqnav2 = sprintf("%.2f", pts.Instrumentation.Nav.Frequencies.selectedMhz[2].getValue());
var freqnav2 = sprintf("%.2f", freqnav2uf);
var namenav2 = getprop("/instrumentation/nav[2]/nav-id") or "";
if (freqnav2 >= 108.00 and freqnav2 <= 117.95) { if (freqnav2 >= 108.00 and freqnav2 <= 117.95) {
if (namenav2 != "") { var namenav2 = getprop("/instrumentation/nav[2]/nav-id") or " ";
setprop("/FMGC/internal/vor1-mcdu", namenav2 ~ "/" ~ freqnav2); fmgc.FMGCInternal.VOR1.mcdu = namenav2 ~ "/" ~ freqnav2;
} else {
setprop("/FMGC/internal/vor1-mcdu", freqnav2);
}
} }
} }
var freqnav3 = nil;
var nav3 = func { var nav3 = func {
var freqnav3uf = getprop("/instrumentation/nav[3]/frequencies/selected-mhz"); freqnav3 = sprintf("%.2f", pts.Instrumentation.Nav.Frequencies.selectedMhz[3].getValue());
var freqnav3 = sprintf("%.2f", freqnav3uf);
var namenav3 = getprop("/instrumentation/nav[3]/nav-id") or "";
if (freqnav3 >= 108.00 and freqnav3 <= 117.95) { if (freqnav3 >= 108.00 and freqnav3 <= 117.95) {
if (namenav3 != "") { var namenav3 = getprop("/instrumentation/nav[3]/nav-id") or " ";
setprop("/FMGC/internal/vor2-mcdu", freqnav3 ~ "/" ~ namenav3); fmgc.FMGCInternal.VOR2.mcdu = freqnav3 ~ "/" ~ namenav3;
} else {
setprop("/FMGC/internal/vor2-mcdu", freqnav3);
}
} }
} }
var freqadf0 = nil;
var adf0 = func { var adf0 = func {
var freqadf0uf = getprop("/instrumentation/adf[0]/frequencies/selected-khz"); freqadf0 = sprintf("%.1f", pts.Instrumentation.Adf.Frequencies.selectedKhz[0].getValue());
var freqadf0 = sprintf("%.2f", freqadf0uf); if (freqadf0 >= 190 and freqadf0 <= 1799) {
var nameadf0 = getprop("/instrumentation/adf[0]/ident") or ""; var nameadf0 = pts.Instrumentation.Adf.ident[0].getValue() or " ";
if (freqadf0 >= 190 and freqadf0 <= 1750) { fmgc.FMGCInternal.ADF1.mcdu = nameadf0 ~ "/" ~ freqadf0;
if (nameadf0 != "") {
setprop("/FMGC/internal/adf1-mcdu", nameadf0 ~ "/" ~ freqadf0);
} else {
setprop("/FMGC/internal/adf1-mcdu", freqadf0);
}
} }
} }
var freqadf1 = nil;
var adf1 = func { var adf1 = func {
var freqadf1uf = getprop("/instrumentation/adf[1]/frequencies/selected-khz"); freqadf1 = sprintf("%.1f", pts.Instrumentation.Adf.Frequencies.selectedKhz[1].getValue());
var freqadf1 = sprintf("%.2f", freqadf1uf); if (freqadf1 >= 190 and freqadf1 <= 1799) {
var nameadf1 = getprop("/instrumentation/adf[1]/ident") or ""; var nameadf1 = pts.Instrumentation.Adf.ident[1].getValue() or " ";
if (freqadf1 >= 190 and freqadf1 <= 1750) { fmgc.FMGCInternal.ADF2.mcdu = freqadf1 ~ "/" ~ nameadf1;
if (nameadf1 != "") {
setprop("/FMGC/internal/adf2-mcdu", freqadf1 ~ "/" ~ nameadf1);
} else {
setprop("/FMGC/internal/adf2-mcdu", freqadf1);
}
} }
} }
var radios = maketimer(1, func() { var radios = maketimer(1, func() {
nav0(); nav0();
nav1();
nav2(); nav2();
nav3(); nav3();
adf0(); adf0();
@ -957,28 +924,28 @@ var updateAirportRadios = func {
setprop("/FMGC/internal/ldg-elev", airport.elevation * M2FT); # eventually should be runway elevation setprop("/FMGC/internal/ldg-elev", airport.elevation * M2FT); # eventually should be runway elevation
magnetic_hdg = geo.normdeg(destination_rwy.heading - getprop("/environment/magnetic-variation-deg")); magnetic_hdg = geo.normdeg(destination_rwy.heading - getprop("/environment/magnetic-variation-deg"));
runway_ils = destination_rwy.ils_frequency_mhz; runway_ils = destination_rwy.ils_frequency_mhz;
if (runway_ils != nil and !getprop("/FMGC/internal/ils1freq-set") and !getprop("/FMGC/internal/ils1crs-set")) { if (runway_ils != nil and !fmgc.FMGCInternal.ILS.freqSet and !fmgc.FMGCInternal.ILS.crsSet) {
setprop("/FMGC/internal/ils1freq-calculated", runway_ils); fmgc.FMGCInternal.ILS.freqCalculated = runway_ils;
setprop("/instrumentation/nav[0]/frequencies/selected-mhz", runway_ils); pts.Instrumentation.Nav.Frequencies.selectedMhz[0].setValue(runway_ils);
setprop("/instrumentation/nav[0]/radials/selected-deg", magnetic_hdg); pts.Instrumentation.Nav.Radials.selectedDeg[0].setValue(magnetic_hdg);
} elsif (runway_ils != nil and !getprop("/FMGC/internal/ils1freq-set")) { } elsif (runway_ils != nil and !fmgc.FMGCInternal.ILS.freqSet) {
setprop("/FMGC/internal/ils1freq-calculated", runway_ils); fmgc.FMGCInternal.ILS.freqCalculated = runway_ils;
setprop("/instrumentation/nav[0]/frequencies/selected-mhz", runway_ils); pts.Instrumentation.Nav.Frequencies.selectedMhz[0].setValue(runway_ils);
} elsif (!getprop("/FMGC/internal/ils1crs-set")) { } elsif (!fmgc.FMGCInternal.ILS.crsSet) {
setprop("/instrumentation/nav[0]/radials/selected-deg", magnetic_hdg); pts.Instrumentation.Nav.Radials.selectedDeg[0].setValue(magnetic_hdg);
} }
} elsif (airportRadiosPhase <= 1 and departure_rwy != nil) { } elsif (airportRadiosPhase <= 1 and departure_rwy != nil) {
magnetic_hdg = geo.normdeg(departure_rwy.heading - getprop("/environment/magnetic-variation-deg")); magnetic_hdg = geo.normdeg(departure_rwy.heading - getprop("/environment/magnetic-variation-deg"));
runway_ils = departure_rwy.ils_frequency_mhz; runway_ils = departure_rwy.ils_frequency_mhz;
if (runway_ils != nil and !getprop("/FMGC/internal/ils1freq-set") and !getprop("/FMGC/internal/ils1crs-set")) { if (runway_ils != nil and !fmgc.FMGCInternal.ILS.freqSet and !fmgc.FMGCInternal.ILS.crsSet) {
setprop("/FMGC/internal/ils1freq-calculated", runway_ils); fmgc.FMGCInternal.ILS.freqCalculated = runway_ils;
setprop("/instrumentation/nav[0]/frequencies/selected-mhz", runway_ils); pts.Instrumentation.Nav.Frequencies.selectedMhz[0].setValue(runway_ils);
setprop("/instrumentation/nav[0]/radials/selected-deg", magnetic_hdg); pts.Instrumentation.Nav.Radials.selectedDeg[0].setValue(magnetic_hdg);
} elsif (runway_ils != nil and !getprop("/FMGC/internal/ils1freq-set")) { } elsif (runway_ils != nil and !fmgc.FMGCInternal.ILS.freqSet) {
setprop("/FMGC/internal/ils1freq-calculated", runway_ils); fmgc.FMGCInternal.ILS.freqCalculated = runway_ils;
setprop("/instrumentation/nav[0]/frequencies/selected-mhz", runway_ils); pts.Instrumentation.Nav.Frequencies.selectedMhz[0].setValue(runway_ils);
} elsif (!getprop("/FMGC/internal/ils1crs-set")) { } elsif (!fmgc.FMGCInternal.ILS.crsSet) {
setprop("/instrumentation/nav[0]/radials/selected-deg", magnetic_hdg); pts.Instrumentation.Nav.Radials.selectedDeg[0].setValue(magnetic_hdg);
} }
} }
@ -1243,6 +1210,7 @@ setlistener("/FMGC/internal/fuel-calculating", func() {
var timer30secLanding = maketimer(1, func() { var timer30secLanding = maketimer(1, func() {
if (pts.Sim.Time.elapsedSec.getValue() > getprop("/FMGC/internal/landing-time") + 30) { if (pts.Sim.Time.elapsedSec.getValue() > getprop("/FMGC/internal/landing-time") + 30) {
FMGCInternal.phase = 7; FMGCInternal.phase = 7;
if (FMGCInternal.costIndexSet) { if (FMGCInternal.costIndexSet) {
setprop("/FMGC/internal/last-cost-index", FMGCInternal.costIndex); setprop("/FMGC/internal/last-cost-index", FMGCInternal.costIndex);
} else { } else {

View file

@ -156,6 +156,12 @@ var Gear = {
}; };
var Instrumentation = { var Instrumentation = {
Adf: {
ident: [props.globals.getNode("/instrumentation/adf[0]/ident"), props.globals.getNode("/instrumentation/adf[1]/ident")],
Frequencies: {
selectedKhz: [props.globals.getNode("/instrumentation/adf[0]/frequencies/selected-khz"), props.globals.getNode("/instrumentation/adf[1]/frequencies/selected-khz")],
},
},
AirspeedIndicator: { AirspeedIndicator: {
indicatedSpdKt: props.globals.getNode("/instrumentation/airspeed-indicator/indicated-speed-kt"), indicatedSpdKt: props.globals.getNode("/instrumentation/airspeed-indicator/indicated-speed-kt"),
indicatedMach: props.globals.getNode("/instrumentation/airspeed-indicator/indicated-mach"), indicatedMach: props.globals.getNode("/instrumentation/airspeed-indicator/indicated-mach"),
@ -225,6 +231,12 @@ var Instrumentation = {
}, },
}, },
Nav: { Nav: {
Frequencies: {
selectedMhz: [props.globals.getNode("/instrumentation/nav[0]/frequencies/selected-mhz"), props.globals.getNode("/instrumentation/nav[1]/frequencies/selected-mhz"), props.globals.getNode("/instrumentation/nav[2]/frequencies/selected-mhz"), props.globals.getNode("/instrumentation/nav[3]/frequencies/selected-mhz")],
},
Radials: {
selectedDeg: [props.globals.getNode("/instrumentation/nav[0]/radials/selected-deg"), props.globals.getNode("/instrumentation/nav[1]/radials/selected-deg"), props.globals.getNode("/instrumentation/nav[2]/radials/selected-deg"), props.globals.getNode("/instrumentation/nav[3]/radials/selected-deg")],
},
gsDeflection: props.globals.getNode("/instrumentation/nav[0]/gs-needle-deflection-norm"), gsDeflection: props.globals.getNode("/instrumentation/nav[0]/gs-needle-deflection-norm"),
locDeflection: props.globals.getNode("/instrumentation/nav[0]/heading-needle-deflection-norm"), locDeflection: props.globals.getNode("/instrumentation/nav[0]/heading-needle-deflection-norm"),
}, },

View file

@ -45,15 +45,15 @@ var MCDU_reset = func(i) {
setprop("/FMGC/print/mcdu/page2/R4req", 0); setprop("/FMGC/print/mcdu/page2/R4req", 0);
#RADNAV #RADNAV
setprop("/FMGC/internal/ils1freq-set", 0); fmgc.FMGCInternal.ILS.freqSet = 0;
setprop("/FMGC/internal/ils1crs-set", 0); fmgc.FMGCInternal.ILS.freqCalculated = 0;
setprop("/FMGC/internal/ils1freq-calculated", 0); fmgc.FMGCInternal.ILS.crsSet = 0;
setprop("/FMGC/internal/vor1freq-set", 0); fmgc.FMGCInternal.VOR1.freqSet = 0;
setprop("/FMGC/internal/vor1crs-set", 0); fmgc.FMGCInternal.VOR1.crsSet = 0;
setprop("/FMGC/internal/vor2freq-set", 0); fmgc.FMGCInternal.VOR2.freqSet = 0;
setprop("/FMGC/internal/vor2crs-set", 0); fmgc.FMGCInternal.VOR2.crsSet = 0;
setprop("/FMGC/internal/adf1freq-set", 0); fmgc.FMGCInternal.ADF1.freqSet = 0;
setprop("/FMGC/internal/adf2freq-set", 0); fmgc.FMGCInternal.ADF2.freqSet = 0;
# INT-A # INT-A
fmgc.FMGCInternal.altAirport = ""; fmgc.FMGCInternal.altAirport = "";
@ -847,6 +847,8 @@ var lskbutton = func(btn, i) {
pageNode[i].setValue("WINDCLB"); pageNode[i].setValue("WINDCLB");
} else if (page == "ROUTESELECTION") { } else if (page == "ROUTESELECTION") {
initInputROUTESEL("L6",i); initInputROUTESEL("L6",i);
} else if (page == "RADNAV") {
radnavInput("L6",i);
} else if (page == "PERFCLB") { } else if (page == "PERFCLB") {
perfCLBInput("L6",i); perfCLBInput("L6",i);
} else if (page == "PERFCRZ") { } else if (page == "PERFCRZ") {
@ -1303,6 +1305,8 @@ var rskbutton = func(btn, i) {
mcdu_message(i, "AOC DISABLED"); mcdu_message(i, "AOC DISABLED");
} else if (page == "INITA") { } else if (page == "INITA") {
initInputA("R6",i); initInputA("R6",i);
} else if (page == "RADNAV") {
radnavInput("R6",i);
} else if (page == "F-PLNA" or page == "F-PLNB") { } else if (page == "F-PLNA" or page == "F-PLNB") {
canvas_mcdu.myFpln[i].pushButtonRight(6); canvas_mcdu.myFpln[i].pushButtonRight(6);
} else if (page == "VERTREV") { } else if (page == "VERTREV") {

View file

@ -1,31 +1,33 @@
# A3XX mCDU by Joshua Davidson (Octal450), Jonathan Redpath, and Matthew Maring (mattmaring) # A3XX mCDU by Joshua Davidson (Octal450), Jonathan Redpath, and Matthew Maring (mattmaring)
# Copyright (c) 2021 Josh Davidson (Octal450) # Copyright (c) 2021 Josh Davidson (Octal450)
var radNavScratchpad = nil;
var radNavScratchpadSize = nil;
var radnavInput = func(key, i) { var radnavInput = func(key, i) {
var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; radNavScratchpad = mcdu_scratchpad.scratchpads[i].scratchpad;
if (!getprop("/systems/radio/rmp[0]/nav") and !getprop("/systems/radio/rmp[1]/nav")) { radNavScratchpadSize = size(radNavScratchpad);
if (!rmp.rmpNav[0].getValue() and !rmp.rmpNav[1].getValue()) {
if (key == "L1") { if (key == "L1") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/vor1freq-set", 0); fmgc.FMGCInternal.VOR1.freqSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize == 3 or radNavScratchpadSize == 5 or radNavScratchpadSize == 6) {
if (tfs == 3 or tfs == 5 or tfs == 6) { if (radNavScratchpad >= 108.00 and radNavScratchpad <= 111.95) {
if (scratchpad >= 108.00 and scratchpad <= 111.95) { if (radNavScratchpad == 108.10 or radNavScratchpad == 108.15 or radNavScratchpad == 108.30 or radNavScratchpad == 108.35 or radNavScratchpad == 108.50 or radNavScratchpad == 108.55 or radNavScratchpad == 108.70 or radNavScratchpad == 108.75 or radNavScratchpad == 108.90 or radNavScratchpad == 108.95
if (scratchpad == 108.10 or scratchpad == 108.15 or scratchpad == 108.30 or scratchpad == 108.35 or scratchpad == 108.50 or scratchpad == 108.55 or scratchpad == 108.70 or scratchpad == 108.75 or scratchpad == 108.90 or scratchpad == 108.95 or radNavScratchpad == 109.10 or radNavScratchpad == 109.15 or radNavScratchpad == 109.30 or radNavScratchpad == 109.35 or radNavScratchpad == 109.50 or radNavScratchpad == 109.55 or radNavScratchpad == 109.70 or radNavScratchpad == 109.75 or radNavScratchpad == 109.90 or radNavScratchpad == 109.95
or scratchpad == 109.10 or scratchpad == 109.15 or scratchpad == 109.30 or scratchpad == 109.35 or scratchpad == 109.50 or scratchpad == 109.55 or scratchpad == 109.70 or scratchpad == 109.75 or scratchpad == 109.90 or scratchpad == 109.95 or radNavScratchpad == 110.10 or radNavScratchpad == 110.15 or radNavScratchpad == 110.30 or radNavScratchpad == 110.35 or radNavScratchpad == 110.50 or radNavScratchpad == 110.55 or radNavScratchpad == 110.70 or radNavScratchpad == 110.75 or radNavScratchpad == 110.90 or radNavScratchpad == 110.95
or scratchpad == 110.10 or scratchpad == 110.15 or scratchpad == 110.30 or scratchpad == 110.35 or scratchpad == 110.50 or scratchpad == 110.55 or scratchpad == 110.70 or scratchpad == 110.75 or scratchpad == 110.90 or scratchpad == 110.95 or radNavScratchpad == 111.10 or radNavScratchpad == 111.15 or radNavScratchpad == 111.30 or radNavScratchpad == 111.35 or radNavScratchpad == 111.50 or radNavScratchpad == 111.55 or radNavScratchpad == 111.70 or radNavScratchpad == 111.75 or radNavScratchpad == 111.90 or radNavScratchpad == 111.95) {
or scratchpad == 111.10 or scratchpad == 111.15 or scratchpad == 111.30 or scratchpad == 111.35 or scratchpad == 111.50 or scratchpad == 111.55 or scratchpad == 111.70 or scratchpad == 111.75 or scratchpad == 111.90 or scratchpad == 111.95) {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} else { } else {
setprop("instrumentation/nav[2]/frequencies/selected-mhz", scratchpad); pts.Instrumentation.Nav.Frequencies.selectedMhz[2].setValue(radNavScratchpad);
setprop("/FMGC/internal/vor1freq-set", 1); fmgc.FMGCInternal.VOR1.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} }
} else if (scratchpad >= 112.00 and scratchpad <= 117.95) { } else if (radNavScratchpad >= 112.00 and radNavScratchpad <= 117.95) {
setprop("instrumentation/nav[2]/frequencies/selected-mhz", scratchpad); pts.Instrumentation.Nav.Frequencies.selectedMhz[2].setValue(radNavScratchpad);
setprop("/FMGC/internal/vor1freq-set", 1); fmgc.FMGCInternal.VOR1.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
@ -35,15 +37,14 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "L2") { } else if (key == "L2") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/vor1crs-set", 0); fmgc.FMGCInternal.VOR1.crsSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize >= 1 and radNavScratchpadSize <= 3) {
if (tfs >= 1 and tfs <= 3) { if (radNavScratchpad >= 0 and radNavScratchpad <= 360) {
if (scratchpad >= 0 and scratchpad <= 360) { pts.Instrumentation.Nav.Radials.selectedDeg[2].setValue(radNavScratchpad);
setprop("instrumentation/nav[2]/radials/selected-deg", scratchpad); fmgc.FMGCInternal.VOR1.crsSet = 1;
setprop("/FMGC/internal/vor1crs-set", 1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
@ -53,21 +54,20 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "L3") { } else if (key == "L3") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/ils1freq-set", 0); fmgc.FMGCInternal.ILS.freqSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize == 3 or radNavScratchpadSize == 5 or radNavScratchpadSize == 6) {
if (tfs == 3 or tfs == 5 or tfs == 6) { if (radNavScratchpad >= 108.00 and radNavScratchpad <= 111.95) {
if (scratchpad >= 108.00 and scratchpad <= 111.95) { if (radNavScratchpad == 108.10 or radNavScratchpad == 108.15 or radNavScratchpad == 108.30 or radNavScratchpad == 108.35 or radNavScratchpad == 108.50 or radNavScratchpad == 108.55 or radNavScratchpad == 108.70 or radNavScratchpad == 108.75 or radNavScratchpad == 108.90 or radNavScratchpad == 108.95
if (scratchpad == 108.10 or scratchpad == 108.15 or scratchpad == 108.30 or scratchpad == 108.35 or scratchpad == 108.50 or scratchpad == 108.55 or scratchpad == 108.70 or scratchpad == 108.75 or scratchpad == 108.90 or scratchpad == 108.95 or radNavScratchpad == 109.10 or radNavScratchpad == 109.15 or radNavScratchpad == 109.30 or radNavScratchpad == 109.35 or radNavScratchpad == 109.50 or radNavScratchpad == 109.55 or radNavScratchpad == 109.70 or radNavScratchpad == 109.75 or radNavScratchpad == 109.90 or radNavScratchpad == 109.95
or scratchpad == 109.10 or scratchpad == 109.15 or scratchpad == 109.30 or scratchpad == 109.35 or scratchpad == 109.50 or scratchpad == 109.55 or scratchpad == 109.70 or scratchpad == 109.75 or scratchpad == 109.90 or scratchpad == 109.95 or radNavScratchpad == 110.10 or radNavScratchpad == 110.15 or radNavScratchpad == 110.30 or radNavScratchpad == 110.35 or radNavScratchpad == 110.50 or radNavScratchpad == 110.55 or radNavScratchpad == 110.70 or radNavScratchpad == 110.75 or radNavScratchpad == 110.90 or radNavScratchpad == 110.95
or scratchpad == 110.10 or scratchpad == 110.15 or scratchpad == 110.30 or scratchpad == 110.35 or scratchpad == 110.50 or scratchpad == 110.55 or scratchpad == 110.70 or scratchpad == 110.75 or scratchpad == 110.90 or scratchpad == 110.95 or radNavScratchpad == 111.10 or radNavScratchpad == 111.15 or radNavScratchpad == 111.30 or radNavScratchpad == 111.35 or radNavScratchpad == 111.50 or radNavScratchpad == 111.55 or radNavScratchpad == 111.70 or radNavScratchpad == 111.75 or radNavScratchpad == 111.90 or radNavScratchpad == 111.95) {
or scratchpad == 111.10 or scratchpad == 111.15 or scratchpad == 111.30 or scratchpad == 111.35 or scratchpad == 111.50 or scratchpad == 111.55 or scratchpad == 111.70 or scratchpad == 111.75 or scratchpad == 111.90 or scratchpad == 111.95) { pts.Instrumentation.Nav.Frequencies.selectedMhz[0].setValue(radNavScratchpad);
setprop("instrumentation/nav[0]/frequencies/selected-mhz", scratchpad); fmgc.FMGCInternal.ILS.freqSet = 1;
setprop("/FMGC/internal/ils1freq-set", 1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
if (num(getprop("/FMGC/internal/ils1freq-calculated")) != 0 and num(getprop("/FMGC/internal/ils1freq-calculated")) != num(getprop("instrumentation/nav[0]/frequencies/selected-mhz"))) { if (num(fmgc.FMGCInternal.ILS.freqCalculated) != 0 and num(fmgc.FMGCInternal.ILS.freqCalculated) != num(pts.Instrumentation.Nav.Frequencies.selectedMhz[0].getValue())) {
mcdu_message(i, "RWY/LS MISMATCH"); mcdu_message(i, "RWY/LS MISMATCH");
} }
} else { } else {
@ -81,15 +81,14 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "L4") { } else if (key == "L4") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/ils1crs-set", 0); fmgc.FMGCInternal.ILS.crsSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize >= 1 and radNavScratchpadSize <= 3) {
if (tfs >= 1 and tfs <= 3) { if (radNavScratchpad >= 0 and radNavScratchpad <= 360) {
if (scratchpad >= 0 and scratchpad <= 360) { pts.Instrumentation.Nav.Radials.selectedDeg[0].setValue(radNavScratchpad);
setprop("instrumentation/nav[0]/radials/selected-deg", scratchpad); fmgc.FMGCInternal.ILS.crsSet = 1;
setprop("/FMGC/internal/ils1crs-set", 1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
@ -99,16 +98,26 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "L5") { } else if (key == "L5") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/adf1freq-set", 0); fmgc.FMGCInternal.ADF1.freqSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize >= 3 and radNavScratchpadSize <= 6) {
if (tfs == 3 or tfs == 4) { if (radNavScratchpad >= 190 and radNavScratchpad <= 1799) {
if (scratchpad >= 190 and scratchpad <= 1750) { if (radNavScratchpad != int(radNavScratchpad)) {
setprop("instrumentation/adf[0]/frequencies/selected-khz", scratchpad); var splitradNavScratchpad = split(".",radNavScratchpad);
setprop("/FMGC/internal/adf1freq-set", 1); if (size(splitradNavScratchpad) != 2 or splitradNavScratchpad[1] != "5") {
mcdu_scratchpad.scratchpads[i].empty(); mcdu_message(i, "NOT ALLOWED");
} else {
pts.Instrumentation.Adf.Frequencies.selectedKhz[0].setValue(radNavScratchpad);
fmgc.FMGCInternal.ADF1.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty();
}
} else {
pts.Instrumentation.Adf.Frequencies.selectedKhz[0].setValue(radNavScratchpad);
fmgc.FMGCInternal.ADF1.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty();
}
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
@ -116,27 +125,41 @@ var radnavInput = func(key, i) {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
} }
} else if (key == "L6") {
if (fmgc.FMGCInternal.ADF1.freqSet) {
if (radNavScratchpad == "CLR" and rmp.BFOActive[0].getValue()) {
rmp.BFOActive[0].setValue(0);
mcdu_scratchpad.scratchpads[i].empty();
} else {
if (radNavScratchpadSize == 0 and !rmp.BFOActive[0].getValue()) {
rmp.BFOActive[0].setValue(1);
} else {
mcdu_message(i, "NOT ALLOWED");
}
}
} else {
mcdu_message(i, "NOT ALLOWED");
}
} else if (key == "R1") { } else if (key == "R1") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/vor2freq-set", 0); fmgc.FMGCInternal.VOR2.freqSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize == 3 or radNavScratchpadSize == 5 or radNavScratchpadSize == 6) {
if (tfs == 3 or tfs == 5 or tfs == 6) { if (radNavScratchpad >= 108.10 and radNavScratchpad <= 111.95) {
if (scratchpad >= 108.10 and scratchpad <= 111.95) { if (radNavScratchpad == 108.10 or radNavScratchpad == 108.15 or radNavScratchpad == 108.30 or radNavScratchpad == 108.35 or radNavScratchpad == 108.50 or radNavScratchpad == 108.55 or radNavScratchpad == 108.70 or radNavScratchpad == 108.75 or radNavScratchpad == 108.90 or radNavScratchpad == 108.95
if (scratchpad == 108.10 or scratchpad == 108.15 or scratchpad == 108.30 or scratchpad == 108.35 or scratchpad == 108.50 or scratchpad == 108.55 or scratchpad == 108.70 or scratchpad == 108.75 or scratchpad == 108.90 or scratchpad == 108.95 or radNavScratchpad == 109.10 or radNavScratchpad == 109.15 or radNavScratchpad == 109.30 or radNavScratchpad == 109.35 or radNavScratchpad == 109.50 or radNavScratchpad == 109.55 or radNavScratchpad == 109.70 or radNavScratchpad == 109.75 or radNavScratchpad == 109.90 or radNavScratchpad == 109.95
or scratchpad == 109.10 or scratchpad == 109.15 or scratchpad == 109.30 or scratchpad == 109.35 or scratchpad == 109.50 or scratchpad == 109.55 or scratchpad == 109.70 or scratchpad == 109.75 or scratchpad == 109.90 or scratchpad == 109.95 or radNavScratchpad == 110.10 or radNavScratchpad == 110.15 or radNavScratchpad == 110.30 or radNavScratchpad == 110.35 or radNavScratchpad == 110.50 or radNavScratchpad == 110.55 or radNavScratchpad == 110.70 or radNavScratchpad == 110.75 or radNavScratchpad == 110.90 or radNavScratchpad == 110.95
or scratchpad == 110.10 or scratchpad == 110.15 or scratchpad == 110.30 or scratchpad == 110.35 or scratchpad == 110.50 or scratchpad == 110.55 or scratchpad == 110.70 or scratchpad == 110.75 or scratchpad == 110.90 or scratchpad == 110.95 or radNavScratchpad == 111.10 or radNavScratchpad == 111.15 or radNavScratchpad == 111.30 or radNavScratchpad == 111.35 or radNavScratchpad == 111.50 or radNavScratchpad == 111.55 or radNavScratchpad == 111.70 or radNavScratchpad == 111.75 or radNavScratchpad == 111.90 or radNavScratchpad == 111.95) {
or scratchpad == 111.10 or scratchpad == 111.15 or scratchpad == 111.30 or scratchpad == 111.35 or scratchpad == 111.50 or scratchpad == 111.55 or scratchpad == 111.70 or scratchpad == 111.75 or scratchpad == 111.90 or scratchpad == 111.95) {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} else { } else {
setprop("instrumentation/nav[3]/frequencies/selected-mhz", scratchpad); pts.Instrumentation.Nav.Frequencies.selectedMhz[3].setValue(radNavScratchpad);
setprop("/FMGC/internal/vor2freq-set", 1); fmgc.FMGCInternal.VOR2.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} }
} else if (scratchpad >= 112.00 and scratchpad <= 117.95) { } else if (radNavScratchpad >= 112.00 and radNavScratchpad <= 117.95) {
setprop("instrumentation/nav[3]/frequencies/selected-mhz", scratchpad); pts.Instrumentation.Nav.Frequencies.selectedMhz[3].setValue(radNavScratchpad);
setprop("/FMGC/internal/vor2freq-set", 1); fmgc.FMGCInternal.VOR2.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
@ -146,15 +169,14 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "R2") { } else if (key == "R2") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/vor2crs-set", 0); fmgc.FMGCInternal.VOR2.crsSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize >= 1 and radNavScratchpadSize <= 3) {
if (tfs >= 1 and tfs <= 3) { if (radNavScratchpad >= 0 and radNavScratchpad <= 360) {
if (scratchpad >= 0 and scratchpad <= 360) { pts.Instrumentation.Nav.Radials.selectedDeg[3].setValue(radNavScratchpad);
setprop("instrumentation/nav[3]/radials/selected-deg", scratchpad); fmgc.FMGCInternal.VOR2.crsSet = 1;
setprop("/FMGC/internal/vor2crs-set", 1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
@ -164,16 +186,26 @@ var radnavInput = func(key, i) {
} }
} }
} else if (key == "R5") { } else if (key == "R5") {
if (scratchpad == "CLR") { if (radNavScratchpad == "CLR") {
setprop("/FMGC/internal/adf2freq-set", 0); fmgc.FMGCInternal.ADF2.freqSet = 0;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else { } else {
var tfs = size(scratchpad); if (radNavScratchpadSize >= 3 and radNavScratchpadSize <= 6) {
if (tfs == 3 or tfs == 4) { if (radNavScratchpad >= 190 and radNavScratchpad <= 1799) {
if (scratchpad >= 190 and scratchpad <= 1750) { if (radNavScratchpad != int(radNavScratchpad)) {
setprop("instrumentation/adf[1]/frequencies/selected-khz", scratchpad); var splitradNavScratchpad = split(".",radNavScratchpad);
setprop("/FMGC/internal/adf2freq-set", 1); if (size(splitradNavScratchpad) != 2 or splitradNavScratchpad[1] != "5") {
mcdu_scratchpad.scratchpads[i].empty(); mcdu_message(i, "NOT ALLOWED");
} else {
pts.Instrumentation.Adf.Frequencies.selectedKhz[1].setValue(radNavScratchpad);
fmgc.FMGCInternal.ADF2.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty();
}
} else {
pts.Instrumentation.Adf.Frequencies.selectedKhz[1].setValue(radNavScratchpad);
fmgc.FMGCInternal.ADF2.freqSet = 1;
mcdu_scratchpad.scratchpads[i].empty();
}
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
@ -181,8 +213,23 @@ var radnavInput = func(key, i) {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
} }
} else if (key == "R6") {
if (fmgc.FMGCInternal.ADF2.freqSet) {
if (radNavScratchpad == "CLR" and rmp.BFOActive[1].getValue()) {
rmp.BFOActive[1].setValue(0);
mcdu_scratchpad.scratchpads[i].empty();
} else {
if (radNavScratchpadSize == 0 and !rmp.BFOActive[1].getValue()) {
rmp.BFOActive[1].setValue(1);
} else {
mcdu_message(i, "NOT ALLOWED");
}
}
} else {
mcdu_message(i, "NOT ALLOWED");
}
} else {
mcdu_message(i, "NOT ALLOWED");
} }
} else {
mcdu_message(i, "NOT ALLOWED");
} }
} }

View file

@ -7,15 +7,40 @@
# NOTE: This is just temporary until FG allows a full implementation of the audio system. # NOTE: This is just temporary until FG allows a full implementation of the audio system.
var mkr_capt_recive = props.globals.initNode("/controls/audio/acp[0]/mkr-recive", 0, "BOOL");
var mkr_capt_volume = props.globals.initNode("/controls/audio/acp[0]/mkr-volume", 1, "DOUBLE");
var mkr_fo_recive = props.globals.initNode("/controls/audio/acp[1]/mkr-recive", 0, "BOOL");
var mkr_fo_volume = props.globals.initNode("/controls/audio/acp[1]/mkr-volume", 1, "DOUBLE");
var ils_capt_recive = props.globals.initNode("/controls/audio/acp[0]/ils-recive", 0, "BOOL");
var ils_capt_volume = props.globals.initNode("/controls/audio/acp[0]/ils-volume", 1, "DOUBLE");
var ils_fo_recive = props.globals.initNode("/controls/audio/acp[1]/ils-recive", 0, "BOOL");
var ils_fo_volume = props.globals.initNode("/controls/audio/acp[1]/ils-volume", 1, "DOUBLE");
var vhf1_capt_recive = props.globals.initNode("/controls/audio/acp[0]/vhf1-recive", 1, "BOOL"); var vhf1_capt_recive = props.globals.initNode("/controls/audio/acp[0]/vhf1-recive", 1, "BOOL");
var vhf2_capt_recive = props.globals.initNode("/controls/audio/acp[0]/vhf2-recive", 1, "BOOL"); var vhf2_capt_recive = props.globals.initNode("/controls/audio/acp[0]/vhf2-recive", 1, "BOOL");
var vhf1_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vhf1-volume", 1, "DOUBLE"); var vhf1_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vhf1-volume", 1, "DOUBLE");
var vhf2_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vhf2-volume", 1, "DOUBLE"); var vhf2_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vhf2-volume", 1, "DOUBLE");
var adf1_capt_receive = props.globals.initNode("/controls/audio/acp[0]/adf1-recive", 0, "BOOL");
var adf1_capt_volume = props.globals.initNode("/controls/audio/acp[0]/adf1-volume", 1, "DOUBLE");
var adf2_capt_receive = props.globals.initNode("/controls/audio/acp[0]/adf2-recive", 0, "BOOL");
var adf2_capt_volume = props.globals.initNode("/controls/audio/acp[0]/adf2-volume", 1, "DOUBLE");
var vor1_capt_receive = props.globals.initNode("/controls/audio/acp[0]/vor1-recive", 0, "BOOL");
var vor1_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vor1-volume", 1, "DOUBLE");
var vor2_capt_receive = props.globals.initNode("/controls/audio/acp[0]/vor2-recive", 0, "BOOL");
var vor2_capt_volume = props.globals.initNode("/controls/audio/acp[0]/vor2-volume", 1, "DOUBLE");
var vhf1_fo_recive = props.globals.initNode("/controls/audio/acp[1]/vhf1-recive", 1, "BOOL"); var vhf1_fo_recive = props.globals.initNode("/controls/audio/acp[1]/vhf1-recive", 1, "BOOL");
var vhf2_fo_recive = props.globals.initNode("/controls/audio/acp[1]/vhf2-recive", 1, "BOOL"); var vhf2_fo_recive = props.globals.initNode("/controls/audio/acp[1]/vhf2-recive", 1, "BOOL");
var vhf1_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vhf1-volume", 1, "DOUBLE"); var vhf1_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vhf1-volume", 1, "DOUBLE");
var vhf2_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vhf2-volume", 1, "DOUBLE"); var vhf2_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vhf2-volume", 1, "DOUBLE");
var adf1_fo_receive = props.globals.initNode("/controls/audio/acp[1]/adf1-recive", 0, "BOOL");
var adf1_fo_volume = props.globals.initNode("/controls/audio/acp[1]/adf1-volume", 1, "DOUBLE");
var adf2_fo_receive = props.globals.initNode("/controls/audio/acp[1]/adf2-recive", 0, "BOOL");
var adf2_fo_volume = props.globals.initNode("/controls/audio/acp[1]/adf2-volume", 1, "DOUBLE");
var vor1_fo_receive = props.globals.initNode("/controls/audio/acp[1]/vor1-recive", 0, "BOOL");
var vor1_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vor1-volume", 1, "DOUBLE");
var vor2_fo_receive = props.globals.initNode("/controls/audio/acp[1]/vor2-recive", 0, "BOOL");
var vor2_fo_volume = props.globals.initNode("/controls/audio/acp[1]/vor2-volume", 1, "DOUBLE");
var com1_volume = props.globals.getNode("instrumentation/comm[0]/volume"); var com1_volume = props.globals.getNode("instrumentation/comm[0]/volume");
var com2_volume = props.globals.getNode("instrumentation/comm[1]/volume"); var com2_volume = props.globals.getNode("instrumentation/comm[1]/volume");

View file

@ -97,6 +97,7 @@ var sel_crs_rmp1 = props.globals.initNode("/systems/radio/rmp[0]/select-crs", 1,
var sel_crs_rmp2 = props.globals.initNode("/systems/radio/rmp[1]/select-crs", 1, "BOOL"); var sel_crs_rmp2 = props.globals.initNode("/systems/radio/rmp[1]/select-crs", 1, "BOOL");
var vhf3_data_mode = props.globals.initNode("/systems/radio/vhf3-data-mode", 1, "BOOL"); var vhf3_data_mode = props.globals.initNode("/systems/radio/vhf3-data-mode", 1, "BOOL");
var rmpNav = [props.globals.initNode("/systems/radio/rmp[0]/nav", 0, "BOOL"),props.globals.initNode("/systems/radio/rmp[1]/nav", 0, "BOOL")];
var init = func() { var init = func() {
chan_rmp1.setValue("vhf1"); chan_rmp1.setValue("vhf1");
@ -277,11 +278,11 @@ var update_displays_nav = func(nav) {
stby_display_rmp2.setValue(sprintf("%3.2f", stby_vor2.getValue())); stby_display_rmp2.setValue(sprintf("%3.2f", stby_vor2.getValue()));
} }
} else if (nav == 5 and chan1 == "adf") { } else if (nav == 5 and chan1 == "adf") {
act_display_rmp1.setValue(sprintf("%4.0f", act_adf1.getValue())); act_display_rmp1.setValue(sprintf("%4.2f", act_adf1.getValue()));
stby_display_rmp1.setValue(sprintf("%4.0f", stby_adf1.getValue())); stby_display_rmp1.setValue(sprintf("%4.2f", stby_adf1.getValue()));
} else if (nav == 6 and chan2 == "adf") { } else if (nav == 6 and chan2 == "adf") {
act_display_rmp2.setValue(sprintf("%4.0f", act_adf2.getValue())); act_display_rmp2.setValue(sprintf("%4.2f", act_adf2.getValue()));
stby_display_rmp2.setValue(sprintf("%4.0f", stby_adf2.getValue())); stby_display_rmp2.setValue(sprintf("%4.2f", stby_adf2.getValue()));
} }
} }
@ -478,19 +479,19 @@ var change_nav_mode = func(rmp_nr, nav_mode) {
if (rmp_nr == 2 and (chan_rmp2.getValue() == "vor" or chan_rmp2.getValue() == "ls" or chan_rmp2.getValue() == "adf")) { if (rmp_nr == 2 and (chan_rmp2.getValue() == "vor" or chan_rmp2.getValue() == "ls" or chan_rmp2.getValue() == "adf")) {
chan_rmp2.setValue("vhf2"); chan_rmp2.setValue("vhf2");
} }
setprop("/FMGC/internal/ils1freq-set", 1); fmgc.FMGCInternal.ILS.freqSet = 1;
setprop("/FMGC/internal/ils1crs-set", 1); fmgc.FMGCInternal.ILS.crsSet = 1;
setprop("/FMGC/internal/vor1freq-set", 1); fmgc.FMGCInternal.VOR1.freqSet = 1;
setprop("/FMGC/internal/vor1crs-set", 1); fmgc.FMGCInternal.VOR1.crsSet = 1;
setprop("/FMGC/internal/vor2freq-set", 1); fmgc.FMGCInternal.VOR2.freqSet = 1;
setprop("/FMGC/internal/vor2crs-set", 1); fmgc.FMGCInternal.VOR2.crsSet = 1;
setprop("/FMGC/internal/adf1freq-set", 1); fmgc.FMGCInternal.ADF1.freqSet = 1;
setprop("/FMGC/internal/adf2freq-set", 1); fmgc.FMGCInternal.ADF2.freqSet = 1;
} }
} }
# ADF Radio: Implement BFO such that you will hear audio # ADF Radio: Implement BFO such that you will hear audio
var BFOActive = [props.globals.getNode("/systems/radio/rmp[0]/bfo-active"),props.globals.getNode("/systems/radio/rmp[1]/bfo-active")]; var BFOActive = [props.globals.initNode("/systems/radio/rmp[0]/bfo-active", 0, "BOOL"),props.globals.initNode("/systems/radio/rmp[1]/bfo-active", 0, "BOOL")];
var ADFIdent = [props.globals.getNode("/instrumentation/adf[0]/ident-audible"),props.globals.getNode("/instrumentation/adf[1]/ident-audible")]; var ADFIdent = [props.globals.getNode("/instrumentation/adf[0]/ident-audible"),props.globals.getNode("/instrumentation/adf[1]/ident-audible")];
var ADFMode = [props.globals.getNode("/instrumentation/adf[0]/mode"),props.globals.getNode("/instrumentation/adf[1]/mode")]; var ADFMode = [props.globals.getNode("/instrumentation/adf[0]/mode"),props.globals.getNode("/instrumentation/adf[1]/mode")];

View file

@ -49,8 +49,6 @@ var ELEC = {
tr2Fault: props.globals.getNode("/systems/failures/electrical/tr-2"), tr2Fault: props.globals.getNode("/systems/failures/electrical/tr-2"),
}, },
Generic: { Generic: {
adf: props.globals.initNode("/systems/electrical/outputs/adf", 0, "DOUBLE"),
dme: props.globals.initNode("/systems/electrical/outputs/dme", 0, "DOUBLE"),
efis: props.globals.initNode("/systems/electrical/outputs/efis", 0, "DOUBLE"), efis: props.globals.initNode("/systems/electrical/outputs/efis", 0, "DOUBLE"),
fcpPower: props.globals.initNode("/systems/electrical/outputs/fcp-power", 0, "DOUBLE"), fcpPower: props.globals.initNode("/systems/electrical/outputs/fcp-power", 0, "DOUBLE"),
fuelPump0: props.globals.initNode("/systems/electrical/outputs/fuel-pump[0]", 0, "DOUBLE"), fuelPump0: props.globals.initNode("/systems/electrical/outputs/fuel-pump[0]", 0, "DOUBLE"),
@ -58,10 +56,6 @@ var ELEC = {
fuelPump2: props.globals.initNode("/systems/electrical/outputs/fuel-pump[2]", 0, "DOUBLE"), fuelPump2: props.globals.initNode("/systems/electrical/outputs/fuel-pump[2]", 0, "DOUBLE"),
gps: props.globals.initNode("/systems/electrical/outputs/gps", 0, "DOUBLE"), gps: props.globals.initNode("/systems/electrical/outputs/gps", 0, "DOUBLE"),
mkViii: props.globals.initNode("/systems/electrical/outputs/mk-viii", 0, "DOUBLE"), mkViii: props.globals.initNode("/systems/electrical/outputs/mk-viii", 0, "DOUBLE"),
nav0: props.globals.initNode("/systems/electrical/outputs/nav[0]", 0, "DOUBLE"),
nav1: props.globals.initNode("/systems/electrical/outputs/nav[1]", 0, "DOUBLE"),
nav2: props.globals.initNode("/systems/electrical/outputs/nav[2]", 0, "DOUBLE"),
nav3: props.globals.initNode("/systems/electrical/outputs/nav[3]", 0, "DOUBLE"),
tacan: props.globals.initNode("/systems/electrical/outputs/tacan", 0, "DOUBLE"), tacan: props.globals.initNode("/systems/electrical/outputs/tacan", 0, "DOUBLE"),
transponder: props.globals.initNode("/systems/electrical/outputs/transponder", 0, "DOUBLE"), transponder: props.globals.initNode("/systems/electrical/outputs/transponder", 0, "DOUBLE"),
turnCoordinator: props.globals.initNode("/systems/electrical/outputs/turn-coordinator", 0, "DOUBLE"), turnCoordinator: props.globals.initNode("/systems/electrical/outputs/turn-coordinator", 0, "DOUBLE"),

View file

@ -2242,12 +2242,23 @@
<output>/systems/electrical/outputs/fuel-pump[0]</output> <output>/systems/electrical/outputs/fuel-pump[0]</output>
<output>/systems/electrical/outputs/fuel-pump[1]</output> <output>/systems/electrical/outputs/fuel-pump[1]</output>
<output>/systems/electrical/outputs/fuel-pump[2]</output> <output>/systems/electrical/outputs/fuel-pump[2]</output>
<output>/systems/electrical/outputs/gps</output>
<output>/systems/electrical/outputs/mk-viii</output> <output>/systems/electrical/outputs/mk-viii</output>
<output>/systems/electrical/outputs/tacan</output> <output>/systems/electrical/outputs/tacan</output>
<output>/systems/electrical/outputs/turn-coordinator</output> <output>/systems/electrical/outputs/turn-coordinator</output>
</switch> </switch>
<switch name="/systems/electrical/generic-ac-pwr">
<description>This makes the FG stuff work because we killed the generic electrical</description>
<default value="0"/>
<test value="/systems/electrical/bus/ac-ess">
/systems/electrical/bus/ac-ess ge 25
</test>
<test value="/systems/electrical/bus/ac-2">
/systems/electrical/bus/ac-2 ge 25
</test>
<output>/systems/electrical/outputs/gps</output>
</switch>
<switch name="/instrumentation/comm[0]/power-btn"> <switch name="/instrumentation/comm[0]/power-btn">
<default value="0"/> <default value="0"/>
<test logic="AND" value="1"> <test logic="AND" value="1">

View file

@ -39,6 +39,352 @@
</channel> </channel>
<channel name="ADF" execrate="8">
<switch name="/instrumentation/adf[0]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-ess-shed ge 110
</test>
</switch>
<actuator name="/instrumentation/adf[0]/power-supply-bite-enable">
<input>/instrumentation/adf[0]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.5</rate_limit>
</actuator>
<actuator name="/instrumentation/adf[0]/power-supply-bite-timer">
<input>/instrumentation/adf[0]/power-supply</input>
<rate_limit sense="incr">0.5</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/adf[0]/power-supply-was-off">
<default value="/instrumentation/adf[0]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/adf[0]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/adf[0]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/adf[0]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-ess-shed">
/instrumentation/adf[0]/power-supply-was-off eq 0
/instrumentation/adf[0]/power-supply-bite-timer eq 1
</test>
</switch>
<switch name="/instrumentation/adf[1]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-2 ge 110
</test>
</switch>
<actuator name="/instrumentation/adf[1]/power-supply-bite-enable">
<input>/instrumentation/adf[1]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.5</rate_limit>
</actuator>
<actuator name="/instrumentation/adf[1]/power-supply-bite-timer">
<input>/instrumentation/adf[1]/power-supply</input>
<rate_limit sense="incr">0.5</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/adf[1]/power-supply-was-off">
<default value="/instrumentation/adf[1]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/adf[1]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/adf[1]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/adf[1]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-2">
/instrumentation/adf[1]/power-supply-was-off eq 0
/instrumentation/adf[1]/power-supply-bite-timer eq 1
</test>
</switch>
</channel>
<channel name="VOR" execrate="8">
<switch name="/instrumentation/nav[2]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-ess ge 110
</test>
</switch>
<actuator name="/instrumentation/nav[2]/power-supply-bite-enable">
<input>/instrumentation/nav[2]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.333</rate_limit>
</actuator>
<actuator name="/instrumentation/nav[2]/power-supply-bite-timer">
<input>/instrumentation/nav[2]/power-supply</input>
<rate_limit sense="incr">0.333</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/nav[2]/power-supply-was-off">
<default value="/instrumentation/nav[2]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/nav[2]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/nav[2]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/nav[2]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-ess">
/instrumentation/nav[2]/power-supply-was-off eq 0
/instrumentation/nav[2]/power-supply-bite-timer eq 1
</test>
</switch>
<switch name="/instrumentation/nav[3]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-2 ge 110
</test>
</switch>
<actuator name="/instrumentation/nav[3]/power-supply-bite-enable">
<input>/instrumentation/nav[3]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.333</rate_limit>
</actuator>
<actuator name="/instrumentation/nav[3]/power-supply-bite-timer">
<input>/instrumentation/nav[3]/power-supply</input>
<rate_limit sense="incr">0.333</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/nav[3]/power-supply-was-off">
<default value="/instrumentation/nav[3]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/nav[3]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/nav[3]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/nav[3]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-2">
/instrumentation/nav[3]/power-supply-was-off eq 0
/instrumentation/nav[3]/power-supply-bite-timer eq 1
</test>
</switch>
</channel>
<channel name="DME" execrate="8">
<switch name="/instrumentation/dme[0]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-ess-shed ge 110
</test>
</switch>
<actuator name="/instrumentation/dme[0]/power-supply-bite-enable">
<input>/instrumentation/dme[0]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.5</rate_limit>
</actuator>
<actuator name="/instrumentation/dme[0]/power-supply-bite-timer">
<input>/instrumentation/dme[0]/power-supply</input>
<rate_limit sense="incr">0.5</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/dme[0]/power-supply-was-off">
<default value="/instrumentation/dme[0]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/dme[0]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/dme[0]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/dme[0]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-ess-shed">
/instrumentation/dme[0]/power-supply-was-off eq 0
/instrumentation/dme[0]/power-supply-bite-timer eq 1
</test>
</switch>
<switch name="/instrumentation/dme[1]/power-supply">
<default value="0"/>
<test logic="AND" value="1">
/systems/electrical/bus/ac-2 ge 110
</test>
</switch>
<actuator name="/instrumentation/dme[1]/power-supply-bite-enable">
<input>/instrumentation/dme[1]/power-supply</input>
<rate_limit sense="incr">100</rate_limit>
<rate_limit sense="decr">0.5</rate_limit>
</actuator>
<actuator name="/instrumentation/dme[1]/power-supply-bite-timer">
<input>/instrumentation/dme[1]/power-supply</input>
<rate_limit sense="incr">0.5</rate_limit>
<rate_limit sense="decr">100</rate_limit>
</actuator>
<switch name="/instrumentation/dme[1]/power-supply-was-off">
<default value="/instrumentation/dme[1]/power-supply-was-off"/>
<test logic="AND" value="0">
/instrumentation/dme[1]/power-supply-bite-timer eq 1
</test>
<test logic="AND" value="1">
/instrumentation/dme[1]/power-supply-bite-enable eq 0
</test>
</switch>
<switch name="/instrumentation/dme[1]/power-supply-node">
<default value="0"/>
<test logic="OR" value="/systems/electrical/bus/ac-2">
/instrumentation/dme[1]/power-supply-was-off eq 0
/instrumentation/dme[1]/power-supply-bite-timer eq 1
</test>
</switch>
</channel>
<channel name="ACP" execrate="8">
<switch name="/instrumentation/adf[0]/volume-norm">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/adf1-volume">
/controls/audio/acp[0]/adf1-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/adf1-recive eq 0
/controls/audio/acp[0]/adf1-volume ge /controls/audio/acp[1]/adf1-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/adf1-volume">
/controls/audio/acp[1]/adf1-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/adf1-recive eq 0
/controls/audio/acp[0]/adf1-volume lt /controls/audio/acp[1]/adf1-volume
</test>
</test>
</switch>
<switch name="/instrumentation/adf[1]/volume-norm">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/adf2-volume">
/controls/audio/acp[0]/adf2-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/adf2-recive eq 0
/controls/audio/acp[0]/adf2-volume ge /controls/audio/acp[1]/adf2-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/adf2-volume">
/controls/audio/acp[1]/adf2-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/adf2-recive eq 0
/controls/audio/acp[0]/adf2-volume lt /controls/audio/acp[1]/adf2-volume
</test>
</test>
</switch>
<switch name="/instrumentation/marker-beacon/volume">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/mkr-volume">
/controls/audio/acp[0]/mkr-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/mkr-recive eq 0
/controls/audio/acp[0]/mkr-volume ge /controls/audio/acp[1]/mkr-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/mkr-volume">
/controls/audio/acp[1]/mkr-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/mkr-recive eq 0
/controls/audio/acp[0]/mkr-volume lt /controls/audio/acp[1]/mkr-volume
</test>
</test>
</switch>
<switch name="/instrumentation/nav[0]/volume">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/ils-volume">
/controls/audio/acp[0]/ils-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/ils-recive eq 0
/controls/audio/acp[0]/ils-volume ge /controls/audio/acp[1]/ils-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/ils-volume">
/controls/audio/acp[1]/ils-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/ils-recive eq 0
/controls/audio/acp[0]/ils-volume lt /controls/audio/acp[1]/ils-volume
</test>
</test>
</switch>
<switch name="/instrumentation/nav[2]/volume">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/vor1-volume">
/controls/audio/acp[0]/vor1-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/vor1-recive eq 0
/controls/audio/acp[0]/vor1-volume ge /controls/audio/acp[1]/vor1-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/vor1-volume">
/controls/audio/acp[1]/vor1-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/vor1-recive eq 0
/controls/audio/acp[0]/vor1-volume lt /controls/audio/acp[1]/vor1-volume
</test>
</test>
</switch>
<switch name="/instrumentation/nav[3]/volume">
<default value="0"/>
<test logic="AND" value="/controls/audio/acp[0]/vor2-volume">
/controls/audio/acp[0]/vor2-recive eq 1
<test logic="OR">
/controls/audio/acp[1]/vor2-recive eq 0
/controls/audio/acp[0]/vor2-volume ge /controls/audio/acp[1]/vor2-volume
</test>
</test>
<test logic="AND" value="/controls/audio/acp[1]/vor2-volume">
/controls/audio/acp[1]/vor2-recive eq 1
<test logic="OR">
/controls/audio/acp[0]/vor2-recive eq 0
/controls/audio/acp[0]/vor2-volume lt /controls/audio/acp[1]/vor2-volume
</test>
</test>
</switch>
</channel>
<channel name="System Display" execrate="8"> <channel name="System Display" execrate="8">
<switch name="/ECAM/Lower/g-force-display-cmd"> <switch name="/ECAM/Lower/g-force-display-cmd">

View file

@ -9,14 +9,14 @@
<adf> <adf>
<name>adf</name> <name>adf</name>
<number>0</number> <number>0</number>
<power-supply>/systems/electrical/bus/ac-ess-shed</power-supply> <power-supply>/instrumentation/adf[0]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</adf> </adf>
<adf> <adf>
<name>adf</name> <name>adf</name>
<number>1</number> <number>1</number>
<power-supply>/systems/electrical/bus/ac-2</power-supply> <power-supply>/instrumentation/adf[1]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</adf> </adf>
@ -126,10 +126,10 @@
<eight-point-three>1</eight-point-three> <eight-point-three>1</eight-point-three>
</comm-radio> </comm-radio>
<dme> <dme> <!-- fake extra dme units for the ILS -->
<name>dme</name> <name>dme</name>
<number>0</number> <number>0</number>
<power-supply>/systems/electrical/bus/ac-ess-shed</power-supply> <power-supply>/systems/electrical/bus/ac-ess</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</dme> </dme>
@ -140,17 +140,17 @@
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</dme> </dme>
<dme> <!-- fake extra dme units for the ILS --> <dme> <!-- VOR DME -->
<name>dme</name> <name>dme</name>
<number>2</number> <number>2</number>
<power-supply>/systems/electrical/bus/ac-ess</power-supply> <power-supply>/instrumentation/dme[0]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</dme> </dme>
<dme> <dme>
<name>dme</name> <name>dme</name>
<number>3</number> <number>3</number>
<power-supply>/systems/electrical/bus/ac-2</power-supply> <power-supply>/instrumentation/dme[1]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</dme> </dme>
@ -176,11 +176,11 @@
<marker-beacon> <!-- part of VOR1 unit --> <marker-beacon> <!-- part of VOR1 unit -->
<name>marker-beacon</name> <name>marker-beacon</name>
<number>0</number> <number>0</number>
<power-supply>/systems/electrical/bus/ac-ess</power-supply> <power-supply>/instrumentation/nav[2]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</marker-beacon> </marker-beacon>
<nav-radio> <!-- VOR unit --> <nav-radio> <!-- ILS unit -->
<name>nav</name> <name>nav</name>
<number>0</number> <number>0</number>
<power-supply>/systems/electrical/bus/ac-ess</power-supply> <power-supply>/systems/electrical/bus/ac-ess</power-supply>
@ -194,17 +194,17 @@
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</nav-radio> </nav-radio>
<nav-radio> <!-- ILS unit --> <nav-radio> <!-- VOR unit -->
<name>nav</name> <name>nav</name>
<number>2</number> <number>2</number>
<power-supply>/systems/electrical/bus/ac-ess</power-supply> <power-supply>/instrumentation/nav[2]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</nav-radio> </nav-radio>
<nav-radio> <nav-radio>
<name>nav</name> <name>nav</name>
<number>3</number> <number>3</number>
<power-supply>/systems/electrical/bus/ac-2</power-supply> <power-supply>/instrumentation/nav[3]/power-supply-node</power-supply>
<minimum-supply-volts>109.9</minimum-supply-volts> <minimum-supply-volts>109.9</minimum-supply-volts>
</nav-radio> </nav-radio>

View file

@ -878,13 +878,27 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <!-- TODO ATT HDG SWITCH --> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
</and> </and>
</condition> </condition>
</enable> </enable>
@ -919,8 +933,8 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-1</property> <property>/instrumentation/ddrmi/vor-adf-1</property>
@ -930,10 +944,24 @@
<property>/instrumentation/nav[2]/in-range</property> <property>/instrumentation/nav[2]/in-range</property>
<value>1</value> <value>1</value>
</equals> </equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
</and> </and>
</condition> </condition>
<property>/instrumentation/ddrmi/vor-1-error</property> <property>/instrumentation/ddrmi/vor-1-error</property>
@ -943,27 +971,43 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-1</property> <property>/instrumentation/ddrmi/vor-adf-1</property>
<value>-1</value> <value>0</value>
</equals> </equals>
<equals> <equals>
<property>/instrumentation/adf[0]/in-range</property> <property>/instrumentation/adf[0]/in-range</property>
<value>1</value> <value>1</value>
</equals> </equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
</and> </and>
</condition> </condition>
<property>/instrumentation/adf[0]/indicated-bearing-deg</property> <property>/instrumentation/adf[0]/indicated-bearing-deg</property>
<scale>-1.0</scale> <scale>-1.0</scale>
</input> </input>
<input>-90</input> <input>
<property>/instrumentation/ddrmi/needle-1</property>
</input>
<output>/instrumentation/ddrmi/needle-1</output> <output>/instrumentation/ddrmi/needle-1</output>
</filter> </filter>
@ -994,8 +1038,8 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-2</property> <property>/instrumentation/ddrmi/vor-adf-2</property>
@ -1005,10 +1049,24 @@
<property>/instrumentation/nav[3]/in-range</property> <property>/instrumentation/nav[3]/in-range</property>
<value>1</value> <value>1</value>
</equals> </equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
</and> </and>
</condition> </condition>
<property>/instrumentation/ddrmi/vor-2-error</property> <property>/instrumentation/ddrmi/vor-2-error</property>
@ -1018,27 +1076,43 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-2</property> <property>/instrumentation/ddrmi/vor-adf-2</property>
<value>-1</value> <value>0</value>
</equals> </equals>
<equals> <equals>
<property>/instrumentation/adf[1]/in-range</property> <property>/instrumentation/adf[1]/in-range</property>
<value>1</value> <value>1</value>
</equals> </equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
</and> </and>
</condition> </condition>
<property>/instrumentation/adf[1]/indicated-bearing-deg</property> <property>/instrumentation/adf[1]/indicated-bearing-deg</property>
<scale>-1.0</scale> <scale>-1.0</scale>
</input> </input>
<input>-90</input> <input>
<property>/instrumentation/ddrmi/needle-2</property>
</input>
<output>/instrumentation/ddrmi/needle-2</output> <output>/instrumentation/ddrmi/needle-2</output>
</filter> </filter>
@ -1050,13 +1124,27 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
<or> <or>
<and> <and>
<equals> <equals>
@ -1071,7 +1159,7 @@
<and> <and>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-1</property> <property>/instrumentation/ddrmi/vor-adf-1</property>
<value>-1</value> <value>0</value>
</equals> </equals>
<equals> <equals>
<property>/instrumentation/adf[0]/in-range</property> <property>/instrumentation/adf[0]/in-range</property>
@ -1096,13 +1184,27 @@
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
<property>/systems/electrical/bus/dc-ess</property> <property>/systems/electrical/bus/ac-ess</property>
<value>25</value> <value>110</value>
</greater-than-equals> </greater-than-equals>
<equals> <or>
<property>/systems/navigation/aligned-1</property> <and>
<value>1</value> <property>/systems/navigation/aligned-1</property>
</equals> <not>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</not>
</and>
<and>
<property>/systems/navigation/aligned-3</property>
<equals>
<property>/controls/navigation/switching/att-hdg</property>
<value>-1</value>
</equals>
</and>
</or>
<or> <or>
<and> <and>
<equals> <equals>
@ -1117,7 +1219,7 @@
<and> <and>
<equals> <equals>
<property>/instrumentation/ddrmi/vor-adf-2</property> <property>/instrumentation/ddrmi/vor-adf-2</property>
<value>-1</value> <value>0</value>
</equals> </equals>
<equals> <equals>
<property>/instrumentation/adf[1]/in-range</property> <property>/instrumentation/adf[1]/in-range</property>