Fix bugs with approach, protection bars fully work, go-around still buggy
This commit is contained in:
parent
b163a833cf
commit
30497a8cf2
4 changed files with 5512 additions and 5479 deletions
|
@ -1687,9 +1687,9 @@ var canvas_MCDU_base = {
|
|||
} else {
|
||||
me["Simple_L1"].setText("SELECTED");
|
||||
if (getprop("it-autoflight/input/kts-mach")) {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
|
||||
} else {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
|
||||
}
|
||||
me.fontLeft(0, 0, 0, default, 0, 0);
|
||||
}
|
||||
|
@ -1830,9 +1830,9 @@ var canvas_MCDU_base = {
|
|||
} else {
|
||||
me["Simple_L1"].setText("SELECTED");
|
||||
if (getprop("it-autoflight/input/kts-mach")) {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
|
||||
} else {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
|
||||
}
|
||||
me.fontLeft(0, 0, 0, default, 0, 0);
|
||||
}
|
||||
|
@ -1980,9 +1980,9 @@ var canvas_MCDU_base = {
|
|||
} else {
|
||||
me["Simple_L1"].setText("SELECTED");
|
||||
if (getprop("it-autoflight/input/kts-mach")) {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
|
||||
} else {
|
||||
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts"))));
|
||||
me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
|
||||
}
|
||||
me.fontLeft(0, 0, 0, default, 0, 0);
|
||||
}
|
||||
|
|
|
@ -215,7 +215,7 @@ var canvas_PFD_base = {
|
|||
getKeys: func() {
|
||||
return ["FMA_man","FMA_manmode","FMA_flxmode","FMA_flxtemp","FMA_thrust","FMA_lvrclb","FMA_pitch","FMA_pitcharm","FMA_pitcharm2","FMA_roll","FMA_rollarm","FMA_combined","FMA_ctr_msg","FMA_catmode","FMA_cattype","FMA_nodh","FMA_dh","FMA_dhn","FMA_ap","FMA_fd","FMA_athr",
|
||||
"FMA_man_box","FMA_flx_box","FMA_thrust_box","FMA_pitch_box","FMA_pitcharm_box","FMA_roll_box","FMA_rollarm_box","FMA_combined_box","FMA_catmode_box","FMA_cattype_box","FMA_cat_box","FMA_dh_box","FMA_ap_box","FMA_fd_box","FMA_athr_box","FMA_Middle1",
|
||||
"FMA_Middle2","ALPHA_MAX","ALPHA_PROT","ALPHA_SW","VLS_min","ASI_max","ASI_scale","ASI_target","ASI_mach","ASI_mach_decimal","ASI_trend_up","ASI_trend_down","ASI_digit_UP","ASI_digit_DN","ASI_decimal_UP","ASI_decimal_DN","ASI_index","ASI_error","ASI_group","ASI_frame","AI_center","AI_bank",
|
||||
"FMA_Middle2","ALPHA_MAX","ALPHA_PROT","ALPHA_SW","ALPHA_clip","VLS_min","ASI_max","ASI_scale","ASI_target","ASI_mach","ASI_mach_decimal","ASI_trend_up","ASI_trend_down","ASI_digit_UP","ASI_digit_DN","ASI_decimal_UP","ASI_decimal_DN","ASI_index","ASI_error","ASI_group","ASI_frame","AI_center","AI_bank",
|
||||
"AI_bank_lim","AI_bank_lim_X","AI_pitch_lim","AI_pitch_lim_X","AI_slipskid","AI_horizon","AI_horizon_ground","AI_horizon_sky","AI_stick","AI_stick_pos","AI_heading","AI_agl_g","AI_agl","AI_error","AI_group","FD_roll","FD_pitch","ALT_box_flash","ALT_box","ALT_box_amber",
|
||||
"ALT_scale","ALT_target","ALT_target_digit","ALT_one","ALT_two","ALT_three","ALT_four","ALT_five","ALT_digits","ALT_tens","ALT_digit_UP","ALT_digit_DN","ALT_error","ALT_group","ALT_group2","ALT_frame","VS_pointer","VS_box","VS_digit","VS_error","VS_group","QNH","QNH_setting",
|
||||
"QNH_std","QNH_box","LOC_pointer","LOC_scale","GS_scale","GS_pointer","CRS_pointer","HDG_target","HDG_scale","HDG_one","HDG_two","HDG_three","HDG_four","HDG_five","HDG_six","HDG_seven","HDG_digit_L","HDG_digit_R","HDG_error","HDG_group","HDG_frame",
|
||||
|
@ -1106,6 +1106,10 @@ var canvas_PFD_1 = {
|
|||
me["ASI_error"].hide();
|
||||
me["ASI_frame"].setColor(1,1,1);
|
||||
me["ASI_group"].show();
|
||||
me["VLS_min"].hide();
|
||||
me["ALPHA_PROT"].hide();
|
||||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].hide();
|
||||
|
||||
if (ind_spd <= 30) {
|
||||
me.ASI = 0;
|
||||
|
@ -1136,7 +1140,7 @@ var canvas_PFD_1 = {
|
|||
} else {
|
||||
me.VLSmin = me.FMGC_vls - 30 - me.ASI;
|
||||
}
|
||||
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/vls_min") * 0.95;
|
||||
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/alpha_prot");
|
||||
if (me.FMGC_prot <= 30) {
|
||||
me.ALPHAprot = 0 - me.ASI;
|
||||
} else if (me.FMGC_prot >= 420) {
|
||||
|
@ -1144,7 +1148,7 @@ var canvas_PFD_1 = {
|
|||
} else {
|
||||
me.ALPHAprot = me.FMGC_prot - 30 - me.ASI;
|
||||
}
|
||||
me.FMGC_max = getprop("FMGC/internal/computed-speeds/vls_min") * 0.90;
|
||||
me.FMGC_max = getprop("FMGC/internal/computed-speeds/alpha_max");
|
||||
if (me.FMGC_max <= 30) {
|
||||
me.ALPHAmax = 0 - me.ASI;
|
||||
} else if (me.FMGC_max >= 420) {
|
||||
|
@ -1154,8 +1158,8 @@ var canvas_PFD_1 = {
|
|||
}
|
||||
me["VLS_min"].setTranslation(0, me.VLSmin * -6.6);
|
||||
me["VLS_min"].show();
|
||||
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6); #CHANGE LATER
|
||||
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6); #CHANGE LATER
|
||||
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6);
|
||||
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6);
|
||||
if (getprop("it-fbw/law") == 0) {
|
||||
me["ALPHA_PROT"].show();
|
||||
me["ALPHA_MAX"].show();
|
||||
|
@ -1165,15 +1169,10 @@ var canvas_PFD_1 = {
|
|||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].show();
|
||||
}
|
||||
} else {
|
||||
me["VLS_min"].hide();
|
||||
me["ALPHA_PROT"].hide();
|
||||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].hide();
|
||||
}
|
||||
|
||||
if (managed_spd.getValue() == 1) {
|
||||
if (FMGCphase.getValue() == 5) {
|
||||
if (getprop("FMGC/internal/decel") == 1) {
|
||||
vapp = getprop("FMGC/internal/computed-speeds/vapp");
|
||||
tgt_ias = vapp;
|
||||
tgt_kts = vapp;
|
||||
|
@ -1809,6 +1808,10 @@ var canvas_PFD_2 = {
|
|||
me["ASI_error"].hide();
|
||||
me["ASI_frame"].setColor(1,1,1);
|
||||
me["ASI_group"].show();
|
||||
me["VLS_min"].hide();
|
||||
me["ALPHA_PROT"].hide();
|
||||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].hide();
|
||||
|
||||
if (ind_spd <= 30) {
|
||||
me.ASI = 0;
|
||||
|
@ -1839,7 +1842,7 @@ var canvas_PFD_2 = {
|
|||
} else {
|
||||
me.VLSmin = me.FMGC_vls - 30 - me.ASI;
|
||||
}
|
||||
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/vls_min") * 0.95;
|
||||
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/alpha_prot");
|
||||
if (me.FMGC_prot <= 30) {
|
||||
me.ALPHAprot = 0 - me.ASI;
|
||||
} else if (me.FMGC_prot >= 420) {
|
||||
|
@ -1847,7 +1850,7 @@ var canvas_PFD_2 = {
|
|||
} else {
|
||||
me.ALPHAprot = me.FMGC_prot - 30 - me.ASI;
|
||||
}
|
||||
me.FMGC_max = getprop("FMGC/internal/computed-speeds/vls_min") * 0.90;
|
||||
me.FMGC_max = getprop("FMGC/internal/computed-speeds/alpha_max");
|
||||
if (me.FMGC_max <= 30) {
|
||||
me.ALPHAmax = 0 - me.ASI;
|
||||
} else if (me.FMGC_max >= 420) {
|
||||
|
@ -1857,8 +1860,8 @@ var canvas_PFD_2 = {
|
|||
}
|
||||
me["VLS_min"].setTranslation(0, me.VLSmin * -6.6);
|
||||
me["VLS_min"].show();
|
||||
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6); #CHANGE LATER
|
||||
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6); #CHANGE LATER
|
||||
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6);
|
||||
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6);
|
||||
if (getprop("it-fbw/law") == 0) {
|
||||
me["ALPHA_PROT"].show();
|
||||
me["ALPHA_MAX"].show();
|
||||
|
@ -1868,15 +1871,10 @@ var canvas_PFD_2 = {
|
|||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].show();
|
||||
}
|
||||
} else {
|
||||
me["VLS_min"].hide();
|
||||
me["ALPHA_PROT"].hide();
|
||||
me["ALPHA_MAX"].hide();
|
||||
me["ALPHA_SW"].hide();
|
||||
}
|
||||
|
||||
if (managed_spd.getValue() == 1) {
|
||||
if (FMGCphase.getValue() == 5) {
|
||||
if (getprop("FMGC/internal/decel") == 1) {
|
||||
vapp = getprop("FMGC/internal/computed-speeds/vapp");
|
||||
tgt_ias = vapp;
|
||||
tgt_kts = vapp;
|
||||
|
|
File diff suppressed because it is too large
Load diff
Before Width: | Height: | Size: 364 KiB After Width: | Height: | Size: 361 KiB |
|
@ -246,30 +246,32 @@ var masterFMGC = maketimer(0.2, func {
|
|||
setprop("systems/pressurization/mode", "DE");
|
||||
}
|
||||
|
||||
if (aglalt < 7200 and (phase == "4" or mode == "G/S" or mode == "LAND" or mode == "FLARE")) {
|
||||
if (!wowl and !wowr and aglalt < 7200 and (phase == "4" or mode == "G/S" or mode == "LAND" or mode == "FLARE")) {
|
||||
setprop("FMGC/status/phase", 5);
|
||||
}
|
||||
|
||||
if (getprop("autopilot/route-manager/route/num") > 0 and getprop("autopilot/route-manager/active") == 1 and getprop("autopilot/route-manager/distance-remaining-nm") <= 15) {
|
||||
setprop("FMGC/internal/decel", 1);
|
||||
setprop("FMGC/status/phase", 5);
|
||||
} else if (getprop("FMGC/internal/decel") == 1 and (phase == 0 or phase == 6)) {
|
||||
setprop("FMGC/internal/decel", 0);
|
||||
}
|
||||
|
||||
if (phase == "5" and state1 == "TOGA" and state2 == "TOGA") {
|
||||
#handle go-around
|
||||
if ((phase == "5" or phase == "7") and state1 == "TOGA" and state2 == "TOGA") {
|
||||
setprop("FMGC/status/phase", 6);
|
||||
# set speed to green dot here
|
||||
setprop("systems/pressurization/mode", "TO");
|
||||
setprop("it-autoflight/input/toga", 1);
|
||||
}
|
||||
|
||||
#handle go-around
|
||||
if (phase == "6" and alt >= reduc_agl_ft) {
|
||||
setprop("FMGC/status/phase", 2);
|
||||
}
|
||||
|
||||
if (wowl and wowr and gs <= 40 and (phase == "2" or phase == "3" or phase == "4" or phase == "5" or phase == "6") and ap1 == 0 and ap2 == 0) {
|
||||
if (wowl and wowr and (phase == "2" or phase == "3" or phase == "4" or phase == "5" or phase == "6")) {
|
||||
setprop("FMGC/status/phase", 7);
|
||||
}
|
||||
|
||||
if (wowl and wowr and gs <= 40 and phase == "7" and ap1 == 0 and ap2 == 0) {
|
||||
reset_FMGC();
|
||||
}
|
||||
|
||||
|
@ -321,6 +323,15 @@ var masterFMGC = maketimer(0.2, func {
|
|||
}
|
||||
}
|
||||
|
||||
aoa_prot = 15;
|
||||
aoa_max = 17.5;
|
||||
aoa_0 = -5;
|
||||
aoa = getprop("systems/navigation/adr/output/aoa-1");
|
||||
cas = getprop("systems/navigation/adr/output/cas-1");
|
||||
|
||||
alpha_prot = cas * math.sqrt((aoa - aoa_0)/(aoa_prot - aoa_0));
|
||||
alpha_max = cas * math.sqrt((aoa - aoa_0)/(aoa_max - aoa_0));
|
||||
|
||||
# predicted to speeds
|
||||
clean_to = 2 * tow * 0.45359237 + 85;
|
||||
if (altitude > 20000) {
|
||||
|
@ -374,6 +385,8 @@ var masterFMGC = maketimer(0.2, func {
|
|||
setprop("FMGC/internal/computed-speeds/flap3", flap3);
|
||||
setprop("FMGC/internal/computed-speeds/vls", vls);
|
||||
setprop("FMGC/internal/computed-speeds/vapp", vapp);
|
||||
setprop("FMGC/internal/computed-speeds/alpha_prot", alpha_prot);
|
||||
setprop("FMGC/internal/computed-speeds/alpha_max", alpha_max);
|
||||
|
||||
setprop("FMGC/internal/computed-speeds/vs1g_clean_to", vs1g_clean_to);
|
||||
setprop("FMGC/internal/computed-speeds/vs1g_conf_2_to", vs1g_conf_2_to);
|
||||
|
@ -393,18 +406,30 @@ var masterFMGC = maketimer(0.2, func {
|
|||
setprop("FMGC/internal/computed-speeds/vls_appr", vls_appr);
|
||||
setprop("FMGC/internal/computed-speeds/vapp_appr", vapp_appr);
|
||||
|
||||
if (flap == 0) { # 0
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.23);
|
||||
} else if (flap == 1) { # 1
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1 * 1.23);
|
||||
} else if (flap == 2) { # 1+F
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1f * 1.23);
|
||||
} else if (flap == 3) { # 2
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_2 * 1.23);
|
||||
} else if (flap == 4) { # 3
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_3 * 1.23);;
|
||||
} else if (flap == 5) { # FULL
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_full * 1.23);
|
||||
# Need info on these, also correct for height at altitude...
|
||||
# https://www.pprune.org/archive/index.php/t-587639.html
|
||||
if (getprop("FMGC/status/to-state") == 1) {
|
||||
if (flap == 0) { # 0
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.28);
|
||||
} else if (flap == 1) { # 1
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1 * 1.23);
|
||||
} else { # 1+F
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.13);
|
||||
}
|
||||
} else {
|
||||
if (flap == 0) { # 0
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.23);
|
||||
} else if (flap == 1) { # 1
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1 * 1.23);
|
||||
} else if (flap == 2) { # 1+F
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1f * 1.23);
|
||||
} else if (flap == 3) { # 2
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_2 * 1.23);
|
||||
} else if (flap == 4) { # 3
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_3 * 1.23);;
|
||||
} else if (flap == 5) { # FULL
|
||||
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_full * 1.23);
|
||||
}
|
||||
}
|
||||
|
||||
if (flap == 0) { # 0
|
||||
|
|
Loading…
Add table
Reference in a new issue