Fix bugs in the fuel system, and add refuelling dialog to the ground services menu
This commit is contained in:
parent
f1e1dc5b56
commit
62d7447b1f
17 changed files with 359 additions and 188 deletions
|
@ -160,7 +160,6 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
</tank>
|
||||
</propulsion>
|
||||
|
||||
<system file="fuel"/>
|
||||
<system file="glass-effect1"/>
|
||||
<system file="a320-fcs"/>
|
||||
<system file="a320-100-fuel"/>
|
||||
|
|
|
@ -79,7 +79,7 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
<capacity unit="LBS"> 1523.00 </capacity>
|
||||
<contents unit="LBS"> 1523.00 </contents>
|
||||
<unusable-volume unit="LTR"> 4.0 </unusable-volume>
|
||||
<priority>1</priority>
|
||||
<priority>0</priority>
|
||||
<density unit="LBS/GAL">6.71</density>
|
||||
<temperature>50</temperature>
|
||||
</tank>
|
||||
|
@ -92,7 +92,7 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
<capacity unit="LBS"> 12591.95 </capacity>
|
||||
<contents unit="LBS"> 6000.00 </contents>
|
||||
<unusable-volume unit="LTR"> 28.0 </unusable-volume>
|
||||
<priority>1</priority>
|
||||
<priority>0</priority>
|
||||
<density unit="LBS/GAL">6.71</density>
|
||||
<temperature>50</temperature>
|
||||
</tank>
|
||||
|
@ -105,7 +105,7 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
<capacity unit="LBS"> 14623.00 </capacity>
|
||||
<contents unit="LBS"> 42 </contents>
|
||||
<unusable-volume unit="LTR"> 23.20 </unusable-volume>
|
||||
<priority>1</priority>
|
||||
<priority>0</priority>
|
||||
<density unit="LBS/GAL">6.71</density>
|
||||
<temperature>50</temperature>
|
||||
</tank>
|
||||
|
@ -118,7 +118,7 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
<capacity unit="LBS"> 12591.95 </capacity>
|
||||
<contents unit="LBS"> 6000.00 </contents>
|
||||
<unusable-volume unit="LTR"> 28.0 </unusable-volume>
|
||||
<priority>1</priority>
|
||||
<priority>0</priority>
|
||||
<density unit="LBS/GAL">6.71</density>
|
||||
<temperature>50</temperature>
|
||||
</tank>
|
||||
|
@ -131,7 +131,7 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
<capacity unit="LBS"> 1523.00 </capacity>
|
||||
<contents unit="LBS"> 1523.00 </contents>
|
||||
<unusable-volume unit="LTR"> 4.0 </unusable-volume>
|
||||
<priority>1</priority>
|
||||
<priority>0</priority>
|
||||
<density unit="LBS/GAL">6.71</density>
|
||||
<temperature>50</temperature>
|
||||
</tank>
|
||||
|
@ -159,7 +159,6 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
</tank>
|
||||
</propulsion>
|
||||
|
||||
<system file="fuel"/>
|
||||
<system file="glass-effect1"/>
|
||||
<system file="a320-fcs"/>
|
||||
<system file="a320-fuel"/>
|
||||
|
|
|
@ -159,7 +159,6 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
</tank>
|
||||
</propulsion>
|
||||
|
||||
<system file="fuel"/>
|
||||
<system file="glass-effect1"/>
|
||||
<system file="a320-fcs"/>
|
||||
<system file="a320-fuel"/>
|
||||
|
|
|
@ -802,6 +802,13 @@
|
|||
<left type="bool">0</left>
|
||||
<right type="bool">0</right>
|
||||
</chocks>
|
||||
<fuel-truck>
|
||||
<connect type="bool">0</connect>
|
||||
<enable type="bool">0</enable>
|
||||
<operate type="bool">0</operate>
|
||||
<request-lbs type="double">0</request-lbs>
|
||||
<request-total-lbs type="double">0</request-total-lbs>
|
||||
</fuel-truck>
|
||||
</services>
|
||||
|
||||
<systems>
|
||||
|
@ -1634,6 +1641,7 @@
|
|||
<file>Aircraft/A320-family/Nasal/fire.nas</file>
|
||||
<file>Aircraft/A320-family/Nasal/brakes.nas</file>
|
||||
<file>Aircraft/A320-family/Nasal/ground_services.nas</file>
|
||||
<file>Aircraft/A320-family/Nasal/payload.nas</file>
|
||||
<file>Aircraft/A320-family/Nasal/effects.nas</file>
|
||||
</systems>
|
||||
<fadec>
|
||||
|
|
|
@ -159,7 +159,6 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
</tank>
|
||||
</propulsion>
|
||||
|
||||
<system file="fuel"/>
|
||||
<system file="glass-effect1"/>
|
||||
<system file="a320-fcs"/>
|
||||
<system file="a320-fuel"/>
|
||||
|
|
|
@ -159,7 +159,6 @@ xsi:noNamespaceSchemaLocation="http://jsbsim.sourceforge.net/JSBSim.xsd">
|
|||
</tank>
|
||||
</propulsion>
|
||||
|
||||
<system file="fuel"/>
|
||||
<system file="glass-effect1"/>
|
||||
<system file="a320-fcs"/>
|
||||
<system file="a320-fuel"/>
|
||||
|
|
|
@ -113,6 +113,7 @@ var about_dlg = gui.Dialog.new("sim/gui/dialogs/acconfig/about/dialog", "Aircraf
|
|||
var update_dlg = gui.Dialog.new("sim/gui/dialogs/acconfig/update/dialog", "Aircraft/A320-family/AircraftConfig/update.xml");
|
||||
var updated_dlg = gui.Dialog.new("sim/gui/dialogs/acconfig/updated/dialog", "Aircraft/A320-family/AircraftConfig/updated.xml");
|
||||
var error_mismatch = gui.Dialog.new("sim/gui/dialogs/acconfig/error/mismatch/dialog", "Aircraft/A320-family/AircraftConfig/error-mismatch.xml");
|
||||
var fuel_dlg = gui.Dialog.new("sim/gui/dialogs/acconfig/fuel/dialog", "Aircraft/A320-family/AircraftConfig/fuel.xml");
|
||||
var groundservices_dlg = gui.Dialog.new("sim/gui/dialogs/acconfig/groundsrvc/dialog", "Aircraft/A320-family/AircraftConfig/groundservices.xml");
|
||||
var du_quality = gui.Dialog.new("sim/gui/dialogs/acconfig/du-quality/dialog", "Aircraft/A320-family/AircraftConfig/du-quality.xml");
|
||||
var rendering_dlg = gui.Dialog.new("sim/gui/dialogs/rendering/dialog", "Aircraft/A320-family/AircraftConfig/rendering.xml");
|
||||
|
|
160
AircraftConfig/fuel.xml
Normal file
160
AircraftConfig/fuel.xml
Normal file
|
@ -0,0 +1,160 @@
|
|||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
|
||||
<!-- Copyright (c) 2019 Joshua Davidson (Octal450) -->
|
||||
|
||||
<!-- A3XX Aircraft Config Dialog -->
|
||||
|
||||
<PropertyList>
|
||||
|
||||
<name>fuel-dlg</name>
|
||||
<layout>vbox</layout>
|
||||
|
||||
<group>
|
||||
<layout>hbox</layout>
|
||||
<text>
|
||||
<halign>left</halign>
|
||||
<label>Ground Services: Fuel</label>
|
||||
</text>
|
||||
<button>
|
||||
<halign>right</halign>
|
||||
<pref-width>20</pref-width>
|
||||
<pref-height>20</pref-height>
|
||||
<legend>X</legend>
|
||||
<key>Esc</key>
|
||||
<binding>
|
||||
<command>dialog-close</command>
|
||||
</binding>
|
||||
</button>
|
||||
</group>
|
||||
|
||||
<hrule/>
|
||||
|
||||
<group>
|
||||
<layout>vbox</layout>
|
||||
|
||||
<checkbox>
|
||||
<label>Enable Fuel Truck</label>
|
||||
<halign>left</halign>
|
||||
<enable>
|
||||
<not><property>/services/fuel-truck/connect</property></not>
|
||||
</enable>
|
||||
<property>/services/fuel-truck/enable</property>
|
||||
<binding>
|
||||
<command>dialog-apply</command>
|
||||
</binding>
|
||||
<live>true</live>
|
||||
</checkbox>
|
||||
|
||||
<checkbox>
|
||||
<label>Connect Fuel Truck</label>
|
||||
<halign>left</halign>
|
||||
<enable>
|
||||
<property>/services/fuel-truck/enable</property>
|
||||
</enable>
|
||||
<property>/services/fuel-truck/connect</property>
|
||||
<binding>
|
||||
<command>dialog-apply</command>
|
||||
</binding>
|
||||
<live>true</live>
|
||||
</checkbox>
|
||||
|
||||
<hrule />
|
||||
|
||||
<group>
|
||||
<layout>table</layout>
|
||||
<text>
|
||||
<label>Total Fuel Quantity (Lbs):</label>
|
||||
<halign>right</halign>
|
||||
<padding>2</padding>
|
||||
<row>0</row>
|
||||
<col>0</col>
|
||||
</text>
|
||||
|
||||
<text>
|
||||
<label>Requested Fuel Quantity (Lbs):</label>
|
||||
<halign>right</halign>
|
||||
<padding>2</padding>
|
||||
<row>1</row>
|
||||
<col>0</col>
|
||||
</text>
|
||||
|
||||
<text>
|
||||
<label>New Total Fuel Quantity (Lbs):</label>
|
||||
<halign>right</halign>
|
||||
<padding>2</padding>
|
||||
<row>2</row>
|
||||
<col>0</col>
|
||||
</text>
|
||||
|
||||
<text>
|
||||
<row>0</row>
|
||||
<col>1</col>
|
||||
<halign>left</halign>
|
||||
<padding>2</padding>
|
||||
<property>/consumables/fuel/total-fuel-lbs</property>
|
||||
<live>true</live>
|
||||
<format>%.1f</format>
|
||||
</text>
|
||||
|
||||
<input>
|
||||
<row>1</row>
|
||||
<col>1</col>
|
||||
<halign>left</halign>
|
||||
<padding>1</padding>
|
||||
<property>/services/fuel-truck/request-lbs</property>
|
||||
<live>true</live>
|
||||
<binding>
|
||||
<command>dialog-apply</command>
|
||||
</binding>
|
||||
</input>
|
||||
|
||||
<text>
|
||||
<row>2</row>
|
||||
<col>1</col>
|
||||
<halign>left</halign>
|
||||
<padding>2</padding>
|
||||
<property>/services/fuel-truck/request-total-lbs</property>
|
||||
<live>true</live>
|
||||
<format>%.1f</format>
|
||||
</text>
|
||||
</group>
|
||||
|
||||
<hrule />
|
||||
|
||||
<group>
|
||||
<layout>hbox</layout>
|
||||
|
||||
<button>
|
||||
<legend>Refuel</legend>
|
||||
<padding>2</padding>
|
||||
<pref-width>80</pref-width>
|
||||
<pref-height>24</pref-height>
|
||||
<binding>
|
||||
<command>nasal</command>
|
||||
<script>
|
||||
if ((getprop("/services/fuel-truck/enable") == 1) and (getprop("/services/fuel-truck/connect") == 1)) {
|
||||
systems.fuelSvc.refuel();
|
||||
screen.log.write("Refueling process started.", 0, 0.584, 1);
|
||||
} else
|
||||
screen.log.write("Please Enable and Connect the Fuel Truck First!", 1, 0, 0);
|
||||
</script>
|
||||
</binding>
|
||||
</button>
|
||||
|
||||
<button>
|
||||
<legend>Stop</legend>
|
||||
<padding>2</padding>
|
||||
<pref-width>80</pref-width>
|
||||
<pref-height>24</pref-height>
|
||||
<binding>
|
||||
<command>nasal</command>
|
||||
<script>
|
||||
systems.fuelSvc.stop();
|
||||
screen.log.write("Refueling process stopped.", 0, 0.584, 1);
|
||||
</script>
|
||||
</binding>
|
||||
</button>
|
||||
</group>
|
||||
</group>
|
||||
|
||||
</PropertyList>
|
|
@ -56,31 +56,21 @@
|
|||
</binding>
|
||||
</button>
|
||||
|
||||
<checkbox>
|
||||
<label>Enable Fuel Truck</label>
|
||||
<halign>left</halign>
|
||||
<enable>
|
||||
<not><property>/services/fuel-truck/connect</property></not>
|
||||
</enable>
|
||||
<property>/services/fuel-truck/enable</property>
|
||||
<binding>
|
||||
<command>dialog-apply</command>
|
||||
</binding>
|
||||
<live>true</live>
|
||||
</checkbox>
|
||||
<hrule />
|
||||
|
||||
<checkbox>
|
||||
<label>Connect Fuel Truck</label>
|
||||
<halign>left</halign>
|
||||
<enable>
|
||||
<property>/services/fuel-truck/enable</property>
|
||||
</enable>
|
||||
<property>/services/fuel-truck/connect</property>
|
||||
<button>
|
||||
<legend>Fuel Truck</legend>
|
||||
<halign>center</halign>
|
||||
<padding>5</padding>
|
||||
<binding>
|
||||
<command>dialog-apply</command>
|
||||
<command>nasal</command>
|
||||
<script>
|
||||
acconfig.fuel_dlg.open();
|
||||
</script>
|
||||
</binding>
|
||||
<live>true</live>
|
||||
</checkbox>
|
||||
</button>
|
||||
|
||||
<hrule />
|
||||
|
||||
<checkbox>
|
||||
<label>Enable Catering Truck</label>
|
||||
|
|
|
@ -222,9 +222,9 @@ var fadec2 = props.globals.getNode("/systems/fadec/powered2", 1);
|
|||
var fuel_flow1 = props.globals.getNode("/engines/engine[0]/fuel-flow_actual", 1);
|
||||
var fuel_flow2 = props.globals.getNode("/engines/engine[1]/fuel-flow_actual", 1);
|
||||
var fuel_left_outer_temp = props.globals.getNode("/consumables/fuel/tank[0]/temperature_degC", 1);
|
||||
var fuel_left_inner_temp = props.globals.getNode("/consumables/fuel/tank[0]/temperature_degC", 1);
|
||||
var fuel_right_outer_temp = props.globals.getNode("/consumables/fuel/tank[1]/temperature_degC", 1);
|
||||
var fuel_right_inner_temp = props.globals.getNode("/consumables/fuel/tank[1]/temperature_degC", 1);
|
||||
var fuel_left_inner_temp = props.globals.getNode("/consumables/fuel/tank[1]/temperature_degC", 1);
|
||||
var fuel_right_outer_temp = props.globals.getNode("/consumables/fuel/tank[3]/temperature_degC", 1);
|
||||
var fuel_right_inner_temp = props.globals.getNode("/consumables/fuel/tank[4]/temperature_degC", 1);
|
||||
var cutoff_switch1 = props.globals.getNode("/controls/engines/engine[0]/cutoff-switch", 1);
|
||||
var cutoff_switch2 = props.globals.getNode("/controls/engines/engine[1]/cutoff-switch", 1);
|
||||
var fuel_xfeed = props.globals.getNode("/controls/fuel/x-feed", 1);
|
||||
|
|
|
@ -8,6 +8,7 @@ var FUEL = {
|
|||
offset2: 0,
|
||||
timeEngStart: 0,
|
||||
cmdCtrOn: props.globals.getNode("/systems/fuel/ctr-pump-cmd-on-eng-start"),
|
||||
refuelling: props.globals.getNode("/systems/fuel/refuel/refuelling"),
|
||||
|
||||
Fail: {
|
||||
},
|
||||
|
@ -27,13 +28,21 @@ var FUEL = {
|
|||
lpValve2: props.globals.getNode("/systems/fuel/valves/engine-2-lp-valve"),
|
||||
transfer1: props.globals.getNode("/systems/fuel/valves/outer-inner-transfer-valve-1"),
|
||||
transfer2: props.globals.getNode("/systems/fuel/valves/outer-inner-transfer-valve-2"),
|
||||
refuelLeft: props.globals.getNode("/systems/fuel/refuel/left-valve"),
|
||||
refuelCenter: props.globals.getNode("/systems/fuel/refuel/center-valve"),
|
||||
refuelRight: props.globals.getNode("/systems/fuel/refuel/right-valve"),
|
||||
},
|
||||
Quantity: {
|
||||
leftOuter: props.globals.getNode("/consumables/fuel/tank[0]/level-lbs"),
|
||||
leftOuterPct: props.globals.getNode("/consumables/fuel/tank[0]/level-norm"),
|
||||
leftInner: props.globals.getNode("/consumables/fuel/tank[1]/level-lbs"),
|
||||
leftInnerPct: props.globals.getNode("/consumables/fuel/tank[1]/level-norm"),
|
||||
center: props.globals.getNode("/consumables/fuel/tank[2]/level-lbs"),
|
||||
centerPct: props.globals.getNode("/consumables/fuel/tank[2]/level-norm"),
|
||||
rightInner: props.globals.getNode("/consumables/fuel/tank[3]/level-lbs"),
|
||||
rightInnerPct: props.globals.getNode("/consumables/fuel/tank[3]/level-norm"),
|
||||
rightOuter: props.globals.getNode("/consumables/fuel/tank[4]/level-lbs"),
|
||||
rightOuterPct: props.globals.getNode("/consumables/fuel/tank[4]/level-norm"),
|
||||
usedLeft: props.globals.getNode("/systems/fuel/fuel-used-1"),
|
||||
usedRight: props.globals.getNode("/systems/fuel/fuel-used-2"),
|
||||
},
|
||||
|
|
|
@ -266,10 +266,10 @@ var systemsLoop = maketimer(0.1, func {
|
|||
setprop("/engines/ready", 0);
|
||||
}
|
||||
|
||||
if ((getprop("/engines/engine[0]/state") == 2 or getprop("/engines/engine[0]/state") == 3) and getprop("/fdm/jsbsim/propulsion/tank[3]/contents-lbs") < 1) {
|
||||
if ((getprop("/engines/engine[0]/state") == 2 or getprop("/engines/engine[0]/state") == 3) and getprop("/fdm/jsbsim/propulsion/tank[5]/contents-lbs") < 1) {
|
||||
systems.cutoff_one();
|
||||
}
|
||||
if ((getprop("/engines/engine[1]/state") == 2 or getprop("/engines/engine[1]/state") == 3) and getprop("/fdm/jsbsim/propulsion/tank[4]/contents-lbs") < 1) {
|
||||
if ((getprop("/engines/engine[1]/state") == 2 or getprop("/engines/engine[1]/state") == 3) and getprop("/fdm/jsbsim/propulsion/tank[6]/contents-lbs") < 1) {
|
||||
systems.cutoff_two();
|
||||
}
|
||||
|
||||
|
|
87
Nasal/payload.nas
Normal file
87
Nasal/payload.nas
Normal file
|
@ -0,0 +1,87 @@
|
|||
# A32X Fuelling and Loading
|
||||
# Jonathan Redpath
|
||||
|
||||
var fuelSvc = {
|
||||
enable: props.globals.getNode("/services/fuel-truck/enable"),
|
||||
connect: props.globals.getNode("/services/fuel-truck/connect"),
|
||||
operate: props.globals.getNode("/services/fuel-truck/operate"),
|
||||
Nodes: {
|
||||
requestLbs: props.globals.getNode("/services/fuel-truck/request-lbs"),
|
||||
requestTotalLbs: props.globals.getNode("/services/fuel-truck/request-total-lbs"),
|
||||
},
|
||||
|
||||
newRequest: func() {
|
||||
if (pts.Sim.aero.getValue() == "A320-200-CFM") {
|
||||
me.Nodes.requestTotalLbs.setValue(math.min(pts.Consumables.Fuel.totalFuelLbs.getValue() + me.Nodes.requestLbs.getValue(), 42872));
|
||||
} elsif (pts.Sim.aero.getValue() == "A320-200-IAE" or pts.Sim.aero.getValue() == "A320-100-CFM") {
|
||||
me.Nodes.requestTotalLbs.setValue(math.min(pts.Consumables.Fuel.totalFuelLbs.getValue() + me.Nodes.requestLbs.getValue(), 42214));
|
||||
} elsif (pts.Sim.aero.getValue() == "A320neo-CFM" or pts.Sim.aero.getValue() == "A320neo-PW") {
|
||||
me.Nodes.requestTotalLbs.setValue(math.min(pts.Consumables.Fuel.totalFuelLbs.getValue() + me.Nodes.requestLbs.getValue(), 41977));
|
||||
}
|
||||
},
|
||||
|
||||
refuel: func() {
|
||||
if (me.operate.getBoolValue()) { return; }
|
||||
|
||||
if (me.enable.getValue() and me.connect.getValue()) {
|
||||
me.operate.setBoolValue(1);
|
||||
}
|
||||
|
||||
fuelTimer.start();
|
||||
systems.FUEL.refuelling.setBoolValue(1);
|
||||
|
||||
systems.FUEL.Valves.refuelLeft.setBoolValue(1);
|
||||
systems.FUEL.Valves.refuelRight.setBoolValue(1);
|
||||
|
||||
if (pts.Sim.aero.getValue() == "A320-200-CFM" and me.Nodes.requestTotalLbs.getValue() > 28229.9) {
|
||||
systems.FUEL.Valves.refuelCenter.setBoolValue(1);
|
||||
} elsif ((pts.Sim.aero.getValue() == "A320-200-IAE" or pts.Sim.aero.getValue() == "A320-100-CFM") and me.Nodes.requestTotalLbs.getValue() > 27591.8) {
|
||||
systems.FUEL.Valves.refuelCenter.setBoolValue(1);
|
||||
} elsif ((pts.Sim.aero.getValue() == "A320neo-CFM" or pts.Sim.aero.getValue() == "A320neo-PW") and me.Nodes.requestTotalLbs.getValue() > 27357.8) {
|
||||
systems.FUEL.Valves.refuelCenter.setBoolValue(1);
|
||||
}
|
||||
},
|
||||
|
||||
stop: func() {
|
||||
systems.FUEL.refuelling.setBoolValue(0);
|
||||
systems.FUEL.Valves.refuelLeft.setBoolValue(0);
|
||||
systems.FUEL.Valves.refuelCenter.setBoolValue(0);
|
||||
systems.FUEL.Valves.refuelRight.setBoolValue(0);
|
||||
me.operate.setBoolValue(0);
|
||||
},
|
||||
};
|
||||
|
||||
setlistener("/services/fuel-truck/request-lbs", func() {
|
||||
fuelSvc.newRequest();
|
||||
}, 0, 0);
|
||||
|
||||
setlistener("/services/fuel-truck/enable", func() {
|
||||
if (!fuelSvc.enable.getBoolValue()) {
|
||||
fuelSvc.stop();
|
||||
}
|
||||
}, 0, 0);
|
||||
|
||||
setlistener("/services/fuel-truck/connect", func() {
|
||||
if (!fuelSvc.connect.getBoolValue()) {
|
||||
fuelSvc.stop();
|
||||
}
|
||||
}, 0, 0);
|
||||
|
||||
var fuelTimer = maketimer(0.25, func() {
|
||||
if (systems.FUEL.Quantity.leftInnerPct.getValue() >= 0.999) {
|
||||
systems.FUEL.Valves.refuelLeft.setBoolValue(0);
|
||||
}
|
||||
|
||||
if (systems.FUEL.Quantity.centerPct.getValue() >= 0.999) {
|
||||
systems.FUEL.Valves.refuelCenter.setBoolValue(0);
|
||||
}
|
||||
|
||||
if (systems.FUEL.Quantity.rightInnerPct.getValue() >= 0.999) {
|
||||
systems.FUEL.Valves.refuelRight.setBoolValue(0);
|
||||
}
|
||||
|
||||
if (abs(pts.Consumables.Fuel.totalFuelLbs.getValue() - fuelSvc.Nodes.requestTotalLbs.getValue()) < 5) {
|
||||
fuelSvc.stop();
|
||||
fuelTimer.stop();
|
||||
}
|
||||
});
|
|
@ -5,6 +5,12 @@
|
|||
# Anything that says Temp is set by another file to avoid multiple getValue calls
|
||||
# Usage Example: pts.Class.SubClass.node.getValue()
|
||||
|
||||
var Consumables = {
|
||||
Fuel: {
|
||||
totalFuelLbs: props.globals.getNode("/consumables/fuel/total-fuel-lbs"),
|
||||
},
|
||||
};
|
||||
|
||||
var Controls = {
|
||||
Engines: {
|
||||
Engine1: {
|
||||
|
@ -69,6 +75,7 @@ var Position = {
|
|||
};
|
||||
|
||||
var Sim = {
|
||||
aero: props.globals.getNode("/sim/aero"),
|
||||
Replay: {
|
||||
replayActive: props.globals.getNode("/sim/replay/replay-state"),
|
||||
},
|
||||
|
|
|
@ -62,15 +62,33 @@
|
|||
</test>
|
||||
</switch>
|
||||
|
||||
<fcs_function name="/systems/fuel/internal/left-inner-tank-underfull-level">
|
||||
<function>
|
||||
<difference>
|
||||
<property>/consumables/fuel/tank[1]/capacity-gal_us</property>
|
||||
<value>106.197</value>
|
||||
</difference>
|
||||
</function>
|
||||
</fcs_function>
|
||||
|
||||
<fcs_function name="/systems/fuel/internal/right-inner-tank-underfull-level">
|
||||
<function>
|
||||
<difference>
|
||||
<property>/consumables/fuel/tank[3]/capacity-gal_us</property>
|
||||
<value>106.197</value>
|
||||
</difference>
|
||||
</function>
|
||||
</fcs_function>
|
||||
|
||||
<switch name="/systems/fuel/left-inner-full">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="1">
|
||||
/systems/fuel/left-inner-full eq 1
|
||||
propulsion/tank[1]/contents-lbs lt 12270
|
||||
propulsion/tank[1]/contents-lbs ge 10300
|
||||
/consumables/fuel/tank[1]/level-norm lt 0.999
|
||||
/consumables/fuel/tank[1]/level-gal_us ge /systems/fuel/internal/left-inner-tank-underfull-level
|
||||
</test>
|
||||
<test value="1">
|
||||
propulsion/tank[1]/contents-lbs eq 12270
|
||||
/consumables/fuel/tank[1]/level-norm gt 0.999
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
@ -78,11 +96,11 @@
|
|||
<default value="0"/>
|
||||
<test logic="AND" value="1">
|
||||
/systems/fuel/right-inner-full eq 1
|
||||
propulsion/tank[3]/contents-lbs lt 12270
|
||||
propulsion/tank[3]/contents-lbs ge 10300
|
||||
/consumables/fuel/tank[3]/level-norm lt 0.999
|
||||
/consumables/fuel/tank[3]/level-gal_us ge /systems/fuel/internal/right-inner-tank-underfull-level
|
||||
</test>
|
||||
<test value="1">
|
||||
propulsion/tank[3]/contents-lbs eq 12270
|
||||
/consumables/fuel/tank[3]/level-norm gt 0.999
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
@ -92,8 +110,9 @@
|
|||
/controls/fuel/switches/pump-center-1 eq 1
|
||||
<test logic="OR">
|
||||
/controls/fuel/switches/center-mode eq 0
|
||||
<test logic="OR">
|
||||
<test logic="AND">
|
||||
/systems/fuel/pumps/center-control-low-level ne 1
|
||||
<test logic="OR">
|
||||
/systems/fuel/ctr-pump-cmd-on-eng-start eq 1
|
||||
<test logic="AND">
|
||||
fcs/slat-pos-deg lt 16
|
||||
|
@ -101,6 +120,7 @@
|
|||
</test>
|
||||
</test>
|
||||
</test>
|
||||
</test>
|
||||
/systems/electrical/bus/ac-1 ge 110
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -111,13 +131,14 @@
|
|||
/controls/fuel/switches/pump-center-2 eq 1
|
||||
<test logic="OR">
|
||||
/controls/fuel/switches/center-mode eq 0
|
||||
<test logic="OR">
|
||||
<test logic="AND">
|
||||
/systems/fuel/pumps/center-control-low-level ne 1
|
||||
<test logic="OR">
|
||||
/systems/fuel/ctr-pump-cmd-on-eng-start eq 1
|
||||
<test logic="AND">
|
||||
fcs/slat-pos-deg lt 16
|
||||
/systems/fuel/pumps/center-control-low-level ne 1
|
||||
/systems/fuel/right-inner-full ne 1
|
||||
/systems/fuel/left-inner-full ne 1
|
||||
</test>
|
||||
</test>
|
||||
</test>
|
||||
</test>
|
||||
|
@ -423,19 +444,7 @@
|
|||
</test>
|
||||
</switch>
|
||||
|
||||
<switch name="/systems/fuel/internal/left-wing-tank-eng-1">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
<test logic="OR">
|
||||
/systems/fuel/quantity/center-low eq 1
|
||||
/systems/fuel/feed-center-1 eq 0
|
||||
</test>
|
||||
/systems/fuel/feed-left-inner eq 1
|
||||
propulsion/tank[1]/contents-lbs gt 22.68
|
||||
propulsion/tank[5]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<!-- Refuel system -->
|
||||
<switch name="/systems/fuel/internal/left-outer-wing-tank-refuel">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="16.615">
|
||||
|
@ -454,7 +463,7 @@
|
|||
<default value="0"/>
|
||||
<test logic="AND" value="/systems/fuel/internal/left-outer-wing-tank-refuel">
|
||||
/systems/fuel/refuel/refuelling eq 1
|
||||
propulsion/tank[0]/contents-lbs ge 1523
|
||||
propulsion/tank[0]/pct-full ge 99.9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
@ -505,7 +514,21 @@
|
|||
<default value="0"/>
|
||||
<test logic="AND" value="/systems/fuel/internal/right-outer-wing-tank-refuel">
|
||||
/systems/fuel/refuel/refuelling eq 1
|
||||
propulsion/tank[4]/contents-lbs ge 1523
|
||||
propulsion/tank[4]/pct-full ge 99.9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<!-- Feed system -->
|
||||
<switch name="/systems/fuel/internal/left-wing-tank-eng-1">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
<test logic="OR">
|
||||
/systems/fuel/quantity/center-low eq 1
|
||||
/systems/fuel/feed-center-1 eq 0
|
||||
</test>
|
||||
/systems/fuel/feed-left-inner eq 1
|
||||
/consumables/fuel/tank[1]/level-gal_us gt /consumables/fuel/tank[1]/unusable-gal_us
|
||||
propulsion/tank[5]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
@ -519,7 +542,7 @@
|
|||
/systems/fuel/valves/crossfeed-valve eq 1
|
||||
</test>
|
||||
</test>
|
||||
propulsion/tank[3]/contents-lbs gt 22.68
|
||||
/consumables/fuel/tank[2]/level-gal_us gt /consumables/fuel/tank[2]/unusable-gal_us
|
||||
propulsion/tank[5]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -533,7 +556,7 @@
|
|||
/systems/fuel/feed-center-2 eq 0
|
||||
</test>
|
||||
/systems/fuel/valves/crossfeed-valve eq 1
|
||||
propulsion/tank[3]/contents-lbs gt 22.68
|
||||
/consumables/fuel/tank[3]/level-gal_us gt /consumables/fuel/tank[3]/unusable-gal_us
|
||||
propulsion/tank[5]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -547,7 +570,7 @@
|
|||
/systems/fuel/feed-center-1 eq 0
|
||||
</test>
|
||||
/systems/fuel/feed-left-inner eq 1
|
||||
propulsion/tank[1]/contents-lbs gt 22.68
|
||||
/consumables/fuel/tank[1]/level-gal_us gt /consumables/fuel/tank[1]/unusable-gal_us
|
||||
propulsion/tank[6]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -562,7 +585,7 @@
|
|||
/systems/fuel/valves/crossfeed-valve eq 1
|
||||
</test>
|
||||
</test>
|
||||
propulsion/tank[3]/contents-lbs gt 22.68
|
||||
/consumables/fuel/tank[2]/level-gal_us gt /consumables/fuel/tank[2]/unusable-gal_us
|
||||
propulsion/tank[6]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -575,7 +598,7 @@
|
|||
/systems/fuel/feed-center-2 eq 0
|
||||
</test>
|
||||
/systems/fuel/feed-right-inner eq 1
|
||||
propulsion/tank[3]/contents-lbs gt 22.68
|
||||
/consumables/fuel/tank[3]/level-gal_us gt /consumables/fuel/tank[3]/unusable-gal_us
|
||||
propulsion/tank[6]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
@ -585,6 +608,8 @@
|
|||
<test logic="AND" value="9">
|
||||
/systems/fuel/valves/outer-inner-transfer-valve-1 eq 1
|
||||
/accelerations/pilot-gdamped ge 0.5
|
||||
/consumables/fuel/tank[0]/level-gal_us gt /consumables/fuel/tank[0]/unusable-gal_us
|
||||
/consumables/fuel/tank[1]/level-norm lt 0.999
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
@ -593,6 +618,8 @@
|
|||
<test logic="AND" value="9">
|
||||
/systems/fuel/valves/outer-inner-transfer-valve-2 eq 1
|
||||
/accelerations/pilot-gdamped ge 0.5
|
||||
/consumables/fuel/tank[4]/level-gal_us gt /consumables/fuel/tank[4]/unusable-gal_us
|
||||
/consumables/fuel/tank[3]/level-norm lt 0.999
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
|
|
113
Systems/fuel.xml
113
Systems/fuel.xml
|
@ -1,113 +0,0 @@
|
|||
<?xml version="1.0"?>
|
||||
|
||||
<!-- A3XX Fuel System -->
|
||||
|
||||
<!-- Copyright (c) 2019 Joshua Davidson (Octal450) -->
|
||||
|
||||
<system name="fuel">
|
||||
|
||||
<channel name="Fuel to Engine 1 Pipes">
|
||||
<switch name="fuel/from-tank0-to-tank3">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/only-use-ctr-tank == 0
|
||||
/systems/fuel/tank[0]/feed == 1
|
||||
propulsion/tank[0]/contents-lbs gt 0
|
||||
propulsion/tank[3]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<switch name="fuel/from-tank1-to-tank3">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/tank[1]/feed == 1
|
||||
propulsion/tank[1]/contents-lbs gt 0
|
||||
propulsion/tank[3]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<switch name="fuel/from-tank2-to-tank3">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/valves/crossfeed-valve == 1
|
||||
/systems/fuel/only-use-ctr-tank == 0
|
||||
/systems/fuel/tank[2]/feed == 1
|
||||
propulsion/tank[0]/contents-lbs eq 0
|
||||
propulsion/tank[2]/contents-lbs gt 0
|
||||
propulsion/tank[3]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
</channel>
|
||||
|
||||
<channel name="Fuel to Engine 2 Pipes">
|
||||
<switch name="fuel/from-tank2-to-tank4">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/only-use-ctr-tank == 0
|
||||
/systems/fuel/tank[2]/feed == 1
|
||||
propulsion/tank[2]/contents-lbs gt 0
|
||||
propulsion/tank[4]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<switch name="fuel/from-tank1-to-tank4">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/tank[1]/feed == 1
|
||||
propulsion/tank[1]/contents-lbs gt 0
|
||||
propulsion/tank[4]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
|
||||
<switch name="fuel/from-tank0-to-tank4">
|
||||
<default value="0"/>
|
||||
<test logic="AND" value="9">
|
||||
/systems/fuel/valves/crossfeed-valve == 1
|
||||
/systems/fuel/only-use-ctr-tank == 0
|
||||
/systems/fuel/tank[0]/feed == 1
|
||||
propulsion/tank[2]/contents-lbs eq 0
|
||||
propulsion/tank[0]/contents-lbs gt 0
|
||||
propulsion/tank[4]/contents-lbs lt 9
|
||||
</test>
|
||||
</switch>
|
||||
</channel>
|
||||
|
||||
<channel name="Engine 1 Pipes">
|
||||
<summer name="tank0 tank1 tank 2 to tank3">
|
||||
<input>fuel/from-tank0-to-tank3</input>
|
||||
<input>fuel/from-tank1-to-tank3</input>
|
||||
<input>fuel/from-tank2-to-tank3</input>
|
||||
<output>propulsion/tank[3]/external-flow-rate-pps</output>
|
||||
</summer>
|
||||
</channel>
|
||||
|
||||
<channel name="Engine 2 Pipes">
|
||||
<summer name="tank0 tank1 tank 2 to tank4">
|
||||
<input>fuel/from-tank2-to-tank4</input>
|
||||
<input>fuel/from-tank1-to-tank4</input>
|
||||
<input>fuel/from-tank0-to-tank4</input>
|
||||
<output>propulsion/tank[4]/external-flow-rate-pps</output>
|
||||
</summer>
|
||||
</channel>
|
||||
|
||||
<channel name="Total PPS">
|
||||
<summer name="fuel/tank0-flow-rate">
|
||||
<input>-fuel/from-tank0-to-tank3</input>
|
||||
<input>-fuel/from-tank0-to-tank4</input>
|
||||
<output>propulsion/tank[0]/external-flow-rate-pps</output>
|
||||
</summer>
|
||||
|
||||
<summer name="fuel/tank1-flow-rate">
|
||||
<input>-fuel/from-tank1-to-tank3</input>
|
||||
<input>-fuel/from-tank1-to-tank4</input>
|
||||
<output>propulsion/tank[1]/external-flow-rate-pps</output>
|
||||
</summer>
|
||||
|
||||
<summer name="fuel/tank2-flow-rate">
|
||||
<input>-fuel/from-tank2-to-tank4</input>
|
||||
<input>-fuel/from-tank2-to-tank3</input>
|
||||
<output>propulsion/tank[2]/external-flow-rate-pps</output>
|
||||
</summer>
|
||||
</channel>
|
||||
|
||||
</system>
|
|
@ -1 +1 @@
|
|||
8
|
||||
9
|
Loading…
Add table
Reference in a new issue