1
0
Fork 0
fgdata/Aircraft/Instruments-3d/FG1000/Nasal/MFD.nas

157 lines
4.3 KiB
Text
Raw Normal View History

2017-11-24 23:04:46 +00:00
# FG1000 MFD
print("##############");
print("# FG1000 MFD #");
print("##############\n");
io.include("constants.nas");
2017-11-24 23:04:46 +00:00
var nasal_dir = getprop("/sim/fg-root") ~ "/Aircraft/Instruments-3d/FG1000/Nasal/";
io.load_nasal(nasal_dir ~ '/MFDPage.nas', "fg1000");
io.load_nasal(nasal_dir ~ '/MFDPageController.nas', "fg1000");
var MFDPages = [
"Surround",
"NavigationMap",
"EIS",
"TrafficMap",
"Stormscope",
"WeatherDataLink",
"TAWSB",
"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");
}
2017-11-24 23:04:46 +00:00
var MFD =
{
new : func (myCanvas)
{
var obj = {
parents : [ MFD ],
EIS : nil,
NavigationMap: nil,
Surround : nil,
};
2017-11-24 23:04:46 +00:00
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});
2017-11-24 23:04:46 +00:00
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
2017-11-24 23:04:46 +00:00
# of page groups and individual pages using the FMS controller.
obj.Surround = fg1000.Surround.new(obj, myCanvas, obj._MFDDevice, obj._svg);
obj.SurroundController = obj.Surround.controller;
2017-11-24 23:04:46 +00:00
# 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();
}
}
2017-11-24 23:04:46 +00:00
# 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);
2017-11-24 23:04:46 +00:00
2017-11-24 23:04:46 +00:00
# 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);
2017-11-24 23:04:46 +00:00
} else {
obj._MFDDevice.current_page.controller.handleFMSInner(-1);
2017-11-24 23:04:46 +00:00
}
});
return obj;
},
getDevice : func () {
return me._MFDDevice;
},
2017-11-24 23:04:46 +00:00
del: func()
{
me._MFDDevice.current_page.offdisplay();
me._MFDDevice.DeRegisterWithEmesary();
me.SurroundController.del();
},
setPageTitle: func(title)
{
me._pageTitle.setText(title);
2017-11-24 23:04:46 +00:00
}
};