2014-04-28 21:26:32 -05:00
|
|
|
# WARNING: *.model files will be deprecated, see: http://wiki.flightgear.org/MapStructure
|
2013-12-04 23:19:22 +01:00
|
|
|
var StormModel = {};
|
|
|
|
StormModel.new = func make( LayerModel, StormModel );
|
|
|
|
|
|
|
|
StormModel.init = func {
|
|
|
|
me._view.reset(); # wraps removeAllChildren() ATM
|
|
|
|
|
|
|
|
foreach (var n; props.globals.getNode("/instrumentation/wxradar",1).getChildren("storm")) {
|
|
|
|
# Model 3 degree radar beam
|
|
|
|
var stormLat = n.getNode("latitude-deg").getValue();
|
2014-05-25 13:11:13 -05:00
|
|
|
var stormLon = n.getNode("longitude-deg").getValue();
|
|
|
|
|
|
|
|
# FIXME: once ported to MapStructure, these should use the encapsulated "aircraft source"/driver stuff
|
|
|
|
var acLat = getprop("/position/latitude-deg");
|
|
|
|
var acLon = getprop("/position/longitude-deg");
|
|
|
|
var stormGeo = geo.Coord.new();
|
|
|
|
var acGeo = geo.Coord.new();
|
2013-12-04 23:19:22 +01:00
|
|
|
|
|
|
|
stormGeo.set_latlon(stormLat, stormLon);
|
|
|
|
acGeo.set_latlon(acLat, acLon);
|
|
|
|
|
|
|
|
var directDistance = acGeo.direct_distance_to(stormGeo);
|
2014-05-25 13:11:13 -05:00
|
|
|
var beamH = 0.1719 * directDistance; # M2FT * tan(3deg)
|
|
|
|
var beamBase = getprop("position/altitude-ft") - beamH;
|
2013-12-04 23:19:22 +01:00
|
|
|
|
|
|
|
if (n.getNode("top-altitude-ft").getValue() > beamBase) {
|
|
|
|
me.push( { lat: stormLat, lon : stormLon, radiusNm : n.getNode("radius-nm").getValue() } );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
me.notifyView();
|
|
|
|
}
|
|
|
|
|
|
|
|
|