1
0
Fork 0

Merge branch '3D' into cpdlc

This commit is contained in:
legoboyvdlp R 2021-01-18 12:32:59 +00:00
commit 4aae0ca23e
22 changed files with 915 additions and 299 deletions

View file

@ -1956,20 +1956,37 @@
<key n="8"> <key n="8">
<name>Del</name> <name>Del</name>
<desc>CLR</desc> <desc>CLR</desc>
<repeatable type="bool">true</repeatable>
<binding> <binding>
<condition> <condition>
<property>/FMGC/keyboard-left</property> <property>/FMGC/keyboard-left</property>
</condition> </condition>
<command>nasal</command> <command>nasal</command>
<script>mcdu.button("CLR", 0);</script> <script>mcdu.button("CLR", 0, "down");</script>
</binding> </binding>
<binding> <binding>
<condition> <condition>
<property>/FMGC/keyboard-right</property> <property>/FMGC/keyboard-right</property>
</condition> </condition>
<command>nasal</command> <command>nasal</command>
<script>mcdu.button("CLR", 1);</script> <script>mcdu.button("CLR", 1, "down");</script>
</binding> </binding>
<mod-up>
<binding>
<condition>
<property>/FMGC/keyboard-left</property>
</condition>
<command>nasal</command>
<script>mcdu.button("CLR", 0, "up");</script>
</binding>
<binding>
<condition>
<property>/FMGC/keyboard-right</property>
</condition>
<command>nasal</command>
<script>mcdu.button("CLR", 1, "up");</script>
</binding>
</mod-up>
</key> </key>
<key n="11"> <key n="11">
<name>Disable MCDU keyboard mode</name> <name>Disable MCDU keyboard mode</name>
@ -4688,7 +4705,8 @@
<file>Aircraft/A320-family/Nasal/MCDU/WINDCRZ.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/WINDCRZ.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/WINDDES.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/WINDDES.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/WINDHIST.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/WINDHIST.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/ATIS.nas</file> <!-- Last Dynamic Page --> <file>Aircraft/A320-family/Nasal/MCDU/ATIS.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/FLIGHTLOG.nas</file> <!-- Last Dynamic Page -->
<file>Aircraft/A320-family/Nasal/MCDU/MCDU.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/MCDU.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/INITA.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/INITA.nas</file>
<file>Aircraft/A320-family/Nasal/MCDU/IRSINIT.nas</file> <file>Aircraft/A320-family/Nasal/MCDU/IRSINIT.nas</file>

View file

