add VNAV to FMA, fix autothrottle
This commit is contained in:
parent
59870ebb44
commit
ed16358d5f
3 changed files with 134 additions and 107 deletions
|
@ -237,8 +237,8 @@
|
|||
<kp-cws>0.09</kp-cws>
|
||||
</roll>
|
||||
<pitch>
|
||||
<umin>-0.30</umin>
|
||||
<umax>0.30</umax>
|
||||
<umin>-0.40</umin>
|
||||
<umax>0.40</umax>
|
||||
<kp>-0.04</kp>
|
||||
<ti>10.0</ti>
|
||||
<td>0.0001</td>
|
||||
|
@ -268,7 +268,7 @@
|
|||
<land-flap>0.645</land-flap> <!-- Minimum Flap used for Landing -->
|
||||
<retard-ft>40</retard-ft> <!-- Enable Thrust Retard -->
|
||||
<retard-enable>0</retard-enable> <!-- AGL to Thrust Retard -->
|
||||
<togaspd>157</togaspd> <!-- V2 + 10kts -->
|
||||
<togaspd>162</togaspd> <!-- V2 + 10kts -->
|
||||
<lat-agl-ft>100</lat-agl-ft> <!-- Set to 999999 if you do not want T/O to change automatically to HDG, or LNAV -->
|
||||
<reduc-agl-ft>1500</reduc-agl-ft> <!-- Set to 999999 if you do not want TOGA to change automatically to FLCH -->
|
||||
</settings>
|
||||
|
|
|
@ -3,152 +3,179 @@
|
|||
|
||||
# Speed or Mach?
|
||||
var speedmach = func {
|
||||
if ((getprop("/it-autoflight/output/vert") == 4) or (getprop("/it-autoflight/output/vert") == 6) or (getprop("/it-autoflight/output/vert") == 7)) {
|
||||
# Do nothing because it's in FLCH mode.
|
||||
} else {
|
||||
if (getprop("/it-autoflight/input/kts-mach") == 0) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "SPEED");
|
||||
} else if (getprop("/it-autoflight/input/kts-mach") == 1) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "MACH");
|
||||
}
|
||||
}
|
||||
if ((getprop("/it-autoflight/output/vert") == 4) or (getprop("/it-autoflight/output/vert") == 6) or (getprop("/it-autoflight/output/vert") == 7)) {
|
||||
# Do nothing because it's in FLCH mode.
|
||||
} else {
|
||||
if (getprop("/it-autoflight/input/kts-mach") == 0) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "SPEED");
|
||||
} else if (getprop("/it-autoflight/input/kts-mach") == 1) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "MACH");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
# Update Speed or Mach
|
||||
setlistener("/it-autoflight/input/kts-mach", func {
|
||||
speedmach();
|
||||
speedmach();
|
||||
});
|
||||
|
||||
# Master Thrust
|
||||
setlistener("/it-autoflight/output/thr-mode", func {
|
||||
var thr = getprop("/it-autoflight/output/thr-mode");
|
||||
if (thr == 0) {
|
||||
speedmach();
|
||||
} else if (thr == 1) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "THR IDLE");
|
||||
} else if (thr == 2) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "THR CLB");
|
||||
}
|
||||
var thr = getprop("/it-autoflight/output/thr-mode");
|
||||
if (thr == 0) {
|
||||
speedmach();
|
||||
} else if (thr == 1) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "THR IDLE");
|
||||
} else if (thr == 2) {
|
||||
setprop("/modes/pfd/fma/throttle-mode", "THR CLB");
|
||||
}
|
||||
});
|
||||
|
||||
# Master Lateral
|
||||
setlistener("/it-autoflight/mode/lat", func {
|
||||
var lat = getprop("/it-autoflight/mode/lat");
|
||||
if (lat == "HDG") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "HDG");
|
||||
} else if (lat == "LNAV") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "NAV");
|
||||
} else if (lat == "LOC") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "LOC");
|
||||
} else if (lat == "ALGN") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "LAND");
|
||||
} else if (lat == "T/O") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "RWY");
|
||||
}
|
||||
var lat = getprop("/it-autoflight/mode/lat");
|
||||
if (lat == "HDG") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "HDG");
|
||||
} else if (lat == "LNAV") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "NAV");
|
||||
} else if (lat == "LOC") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "LOC");
|
||||
} else if (lat == "ALGN") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "LAND");
|
||||
} else if (lat == "T/O") {
|
||||
setprop("/modes/pfd/fma/roll-mode", "RWY");
|
||||
}
|
||||
});
|
||||
|
||||
# Master Vertical
|
||||
setlistener("/it-autoflight/mode/vert", func {
|
||||
var vert = getprop("/it-autoflight/mode/vert");
|
||||
if (vert == "ALT HLD") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT HLD");
|
||||
} else if (vert == "ALT CAP") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT CAP");
|
||||
} else if (vert == "V/S") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "V/S");
|
||||
} else if (vert == "G/S") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "G/S");
|
||||
} else if (vert == "SPD CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "OP CLB");
|
||||
} else if (vert == "SPD DES") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "OP DES");
|
||||
} else if (vert == "FPA") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "FPA");
|
||||
} else if (vert == "LAND 3") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "LAND");
|
||||
} else if (vert == "FLARE") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "FLARE");
|
||||
} else if (vert == "T/O CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "SRS");
|
||||
} else if (vert == "G/A CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "SRS");
|
||||
}
|
||||
var vert = getprop("/it-autoflight/mode/vert");
|
||||
if (vert == "ALT HLD") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT");
|
||||
} else if (vert == "ALT CAP") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT");
|
||||
} else if (vert == "V/S") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "V/S");
|
||||
} else if (vert == "G/S") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "G/S");
|
||||
} else if (vert == "SPD CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "OP CLB");
|
||||
} else if (vert == "SPD DES") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "OP DES");
|
||||
} else if (vert == "FPA") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "FPA");
|
||||
} else if (vert == "LAND 3") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "LAND");
|
||||
} else if (vert == "FLARE") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "FLARE");
|
||||
} else if (vert == "T/O CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "SRS");
|
||||
} else if (vert == "G/A CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "SRS");
|
||||
}
|
||||
});
|
||||
|
||||
# Master VNAV
|
||||
setlistener("/it-autoflight/mode/prof", func {
|
||||
var prof = getprop("/it-autoflight/mode/prof");
|
||||
if (prof == "VNAV HLD") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT");
|
||||
} else if (prof == "VNAV CAP") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "ALT");
|
||||
} else if (prof == "VNAV SPD") {
|
||||
vnav_clbdes();
|
||||
} else if (prof == "VNAV PTH") {
|
||||
vnav_clbdes();
|
||||
}
|
||||
});
|
||||
|
||||
var vnav_clbdes = func {
|
||||
var vert = getprop("/it-autoflight/output/vert");
|
||||
if (vert == 8) {
|
||||
var prof = getprop("/it-autoflight/internal/prof-mode");
|
||||
if (prof == "XX") {
|
||||
# Do nothing
|
||||
} else if (prof == "DES") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "DES");
|
||||
} else if (prof == "CLB") {
|
||||
setprop("/modes/pfd/fma/pitch-mode", "CLB");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
# Arm LOC
|
||||
setlistener("/it-autoflight/output/loc-armed", func {
|
||||
var loca = getprop("/it-autoflight/output/loc-armed");
|
||||
if (loca) {
|
||||
setprop("/modes/pfd/fma/roll-mode-armed", "LOC");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/roll-mode-armed", " ");
|
||||
}
|
||||
var loca = getprop("/it-autoflight/output/loc-armed");
|
||||
if (loca) {
|
||||
setprop("/modes/pfd/fma/roll-mode-armed", "LOC");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/roll-mode-armed", " ");
|
||||
}
|
||||
});
|
||||
|
||||
# Arm G/S
|
||||
setlistener("/it-autoflight/output/appr-armed", func {
|
||||
var appa = getprop("/it-autoflight/output/appr-armed");
|
||||
if (appa) {
|
||||
setprop("/modes/pfd/fma/pitch-mode-armed", "G/S");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/pitch-mode-armed", " ");
|
||||
}
|
||||
var appa = getprop("/it-autoflight/output/appr-armed");
|
||||
if (appa) {
|
||||
setprop("/modes/pfd/fma/pitch-mode-armed", "G/S");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/pitch-mode-armed", " ");
|
||||
}
|
||||
});
|
||||
|
||||
# AP
|
||||
var ap = func {
|
||||
var ap1 = getprop("/it-autoflight/output/ap1");
|
||||
var ap2 = getprop("/it-autoflight/output/ap2");
|
||||
if (ap1 and ap2) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP1+2");
|
||||
} else if (ap1 and !ap2) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP1");
|
||||
} else if (ap2 and !ap1) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP2");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/ap-mode", " ");
|
||||
}
|
||||
var ap1 = getprop("/it-autoflight/output/ap1");
|
||||
var ap2 = getprop("/it-autoflight/output/ap2");
|
||||
if (ap1 and ap2) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP1+2");
|
||||
} else if (ap1 and !ap2) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP1");
|
||||
} else if (ap2 and !ap1) {
|
||||
setprop("/modes/pfd/fma/ap-mode", "AP2");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/ap-mode", " ");
|
||||
}
|
||||
}
|
||||
|
||||
# FD
|
||||
var fd = func {
|
||||
var fd1 = getprop("/it-autoflight/output/fd1");
|
||||
var fd2 = getprop("/it-autoflight/output/fd2");
|
||||
if (fd1 and fd2) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "1FD2");
|
||||
} else if (fd1 and !fd2) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "1FD-");
|
||||
} else if (fd2 and !fd1) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "-FD2");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/fd-mode", " ");
|
||||
}
|
||||
var fd1 = getprop("/it-autoflight/output/fd1");
|
||||
var fd2 = getprop("/it-autoflight/output/fd2");
|
||||
if (fd1 and fd2) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "1FD2");
|
||||
} else if (fd1 and !fd2) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "1FD-");
|
||||
} else if (fd2 and !fd1) {
|
||||
setprop("/modes/pfd/fma/fd-mode", "-FD2");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/fd-mode", " ");
|
||||
}
|
||||
}
|
||||
|
||||
# AT
|
||||
var at = func {
|
||||
var at = getprop("/it-autoflight/output/athr");
|
||||
if (at) {
|
||||
setprop("/modes/pfd/fma/at-mode", "A/THR");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/at-mode", " ");
|
||||
}
|
||||
var at = getprop("/it-autoflight/output/athr");
|
||||
if (at) {
|
||||
setprop("/modes/pfd/fma/at-mode", "A/THR");
|
||||
} else {
|
||||
setprop("/modes/pfd/fma/at-mode", " ");
|
||||
}
|
||||
}
|
||||
|
||||
# Update AP FD ATHR
|
||||
setlistener("/it-autoflight/output/ap1", func {
|
||||
ap();
|
||||
ap();
|
||||
});
|
||||
setlistener("/it-autoflight/output/ap2", func {
|
||||
ap();
|
||||
ap();
|
||||
});
|
||||
setlistener("/it-autoflight/output/fd1", func {
|
||||
fd();
|
||||
fd();
|
||||
});
|
||||
setlistener("/it-autoflight/output/fd2", func {
|
||||
fd();
|
||||
fd();
|
||||
});
|
||||
setlistener("/it-autoflight/output/athr", func {
|
||||
at();
|
||||
at();
|
||||
});
|
||||
|
||||
|
|
|
@ -42,7 +42,7 @@
|
|||
<property>/controls/engines/engine[0]/throttle-cmd</property>
|
||||
</output>
|
||||
<config>
|
||||
<Kp>0.01</Kp>
|
||||
<Kp>0.1</Kp>
|
||||
<beta>1.0</beta>
|
||||
<alpha>0.1</alpha>
|
||||
<gamma>0.0</gamma>
|
||||
|
@ -90,7 +90,7 @@
|
|||
<property>/controls/engines/engine[0]/throttle-cmd</property>
|
||||
</output>
|
||||
<config>
|
||||
<Kp>0.01</Kp>
|
||||
<Kp>0.1</Kp>
|
||||
<beta>1.0</beta>
|
||||
<alpha>0.1</alpha>
|
||||
<gamma>0.0</gamma>
|
||||
|
@ -218,7 +218,7 @@
|
|||
<property>/controls/engines/engine[1]/throttle-cmd</property>
|
||||
</output>
|
||||
<config>
|
||||
<Kp>0.01</Kp>
|
||||
<Kp>0.1</Kp>
|
||||
<beta>1.0</beta>
|
||||
<alpha>0.1</alpha>
|
||||
<gamma>0.0</gamma>
|
||||
|
@ -266,7 +266,7 @@
|
|||
<property>/controls/engines/engine[1]/throttle-cmd</property>
|
||||
</output>
|
||||
<config>
|
||||
<Kp>0.01</Kp>
|
||||
<Kp>0.1</Kp>
|
||||
<beta>1.0</beta>
|
||||
<alpha>0.1</alpha>
|
||||
<gamma>0.0</gamma>
|
||||
|
|
Reference in a new issue