73424c1791
- Add new Emesary notification type for NAV/COM data - Create Update/Publish interfaces using Emesary from properties - Use interfaces to drive updates to EIS and NAV/COM frequencies - Change the PageGroupController to a "proper" MFD page
152 lines
4.2 KiB
Text
152 lines
4.2 KiB
Text
# FG1000 MFD
|
|
|
|
print("##############");
|
|
print("# FG1000 MFD #");
|
|
print("##############\n");
|
|
|
|
io.include("constants.nas");
|
|
|
|
var nasal_dir = getprop("/sim/fg-root") ~ "/Aircraft/Instruments-3d/FG1000/Nasal/";
|
|
|
|
io.load_nasal(nasal_dir ~ '/MFDPage.nas', "fg1000");
|
|
|
|
var MFDPages = [
|
|
"Surround",
|
|
"NavigationMap",
|
|
"EIS",
|
|
"TrafficMap",
|
|
"Stormscope",
|
|
"WeatherDataLink",
|
|
"TAWS",
|
|
"AirportInfo",
|
|
"AirportDirectory",
|
|
"AirportDeparture",
|
|
"AirportArrival",
|
|
"AirportApproach",
|
|
"AirportWeather",
|
|
"IntersectionInfo",
|
|
"NDBInfo",
|
|
"VORInfo",
|
|
"UserWPTInfo",
|
|
"TripPlanning",
|
|
"Utility",
|
|
"GPSStatus",
|
|
"XMRadio",
|
|
"XMInfo",
|
|
"SystemStatus",
|
|
"ActiveFlightPlanWide",
|
|
"ActiveFlightPlanNarrow",
|
|
"FlightPlanCatalog",
|
|
"StoredFlightPlan",
|
|
"Checklist1",
|
|
"Checklist2",
|
|
"Checklist3",
|
|
"Checklist4",
|
|
"Checklist5",
|
|
"NearestAirports",
|
|
"NearestIntersections",
|
|
"NearestNDB",
|
|
"NearestVOR",
|
|
"NearestUserWPT",
|
|
"NearestFrequencies",
|
|
"NearestAirspaces"
|
|
];
|
|
|
|
foreach (var page; MFDPages) {
|
|
io.load_nasal(nasal_dir ~ page ~ '/' ~ page ~ '.nas', "fg1000");
|
|
io.load_nasal(nasal_dir ~ page ~ '/' ~ page ~ 'Styles.nas', "fg1000");
|
|
io.load_nasal(nasal_dir ~ page ~ '/' ~ page ~ 'Options.nas', "fg1000");
|
|
io.load_nasal(nasal_dir ~ page ~ '/' ~ page ~ 'Controller.nas', "fg1000");
|
|
}
|
|
|
|
var MFD =
|
|
{
|
|
new : func (myCanvas)
|
|
{
|
|
var obj = {
|
|
parents : [ MFD ],
|
|
EIS : nil,
|
|
NavigationMap: nil,
|
|
Surround : nil,
|
|
};
|
|
|
|
obj._svg = myCanvas.createGroup("softkeys");
|
|
|
|
var fontmapper = func (family, weight) {
|
|
#if( family == "Liberation Sans" and weight == "narrow" ) {
|
|
return "LiberationFonts/LiberationSansNarrow-Regular.ttf";
|
|
#}
|
|
# If we don't return anything the default font is used
|
|
};
|
|
|
|
foreach (var page; MFDPages) {
|
|
var svg_file ='/Aircraft/Instruments-3d/FG1000/Models/' ~ page ~ '.svg';
|
|
if (resolvepath(svg_file) != "") {
|
|
# Load an SVG file if available.
|
|
canvas.parsesvg(obj._svg,
|
|
svg_file,
|
|
{'font-mapper': fontmapper});
|
|
}
|
|
}
|
|
|
|
canvas.parsesvg(obj._svg,
|
|
'/Aircraft/Instruments-3d/FG1000/Models/MFD.svg',
|
|
{'font-mapper': fontmapper});
|
|
|
|
obj._MFDDevice = canvas.PFD_Device.new(obj._svg, 12, "SoftKey", myCanvas, "MFD");
|
|
obj._MFDDevice.RegisterWithEmesary();
|
|
|
|
# Surround dynamic elements
|
|
obj._pageTitle = obj._svg.getElementById("PageTitle");
|
|
|
|
# Controller for the header and display on the bottom left which allows selection
|
|
# of page groups and individual pages using the FMS controller.
|
|
obj.Surround = fg1000.Surround.new(obj, myCanvas, obj._MFDDevice, obj._svg);
|
|
obj._pageGroupController = obj.Surround.controller;
|
|
|
|
# Engine Information System. A special case as it's always displayed on the MFD.
|
|
obj.EIS = obj.Surround.addPage("EIS", fg1000.EIS.new(obj, myCanvas, obj._MFDDevice, obj._svg));
|
|
|
|
# The NavigationMap page is a special case, as it is displayed with the Nearest... pages as an overlay
|
|
obj.NavigationMap = obj.Surround.addPage("NavigationMap", fg1000.NavigationMap.new(obj, myCanvas, obj._MFDDevice, obj._svg));
|
|
obj.NavigationMap.topMenu(obj._MFDDevice, obj.NavigationMap, nil);
|
|
|
|
foreach (var page; MFDPages) {
|
|
if ((page != "NavigationMap") and (page != "EIS")) {
|
|
var code = "obj.Surround.addPage(\"" ~ page ~ "\", fg1000." ~ page ~ ".new(obj, myCanvas, obj._MFDDevice, obj._svg));";
|
|
var addPageFn = compile(code);
|
|
addPageFn();
|
|
}
|
|
}
|
|
|
|
# Display the Surround, EIS and NavMap and the appropriate top level on startup.
|
|
obj.Surround.setVisible(1);
|
|
obj.EIS.setVisible(1);
|
|
obj.EIS.ondisplay();
|
|
obj._MFDDevice.selectPage(obj.NavigationMap);
|
|
|
|
|
|
# Add a wheel controller., which we will attach to the zoom.
|
|
myCanvas.addEventListener("wheel", func(e)
|
|
{
|
|
if (e.deltaY >0) {
|
|
obj._MFDDevice.current_page.controller.handleFMSInner(1);
|
|
} else {
|
|
obj._MFDDevice.current_page.controller.handleFMSInner(-1);
|
|
}
|
|
});
|
|
|
|
return obj;
|
|
},
|
|
del: func()
|
|
{
|
|
me._MFDDevice.current_page.offdisplay();
|
|
me._MFDDevice.DeRegisterWithEmesary();
|
|
me._pageGroupController.del();
|
|
|
|
},
|
|
setPageTitle: func(title)
|
|
{
|
|
me._pageTitle.setText(title);
|
|
}
|
|
};
|