@ -197,10 +197,10 @@ var renderingSettings = {
check: func() { check: func() {
var rembrandt = getprop("/sim/rendering/rembrandt/enabled"); var rembrandt = getprop("/sim/rendering/rembrandt/enabled");
var ALS = getprop("/sim/rendering/shaders/skydome"); var ALS = getprop("/sim/rendering/shaders/skydome");
var customSettings = getprop("/sim/rendering/shaders/custom-settings") == 1;
var landmass = getprop("/sim/rendering/shaders/landmass") >= 4; var landmass = getprop("/sim/rendering/shaders/landmass") >= 4;
var model = getprop("/sim/rendering/shaders/model") >= 2; var model = getprop("/sim/rendering/shaders/model") >= 2;
if (!rembrandt and (!ALS or !customSettings or !landmass or !model)) { if (!rembrandt and (!ALS or !landmass or !model)) {
rendering_dlg.open(); rendering_dlg.open();
} }
}, },
@ -256,6 +256,15 @@ var writeSettings = func {
# Panel States # # Panel States #
################ ################
# Abort auto-config and close dialog
var abortPanelStates = func {
if (getprop("/systems/acconfig/autoconfig-running") == 1) {
setprop("/systems/acconfig/autoconfig-running", 0);
}
ps_load_dlg.close();
spinning.stop();
}
# Cold and Dark # Cold and Dark
var colddark = func { var colddark = func {
if (getprop("/systems/acconfig/mismatch-code") == "0x000") { if (getprop("/systems/acconfig/mismatch-code") == "0x000") {
@ -352,6 +361,10 @@ var beforestart = func {
} }
} }
var beforestart_b = func { var beforestart_b = func {
if (getprop("/systems/acconfig/autoconfig-running") == 0) {
colddark();
return 0; # auto-config aborted
}
# Continue with engine start prep. # Continue with engine start prep.
systems.FUEL.Switches.pumpLeft1.setValue(1); systems.FUEL.Switches.pumpLeft1.setValue(1);
systems.FUEL.Switches.pumpLeft2.setValue(1); systems.FUEL.Switches.pumpLeft2.setValue(1);
@ -439,6 +452,10 @@ var taxi = func {
} }
} }
var taxi_b = func { var taxi_b = func {
if (getprop("/systems/acconfig/autoconfig-running") == 0) {
colddark();
return 0; # auto-config aborted
}
# Continue with engine start prep, and start engines. # Continue with engine start prep, and start engines.
systems.FUEL.Switches.pumpLeft1.setValue(1); systems.FUEL.Switches.pumpLeft1.setValue(1);
systems.FUEL.Switches.pumpLeft2.setValue(1); systems.FUEL.Switches.pumpLeft2.setValue(1);
@ -492,6 +509,10 @@ var taxi_b = func {
settimer(taxi_c, 2); settimer(taxi_c, 2);
} }
var taxi_c = func { var taxi_c = func {
if (getprop("/systems/acconfig/autoconfig-running") == 0) {
colddark();
return 0; # auto-config aborted
}
setprop("/controls/engines/engine-start-switch", 2); setprop("/controls/engines/engine-start-switch", 2);
setprop("/controls/engines/engine[0]/cutoff-switch", 0); setprop("/controls/engines/engine[0]/cutoff-switch", 0);
setprop("/controls/engines/engine[1]/cutoff-switch", 0); setprop("/controls/engines/engine[1]/cutoff-switch", 0);
@ -500,6 +521,10 @@ var taxi_c = func {
}, 10); }, 10);
} }
var taxi_d = func { var taxi_d = func {
if (getprop("/systems/acconfig/autoconfig-running") == 0) {
colddark();
return 0; # auto-config aborted
}
# After Start items. # After Start items.
setprop("/controls/engines/engine-start-switch", 1); setprop("/controls/engines/engine-start-switch", 1);
setprop("/controls/apu/master", 0); setprop("/controls/apu/master", 0);

View file

@ -15,6 +15,16 @@
<halign>left</halign> <halign>left</halign>
<label>Please wait...</label> <label>Please wait...</label>
</text> </text>
<button>
<halign>right</halign>
<legend>Abort</legend>
<pref-width>60</pref-width>
<key>Esc</key>
<binding>
<command>nasal</command>
<script>acconfig.abortPanelStates();</script>
</binding>
</button>
</group> </group>
<hrule/> <hrule/>

View file

@ -309,6 +309,33 @@
</offsets> </offsets>
</model> </model>
<animation>
<type>select</type>
<object-name>Left nav light</object-name>
<object-name>Left nav light ALS</object-name>
<condition>
<not><property>sim/multiplay/generic/int[12]</property></not>
</condition>
</animation>
<model>
<name>Left nav light ALS sharklet</name>
<path>Aircraft/A320-family/Models/Lights/ALS/rednav.xml</path>
<offsets>
<x-m>1.54364</x-m>
<y-m>-16.38</y-m>
<z-m>0.317012</z-m>
</offsets>
</model>
<animation>
<type>select</type>
<object-name>Left nav light ALS sharklet</object-name>
<condition>
<property>sim/multiplay/generic/int[12]</property>
</condition>
</animation>
<model> <model>
<name>Right nav light</name> <name>Right nav light</name>
<path>Aircraft/A320-family/Models/Lights/greennav.xml</path> <path>Aircraft/A320-family/Models/Lights/greennav.xml</path>
@ -329,6 +356,33 @@
</offsets> </offsets>
</model> </model>
<animation>
<type>select</type>
<object-name>Right nav light</object-name>
<object-name>Right nav light ALS</object-name>
<condition>
<not><property>sim/multiplay/generic/int[12]</property></not>
</condition>
</animation>
<model>
<name>Right nav light ALS sharklet</name>
<path>Aircraft/A320-family/Models/Lights/ALS/greennav.xml</path>
<offsets>
<x-m>1.54364</x-m>
<y-m>16.38</y-m>
<z-m>0.317012</z-m>
</offsets>
</model>
<animation>
<type>select</type>
<object-name>Right nav light ALS sharklet</object-name>
<condition>
<property>sim/multiplay/generic/int[12]</property>
</condition>
</animation>
<model> <model>
<name>Tail nav light</name> <name>Tail nav light</name>
<path>Aircraft/A320-family/Models/Lights/tailnav.xml</path> <path>Aircraft/A320-family/Models/Lights/tailnav.xml</path>
@ -369,6 +423,33 @@
</offsets> </offsets>
</model> </model>
<animation>
<type>select</type>
<object-name>Left strobe light</object-name>
<object-name>Left strobe light ALS</object-name>
<condition>
<not><property>sim/multiplay/generic/int[12]</property></not>
</condition>
</animation>
<model>
<name>Left strobe light ALS sharklet</name>
<path>Aircraft/A320-family/Models/Lights/ALS/right-strobe.xml</path>
<offsets>
<x-m>2.31</x-m>
<y-m>-17.1</y-m>
<z-m>0.66</z-m>
</offsets>
</model>
<animation>
<type>select</type>
<object-name>Left strobe light ALS sharklet</object-name>
<condition>
<property>sim/multiplay/generic/int[12]</property>
</condition>
</animation>
<model> <model>
<name>Right strobe light</name> <name>Right strobe light</name>
<path>Aircraft/A320-family/Models/Lights/strobe.xml</path> <path>Aircraft/A320-family/Models/Lights/strobe.xml</path>
@ -389,6 +470,33 @@
</offsets> </offsets>
</model> </model>
<animation>
<type>select</type>
<object-name>Right strobe light</object-name>
<object-name>Right strobe light ALS</object-name>
<condition>
<not><property>sim/multiplay/generic/int[12]</property></not>
</condition>
</animation>
<model>
<name>Right strobe light ALS sharklet</name>
<path>Aircraft/A320-family/Models/Lights/ALS/right-strobe.xml</path>
<offsets>
<x-m>2.31</x-m>
<y-m>17.1</y-m>
<z-m>0.66</z-m>
</offsets>
</model>
<animation>
<type>select</type>
<object-name>Right strobe light ALS sharklet</object-name>
<condition>
<property>sim/multiplay/generic/int[12]</property>
</condition>
</animation>
<model> <model>
<name>Tail strobe light</name> <name>Tail strobe light</name>
<path>Aircraft/A320-family/Models/Lights/tailstrobe.xml</path> <path>Aircraft/A320-family/Models/Lights/tailstrobe.xml</path>

View file

@ -3,93 +3,14 @@
<name>reflection</name> <name>reflection</name>
<inherits-from>Effects/model-combined-deferred</inherits-from> <inherits-from>Effects/model-combined-deferred</inherits-from>
<parameters> <parameters>
<reflection-enabled type="int">1</reflection-enabled> <reflection-enabled type="int">0</reflection-enabled>
<reflection-dynamic type="int">1</reflection-dynamic> <reflection-dynamic type="int">0</reflection-dynamic>
<reflect_map-enabled type="int">0</reflect_map-enabled> <reflect_map-enabled type="int">0</reflect_map-enabled>
<reflection-correction type="float"><use>/sim/model/reflection/reflection-correction</use></reflection-correction> <reflection-correction type="float"><use>/sim/model/reflection/reflection-correction</use></reflection-correction>
<reflection-type type="int">2</reflection-type> <reflection-type type="int">2</reflection-type>
<ambient-correction type="float"><use>/sim/model/reflection/ambient-correction</use></ambient-correction> <ambient-correction type="float"><use>/sim/model/reflection/ambient-correction</use></ambient-correction>
<lightmap-enabled type="int">1</lightmap-enabled> <lightmap-enabled type="int">0</lightmap-enabled>
<lightmap-multi type="int">0</lightmap-multi> <lightmap-multi type="int">0</lightmap-multi>
<normalmap-enabled type="int">1</normalmap-enabled> <normalmap-enabled type="int">0</normalmap-enabled>
<texture n="2">
<image>Aircraft/A320-family/Models/Effects/res/Fuse-Main-Normal.png</image>
<filter>linear-mipmap-linear</filter>
<wrap-s>clamp</wrap-s>
<wrap-t>clamp</wrap-t>
</texture>
<lightmap-factor type="float" n="0"><use>sim/model/lights/logo-lights</use></lightmap-factor>
<lightmap-color type="vec3d" n="0">1.0 1.0 1.0</lightmap-color>
<texture n="3">
<image>Aircraft/A320-family/Models/Effects/res/fin-lightmap.png</image>
<filter>linear-mipmap-linear</filter>
<wrap-s>clamp</wrap-s>
<wrap-t>clamp</wrap-t>
<internal-format>normalized</internal-format>
</texture>
<texture n="5">
<type>cubemap</type>
<images>
<positive-x>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/1.png</positive-x>
<negative-x>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/4.png</negative-x>
<positive-y>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/2.png</positive-y>
<negative-y>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/3.png</negative-y>
<positive-z>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/6.png</positive-z>
<negative-z>Aircraft/Generic/Effects/CubeMaps/fgfs-sky/5.png</negative-z>
</images>
</texture>
</parameters> </parameters>
<!-- ####################
### NORMALMAP INCLUDE ###
######################### -->
<generate>
<tangent type="int">6</tangent>
<binormal type="int">7</binormal>
</generate>
<technique n="4">
<pass>
<program>
<attribute>
<name>tangent</name>
<index>6</index>
</attribute>
<attribute>
<name>binormal</name>
<index>7</index>
</attribute>
</program>
</pass>
</technique>
<technique n="7">
<pass>
<program>
<attribute>
<name>tangent</name>
<index>6</index>
</attribute>
<attribute>
<name>binormal</name>
<index>7</index>
</attribute>
</program>
</pass>
</technique>
<technique n="9">
<pass>
<program>
<attribute>
<name>tangent</name>
<index>6</index>
</attribute>
<attribute>
<name>binormal</name>
<index>7</index>
</attribute>
</program>
</pass>
</technique>
<!-- ########################
### END NORMALMAP INCLUDE ###
############################# -->
</PropertyList> </PropertyList>

View file

@ -406,7 +406,7 @@
<!-- Effect --> <!-- Effect
<effect> <effect>
<inherits-from>Aircraft/A320-family/Models/Effects/reflection-engine-IAE</inherits-from> <inherits-from>Aircraft/A320-family/Models/Effects/reflection-engine-IAE</inherits-from>
<object-name>EngineIAEV2500L</object-name> <object-name>EngineIAEV2500L</object-name>
@ -425,5 +425,5 @@
<inherits-from>Aircraft/A320-family/Models/Effects/reflection-chrome-engine-IAE</inherits-from> <inherits-from>Aircraft/A320-family/Models/Effects/reflection-chrome-engine-IAE</inherits-from>
<object-name>IntakeIAEV2500L</object-name> <object-name>IntakeIAEV2500L</object-name>
<object-name>IntakeIAEV2500R</object-name> <object-name>IntakeIAEV2500R</object-name>
</effect> </effect>-->
</PropertyList> </PropertyList>

View file

@ -1,4 +1,4 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<!-- Copyright (c) 2020 Josh Davidson (Octal450) --> <!-- Copyright (c) 2020 Josh Davidson (Octal450) -->
@ -138,40 +138,31 @@
<!-- Knobs --> <!-- Knobs -->
<animation> <animation>
<type>pick</type> <type>knob</type>
<object-name>ddrmi_vor_adf_select_1</object-name> <object-name>ddrmi_vor_adf_select_1</object-name>
<action>
<button>0</button>
<repeatable type="bool">false</repeatable>
<binding>
<command>property-cycle</command>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
<value>0</value> <!-- OFF --> <axis>
<value>1</value> <!-- VOR --> <object-name>ddrmi_vor_adf_select_1.axis</object-name>
<value>-1</value> <!-- ADF --> </axis>
</binding>
</action>
<action> <action>
<button>1</button>
<repeatable type="bool">false</repeatable>
<binding> <binding>
<command>property-cycle</command> <command>property-adjust</command>
<property>instrumentation/ddrmi/vor-adf-1</property> <property>instrumentation/ddrmi/vor-adf-1</property>
<value>-1</value> <!-- ADF --> <min>-1</min>
<value>1</value> <!-- VOR --> <max>1</max>
<value>0</value> <!-- OFF -->
</binding> </binding>
</action> </action>
</animation> </animation>
<animation> <animation>
<name>Knob 1 rotate</name> <name>DDRMI vor-adf knob 1</name>
<object-name>ddrmi_vor_adf_select_1</object-name>
<type>rotate</type> <type>rotate</type>
<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> <entry><ind>-1</ind><dep>90</dep></entry> <!-- ADF -->
<entry><ind> 0</ind><dep>45</dep></entry> <entry><ind> 0</ind><dep>45</dep></entry> <!-- OFF -->
<entry><ind> 1</ind><dep> 0</dep></entry> <entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR -->
</interpolation> </interpolation>
<axis> <axis>
<object-name>ddrmi_vor_adf_select_1.axis</object-name> <object-name>ddrmi_vor_adf_select_1.axis</object-name>
@ -179,40 +170,31 @@
</animation> </animation>
<animation> <animation>
<type>pick</type> <type>knob</type>
<object-name>ddrmi_vor_adf_select_2</object-name> <object-name>ddrmi_vor_adf_select_2</object-name>
<action>
<button>0</button>
<repeatable type="bool">false</repeatable>
<binding>
<command>property-cycle</command>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>
<value>0</value> <!-- OFF --> <axis>
<value>1</value> <!-- VOR --> <object-name>ddrmi_vor_adf_select_2.axis</object-name>
<value>-1</value> <!-- ADF --> </axis>
</binding>
</action>
<action> <action>
<button>1</button>
<repeatable type="bool">false</repeatable>
<binding> <binding>
<command>property-cycle</command> <command>property-adjust</command>
<property>instrumentation/ddrmi/vor-adf-2</property> <property>instrumentation/ddrmi/vor-adf-2</property>
<value>-1</value> <!-- ADF --> <min>-1</min>
<value>1</value> <!-- VOR --> <max>1</max>
<value>0</value> <!-- OFF -->
</binding> </binding>
</action> </action>
</animation> </animation>
<animation> <animation>
<name>Knob 2 rotate</name> <name>DDRMI vor-adf knob 2</name>
<object-name>ddrmi_vor_adf_select_2</object-name>
<type>rotate</type> <type>rotate</type>
<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> <entry><ind>-1</ind><dep>-90</dep></entry> <!-- ADF -->
<entry><ind> 0</ind><dep>-45</dep></entry> <entry><ind> 0</ind><dep>-45</dep></entry> <!-- OFF -->
<entry><ind> 1</ind><dep> 0</dep></entry> <entry><ind> 1</ind><dep> 0</dep></entry> <!-- VOR -->
</interpolation> </interpolation>
<axis> <axis>
<object-name>ddrmi_vor_adf_select_2.axis</object-name> <object-name>ddrmi_vor_adf_select_2.axis</object-name>
@ -227,7 +209,7 @@
<type>rotate</type> <type>rotate</type>
<property>instrumentation/ddrmi/flag-1</property> <property>instrumentation/ddrmi/flag-1</property>
<interpolation> <interpolation>
<entry><ind>0</ind><dep>45</dep></entry> <entry><ind>0</ind><dep>-45</dep></entry>
<entry><ind>1</ind><dep> 0</dep></entry> <entry><ind>1</ind><dep> 0</dep></entry>
</interpolation> </interpolation>
<axis> <axis>
@ -241,7 +223,7 @@
<type>rotate</type> <type>rotate</type>
<property>instrumentation/ddrmi/flag-2</property> <property>instrumentation/ddrmi/flag-2</property>
<interpolation> <interpolation>
<entry><ind>0</ind><dep>-45</dep></entry> <entry><ind>0</ind><dep>45</dep></entry>
<entry><ind>1</ind><dep> 0</dep></entry> <entry><ind>1</ind><dep> 0</dep></entry>
</interpolation> </interpolation>
<axis> <axis>
@ -8347,30 +8329,21 @@
</action> </action>
</animation> </animation>
<animation> <animation>
<name>UTC selector rotate</name> <name>UTC selector animation</name>
<type>pick</type> <type>knob</type>
<object-name>clock_knob</object-name> <object-name>clock_knob</object-name>
<action>
<button>0</button>
<repeatable type="bool">false</repeatable>
<binding>
<command>property-cycle</command>
<property>instrumentation/clock/utc-selector</property> <property>instrumentation/clock/utc-selector</property>
<value>0</value><!-- GPS --> <axis>
<value>1</value><!-- INT --> <object-name>clock_knob.axis</object-name>
<value>2</value><!-- SET --> </axis>
</binding>
</action>
<action> <action>
<button>1</button>
<repeatable type="bool">false</repeatable>
<binding> <binding>
<command>property-cycle</command> <command>property-adjust</command>
<property>instrumentation/clock/utc-selector</property> <property>instrumentation/clock/utc-selector</property>
<value>2</value><!-- SET --> <min>0</min>
<value>1</value><!-- INT --> <max>2</max>
<value>0</value><!-- GPS -->
</binding> </binding>
</action> </action>
</animation> </animation>
@ -8381,9 +8354,9 @@
<object-name>clock_knob</object-name> <object-name>clock_knob</object-name>
<property>instrumentation/clock/utc-selector</property> <property>instrumentation/clock/utc-selector</property>
<interpolation> <interpolation>
<entry><ind>0</ind><dep>0</dep></entry> <entry><ind>2</ind><dep>90</dep></entry> <!-- SET -->
<entry><ind>1</ind><dep>45</dep></entry> <entry><ind>1</ind><dep>45</dep></entry> <!-- INT -->
<entry><ind>2</ind><dep>90</dep></entry> <entry><ind>0</ind><dep> 0</dep></entry> <!-- GPS -->
</interpolation> </interpolation>
<axis> <axis>
<object-name>clock_knob.axis</object-name> <object-name>clock_knob.axis</object-name>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 127 KiB

After

Width:  |  Height:  |  Size: 127 KiB

View file

@ -34,7 +34,7 @@
<object-name>OutflowValveDoor2</object-name> <object-name>OutflowValveDoor2</object-name>
<object-name>GPUServiceDoor</object-name> <object-name>GPUServiceDoor</object-name>
</effect> </effect>
<effect> <!--<effect>
<inherits-from>Aircraft/A320-family/Models/Effects/reflection-rudder</inherits-from> <inherits-from>Aircraft/A320-family/Models/Effects/reflection-rudder</inherits-from>
<object-name>Rudder</object-name> <object-name>Rudder</object-name>
</effect> </effect>
@ -112,7 +112,7 @@
<object-name>SpoilerActuatorRodR3</object-name> <object-name>SpoilerActuatorRodR3</object-name>
<object-name>SpoilerActuatorRodR2</object-name> <object-name>SpoilerActuatorRodR2</object-name>
<object-name>SpoilerActuatorRodR1</object-name> <object-name>SpoilerActuatorRodR1</object-name>
</effect> </effect>-->
<!-- Animations --> <!-- Animations -->

View file

@ -152,10 +152,20 @@ var baro = props.globals.getNode("/FMGC/internal/baro", 1);
# GA PERF # GA PERF
# AOC - SENSORS
var parking_brake = props.globals.getNode("/controls/gear/brake-parking", 1);
var gear0_wow = props.globals.getNode("/gear/gear[0]/wow", 1);
var doorL1_pos = props.globals.getNode("/sim/model/door-positions/doorl1/position-norm", 1); #FWD door
var doorR1_pos = props.globals.getNode("/sim/model/door-positions/doorr1/position-norm", 1); #FWD door
var doorL4_pos = props.globals.getNode("/sim/model/door-positions/doorl4/position-norm", 1); #AFT door
var doorR4_pos = props.globals.getNode("/sim/model/door-positions/doorr4/position-norm", 1); #AFT door
# Fetch nodes into vectors # Fetch nodes into vectors
var pageProp = [props.globals.getNode("/MCDU[0]/page", 1), props.globals.getNode("/MCDU[1]/page", 1)]; var pageProp = [props.globals.getNode("/MCDU[0]/page", 1), props.globals.getNode("/MCDU[1]/page", 1)];
var active = [props.globals.getNode("/MCDU[0]/active", 1), props.globals.getNode("/MCDU[1]/active", 1)]; var active = [props.globals.getNode("/MCDU[0]/active", 1), props.globals.getNode("/MCDU[1]/active", 1)];
var activeAtsu = [props.globals.getNode("/MCDU[0]/atsu-active", 1), props.globals.getNode("/MCDU[1]/atsu-active", 1)]; var activeAtsu = [props.globals.getNode("/MCDU[0]/atsu-active", 1), props.globals.getNode("/MCDU[1]/atsu-active", 1)];
props.globals.initNode("/MCDU[0]/active-system", "", "STRING");
props.globals.initNode("/MCDU[1]/active-system", "", "STRING");
# Conversion factor pounds to kilogram # Conversion factor pounds to kilogram
var LBS2KGS = 0.4535924; var LBS2KGS = 0.4535924;
@ -200,23 +210,23 @@ var canvas_MCDU_base = {
me["PERFTO_FE"].setFont(symbol); me["PERFTO_FE"].setFont(symbol);
me["PERFTO_SE"].setFont(symbol); me["PERFTO_SE"].setFont(symbol);
me["PERFTO_OE"].setFont(symbol); me["PERFTO_OE"].setFont(symbol);
me["PERFTO_FE"].setColor(0.8078,0.8039,0.8078); me["PERFTO_FE"].setColor(BLUE);
me["PERFTO_SE"].setColor(0.8078,0.8039,0.8078); me["PERFTO_SE"].setColor(BLUE);
me["PERFTO_OE"].setColor(0.8078,0.8039,0.8078); me["PERFTO_OE"].setColor(BLUE);
me["PERFAPPR_FE"].setFont(symbol); me["PERFAPPR_FE"].setFont(symbol);
me["PERFAPPR_SE"].setFont(symbol); me["PERFAPPR_SE"].setFont(symbol);
me["PERFAPPR_OE"].setFont(symbol); me["PERFAPPR_OE"].setFont(symbol);
me["PERFAPPR_FE"].setColor(0.8078,0.8039,0.8078); me["PERFAPPR_FE"].setColor(BLUE);
me["PERFAPPR_SE"].setColor(0.8078,0.8039,0.8078); me["PERFAPPR_SE"].setColor(BLUE);
me["PERFAPPR_OE"].setColor(0.8078,0.8039,0.8078); me["PERFAPPR_OE"].setColor(BLUE);
me["PERFGA_FE"].setFont(symbol); me["PERFGA_FE"].setFont(symbol);
me["PERFGA_SE"].setFont(symbol); me["PERFGA_SE"].setFont(symbol);
me["PERFGA_OE"].setFont(symbol); me["PERFGA_OE"].setFont(symbol);
me["PERFGA_FE"].setColor(0.8078,0.8039,0.8078); me["PERFGA_FE"].setColor(BLUE);
me["PERFGA_SE"].setColor(0.8078,0.8039,0.8078); me["PERFGA_SE"].setColor(BLUE);
me["PERFGA_OE"].setColor(0.8078,0.8039,0.8078); me["PERFGA_OE"].setColor(BLUE);
me.page = canvas_group; me.page = canvas_group;
@ -282,12 +292,25 @@ var canvas_MCDU_base = {
me["PERFTO"].hide(); me["PERFTO"].hide();
}, },
defaultPageNumbers: func() { defaultPageNumbers: func() {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("X/X"); me["Simple_PageNum"].setText("X/X");
me["Simple_PageNum"].hide(); me["Simple_PageNum"].hide();
me["ArrowLeft"].hide(); me["ArrowLeft"].hide();
me["ArrowRight"].hide(); me["ArrowRight"].hide();
}, },
showPageNumbers: func(pagno=0,pagcnt=0) {
if (pagno == 0) return me.defaultPageNumbers();
me["Simple_PageNum"].show();
me["Simple_PageNum"].setText((pagcnt>0) ? pagno ~ "/" ~ pagcnt : pagno);
me["ArrowLeft"].show();
me["ArrowRight"].show();
},
showPageNumbersOnly: func(pagno,pagcnt) {
me["Simple_PageNum"].show();
me["Simple_PageNum"].setText(sprintf("%9s",pagno ~ "/" ~ pagcnt));
me["ArrowLeft"].hide();
me["ArrowRight"].hide();
},
hideAllArrows: func() { hideAllArrows: func() {
me["Simple_L1_Arrow"].hide(); me["Simple_L1_Arrow"].hide();
me["Simple_L2_Arrow"].hide(); me["Simple_L2_Arrow"].hide();
@ -499,29 +522,36 @@ var canvas_MCDU_base = {
me.standardFontColour(); me.standardFontColour();
me["Simple_L3"].setText(" AIDS"); me["Simple_L3"].setText(" AIDS");
me["Simple_L4"].setText(" CFDS"); me["Simple_L4"].setText(" CFDS");
pageSwitch[i].setBoolValue(1); pageSwitch[i].setBoolValue(1);
} }
if (active[i].getValue() == 0) { if (active[i].getValue() == 0) {
me["Simple_L1"].setText(" FMGC"); me["Simple_L1"].setText(" FMGC");
me["Simple_L1"].setColor(1,1,1); me["Simple_L1"].setColor(WHITE);
me["Simple_L1_Arrow"].setColor(WHITE);
} else if (active[i].getValue() == 1) { } else if (active[i].getValue() == 1) {
me["Simple_L1"].setText(" FMGC(SEL)"); me["Simple_L1"].setText(" FMGC (SEL)");
me["Simple_L1"].setColor(0.0901,0.6039,0.7176); me["Simple_L1"].setColor(BLUE);
me["Simple_L1_Arrow"].setColor(BLUE);
} else if (active[i].getValue() == 2) { } else if (active[i].getValue() == 2) {
me["Simple_L1"].setText(" FMGC"); me["Simple_L1"].setText(" FMGC");
me["Simple_L1"].setColor(0.0509,0.7529,0.2941); me["Simple_L1"].setColor(GREEN);
me["Simple_L1_Arrow"].setColor(GREEN);
} }
if (activeAtsu[i].getValue() == 0) { if (activeAtsu[i].getValue() == 0) {
me["Simple_L2"].setText(" ATSU"); me["Simple_L2"].setText(" ATSU");
me["Simple_L2"].setColor(1,1,1); me["Simple_L2"].setColor(WHITE);
me["Simple_L2_Arrow"].setColor(WHITE);
} else if (activeAtsu[i].getValue() == 1) { } else if (activeAtsu[i].getValue() == 1) {
me["Simple_L2"].setText(" ATSU(SEL)"); me["Simple_L2"].setText(" ATSU (SEL)");
me["Simple_L2"].setColor(0.0901,0.6039,0.7176); me["Simple_L2"].setColor(BLUE);
me["Simple_L2_Arrow"].setColor(BLUE);
} else if (activeAtsu[i].getValue() == 2) { } else if (activeAtsu[i].getValue() == 2) {
me["Simple_L2"].setText(" ATSU"); me["Simple_L2"].setText(" ATSU");
me["Simple_L2"].setColor(0.0509,0.7529,0.2941); me["Simple_L2"].setColor(GREEN);
me["Simple_L2_Arrow"].setColor(GREEN);
} }
} else if (page == "ATSUDLINK") { } else if (page == "ATSUDLINK") {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
@ -590,6 +620,178 @@ var canvas_MCDU_base = {
me["Simple_R6"].hide(); me["Simple_R6"].hide();
me["Simple_R6_Arrow"].hide(); me["Simple_R6_Arrow"].hide();
} }
} else if (page == "FLTLOG") {
if (!pageSwitch[i].getBoolValue()) {
me.defaultHideWithCenter();
me["Simple_L0S"].hide();
me["ArrowLeft"].hide();
me["ArrowRight"].hide();
me.showLeft(1, 1, 1, 1, 1, -1);
me.showLeftS(1, -1, 1, 1, 1, -1);
me.showLeftArrow(-1, -1, -1, -1, -1, -1);
me.showCenter(-1, 1, 1, 1, 1, -1);
me.showCenterS(-1, 1, 1, 1, 1, -1);
me.showRight(1, 1, 1, 1, 1, -1);
me.showRightS(1, 1, 1, 1, 1, -1);
me.showRightArrow(-1, -1, -1, -1, 1, -1);
me["Simple_C3B"].hide();
me["Simple_C4B"].hide();
me.standardFontSize();
me.standardFontColour();
me.colorCenterS("wht", "wht", "wht", "wht", "wht", "wht");
me.colorCenter("wht", "wht", "wht", "wht", "wht", "wht");
#me["PRINTPAGE"] - TODO missing asterisk at 5L - only useful when printing available
me["Simple_L1S"].setText(" FLT NUM-DATE");
me["Simple_R1S"].setText("ORIG-DEST ");
me["Simple_L1"].setFontSize(small);
me["Simple_R1"].setFontSize(small);
me["Simple_L2"].setFontSize(small);
me["Simple_C2"].setFontSize(small);
me["Simple_R2"].setFontSize(small);
me["Simple_L3"].setFontSize(small);
me["Simple_C3"].setFontSize(small);
me["Simple_R3"].setFontSize(small);
me["Simple_L5"].setText(" PRINT");
me["Simple_L5"].setColor(BLUE);
me["Simple_R5"].setText("SENSORS ");
me["Simple_R5"].setColor(WHITE);
me["Simple_L4"].setFontSize(small);
me["Simple_L4"].setText(" FLIGHT");
me["Simple_C4"].setFontSize(small);
me["Simple_C4"].setText("--TIMES--");
me["Simple_R4"].setFontSize(small);
me["Simple_R4"].setText("BLOCK ");
me["Simple_C2S"].setText("TIME");
me["Simple_R2S"].setText("FOB ");
me["Simple_L2"].setText( " OUT -");
me["Simple_L3S"].setText(" OFF -");
me["Simple_L3"].setText( " ON -");
me["Simple_L4S"].setText(" IN -");
me["Simple_C5"].setFontSize(small);
pageSwitch[i].setBoolValue(1);
}
var logid = 1; #mcdu.FlightLogDatabase.getPageSize(); - one page only - TODO: multi pages
if (logid == 0) logid = 1;
me.showPageNumbersOnly(1,1);
me["Simple_Title"].setText(sprintf("FLT LOG.%04d",logid));
me["Simple_C2"].setText( "--.--"); #TODO - missing ":" char on fontset
me["Simple_C3S"].setText("--.--");
me["Simple_C3"].setText( "--.--");
me["Simple_C4S"].setText("--.--");
me["Simple_R2"].setText( "---.- ");
me["Simple_R3S"].setText("---.- ");
me["Simple_R3"].setText( "---.- ");
me["Simple_R4S"].setText("---.- ");
me.colorCenter("wht", "grn", "grn", "wht", "wht", "wht");
me.colorRight("wht", "grn", "grn", "wht", "wht", "wht");
me.colorLeftS("wht", "wht", "wht", "wht", "grn", "wht");
me.colorCenterS("wht", "wht", "grn", "grn", "grn", "wht");
me.colorRightS("wht", "wht", "grn", "grn", "grn", "wht");
var rowsC = ["Simple_C2","Simple_C3S","Simple_C3","Simple_C4S"];
var rowsR = ["Simple_R2","Simple_R3S","Simple_R3","Simple_R4S"];
var logs = mcdu.FlightLogDatabase.getLogByPage(logid);
var len = size(logs);
var flgtime = 0;
var blktime = 0;
for ( var i = 0; i < len; i = i + 1 ) {
if (logs[i] != nil) { # only valid reports
var p = logs[i].state;
if (p == 4) p = 3; # RETURN-IN
me[rowsC[p]].setText(logs[i].time);
me[rowsR[p]].setText(sprintf("%3.1f ",logs[i].fob));
}
}
var logpage = mcdu.FlightLogDatabase.getPage(logid);
me["Simple_L1"].setText(sprintf("%8s - ",logpage.fltnum) ~ logpage.date);
me["Simple_R1"].setText(logpage.tofrom ~ " ");
me["Simple_L5S"].setText( " " ~ logpage.flttime );
me["Simple_C5S"].setText(sprintf("%02.0f", getprop("/sim/time/utc/hour")) ~ "." ~ sprintf("%02.0f", getprop("/sim/time/utc/minute")) ~ "." ~ sprintf("%02.0f", getprop("/sim/time/utc/second")));
me["Simple_R5S"].setText( logpage.blktime ~ " " );
var fltstate = logpage.fltstate;
if (fltstate == "") {
fltstate = (fmgc.FMGCInternal.toFromSet) ? "BEGIN" : "RESET"; #CHECKME - my best guess, only ready when plan inserted
#TODO Pushback detection -> WPUSH state???
}
me["Simple_C5"].setText(fltstate);
} else if (page == "SENSORS") {
if (!pageSwitch[i].getBoolValue()) {
me.defaultHide();
me["Simple_Title"].setText("SENSORS ");
me.defaultPageNumbers();
me["Simple_L0S"].hide();
me.showLeft(1, 1, 1, 1, 1, 1);
me.showLeftS(1, 1, 1, 1, -1, -1);
me.showLeftArrow(-1, -1, -1, -1, -1, 1);
me.colorLeftArrow("wht", "wht", "wht", "wht", "wht", "wht");
me.showRight(1, 1, 1, 1, -1, -1);
me.showRightS(1, 1, 1, 1, -1, -1);
me.showRightArrow(-1, -1, -1, -1, -1, -1);
#me["PRINTPAGE"] - TODO missing asterisk at 5L - only useful when printing available
me.standardFontSize();
me.standardFontColour();
me["Simple_L1"].setFontSize(small);
me["Simple_R1"].setFontSize(small);
me["Simple_L2"].setFontSize(small);
me["Simple_R2"].setFontSize(small);
me["Simple_L3"].setFontSize(small);
me["Simple_R3"].setFontSize(small);
me["Simple_L4"].setFontSize(small);
me["Simple_R4"].setFontSize(small);
me.colorRight("grn", "grn", "grn", "grn", "grn", "grn");
me.colorRightS("grn", "grn", "grn", "grn", "grn", "grn");
me["Simple_L1S"].setText(" PARK BRAKE");
me["Simple_L1"].setText( " NOSE STRUT");
me["Simple_L2S"].setText( " L FWD DOOR");
me["Simple_L2"].setText( " R FWD DOOR");
me["Simple_L3S"].setText( " L AFT DOOR");
me["Simple_L3"].setText( " R AFT DOOR");
me["Simple_L4S"].setText( " GND SPEED");
me["Simple_L4"].setText( " FOB");
me["Simple_L5"].setText(" PRINT");
me["Simple_L5"].setColor(BLUE);
me["Simple_L6"].setText(" RETURN");
pageSwitch[i].setBoolValue(1);
}
me["Simple_R1S"].setText(sprintf("%-10s",(parking_brake.getValue() == 1) ? "SET" : "RELEASED"));
me["Simple_R1"].setText(sprintf("%-10s",(gear0_wow.getValue() == 1) ? "GROUND" : "FLIGHT"));
me["Simple_R2S"].setText(sprintf("%-10s",(doorL1_pos.getValue() > 0.1) ? "OPEN" : "CLOSED"));
me["Simple_R2"].setText(sprintf("%-10s",(doorR1_pos.getValue() > 0.1) ? "OPEN" : "CLOSED"));
me["Simple_R3S"].setText(sprintf("%-10s",(doorL4_pos.getValue() > 0.1) ? "OPEN" : "CLOSED"));
me["Simple_R3"].setText(sprintf("%-10s",(doorR4_pos.getValue() > 0.1) ? "OPEN" : "CLOSED"));
me["Simple_R4S"].setText(sprintf("%-10s",sprintf("%03.3f",pts.Velocities.groundspeed.getValue())));
me["Simple_R4"].setText(sprintf("%-10s",sprintf("%03.1f",fmgc.FMGCInternal.fob)));
} else if (page == "AOCCONFIG") { } else if (page == "AOCCONFIG") {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHideWithCenter(); me.defaultHideWithCenter();
@ -914,7 +1116,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHide(); me.defaultHide();
me["Simple_Title"].setText("ATC MENU"); me["Simple_Title"].setText("ATC MENU");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("1/2"); me["Simple_PageNum"].setText("1/2");
me["Simple_PageNum"].show(); me["Simple_PageNum"].show();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -960,7 +1162,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHideWithCenter(); me.defaultHideWithCenter();
me["Simple_Title"].setText("TEXT"); me["Simple_Title"].setText("TEXT");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("1/2"); me["Simple_PageNum"].setText("1/2");
me["Simple_PageNum"].show(); me["Simple_PageNum"].show();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -1051,7 +1253,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHideWithCenter(); me.defaultHideWithCenter();
me["Simple_Title"].setText("ATC MENU"); me["Simple_Title"].setText("ATC MENU");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("2/2"); me["Simple_PageNum"].setText("2/2");
me["Simple_PageNum"].show(); me["Simple_PageNum"].show();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -1148,7 +1350,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHideWithCenter(); me.defaultHideWithCenter();
me["Simple_Title"].setText("ATS623 ATIS MENU"); me["Simple_Title"].setText("ATS623 ATIS MENU");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].hide(); me["Simple_PageNum"].hide();
me["ArrowLeft"].hide(); me["ArrowLeft"].hide();
me["ArrowRight"].hide(); me["ArrowRight"].hide();
@ -1836,9 +2038,9 @@ var canvas_MCDU_base = {
me["Simple_Title"].setText(sprintf("%s", " " ~ acType.getValue())); me["Simple_Title"].setText(sprintf("%s", " " ~ acType.getValue()));
me.defaultPageNumbers(); me.defaultPageNumbers();
me.showLeft(1, 1, 1, -1, 1, 1); me.showLeft(1, 1, 1, -1, -1, 1);
me["Simple_L0S"].hide(); me["Simple_L0S"].hide();
me.showLeftS(1, 1, 1, -1, 1, 1); me.showLeftS(1, 1, 1, -1, -1, 1);
me.showLeftArrow(-1, -1, 1, -1, -1, -1); me.showLeftArrow(-1, -1, 1, -1, -1, -1);
me.showRight(-1, 1, -1, 1, 1, 1); me.showRight(-1, 1, -1, 1, 1, 1);
me.showRightS(-1, -1, -1, 1, 1, 1); me.showRightS(-1, -1, -1, 1, 1, 1);
@ -1861,13 +2063,19 @@ var canvas_MCDU_base = {
me.colorRightS("wht", "wht", "wht", "wht", "grn", "wht"); me.colorRightS("wht", "wht", "wht", "wht", "grn", "wht");
me.colorRightArrow("wht", "wht", "wht", "wht", "wht", "wht"); me.colorRightArrow("wht", "wht", "wht", "wht", "wht", "wht");
if (fmgc.FMGCInternal.phase == 0 or fmgc.FMGCInternal.phase == 7) { # only on preflight and done phases
me["Simple_L5S"].setText("CHG CODE");
me["Simple_L5S"].show();
me["Simple_L5"].setText("[ ]"); me["Simple_L5"].setText("[ ]");
me["Simple_L5"].show();
} else {
me["Simple_L5"].hide();
}
me["Simple_L6"].setText(sprintf("%s/%s",idleFactor.getValue(),perfFactor.getValue())); me["Simple_L6"].setText(sprintf("%s/%s",idleFactor.getValue(),perfFactor.getValue()));
me["Simple_L1S"].setText(" ENG"); me["Simple_L1S"].setText(" ENG");
me["Simple_L2S"].setText(" ACTIVE NAV DATA BASE"); me["Simple_L2S"].setText(" ACTIVE NAV DATA BASE");
me["Simple_L3S"].setText(" SECOND NAV DATA BASE"); me["Simple_L3S"].setText(" SECOND NAV DATA BASE");
me["Simple_L5S"].setText("CHG CODE");
me["Simple_L6S"].setText("IDLE/PERF"); me["Simple_L6S"].setText("IDLE/PERF");
me["Simple_R6"].setText("STATUS/XLOAD "); me["Simple_R6"].setText("STATUS/XLOAD ");
me["Simple_R6S"].setText("SOFTWARE "); me["Simple_R6S"].setText("SOFTWARE ");
@ -1918,7 +2126,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHide(); me.defaultHide();
me["Simple_Title"].setText("DATA INDEX"); me["Simple_Title"].setText("DATA INDEX");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("1/2"); me["Simple_PageNum"].setText("1/2");
me["Simple_PageNum"].show(); me["Simple_PageNum"].show();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -1958,7 +2166,7 @@ var canvas_MCDU_base = {
if (!pageSwitch[i].getBoolValue()) { if (!pageSwitch[i].getBoolValue()) {
me.defaultHide(); me.defaultHide();
me["Simple_Title"].setText("DATA INDEX"); me["Simple_Title"].setText("DATA INDEX");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("2/2"); me["Simple_PageNum"].setText("2/2");
me["Simple_PageNum"].show(); me["Simple_PageNum"].show();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -2239,7 +2447,7 @@ var canvas_MCDU_base = {
me["PERFGA"].hide(); me["PERFGA"].hide();
me["Simple_Title"].show(); me["Simple_Title"].show();
me["Simple_Title"].setText("INIT"); me["Simple_Title"].setText("INIT");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("X/X"); me["Simple_PageNum"].setText("X/X");
me["Simple_PageNum"].hide(); me["Simple_PageNum"].hide();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -2283,12 +2491,12 @@ var canvas_MCDU_base = {
if (!fmgc.FMGCInternal.toFromSet and !fmgc.FMGCInternal.costIndexSet) { if (!fmgc.FMGCInternal.toFromSet and !fmgc.FMGCInternal.costIndexSet) {
me["INITA_CostIndex"].hide(); me["INITA_CostIndex"].hide();
me["Simple_L5"].setColor(1,1,1); me["Simple_L5"].setColor(WHITE);
me["Simple_L5"].show(); me["Simple_L5"].show();
me["Simple_L5"].setText("---"); me["Simple_L5"].setText("---");
} else if (fmgc.FMGCInternal.costIndexSet) { } else if (fmgc.FMGCInternal.costIndexSet) {
me["INITA_CostIndex"].hide(); me["INITA_CostIndex"].hide();
me["Simple_L5"].setColor(0.0901,0.6039,0.7176); me["Simple_L5"].setColor(BLUE);
me["Simple_L5"].show(); me["Simple_L5"].show();
me["Simple_L5"].setText(sprintf("%s", fmgc.FMGCInternal.costIndex)); me["Simple_L5"].setText(sprintf("%s", fmgc.FMGCInternal.costIndex));
} else { } else {
@ -2297,28 +2505,40 @@ var canvas_MCDU_base = {
} }
if (!fmgc.FMGCInternal.toFromSet and !fmgc.FMGCInternal.crzSet) { if (!fmgc.FMGCInternal.toFromSet and !fmgc.FMGCInternal.crzSet) {
me["INITA_CruiseFLTemp"].hide(); me["INITA_CruiseFLTemp"].hide();
me["Simple_L6"].setColor(1,1,1); me["Simple_L6"].setColor(WHITE);
me["Simple_L6"].setText("-----/---g"); me["Simple_L6"].setText("-----/---g");
} else if (fmgc.FMGCInternal.crzSet and fmgc.FMGCInternal.crzTempSet) { } else if (fmgc.FMGCInternal.crzSet and fmgc.FMGCInternal.crzTempSet) {
me["INITA_CruiseFLTemp"].hide(); me["INITA_CruiseFLTemp"].hide();
me["Simple_L6"].setColor(0.0901,0.6039,0.7176); me["Simple_L6"].setColor(BLUE);
me["Simple_L6"].setText(sprintf("%s", "FL" ~ fmgc.FMGCInternal.crzFl) ~ sprintf("/%sg", fmgc.FMGCInternal.crzTemp)); me["Simple_L6"].setText(sprintf("%s", "FL" ~ fmgc.FMGCInternal.crzFl) ~ sprintf("/%sg", fmgc.FMGCInternal.crzTemp));
} else if (fmgc.FMGCInternal.crzSet) { } else if (fmgc.FMGCInternal.crzSet) {
me["INITA_CruiseFLTemp"].hide(); me["INITA_CruiseFLTemp"].hide();
me["Simple_L6"].setColor(0.0901,0.6039,0.7176); me["Simple_L6"].setColor(BLUE);
fmgc.FMGCInternal.crzTemp = 15 - (2 * fmgc.FMGCInternal.crzFl / 10); fmgc.FMGCInternal.crzTemp = 15 - (2 * fmgc.FMGCInternal.crzFl / 10);
fmgc.FMGCInternal.crzTempSet = 1; fmgc.FMGCInternal.crzTempSet = 1;
me["Simple_L6"].setText(sprintf("%s", "FL" ~ fmgc.FMGCInternal.crzFl) ~ sprintf("/%sg", fmgc.FMGCInternal.crzTemp)); me["Simple_L6"].setText(sprintf("%s", "FL" ~ fmgc.FMGCInternal.crzFl) ~ sprintf("/%sg", fmgc.FMGCInternal.crzTemp));
} else { } else {
me["INITA_CruiseFLTemp"].show(); me["INITA_CruiseFLTemp"].show();
me["Simple_L6"].setColor(0.7333,0.3803,0); me["Simple_L6"].setColor(AMBER);
me["Simple_L6"].setText(" g"); me["Simple_L6"].setText(" g");
} }
if (fmgc.FMGCInternal.coRouteSet) { # show coRoute when valid
me["INITA_CoRoute"].hide();
me["Simple_L1"].setText(fmgc.FMGCInternal.coRoute);
me["Simple_L1"].setColor(BLUE);
me["Simple_L1"].show();
} else {
me["Simple_L1"].hide();
me["INITA_CoRoute"].show();
me["Simple_L1"].setText("NONE");
}
if (fmgc.FMGCInternal.toFromSet) { if (fmgc.FMGCInternal.toFromSet) {
me["INITA_CoRoute"].hide(); me["INITA_CoRoute"].hide();
me["INITA_FromTo"].hide(); me["INITA_FromTo"].hide();
me["Simple_L1"].show(); me["Simple_L1"].show();
me["Simple_L2"].setColor(0.0901,0.6039,0.7176); me["Simple_L2"].setColor(BLUE);
if (fmgc.FMGCInternal.altAirportSet) { if (fmgc.FMGCInternal.altAirportSet) {
me["Simple_L2"].setText(fmgc.FMGCInternal.altAirport); me["Simple_L2"].setText(fmgc.FMGCInternal.altAirport);
} else { } else {
@ -2331,7 +2551,7 @@ var canvas_MCDU_base = {
me["INITA_CoRoute"].show(); me["INITA_CoRoute"].show();
me["INITA_FromTo"].show(); me["INITA_FromTo"].show();
me["Simple_L1"].hide(); me["Simple_L1"].hide();
me["Simple_L2"].setColor(1,1,1); me["Simple_L2"].setColor(WHITE);
me["Simple_L2"].setText("----/----------"); me["Simple_L2"].setText("----/----------");
me.showRight(-1, 1, 0, 0, 0, 0); me.showRight(-1, 1, 0, 0, 0, 0);
me["Simple_R2S"].show(); me["Simple_R2S"].show();
@ -2375,7 +2595,7 @@ var canvas_MCDU_base = {
me["Simple_L3S"].setText("FLT NBR"); me["Simple_L3S"].setText("FLT NBR");
me["Simple_L5S"].setText("COST INDEX"); me["Simple_L5S"].setText("COST INDEX");
me["Simple_L6S"].setText("CRZ FL/TEMP"); me["Simple_L6S"].setText("CRZ FL/TEMP");
me["Simple_L1"].setText("NONE"); #me["Simple_L1"].setText("NONE"); # manage before (coRoute)
me["Simple_L3"].setText(sprintf("%s", fmgc.FMGCInternal.flightNum)); me["Simple_L3"].setText(sprintf("%s", fmgc.FMGCInternal.flightNum));
me["Simple_R1S"].setText("FROM/TO "); me["Simple_R1S"].setText("FROM/TO ");
me["Simple_R2S"].setText("INIT "); me["Simple_R2S"].setText("INIT ");
@ -2677,7 +2897,7 @@ var canvas_MCDU_base = {
me["Simple_R5"].setText(fmgc.FMGCInternal.tripWind); me["Simple_R5"].setText(fmgc.FMGCInternal.tripWind);
me["Simple_R6S"].setText("EXTRA/TIME"); me["Simple_R6S"].setText("EXTRA/TIME");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
if (!fmgc.FMGCInternal.fuelRequest) { if (!fmgc.FMGCInternal.fuelRequest) {
me["Simple_L2"].setText("---.-/----"); me["Simple_L2"].setText("---.-/----");
@ -2717,7 +2937,7 @@ var canvas_MCDU_base = {
me["Simple_R6"].setText("---.-/----"); me["Simple_R6"].setText("---.-/----");
me["Simple_Title"].setText("INIT"); me["Simple_Title"].setText("INIT");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me.colorLeft("ack", "wht", "wht", "wht", "wht", "wht"); me.colorLeft("ack", "wht", "wht", "wht", "wht", "wht");
me.colorRight("ack", "blu", "amb", "wht", "ack", "wht"); me.colorRight("ack", "blu", "amb", "wht", "ack", "wht");
@ -3070,7 +3290,7 @@ var canvas_MCDU_base = {
me["PERFGA"].hide(); me["PERFGA"].hide();
me["Simple_Title"].show(); me["Simple_Title"].show();
me["Simple_Title"].setText("FUEL PRED"); me["Simple_Title"].setText("FUEL PRED");
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me["Simple_PageNum"].setText("X/X"); me["Simple_PageNum"].setText("X/X");
me["Simple_PageNum"].hide(); me["Simple_PageNum"].hide();
me["ArrowLeft"].show(); me["ArrowLeft"].show();
@ -3398,7 +3618,7 @@ var canvas_MCDU_base = {
} }
me["Simple_Title"].show(); me["Simple_Title"].show();
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
me["Simple_PageNum"].setText("X/X"); me["Simple_PageNum"].setText("X/X");
me["Simple_PageNum"].hide(); me["Simple_PageNum"].hide();
me["ArrowLeft"].hide(); me["ArrowLeft"].hide();
@ -3581,9 +3801,9 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 1) { if (fmgc.FMGCInternal.phase == 1) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
} }
if (fmgc.flightPlanController.flightplans[2].departure_runway != nil) { if (fmgc.flightPlanController.flightplans[2].departure_runway != nil) {
@ -3712,7 +3932,7 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 2) { if (fmgc.FMGCInternal.phase == 2) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
me.showLeft(0, 0, 0, 0, 1, 0); me.showLeft(0, 0, 0, 0, 1, 0);
me.showLeftS(0, 0, 0, 0, 1, 0); me.showLeftS(0, 0, 0, 0, 1, 0);
me.showLeftArrow(0, 0, 0, 0, 1, 1); me.showLeftArrow(0, 0, 0, 0, 1, 1);
@ -3753,7 +3973,7 @@ var canvas_MCDU_base = {
setprop("/FMGC/internal/activate-twice", 0); setprop("/FMGC/internal/activate-twice", 0);
} }
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me.showLeft(0, 0, 0, 0, -1, 0); me.showLeft(0, 0, 0, 0, -1, 0);
me.showLeftS(0, 0, 0, 0, -1, 0); me.showLeftS(0, 0, 0, 0, -1, 0);
me.showLeftArrow(0, 0, 0, 0, -1, 0); me.showLeftArrow(0, 0, 0, 0, -1, 0);
@ -3787,10 +4007,10 @@ var canvas_MCDU_base = {
me["Simple_L2S"].setText(" CI"); me["Simple_L2S"].setText(" CI");
if (fmgc.FMGCInternal.costIndexSet) { if (fmgc.FMGCInternal.costIndexSet) {
me["Simple_L2"].setColor(0.0901,0.6039,0.7176); me["Simple_L2"].setColor(BLUE);
me["Simple_L2"].setText(sprintf(" %s", fmgc.FMGCInternal.costIndex)); me["Simple_L2"].setText(sprintf(" %s", fmgc.FMGCInternal.costIndex));
} else { } else {
me["Simple_L2"].setColor(1,1,1); me["Simple_L2"].setColor(WHITE);
me["Simple_L2"].setText(" ---"); me["Simple_L2"].setText(" ---");
} }
@ -3865,7 +4085,7 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 3) { if (fmgc.FMGCInternal.phase == 3) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
if (managedSpeed.getValue() == 1) { if (managedSpeed.getValue() == 1) {
me.showLeft(0, 0, 0, -1, 0, 0); me.showLeft(0, 0, 0, -1, 0, 0);
@ -3900,7 +4120,7 @@ var canvas_MCDU_base = {
setprop("/FMGC/internal/activate-twice", 0); setprop("/FMGC/internal/activate-twice", 0);
} }
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me.colorLeft("ack", "ack", "ack", "ack", "ack", "wht"); me.colorLeft("ack", "ack", "ack", "ack", "ack", "wht");
me.colorLeftS("ack", "ack", "ack", "ack", "ack", "wht"); me.colorLeftS("ack", "ack", "ack", "ack", "ack", "wht");
@ -3927,10 +4147,10 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.costIndexSet) { if (fmgc.FMGCInternal.costIndexSet) {
me["Simple_L2"].setColor(0.0901,0.6039,0.7176); me["Simple_L2"].setColor(BLUE);
me["Simple_L2"].setText(sprintf(" %s", fmgc.FMGCInternal.costIndex)); me["Simple_L2"].setText(sprintf(" %s", fmgc.FMGCInternal.costIndex));
} else { } else {
me["Simple_L2"].setColor(1,1,1); me["Simple_L2"].setColor(WHITE);
me["Simple_L2"].setText(" ---"); me["Simple_L2"].setText(" ---");
} }
@ -4003,7 +4223,7 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 4) { if (fmgc.FMGCInternal.phase == 4) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
me.showLeft(0, 0, 0, 0, 1, 0); me.showLeft(0, 0, 0, 0, 1, 0);
me.showRight(0, 1, 0, 1, 0, 0); me.showRight(0, 1, 0, 1, 0, 0);
me.showRightS(0, 0, 1, 0, 0, 0); me.showRightS(0, 0, 1, 0, 0, 0);
@ -4043,7 +4263,7 @@ var canvas_MCDU_base = {
setprop("/FMGC/internal/activate-twice", 0); setprop("/FMGC/internal/activate-twice", 0);
} }
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
me.showLeft(0, 0, 0, 0, -1, 0); me.showLeft(0, 0, 0, 0, -1, 0);
me.showRight(0, -1, 0, -1, 0, 0); me.showRight(0, -1, 0, -1, 0, 0);
me.showRightS(0, 0, -1, 0, 0, 0); me.showRightS(0, 0, -1, 0, 0, 0);
@ -4075,10 +4295,10 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.costIndexSet) { if (fmgc.FMGCInternal.costIndexSet) {
me["Simple_L2"].setColor(0.0901,0.6039,0.7176); me["Simple_L2"].setColor(BLUE);
me["Simple_L2"].setText(sprintf(" %2.0f", fmgc.FMGCInternal.costIndex)); me["Simple_L2"].setText(sprintf(" %2.0f", fmgc.FMGCInternal.costIndex));
} else { } else {
me["Simple_L2"].setColor(1,1,1); me["Simple_L2"].setColor(WHITE);
me["Simple_L2"].setText(" ---"); me["Simple_L2"].setText(" ---");
} }
@ -4159,9 +4379,9 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 5) { if (fmgc.FMGCInternal.phase == 5) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
} }
me["Simple_L0S"].setText("DEST"); me["Simple_L0S"].setText("DEST");
@ -4342,9 +4562,9 @@ var canvas_MCDU_base = {
} }
if (fmgc.FMGCInternal.phase == 6) { if (fmgc.FMGCInternal.phase == 6) {
me["Simple_Title"].setColor(0.0509,0.7529,0.2941); me["Simple_Title"].setColor(GREEN);
} else { } else {
me["Simple_Title"].setColor(1, 1, 1); me["Simple_Title"].setColor(WHITE);
} }
if (thrAccSet.getValue() == 1) { if (thrAccSet.getValue() == 1) {

View file

@ -1705,7 +1705,7 @@
<repeatable>true</repeatable> <repeatable>true</repeatable>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
<script>mcdu.button("CLR", 0);</script> <script>mcdu.button("CLR", 0, "down");</script>
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
@ -1719,6 +1719,24 @@
</and> </and>
</condition> </condition>
</binding> </binding>
<mod-up>
<binding>
<command>nasal</command>
<script>mcdu.button("CLR", 0, "up");</script>
<condition>
<and>
<greater-than-equals>
<property>systems/electrical/bus/ac-1</property>
<value>110</value>
</greater-than-equals>
<greater-than>
<property>controls/lighting/DU/mcdu1</property>
<value>0.01</value>
</greater-than>
</and>
</condition>
</binding>
</mod-up>
</action> </action>
</animation> </animation>
<animation> <animation>

View file

@ -1705,7 +1705,7 @@
<repeatable>true</repeatable> <repeatable>true</repeatable>
<binding> <binding>
<command>nasal</command> <command>nasal</command>
<script>mcdu.button("CLR", 1);</script> <script>mcdu.button("CLR", 1, "down");</script>
<condition> <condition>
<and> <and>
<greater-than-equals> <greater-than-equals>
@ -1719,6 +1719,24 @@
</and> </and>
</condition> </condition>
</binding> </binding>
<mod-up>
<binding>
<command>nasal</command>
<script>mcdu.button("CLR", 1, "up");</script>
<condition>
<and>
<greater-than-equals>
<property>systems/electrical/bus/ac-2</property>
<value>110</value>
</greater-than-equals>
<greater-than>
<property>controls/lighting/DU/mcdu2</property>
<value>0.01</value>
</greater-than>
</and>
</condition>
</binding>
</mod-up>
</action> </action>
</animation> </animation>
<animation> <animation>

View file

@ -1,31 +0,0 @@
<?xml version="1.0" encoding="UTF-8" ?>
<PropertyList>
<sim>
<model>
<livery>
<name>ICAO Airline Name (Extra Info)</name>
<texture-fuselage>Liveries/A320/CFM/texture.png</texture-fuselage>
<texture-engine>Liveries/A320/CFM/texture.png</texture-engine>
</livery>
</model>
</sim>
<options>
<engine-name type="string">CFM56-5B4</engine-name>
<model-number type="string">A320-214</model-number>
<EIS2 type="bool">1</EIS2>
<company-options>
<idle-factor>+0.0</idle-factor>
<perf-factor>+1.0</perf-factor> <!-- please see https://www.cockpitseeker.com/wp-content/uploads/goodies/ac/a320/pdf/data/PerfoMonitoring.pdf -->
</company-options>
<model-options>
<registration type="string">AB-CDE</registration>
<three-letter type="string">ABC</three-letter>
<two-letter type="string">DE</two-letter>
<sharklet type="bool">0</sharklet>
<wifi-aft type="bool">0</wifi-aft>
<wifi-fwd type="bool">0</wifi-fwd>
</model-options>
</options>
</PropertyList>

View file

@ -167,6 +167,8 @@ var FMGCInternal = {
altAirportSet: 0, altAirportSet: 0,
altSelected: 0, altSelected: 0,
arrApt: "", arrApt: "",
coRoute: "",
coRouteSet: 0,
costIndex: 0, costIndex: 0,
costIndexSet: 0, costIndexSet: 0,
crzFt: 10000, crzFt: 10000,
@ -307,6 +309,7 @@ var updateArptLatLon = func {
updateRouteManagerAlt = func() { updateRouteManagerAlt = func() {
setprop("autopilot/route-manager/cruise/altitude-ft", FMGCInternal.crzFt); setprop("autopilot/route-manager/cruise/altitude-ft", FMGCInternal.crzFt);
# TODO - update FMGCInternal.phase when DES to re-enter in CLIMB/CRUIZE
}; };
######## ########
@ -968,6 +971,7 @@ var reset_FMGC = func {
mcdu.MCDU_reset(0); mcdu.MCDU_reset(0);
mcdu.MCDU_reset(1); mcdu.MCDU_reset(1);
mcdu.ReceivedMessagesDatabase.clearDatabase(); mcdu.ReceivedMessagesDatabase.clearDatabase();
mcdu.FlightLogDatabase.clearDatabase();
Input.fd1.setValue(fd1); Input.fd1.setValue(fd1);
Input.fd2.setValue(fd2); Input.fd2.setValue(fd2);

View file

@ -1,5 +1,6 @@
# A3XX Simbrief Parser # A3XX Simbrief Parser
# Copyright (c) 2020 Jonathan Redpath (legoboyvdlp) # Copyright (c) 2020 Jonathan Redpath (legoboyvdlp)
# enhanceded 12/2020 - parse TOD & TOC psedo waypoints, set computer speeds on fix wps, fake coRoute name
var LBS2KGS = 0.4535924; var LBS2KGS = 0.4535924;
@ -157,12 +158,16 @@ var SimbriefParser = {
if (ident == "TOC") { if (ident == "TOC") {
_foundTOC = 1; _foundTOC = 1;
continue; #setprop("/autopilot/route-manager/vnav/tc/latitude-deg",ofpFix.getNode("pos_lat").getValue());
#setprop("/autopilot/route-manager/vnav/tc/longitude-deg",ofpFix.getNode("pos_long").getValue());
#ident = "(T/C)";
} }
if (ident == "TOD") { if (ident == "TOD") {
_foundTOD = 1; _foundTOD = 1;
continue; #setprop("/autopilot/route-manager/vnav/td/latitude-deg",ofpFix.getNode("pos_lat").getValue());
#setprop("/autopilot/route-manager/vnav/td/longitude-deg",ofpFix.getNode("pos_long").getValue());
#ident = "(T/D)";
} }
coords = geo.Coord.new(); coords = geo.Coord.new();
@ -189,6 +194,34 @@ var SimbriefParser = {
fmgc.flightPlanController.flightplans[3].star = _star; fmgc.flightPlanController.flightplans[3].star = _star;
} }
fmgc.flightPlanController.destroyTemporaryFlightPlan(3, 1); fmgc.flightPlanController.destroyTemporaryFlightPlan(3, 1);
#var idx = 1;
#var plan = fmgc.flightPlanController.flightplans[2];
#var altitude = "";
#var speed = "";
#var wpname = "";
#foreach (var ofpFix; ofpFixes) {
# ident = ofpFix.getNode("ident").getValue();
# if (ident == "TOC") wpname = "(T/C)";
# else if (ident == "TOD") wpname = "(T/D)";
# else wpname = ident;
# wp = plan.getWP(idx); # get leg
# if (wp != nil) {
# if (wp.wp_name == wpname) {
# altitude = ofpFix.getNode("altitude_feet").getValue();
# speed = ofpFix.getNode("ind_airspeed").getValue();
# if (speed>0) wp.setSpeed(speed, "computed");
# if (altitude>0) wp.setAltitude(math.round(altitude, 10), "computed");
#
# idx = idx + 1;
# }
# }
# }
fmgc.windController.updatePlans(); fmgc.windController.updatePlans();
fmgc.updateRouteManagerAlt(); fmgc.updateRouteManagerAlt();
@ -199,6 +232,8 @@ var SimbriefParser = {
if (me.buildFlightplan() == nil) { if (me.buildFlightplan() == nil) {
return nil; return nil;
} }
#fmgc.FMGCInternal.coRoute = "SB" ~ me.OFP.getNode("origin/iata_code").getValue() ~ me.OFP.getNode("destination/iata_code").getValue() ~ "00";
#fmgc.FMGCInternal.coRouteSet = 1;
fmgc.FMGCInternal.flightNum = (me.OFP.getNode("general/icao_airline").getValue() or "") ~ (me.OFP.getNode("general/flight_number").getValue() or ""); fmgc.FMGCInternal.flightNum = (me.OFP.getNode("general/icao_airline").getValue() or "") ~ (me.OFP.getNode("general/flight_number").getValue() or "");
fmgc.FMGCInternal.flightNumSet = 1; fmgc.FMGCInternal.flightNumSet = 1;
fmgc.FMGCInternal.costIndex = me.OFP.getNode("general/costindex").getValue(); fmgc.FMGCInternal.costIndex = me.OFP.getNode("general/costindex").getValue();

View file

@ -69,6 +69,7 @@ var scratchpadController = {
sp.scratchpadColour = "wht"; sp.scratchpadColour = "wht";
sp.showTypeIMsg = 0; sp.showTypeIMsg = 0;
sp.showTypeIIMsg = 0; sp.showTypeIIMsg = 0;
sp.clrmode = 0; # 1 = CLR mode
sp.mcdu = mcdu; sp.mcdu = mcdu;
return sp; return sp;
}, },
@ -88,6 +89,11 @@ var scratchpadController = {
me.clearTypeI(); me.clearTypeI();
} }
if (me.clrmode == 1) { # prevent add chars in CLR mode
me.clear();
}
else if (character == "CLR") me.clrmode = 1;
me.scratchpad = me.scratchpad ~ character; me.scratchpad = me.scratchpad ~ character;
me.scratchpadColour = "wht"; me.scratchpadColour = "wht";
me.update(); me.update();
@ -140,6 +146,7 @@ var scratchpadController = {
}, },
empty: func() { empty: func() {
me.scratchpad = ""; me.scratchpad = "";
me.clrmode = 0;
me.update(); me.update();
}, },
clear: func() { clear: func() {
@ -173,12 +180,16 @@ var MessageController = {
TypeIMessage.new("USING COST INDEX N", 1),TypeIMessage.new("WAIT FOR SYSTEM RESPONSE"),TypeIMessage.new("RWY/LS MISMATCH"), TypeIMessage.new("USING COST INDEX N", 1),TypeIMessage.new("WAIT FOR SYSTEM RESPONSE"),TypeIMessage.new("RWY/LS MISMATCH"),
TypeIMessage.new("VHF3 VOICE MSG NOT GEN"),TypeIMessage.new("NO COMM MSG NOT GEN"),TypeIMessage.new("WX UPLINK"), TypeIMessage.new("VHF3 VOICE MSG NOT GEN"),TypeIMessage.new("NO COMM MSG NOT GEN"),TypeIMessage.new("WX UPLINK"),
TypeIMessage.new("SIMBRIEF DOWNLOAD FAILED"),TypeIMessage.new("MISSING USERNAME"),TypeIMessage.new("AOC ACT F-PLN UPLINK"), TypeIMessage.new("SIMBRIEF DOWNLOAD FAILED"),TypeIMessage.new("MISSING USERNAME"),TypeIMessage.new("AOC ACT F-PLN UPLINK"),
TypeIMessage.new("NO ANSWER TO REQUEST"),TypeIMessage.new("NO D-ATIS AVAILABLE"),TypeIMessage.new("BAD SERVER RESPONSE") TypeIMessage.new("NO ANSWER TO REQUEST"),TypeIMessage.new("NO D-ATIS AVAILABLE"),TypeIMessage.new("BAD SERVER RESPONSE"),
TypeIMessage.new("WIND DATA UPLINK"),TypeIMessage.new("CHECK ALT WIND"),TypeIMessage.new("INVALID WIND UPLINK"),TypeIMessage.new("WIND UPLINK EXISTS"), #p.533
TypeIMessage.new("FM DATALINK UNAVAIL"),TypeIMessage.new("NOT XMITTED TO ACARS"), #p.559
TypeIMessage.new("PRINTER NOT AVAILABLE"),
]), ]),
typeIIMessages: std.Vector.new([ typeIIMessages: std.Vector.new([
TypeIIMessage.new("LAT DISCONT AHEAD", "amb", 0),TypeIIMessage.new("MORE DRAG"),TypeIIMessage.new("RWY/LS MISMATCH", "amb", 0),TypeIIMessage.new("STEP DELETED"), TypeIIMessage.new("LAT DISCONT AHEAD", "amb", 0),TypeIIMessage.new("MORE DRAG"),TypeIIMessage.new("RWY/LS MISMATCH", "amb", 0),TypeIIMessage.new("STEP DELETED"),
TypeIIMessage.new("STEP NOW"),TypeIIMessage.new("TIME TO EXIT", "amb", 0),TypeIIMessage.new("V1/VR/V2 DISAGREE", "amb", 0), TypeIIMessage.new("STEP NOW"),TypeIIMessage.new("TIME TO EXIT", "amb", 0),TypeIIMessage.new("V1/VR/V2 DISAGREE", "amb", 0),
TypeIIMessage.new("TO SPEED TOO LOW", "amb", 0), TypeIIMessage.new("TO SPEED TOO LOW", "amb", 0),
TypeIIMessage.new("CHECK DEST DATA", "amb", 0), #p.533
]), ]),
# to speed to low - new on a320, margin against vmcg / vs1g # to speed to low - new on a320, margin against vmcg / vs1g

View file

@ -68,10 +68,22 @@ var fplnItem = {
me.spd = me.getSpd(); me.spd = me.getSpd();
me.alt = me.getAlt(); me.alt = me.getAlt();
me.dist = me.getDist(); me.dist = me.getDist();
if (me.colour != "yel") { # not temporary flightplan
me._colour = "wht"; me._colour = "wht";
if (me.spd[1] != "wht" or me.alt[1] != "wht") { #if (me.spd[1] != "wht" or me.alt[1] != "wht") {
if (me.spd[1] == me.alt[1]) {
me._colour = me.spd[1];
}
else if (me.spd[1] == "mag" or me.alt[1] == "mag") {
me._colour = "mag"; me._colour = "mag";
} }
else if (me.spd[1] == "grn" or me.alt[1] == "grn") {
me._colour = "grn";
}
} else { # temporary flightplan
me._colour = "yel";
}
return [me.spd[0] ~ "/" ~ me.alt[0], " " ~ me.dist ~ "NM ", me._colour]; return [me.spd[0] ~ "/" ~ me.alt[0], " " ~ me.dist ~ "NM ", me._colour];
} else { } else {
return [nil, nil, "ack"]; return [nil, nil, "ack"];
@ -95,23 +107,25 @@ var fplnItem = {
}, },
getSpd: func() { getSpd: func() {
if (me.index == 0 and left(me.wp.wp_name, 4) == fmgc.FMGCInternal.depApt and fmgc.FMGCInternal.v1set) { if (me.index == 0 and left(me.wp.wp_name, 4) == fmgc.FMGCInternal.depApt and fmgc.FMGCInternal.v1set) {
return [sprintf("%3.0f", math.round(fmgc.FMGCInternal.v1)), "mag"]; return [sprintf("%3.0f", math.round(fmgc.FMGCInternal.v1)), "grn"]; # why "mag"? I think "grn"
} elsif (me.wp.speed_cstr != nil and me.wp.speed_cstr != 0) { } elsif (me.wp.speed_cstr != nil and me.wp.speed_cstr > 0) {
return [sprintf("%3.0f", me.wp.speed_cstr), "mag"]; var tcol = (me.wp.speed_cstr_type == "computed" or me.wp.speed_cstr_type == "computed_mach") ? "grn" : "mag"; # TODO - check if only computed
return [sprintf("%3.0f", me.wp.speed_cstr), tcol];
} else { } else {
return ["---", "wht"]; return ["---", "wht"];
} }
}, },
getAlt: func() { getAlt: func() {
if (me.index == 0 and left(me.wp.wp_name, 4) == fmgc.FMGCInternal.depApt and fmgc.flightPlanController.flightplans[me.plan].departure != nil) { if (me.index == 0 and left(me.wp.wp_name, 4) == fmgc.FMGCInternal.depApt and fmgc.flightPlanController.flightplans[me.plan].departure != nil) {
return [" " ~ sprintf("%-5.0f", math.round(fmgc.flightPlanController.flightplans[me.plan].departure.elevation * M2FT)), "mag"]; return [" " ~ sprintf("%5.0f", math.round(fmgc.flightPlanController.flightplans[me.plan].departure.elevation * M2FT)), "grn"]; #fixed - aligned to right
} elsif (me.index == (fmgc.flightPlanController.currentToWptIndex.getValue() - 1) and fmgc.flightPlanController.fromWptAlt != nil) { } elsif (me.index == (fmgc.flightPlanController.currentToWptIndex.getValue() - 1) and fmgc.flightPlanController.fromWptAlt != nil) {
return [" " ~ fmgc.flightPlanController.fromWptAlt, "mag"]; return [" " ~ fmgc.flightPlanController.fromWptAlt, "mag"];
} elsif (me.wp.alt_cstr != nil and me.wp.alt_cstr != 0) { } elsif (me.wp.alt_cstr != nil and me.wp.alt_cstr > 0) {
var tcol = (me.wp.alt_cstr_type == "computed" or me.wp.alt_cstr_type == "computed_mach") ? "grn" : "mag"; # TODO - check if only computed
if (me.wp.alt_cstr > fmgc.FMGCInternal.transAlt) { if (me.wp.alt_cstr > fmgc.FMGCInternal.transAlt) {
return [" " ~ sprintf("%-5s", "FL" ~ math.round(num(me.wp.alt_cstr) / 100)), "mag"]; return [" " ~ sprintf("%5s", "FL" ~ math.round(num(me.wp.alt_cstr) / 100)), tcol]; #fixed - aligned to right
} else { } else {
return [" " ~ sprintf("%-5.0f", me.wp.alt_cstr), "mag"]; return [" " ~ sprintf("%5.0f", me.wp.alt_cstr), tcol]; #fixed - aligned to right
} }
} else { } else {
return ["------", "wht"]; return ["------", "wht"];
@ -337,7 +351,7 @@ var fplnPage = { # this one is only created once, and then updated - remember th
if (size(me.outputList) >= 1) { if (size(me.outputList) >= 1) {
me.L1 = me.outputList[0].updateLeftText(); me.L1 = me.outputList[0].updateLeftText();
me.C1 = me.outputList[0].updateCenterText(); me.C1 = me.outputList[0].updateCenterText();
me.C1[1] = "TIME "; me.C1[1] = (fmgc.flightPlanController.fromWptTime != nil) ? "UTC " : "TIME "; # since TO change to UTC time (1 space left to center)
me.R1 = me.outputList[0].updateRightText(); me.R1 = me.outputList[0].updateRightText();
me.R1[1] = "SPD/ALT "; me.R1[1] = "SPD/ALT ";
} else { } else {

161
Nasal/MCDU/FLIGHTLOG.nas Normal file
View file

@ -0,0 +1,161 @@
# AOC Flight Log system
# Basic OOOI system implementation
var OOOIReport = {
new: func(state,fob="",time="") {
var report = {parents:[OOOIReport]};
report.state = state;
report.fob = (fob != "") ? fob : fmgc.FMGCInternal.fob;
report.time = (time != "") ? time : sprintf("%02d.%02d", getprop("/sim/time/utc/hour"), getprop("/sim/time/utc/minute"));
report.elapsed = int(getprop("/sim/time/elapsed-sec"));
report.gmt = getprop("/sim/time/gmt-string");
report.date = getprop("/sim/time/utc/day");
report.fltnum = (fmgc.FMGCInternal.flightNumSet == 1) ? fmgc.FMGCInternal.flightNum : "----";
report.tofrom = (fmgc.FMGCInternal.toFromSet) ? fmgc.FMGCInternal.depApt ~ "-" ~ fmgc.FMGCInternal.arrApt : "----/----";
return report;
},
};
# Flight phase states: RESET, BEGIN, WPUSH, OUT, OFF, ON, END
var OOOIReportPage = {
new: func(index) {
var page = {parents:[OOOIReportPage]};
page.index = index;
page.fltstate = ""; #UNDEF state RESET/BEGIN/WPUSH
page.fltnum = (fmgc.FMGCInternal.flightNumSet == 1) ? fmgc.FMGCInternal.flightNum : "";
page.date = getprop("/sim/time/utc/day");
page.tofrom = (fmgc.FMGCInternal.toFromSet) ? fmgc.FMGCInternal.depApt ~ "-" ~ fmgc.FMGCInternal.arrApt : "";
page.fltstart = 0;
page.blkstart = 0;
page.flttime = "--.--";
page.blktime = "--.--";
return page;
},
};
var formatSecToHHMM = func(sec) {
var mn = int(sec / 60);
return sprintf("%02d.%02d",int(mn/60),math.mod(mn,60));
}
var FlightLogDatabase = {
database: std.Vector.new(),
pages: std.Vector.new(),
addReport: func(report) {
if (report.state == 0) me.pages.append( OOOIReportPage.new(me.getSize()) );
me.database.append(report);
var pg = me.pages.vector[me.pages.size()-1];
pg.fltnum = report.fltnum;
pg.tofrom = report.tofrom;
if (report.state == 0) {
pg.fltstate = "OUT";
pg.blkstart = report.elapsed;
}
else if (report.state == 1) {
pg.fltstate = "OFF";
pg.fltstart = report.elapsed;
}
else if (report.state == 2) {
pg.fltstate = "ON";
if (pg.fltstart > 0) pg.flttime = formatSecToHHMM(report.elapsed - pg.fltstart);
}
else if (report.state > 2) {
pg.fltstate = "END";
if (pg.blkstart > 0) pg.blktime = formatSecToHHMM(report.elapsed - pg.blkstart);
}
},
getSize: func() {
return me.database.size();
},
getPageSize: func() {
return me.pages.size();
},
clearDatabase: func() {
me.database.clear();
me.pages.clear();
},
getLogs: func() {
var lst = [];
foreach (var log; me.database) {
append(lst,log);
}
return lst;
},
getPage: func(pg) {
return (pg<=me.getPageSize()) ? me.pages.vector[pg-1] : OOOIReportPage.new(0);
},
getLogByPage: func(no) {
var lst = [nil,nil,nil,nil];
if (me.getPageSize() == 0) return lst;
var i = (me.getPageSize()>=no) ? me.pages.vector[no-1].index : 0;
var len = me.getSize();
var v = 0;
var p = 0;
while (i<len) {
p = me.database.vector[i].state;
if (v == 0 or p != 0) lst[v] = me.database.vector[i];
else i = len;
i+=1;
v+=1;
}
return lst;
},
};
var expectedOOOIState = 0; # OOOI states: 0 = out, 1 = OFF, 2 = ON, 3 = IN, 4 = RETURN-IN
var doorL1_pos = props.globals.getNode("/sim/model/door-positions/doorl1/position-norm", 1);
var doorR1_pos = props.globals.getNode("/sim/model/door-positions/doorr1/position-norm", 1);
var doorL4_pos = props.globals.getNode("/sim/model/door-positions/doorl4/position-norm", 1);
var doorR4_pos = props.globals.getNode("/sim/model/door-positions/doorr4/position-norm", 1);
#check for A/C state change - advice me for a better method, please :/
var waitingOOOIChange = maketimer(1, func(){ # 1sec precision
var phase = fmgc.FMGCInternal.phase;
var gs = pts.Velocities.groundspeed.getValue();
var gear0 = pts.Gear.wow[0].getBoolValue();
#print(sprintf("OOOI check: %d %d %.2f %s",expectedOOOIState,phase,gs,gear0));
if (expectedOOOIState == 0) { # OUT
if (gear0 and phase == 0) {
if (gs>9) { # imho - it's useful few speed tollerance, 10kts min speed on taxiways - CHECKME - better with pushback detection?
FlightLogDatabase.addReport(OOOIReport.new(expectedOOOIState));
expectedOOOIState = 1;
}
}
} else if (expectedOOOIState == 1) { # OFF
if (!gear0) {
FlightLogDatabase.addReport(OOOIReport.new(expectedOOOIState));
expectedOOOIState = 2;
}
else if (gs < 1) { # RETURN-IN ?? - rejected takeoff, A/C back to apron - CHECKME
if (doorL1_pos.getValue()>0 or doorR1_pos.getValue()>0 or doorL4_pos.getValue()>0 or doorR4_pos.getValue()>0) {
FlightLogDatabase.addReport(OOOIReport.new(4)); # RETURN-IN
expectedOOOIState = 0;
}
}
} else if (expectedOOOIState == 2) { # ON
if (gear0 and (phase == 7 or phase == 0)) { #done or preflight
FlightLogDatabase.addReport(OOOIReport.new(expectedOOOIState));
expectedOOOIState = 3;
}
} else if (expectedOOOIState == 3) { # IN
if (gear0 and gs < 1) {
if (doorL1_pos.getValue()>0 or doorR1_pos.getValue()>0 or doorL4_pos.getValue()>0 or doorR4_pos.getValue()>0) {
FlightLogDatabase.addReport(OOOIReport.new(expectedOOOIState));
expectedOOOIState = 0;
}
}
}
});
var engine_one_chk_OOOI = setlistener("/engines/engine[0]/state", func {
if (getprop("/engines/engine[0]/state") == 3) {
removelistener(engine_one_chk_OOOI);
waitingOOOIChange.start();
}
},0,0);

View file

@ -5,7 +5,40 @@
var initInputA = func(key, i) { var initInputA = func(key, i) {
var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad;
if (key == "L2") { if (key == "L1") { #clear coRoute if set
if (scratchpad == "CLR") {
if (fmgc.FMGCInternal.coRouteSet == 1) {
fmgc.FMGCInternal.coRouteSet = 0;
fmgc.FMGCInternal.coRoute = "";
fmgc.FMGCInternal.depApt = "";
fmgc.FMGCInternal.arrApt = "";
fmgc.FMGCInternal.toFromSet = 0;
fmgc.FMGCNodes.toFromSet.setValue(0);
fmgc.windController.resetDesWinds();
setprop("/FMGC/internal/align-ref-lat", 0);
setprop("/FMGC/internal/align-ref-long", 0);
setprop("/FMGC/internal/align-ref-lat-edit", 0);
setprop("/FMGC/internal/align-ref-long-edit", 0);
if (fmgc.FMGCInternal.blockConfirmed) {
fmgc.FMGCInternal.fuelCalculating = 0;
fmgc.fuelCalculating.setValue(0);
fmgc.FMGCInternal.fuelCalculating = 1;
fmgc.fuelCalculating.setValue(1);
}
fmgc.flightPlanController.reset(2);
fmgc.flightPlanController.init();
Simbrief.SimbriefParser.inhibit = 0;
}
mcdu_scratchpad.scratchpads[i].empty();
} else {
var len = size(scratchpad);
if (fmgc.FMGCInternal.coRouteSet == 1 or len != 10) {
mcdu_message(i, "NOT ALLOWED");
} else {
mcdu_message(i, "NOT IN DATA BASE"); # fake message - TODO flightplan loader
}
}
} else if (key == "L2") {
if (scratchpad == "CLR") { if (scratchpad == "CLR") {
fmgc.FMGCInternal.altAirport = ""; fmgc.FMGCInternal.altAirport = "";
fmgc.FMGCInternal.altAirportSet = 0; fmgc.FMGCInternal.altAirportSet = 0;
@ -183,7 +216,10 @@ var initInputA = func(key, i) {
} }
} }
} else if (key == "R1") { } else if (key == "R1") {
if (scratchpad == "CLR") { if (fmgc.FMGCInternal.coRouteSet == 1) {
mcdu_message(i, "NOT ALLOWED");
}
else if (scratchpad == "CLR") {
fmgc.FMGCInternal.depApt = ""; fmgc.FMGCInternal.depApt = "";
fmgc.FMGCInternal.arrApt = ""; fmgc.FMGCInternal.arrApt = "";
fmgc.FMGCInternal.toFromSet = 0; fmgc.FMGCInternal.toFromSet = 0;

View file

@ -18,6 +18,7 @@ var MCDU_reset = func(i) {
setprop("it-autoflight/settings/togaspd", 157); #aka v2 clone setprop("it-autoflight/settings/togaspd", 157); #aka v2 clone
setprop("/MCDU[" ~ i ~ "]/last-fmgc-page", "STATUS"); setprop("/MCDU[" ~ i ~ "]/last-fmgc-page", "STATUS");
setprop("/MCDU[" ~ i ~ "]/last-atsu-page", "ATSUDLINK"); setprop("/MCDU[" ~ i ~ "]/last-atsu-page", "ATSUDLINK");
setprop("/MCDU[" ~ i ~ "]/active-system","");
pageNode[i].setValue("MCDU"); pageNode[i].setValue("MCDU");
setprop("/FMGC/keyboard-left", 0); setprop("/FMGC/keyboard-left", 0);
@ -75,6 +76,8 @@ var MCDU_reset = func(i) {
fmgc.FMGCInternal.gndTempSet = 0; fmgc.FMGCInternal.gndTempSet = 0;
fmgc.FMGCInternal.toFromSet = 0; fmgc.FMGCInternal.toFromSet = 0;
fmgc.FMGCNodes.toFromSet.setValue(0); fmgc.FMGCNodes.toFromSet.setValue(0);
fmgc.FMGCInternal.coRoute = "";
fmgc.FMGCInternal.coRouteSet = 0;
fmgc.FMGCInternal.tropo = 36090; fmgc.FMGCInternal.tropo = 36090;
fmgc.FMGCInternal.tropoSet = 0; fmgc.FMGCInternal.tropoSet = 0;
@ -216,9 +219,11 @@ var lskbutton = func(btn, i) {
pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-fmgc-page")); pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-fmgc-page"));
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
setprop("/MCDU[" ~ i ~ "]/active", 2); setprop("/MCDU[" ~ i ~ "]/active", 2);
setprop("/MCDU[" ~ i ~ "]/active-system","fmgc");
}, 2); }, 2);
} else { } else {
pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-fmgc-page")); pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-fmgc-page"));
setprop("/MCDU[" ~ i ~ "]/active-system","fmgc");
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} }
} }
@ -372,9 +377,11 @@ var lskbutton = func(btn, i) {
pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-atsu-page")); pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-atsu-page"));
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
setprop("/MCDU[" ~ i ~ "]/atsu-active", 2); setprop("/MCDU[" ~ i ~ "]/atsu-active", 2);
setprop("/MCDU[" ~ i ~ "]/active-system","atsu");
}, 2); }, 2);
} else { } else {
pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-atsu-page")); pageNode[i].setValue(getprop("/MCDU[" ~ i ~ "]/last-atsu-page"));
setprop("/MCDU[" ~ i ~ "]/active-system","atsu");
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} }
} }
@ -795,6 +802,8 @@ var lskbutton = func(btn, i) {
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else if (page == "ATCMENU") { } else if (page == "ATCMENU") {
pageNode[i].setValue("NOTIFICATION"); pageNode[i].setValue("NOTIFICATION");
} else if (page == "FLTLOG") {
mcdu_message(i, "NOT ALLOWED");
} else if (page == "MCDUTEXT") { } else if (page == "MCDUTEXT") {
atsu.freeTexts[i].selection = 9; atsu.freeTexts[i].selection = 9;
atsu.freeTexts[i].changed = 1; atsu.freeTexts[i].changed = 1;
@ -857,6 +866,8 @@ var lskbutton = func(btn, i) {
canvas_mcdu.myClosestAirport[i].freeze(); canvas_mcdu.myClosestAirport[i].freeze();
} else if (page == "AOCMENU" or page == "ATCMENU" or page == "ATCMENU2") { } else if (page == "AOCMENU" or page == "ATCMENU" or page == "ATCMENU2") {
pageNode[i].setValue("ATSUDLINK"); pageNode[i].setValue("ATSUDLINK");
} else if (page == "SENSORS") {
pageNode[i].setValue("FLTLOG");
} else if (page == "NOTIFICATION" or page == "CONNECTSTATUS" or page == "MCDUTEXT") { } else if (page == "NOTIFICATION" or page == "CONNECTSTATUS" or page == "MCDUTEXT") {
pageNode[i].setValue("ATCMENU"); pageNode[i].setValue("ATCMENU");
} else if (page == "WEATHERREQ" or page == "RECEIVEDMSGS") { } else if (page == "WEATHERREQ" or page == "RECEIVEDMSGS") {
@ -943,6 +954,8 @@ var rskbutton = func(btn, i) {
} }
} else if (page == "ATSUDLINK") { } else if (page == "ATSUDLINK") {
pageNode[i].setValue("AOCMENU"); pageNode[i].setValue("AOCMENU");
} else if (page == "AOCMENU") {
pageNode[i].setValue("FLTLOG");
} else if (page == "WEATHERREQ") { } else if (page == "WEATHERREQ") {
var result = atsu.AOC.newStation(mcdu_scratchpad.scratchpads[i].scratchpad, i); var result = atsu.AOC.newStation(mcdu_scratchpad.scratchpads[i].scratchpad, i);
if (result == 1) { if (result == 1) {
@ -1210,6 +1223,8 @@ var rskbutton = func(btn, i) {
} }
} else if (page == "ATCMENU") { } else if (page == "ATCMENU") {
pageNode[i].setValue("CONNECTSTATUS"); pageNode[i].setValue("CONNECTSTATUS");
} else if (page == "FLTLOG") {
pageNode[i].setValue("SENSORS");
} else if (page == "WEATHERREQ") { } else if (page == "WEATHERREQ") {
var result = atsu.AOC.sendReq(i); var result = atsu.AOC.sendReq(i);
if (result == 1) { if (result == 1) {
@ -1402,6 +1417,13 @@ var pagebutton = func(btn, i) {
page = pageNode[i].getValue(); page = pageNode[i].getValue();
setprop("/MCDU[" ~ i ~ "]/scratchpad-color", "wht"); setprop("/MCDU[" ~ i ~ "]/scratchpad-color", "wht");
if (page != "MCDU") { if (page != "MCDU") {
# A more flexible system/page tracking for future system expansion
if (getprop("/MCDU[" ~ i ~ "]/active-system") == "fmgc") setprop("/MCDU[" ~ i ~ "]/last-fmgc-page", page);
else setprop("/MCDU[" ~ i ~ "]/last-atsu-page", page);
if (btn == "atc") setprop("/MCDU[" ~ i ~ "]/active-system","atsu");
else setprop("/MCDU[" ~ i ~ "]/active-system","fmgc");
if (btn == "radnav") { if (btn == "radnav") {
pageNode[i].setValue("RADNAV"); pageNode[i].setValue("RADNAV");
} else if (btn == "prog") { } else if (btn == "prog") {
@ -1438,12 +1460,13 @@ var pagebutton = func(btn, i) {
} else if (btn == "data") { } else if (btn == "data") {
pageNode[i].setValue("DATA"); pageNode[i].setValue("DATA");
} else if (btn == "mcdu") { } else if (btn == "mcdu") {
var page = page; #var page = page;
if (page != "ATSUDLINK" and page != "AOCMENU" and page != "AOCCONFIG" and page != "WEATHERREQ" and page != "WEATHERTYPE" and page != "RECEIVEDMSGS" and page != "RECEIVEDMSG" and page != "ATCMENU" and page != "ATCMENU2" and page != "MCDUTEXT" and page != "NOTIFICATION" and page != "CONNECTSTATUS" and page != "COMPANYCALL" and page != "VOICEDIRECTORY" and page != "DATAMODE" and page != "COMMMENU" and page != "COMMSTATUS" and page != "COMMINIT" and page != "ATIS" and page != "ATISDETAIL") { #if (page != "ATSUDLINK" and page != "AOCMENU" and page != "AOCCONFIG" and page != "WEATHERREQ" and page != "WEATHERTYPE" and page != "RECEIVEDMSGS" and page != "RECEIVEDMSG" and page != "ATCMENU" and page != "ATCMENU2" and page != "MCDUTEXT" and page != "NOTIFICATION" and page != "CONNECTSTATUS" and page != "COMPANYCALL" and page != "VOICEDIRECTORY" and page != "DATAMODE" and page != "COMMMENU" and page != "COMMSTATUS" and page != "COMMINIT" and page != "ATIS" and page != "ATISDETAIL") {
setprop("/MCDU[" ~ i ~ "]/last-fmgc-page", page); #if (getprop("/MCDU[0]/active-system") == "fmgc") {
} else { # setprop("/MCDU[" ~ i ~ "]/last-fmgc-page", page);
setprop("/MCDU[" ~ i ~ "]/last-atsu-page", page); #} else {
} # #setprop("/MCDU[" ~ i ~ "]/last-atsu-page", page);
#}
mcdu_message(i, "SELECT DESIRED SYSTEM"); mcdu_message(i, "SELECT DESIRED SYSTEM");
pageNode[i].setValue("MCDU"); pageNode[i].setValue("MCDU");
} else if (btn == "f-pln" or btn == "airport") { } else if (btn == "f-pln" or btn == "airport") {
@ -1491,7 +1514,9 @@ var pagebutton = func(btn, i) {
} }
} }
var button = func(btn, i) { var buttonCLRDown = [0,0]; # counter for down event
var button = func(btn, i, event = "") {
page = pageNode[i].getValue(); page = pageNode[i].getValue();
if (page != "MCDU") { if (page != "MCDU") {
var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad;
@ -1500,12 +1525,25 @@ var button = func(btn, i) {
} else if (btn == "SP") { } else if (btn == "SP") {
mcdu_scratchpad.scratchpads[i].addChar(" "); mcdu_scratchpad.scratchpads[i].addChar(" ");
} else if (btn == "CLR") { } else if (btn == "CLR") {
var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; if (event == "down") {
if (size(scratchpad) > 0) {
if (buttonCLRDown[i] > 4) {
mcdu_scratchpad.scratchpads[i].empty();
}
buttonCLRDown[i] = buttonCLRDown[i] + 1;
}
}
else if (event == "" or buttonCLRDown[i]<=4) {
buttonCLRDown[i] = 0;
#var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; <- useless??
if (size(scratchpad) == 0) { if (size(scratchpad) == 0) {
mcdu_scratchpad.scratchpads[i].addChar("CLR"); mcdu_scratchpad.scratchpads[i].addChar("CLR");
} else { } else {
mcdu_scratchpad.scratchpads[i].clear(); mcdu_scratchpad.scratchpads[i].clear();
} }
} else { # up with buttonCLRDown[i]>4
buttonCLRDown[i] = 0;
}
} else if (btn == "DOT") { } else if (btn == "DOT") {
mcdu_scratchpad.scratchpads[i].addChar("."); mcdu_scratchpad.scratchpads[i].addChar(".");
} else if (btn == "PLUSMINUS") { } else if (btn == "PLUSMINUS") {
@ -1521,6 +1559,12 @@ var mcdu_message = func(i, string, overrideStr = "") {
mcdu_scratchpad.scratchpads[i].override(overrideStr); mcdu_scratchpad.scratchpads[i].override(overrideStr);
} }
# Messagge Type II - TODO 5 messages queue - remove only on resolve
var mcdu_messageTypeII = func(i, string, overrideStr = "") {
mcdu_scratchpad.scratchpads[i].showTypeII(mcdu_scratchpad.MessageController.getTypeIIMsgByText(string));
mcdu_scratchpad.scratchpads[i].override(overrideStr);
}
var screenFlash = func(time, i) { var screenFlash = func(time, i) {
page = pageNode[i].getValue(); page = pageNode[i].getValue();
pageNode[i].setValue("NONE"); pageNode[i].setValue("NONE");

View file

@ -3,6 +3,22 @@
# Copyright (c) 2020 Josh Davidson (Octal450) # Copyright (c) 2020 Josh Davidson (Octal450)
# Copyright (c) 2020 Matthew Maring (mattmaring) # Copyright (c) 2020 Matthew Maring (mattmaring)
# VMCA 109.5 at 0ft
# VMCG 106.5 at 0ft all conf
var standard_VMCA = 109.5; # TODO calculate VMCA/VMCG on altitude (ft) of departure airport (read below)
var standard_VMCG = 106.5;
# TODO - DepArp elevation or current elevation (on ground only!!) -> math.round(fmgc.flightPlanController.flightplans[2].departure.elevation * M2FT))
var perfTOCheckVSpeeds = func(i) {
if (fmgc.FMGCInternal.v1set == 1 and fmgc.FMGCInternal.vrset == 1 and fmgc.FMGCInternal.v2set == 1) { # only when v1/vr/v2 all sets
if (fmgc.FMGCInternal.v1>fmgc.FMGCInternal.vr or fmgc.FMGCInternal.vr > fmgc.FMGCInternal.v2) mcdu_messageTypeII(i,"V1/VR/V2 DISAGREE");
else if (fmgc.FMGCInternal.v1<standard_VMCG or fmgc.FMGCInternal.vr<(standard_VMCA*1.05) or fmgc.FMGCInternal.v2<(standard_VMCA*1.10)) mcdu_messageTypeII(i,"TO SPEED TOO LOW");
#else if (Vr<KVr*VS1G or V2<KV2*VS1G) mcdu_messageTypeII(i,"TO SPEED TOO LOW"); #TODO - check to VS1G and look constant KVr KV2 on manual, not own by me :/
}
}
var perfTOInput = func(key, i) { var perfTOInput = func(key, i) {
var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad; var scratchpad = mcdu_scratchpad.scratchpads[i].scratchpad;
if (key == "L1") { if (key == "L1") {
@ -24,6 +40,8 @@ var perfTOInput = func(key, i) {
fmgc.FMGCNodes.v1.setValue(scratchpad); fmgc.FMGCNodes.v1.setValue(scratchpad);
fmgc.FMGCNodes.v1set.setValue(1); fmgc.FMGCNodes.v1set.setValue(1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
perfTOCheckVSpeeds(i); # do V-speeds validation
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
@ -47,6 +65,8 @@ var perfTOInput = func(key, i) {
fmgc.FMGCInternal.vr = scratchpad; fmgc.FMGCInternal.vr = scratchpad;
fmgc.FMGCInternal.vrset = 1; fmgc.FMGCInternal.vrset = 1;
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
perfTOCheckVSpeeds(i); # do V-speeds validation
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
@ -73,6 +93,8 @@ var perfTOInput = func(key, i) {
fmgc.updatePitchArm2(); fmgc.updatePitchArm2();
setprop("/it-autoflight/settings/togaspd", scratchpad); setprop("/it-autoflight/settings/togaspd", scratchpad);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
perfTOCheckVSpeeds(i); # do V-speeds validation
} else { } else {
mcdu_message(i, "NOT ALLOWED"); mcdu_message(i, "NOT ALLOWED");
} }
@ -112,11 +134,19 @@ var perfTOInput = func(key, i) {
var thrreds = size(thrred); var thrreds = size(thrred);
var acc = thracc[1]; var acc = thracc[1];
var accs = size(acc); var accs = size(acc);
#TODO - manual check - four digit alwway 0000 - default = runaway_elevation + 800 ft, min values runaway_elevation+400ft
if (int(thrred) != nil and (thrreds >= 3 and thrreds <= 5) and thrred >= 400 and thrred <= 39000 and int(acc) != nil and (accs == 3 or accs == 4 or accs == 5) and acc >= 400 and acc <= 39000) { if (int(thrred) != nil and (thrreds >= 3 and thrreds <= 5) and thrred >= 400 and thrred <= 39000 and int(acc) != nil and (accs == 3 or accs == 4 or accs == 5) and acc >= 400 and acc <= 39000) {
if (thrred<=acc) { # validation
setprop("/systems/thrust/clbreduc-ft", int(thrred / 10) * 10); setprop("/systems/thrust/clbreduc-ft", int(thrred / 10) * 10);
setprop("/FMGC/internal/accel-agl-ft", int(acc / 10) * 10); setprop("/FMGC/internal/accel-agl-ft", int(acc / 10) * 10);
setprop("MCDUC/thracc-set", 1); setprop("MCDUC/thracc-set", 1);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();
} else {
mcdu_message(i, "NOT ALLOWED");
}
} else if (thrreds == 0 and int(acc) != nil and (accs >= 3 and accs <= 5) and acc >= 400 and acc <= 39000) { } else if (thrreds == 0 and int(acc) != nil and (accs >= 3 and accs <= 5) and acc >= 400 and acc <= 39000) {
setprop("/FMGC/internal/accel-agl-ft", int(acc / 10) * 10); setprop("/FMGC/internal/accel-agl-ft", int(acc / 10) * 10);
mcdu_scratchpad.scratchpads[i].empty(); mcdu_scratchpad.scratchpads[i].empty();

View file

@ -1175,6 +1175,7 @@
<switch name="fcs/brake-avail"> <switch name="fcs/brake-avail">
<default value="0"/> <default value="0"/>
<test logic="OR" value="1"> <test logic="OR" value="1">
/services/chocks/enable eq 1
/systems/hydraulic/green-psi ge 2500 /systems/hydraulic/green-psi ge 2500
/systems/hydraulic/yellow-psi ge 1000 /systems/hydraulic/yellow-psi ge 1000
/systems/hydraulic/yellow-accumulator-psi gt 0 /systems/hydraulic/yellow-accumulator-psi gt 0