2018-02-09 18:55:53 +00:00
|
|
|
# Copyright 2018 Stuart Buchanan
|
|
|
|
# This file is part of FlightGear.
|
|
|
|
#
|
2018-05-28 20:15:57 +01:00
|
|
|
# FlightGear is free software: you can redistribute it and/or modify
|
2018-02-09 18:55:53 +00:00
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 2 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# FlightGear is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with FlightGear. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
2017-12-10 22:15:21 +00:00
|
|
|
# NearestNDB
|
|
|
|
var NearestNDB =
|
|
|
|
{
|
|
|
|
new : func (mfd, myCanvas, device, svg)
|
|
|
|
{
|
|
|
|
var obj = {
|
2017-12-27 19:51:54 +00:00
|
|
|
parents : [
|
|
|
|
NearestNDB,
|
|
|
|
MFDPage.new(mfd, myCanvas, device, svg, "NearestNDB", "NRST - NEAREST NDB")
|
|
|
|
],
|
2017-12-10 22:15:21 +00:00
|
|
|
};
|
|
|
|
|
2018-01-26 19:06:06 +00:00
|
|
|
obj.setController(fg1000.NearestNDBController.new(obj, svg));
|
2017-12-27 19:51:54 +00:00
|
|
|
|
2018-02-02 16:06:42 +00:00
|
|
|
# Dynamic elements. There is a single dynamic element containing the list of
|
|
|
|
# the 25 nearest intersections.
|
|
|
|
obj.select = PFD.GroupElement.new(
|
|
|
|
obj.pageName,
|
|
|
|
svg,
|
|
|
|
[ "Arrow", "ID", "CRS", "DST"],
|
|
|
|
11,
|
|
|
|
"Arrow",
|
|
|
|
1,
|
|
|
|
"ScrollTrough",
|
|
|
|
"ScrollThumb",
|
|
|
|
250 - 116
|
|
|
|
);
|
|
|
|
|
|
|
|
# Other dynamic text elements
|
|
|
|
obj.addTextElements(["Lat", "Lon", "Name", "Freq"]);
|
|
|
|
|
|
|
|
obj.topMenu(device, obj, nil);
|
|
|
|
|
2017-12-10 22:15:21 +00:00
|
|
|
return obj;
|
|
|
|
},
|
2018-02-02 16:06:42 +00:00
|
|
|
|
|
|
|
# Indicate which group is selected by colour of the softkeys
|
|
|
|
display_toggle : func(device, svg, mi, group) {
|
|
|
|
var bg_name = sprintf("SoftKey%d-bg",mi.menu_id);
|
|
|
|
if (me.getController().getSelectedGroup() == group) {
|
|
|
|
device.svg.getElementById(bg_name).setColorFill(0.5,0.5,0.5);
|
|
|
|
svg.setColor(0.0,0.0,0.0);
|
|
|
|
} else {
|
|
|
|
device.svg.getElementById(bg_name).setColorFill(0.0,0.0,0.0);
|
|
|
|
svg.setColor(1.0,1.0,1.0);
|
|
|
|
}
|
|
|
|
svg.setText(mi.title);
|
|
|
|
svg.setVisible(1); # display function
|
|
|
|
},
|
|
|
|
|
|
|
|
showCRSR : func() {
|
|
|
|
me.select.showCRSR();
|
|
|
|
},
|
|
|
|
|
|
|
|
hideCRSR : func() {
|
|
|
|
me.select.hideCRSR();
|
|
|
|
},
|
|
|
|
|
2017-12-10 22:15:21 +00:00
|
|
|
offdisplay : func() {
|
2018-02-02 16:06:42 +00:00
|
|
|
# The Nearest... pages use the underlying navigation map.
|
|
|
|
me.mfd.NavigationMap.offdisplayPartial();
|
2017-12-10 22:15:21 +00:00
|
|
|
|
|
|
|
# Reset the menu colours. Shouldn't have to do this here, but
|
|
|
|
# there's not currently an obvious other location to do so.
|
2018-02-02 16:06:42 +00:00
|
|
|
me.resetMenuColors();
|
|
|
|
|
2018-01-26 19:06:06 +00:00
|
|
|
me.getController().offdisplay();
|
2017-12-10 22:15:21 +00:00
|
|
|
},
|
|
|
|
ondisplay : func() {
|
2018-01-26 19:06:06 +00:00
|
|
|
me.getController().ondisplay();
|
2018-02-02 16:06:42 +00:00
|
|
|
|
|
|
|
# The Nearest... pages use the underlying navigation map.
|
|
|
|
me.mfd.NavigationMap.ondisplayPartial();
|
|
|
|
|
|
|
|
me.mfd.setPageTitle(me.title);
|
2017-12-10 22:15:21 +00:00
|
|
|
},
|
2018-02-02 16:06:42 +00:00
|
|
|
updateNavData : func(navdata) {
|
|
|
|
|
|
|
|
if ((navdata == nil) or (size(navdata) == 0)) return;
|
|
|
|
|
|
|
|
var navDataList = [];
|
|
|
|
for (var i = 0; i < size(navdata); i = i + 1) {
|
|
|
|
var nav = navdata[i];
|
|
|
|
var crsAndDst = courseAndDistance(nav);
|
|
|
|
|
|
|
|
# Display the course and distance in NM .
|
|
|
|
# 248 is the extended ASCII code for the degree symbol
|
2018-04-16 13:38:41 +01:00
|
|
|
var crs = sprintf("%i°", crsAndDst[0]);
|
2018-02-02 16:06:42 +00:00
|
|
|
var dst = sprintf("%.1fnm", crsAndDst[1]);
|
|
|
|
|
|
|
|
# Convert into something we can pass straight to the UIGroup.
|
|
|
|
append(navDataList, {
|
|
|
|
Arrow : nav.id,
|
|
|
|
ID: nav.id,
|
|
|
|
CRS: crs,
|
|
|
|
DST: dst,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
me.select.setValues(navDataList);
|
|
|
|
|
|
|
|
if (size(navDataList) > 0) {
|
|
|
|
me.updateNavDataItem(navdata[0]);
|
|
|
|
} else {
|
|
|
|
me.setTextElement("Name", "NONE WITHIN 200NM");
|
2018-04-16 13:38:41 +01:00
|
|
|
me.setTextElementLon("Lon", "");
|
|
|
|
me.setTextElementLat("Lat", "");
|
|
|
|
me.setTextElementNavFreq("Freq", "");
|
2018-02-02 16:06:42 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
updateNavDataItem : func(nav) {
|
|
|
|
|
|
|
|
if (nav == nil) return;
|
|
|
|
|
|
|
|
|
2018-04-16 13:38:41 +01:00
|
|
|
me.setTextElementLat("Lat", nav.lat);
|
|
|
|
me.setTextElementLon("Lon", nav.lon);
|
|
|
|
me.setTextElementNavFreq("Freq", nav.frequency / 100.0);
|
2018-02-02 16:06:42 +00:00
|
|
|
me.setTextElement("Name", nav.name);
|
|
|
|
|
|
|
|
# Display the DTO line to the airport
|
|
|
|
me.mfd.NavigationMap.getController().setDTOLineTarget(nav.lat, nav.lon);
|
|
|
|
},
|
|
|
|
|
2018-01-13 18:53:06 +00:00
|
|
|
topMenu : func(device, pg, menuitem) {
|
|
|
|
pg.clearMenu();
|
|
|
|
pg.resetMenuColors();
|
2018-02-02 16:06:42 +00:00
|
|
|
pg.addMenuItem(0, "ENGINE", pg.mfd.EIS, pg.mfd.EIS.engineMenu);
|
|
|
|
pg.addMenuItem(2, "MAP", pg.mfd.NavigationMap, pg.mfd.NavigationMap.mapMenu);
|
|
|
|
|
2018-01-13 18:53:06 +00:00
|
|
|
device.updateMenus();
|
|
|
|
},
|
2017-12-10 22:15:21 +00:00
|
|
|
};
|