1
0
Fork 0

Tech version of terrain radar works (at most)

This commit is contained in:
Inuyaksa 2021-02-13 00:38:43 +01:00
parent c179372ce4
commit f2034e0482
15 changed files with 135 additions and 41 deletions

View file

@ -48,7 +48,7 @@ var myCockpit_switches = {
"toggle_waypoints": {path: "/inputs/wpt", value:0, type:"BOOL"}, "toggle_waypoints": {path: "/inputs/wpt", value:0, type:"BOOL"},
"toggle_position": {path: "/inputs/pos", value:0, type:"BOOL"}, "toggle_position": {path: "/inputs/pos", value:0, type:"BOOL"},
"toggle_data": {path: "/inputs/data",value:0, type:"BOOL"}, "toggle_data": {path: "/inputs/data",value:0, type:"BOOL"},
"toggle_terrain": {path: "/inputs/terr",value:0, type:"BOOL"}, #"toggle_terrain": {path: "/inputs/terr",value:0, type:"BOOL"},
"toggle_traffic": {path: "/inputs/tfc",value:0, type:"BOOL"}, "toggle_traffic": {path: "/inputs/tfc",value:0, type:"BOOL"},
"toggle_centered": {path: "/inputs/nd-centered",value:0, type:"BOOL"}, "toggle_centered": {path: "/inputs/nd-centered",value:0, type:"BOOL"},
"toggle_lh_vor_adf": {path: "/input/lh-vor-adf",value:0, type:"INT"}, "toggle_lh_vor_adf": {path: "/input/lh-vor-adf",value:0, type:"INT"},

View file

@ -374,6 +374,11 @@ canvas.NavDisplay.update = func() # FIXME: This stuff is still too aircraft spec
if(wxr_live_enabled == nil or wxr_live_enabled == '') if(wxr_live_enabled == nil or wxr_live_enabled == '')
wxr_live_enabled = 0; wxr_live_enabled = 0;
me.set_switch('toggle_weather_live', wxr_live_enabled); me.set_switch('toggle_weather_live', wxr_live_enabled);
var terr_enabled = getprop("/controls/switches/terr_on_nd_l");
if (terr_enabled == nil) terr_enabled = 0;
if (me.get_switch('toggle_terrain') != terr_enabled) me.set_switch('toggle_terrain', terr_enabled);
call(me.update_sub, nil, nil, caller(0)[0]); # call this in the same namespace to "steal" its variables call(me.update_sub, nil, nil, caller(0)[0]); # call this in the same namespace to "steal" its variables
# MapStructure update! # MapStructure update!

View file

@ -16,7 +16,7 @@ setlistener("/nasal/canvas/loaded", func() {
var aircraft_root = getprop("/sim/aircraft-dir"); var aircraft_root = getprop("/sim/aircraft-dir");
var load = func(file, name) { var load = func(file, name) {
print("Loading ..." ~ file); #print("Loading ..." ~ file);
if (name == nil) if (name == nil)
var name = split("/", file)[-1]; var name = split("/", file)[-1];
if (substr(name, size(name)-4) == ".draw") if (substr(name, size(name)-4) == ".draw")

View file

@ -41,8 +41,8 @@ var searchCmd = func {
#if(lat == nil or lon == nil) { #if(lat == nil or lon == nil) {
var pos = geo.aircraft_position(); var pos = geo.aircraft_position();
lat = pos.lat(); var lat = pos.lat();
lon = pos.lon(); var lon = pos.lon();
#} #}
var result = geo.Coord.new(); var result = geo.Coord.new();

View file

@ -7,43 +7,110 @@ DotSym.makeinstance( name, __self__ );
var element_type = "group"; var element_type = "group";
var tile_list = ["tile_00.png","tile_04.png","tile_06.png"]; var tile_list = ["tile_01.png","tile_01.png","tile_02.png","tile_03.png","tile_03.png","tile_03.png","tile_04.png","tile_04.png","tile_06.png","tile_09.png",];
var radar_beacon = 0;
var radar_cycle = 0;
var get_elevation = func (lat, lon) {
var info = geodinfo(lat, lon);
var elevation = 0;
if (info != nil) { elevation = int(info[0] * 3.2808399); }
else { elevation = nil; }
return elevation;
}
var updateTerrain = func(r_scaled){
var updateTerrain = func(size){
if(me.fetching) return; if(me.fetching) return;
var pos = geo.aircraft_position();
var lat = pos.lat();
var lon = pos.lon();
me.fetching = 1; me.fetching = 1;
for (var a=0; a < me.tileradius; a+=1) { var RAD2DEG = 57.2957795;
var DEG2RAD = 0.016774532925;
var len = size(me.terrlayer["L" ~ a]); var pos = geo.aircraft_position();
var pos_lat = pos.lat();
var pos_lon = pos.lon();
for (var r=0; r < len; r+=1) { var heading = getprop("orientation/heading-magnetic-deg");
var altitudeagl = getprop("/position/altitude-agl-ft");
var imgx = math.mod(r*a,3); var side = (math.mod(me.radar_beacon,2)==0) ? "L" : "R";
var a = int(me.radar_beacon/2);
var col = a;
me.terrlayer["L" ~ a].setFile(me.imgpath ~ me.tile_list[imgx]).show(); if (side == "L") {
me.terrlayer["R" ~ a].setFile(me.imgpath ~ me.tile_list[2-imgx]).show(); col = -1 + (-1 * a);
}
var col = me.radar_beacon - me.tileradius;
#for (var a=0; a < me.tileradius; a+=1) {
#var trnL = me.terrlayer["L" ~ a];
#var trnR = me.terrlayer["R" ~ a];
var trn = me.terrlayer[side ~ a];
var len = size(trn);
var range = me.range;
var proj_lon = pos_lon + ((col * (range/30) * math.sin(DEG2RAD * (heading - 90))) / 60);
var proj_lat = pos_lat + ((col * (range/30) * math.cos(DEG2RAD * (heading - 90))) / 60);
var elevft = [];
for (var row = 0; row <= len; row += 1) {
var point_lon = proj_lon + ((row * (range/30) / 60) * math.sin(DEG2RAD * heading));
var point_lat = proj_lat + ((row * (range/30) / 60) * math.cos(DEG2RAD * heading));
var elev = me.get_elevation(point_lat, point_lon);
if (elev != nil) {
var grad = int((elev - altitudeagl + 500)/500);
if (grad>6) grad = 6;
else if (grad<-3) grad = -3;
append(elevft,grad+2); # (-1)-8
} else {
append(elevft,8); # magenta
}
} }
for (var r=0; r < len; r+=1) {
var imgx = elevft[r];
if (imgx < 0) trn[r].hide();
else trn[r].setFile(me.imgpath ~ me.tile_list[imgx]).show();
#trnR[r].setFile(me.imgpath ~ me.tile_list[2-imgx]).show();
}
#}
me.radar_beacon += 1;
if (me.radar_beacon >= (me.tileradius*2)) {
me.radar_beacon = 0;
me.radar_cycle += 1;
} }
me.last_request = getprop("sim/time/elapsed-sec"); #me.last_request = getprop("sim/time/elapsed-sec");
me.fetching = 0; me.fetching = 0;
}; };
var init = func { var init = func {
print('TERRAIN init'); #print('TERRAIN init');
me.tile = 20; me.tile = 33; # better 34
me.fetching = 0; me.fetching = 0;
me.timeStamp = nil; me.timeStamp = nil;
me.fetchRad = me.model.fetchRad; # Radius of radar layer to fetch me.fetchRad = me.model.fetchRad; # Radius of radar layer to fetch
me.range = me.model.rangeNm; # Range of Navigation Display me.range = me.model.rangeNm; # Range of Navigation Display
me.viewport_radius = me.getOption('viewport_radius', 670); me.viewport_radius = me.getOption('viewport_radius', 670);
me.imgpath = get_local_path('res/'); me.imgpath = get_local_path('res/terrain/');
var tile = me.tile; var tile = me.tile;
@ -53,27 +120,28 @@ var init = func {
me.terrlayer = {}; #me.element.createChild("image").set("z-index", -100).hide(); me.terrlayer = {}; #me.element.createChild("image").set("z-index", -100).hide();
var centx = me.viewport_radius; var centx = 0; #me.viewport_radius * -0.5;
var centy = -me.viewport_radius;
for (var c=0; c<gx; c+=1) { for (var c=0; c<gx; c+=1) {
var hh = c * tile; var hh = c * tile;
var mx = (c == 0) ? gx : int(math.sqrt(gx*gx-c*c)); var mx = (c == 0) ? gx : int(math.sqrt(gx*gx-c*c) + 0.5);
var py = (gx-1) * tile; var py = centy + (gx-1) * tile;
var pxr = centx+(c*tile); var pxr = centx+(c*tile);
var pxl = centx-(c*tile)-tile; var pxl = centx-(c*tile)-tile;
var grplx = []; var grplx = [];
var grprx = []; var grprx = [];
for (var r=0; r<mx; r+=1) { for (var r=0; r<mx; r+=1) {
append(grplx , me.element.createChild("image").set("z-index", -100).setSize(tile,tile).setTranslation(pxl,py)); append(grplx , me.element.createChild("image").set("z-index", -100).setSize(tile,tile).setTranslation(pxl,py).hide());
append(grprx , me.element.createChild("image").set("z-index", -100).setSize(tile,tile).setTranslation(pxr,py)); append(grprx , me.element.createChild("image").set("z-index", -100).setSize(tile,tile).setTranslation(pxr,py).hide());
py-=tile; py-=tile;
} }
me.terrlayer["L" ~ c] = grplx; me.terrlayer["L" ~ c] = grplx;
me.terrlayer["R" ~ c] = grprx; me.terrlayer["R" ~ c] = grprx;
} }
me.last_request = -600; me.update_interval = 300;
me.update_interval = 600; me.last_request = 0;
#var r_scaled = (me.fetchRad*me.viewport_radius)/me.range; #var r_scaled = (me.fetchRad*me.viewport_radius)/me.range;
#me.fetchWXRMap(r_scaled); #me.fetchWXRMap(r_scaled);
@ -88,19 +156,24 @@ var draw = func {
me.range = range; me.range = range;
me.fetchRad = me.model.fetchRad; # Radius of radar layer to fetch me.fetchRad = me.model.fetchRad; # Radius of radar layer to fetch
var r_scaled = (me.fetchRad*me.viewport_radius)/me.range; var r_scaled = (me.fetchRad*me.viewport_radius)/me.range;
var hdg = me.layer.map.getHdg(); #var hdg = me.layer.map.getHdg();
var rot = 0 - hdg; #var rot = 0 - hdg;
if(rot < 0) rot = 360 + rot + -getprop("/environment/magnetic-variation-deg"); #if(rot < 0) rot = 360 + rot + -getprop("/environment/magnetic-variation-deg");
me.element.setRotation(rot*D2R); #me.element.setRotation(rot*D2R);
if(update_size){ #if(update_size){
#me.terrlayer.hide(); #me.terrlayer.hide();
#me.terrlayer.setSize(2*r_scaled, 2*r_scaled) #me.terrlayer.setSize(2*r_scaled, 2*r_scaled)
# .setTranslation(-r_scaled, -r_scaled); # .setTranslation(-r_scaled, -r_scaled);
#me.terrlayer.show(); #me.terrlayer.show();
} #}
if(getprop("sim/time/elapsed-sec") - me.last_request > me.update_interval) { var rot = getprop("orientation/heading-deg");
rot -= me.layer.map.getHdg();
me.element.setRotation(rot*D2R);
#if(getprop("sim/time/elapsed-sec") - me.last_request >= me.update_interval) {
me.updateTerrain(r_scaled); me.updateTerrain(r_scaled);
} #}
}; };

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 175 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 149 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1,011 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1,017 B

View file

@ -88,17 +88,33 @@ canvas.NDStyles["Airbus"] = {
name:"TERRAIN", name:"TERRAIN",
isMapStructure:1, isMapStructure:1,
always_update: 1, always_update: 1,
update_on:[ "toggle_range","toggle_display_mode","toggle_terrain"], update_on:[ {rate_hz: 0.4}, "toggle_range","toggle_display_mode","toggle_terrain"],
predicate: func(nd, layer) { predicate: func(nd, layer) {
var visible=nd.get_switch("toggle_terrain") and #print("TERRAIN TOGGLE: " ~ nd.get_switch("toggle_terrain"));
nd.get_switch("toggle_display_mode") != "PLAN" and (nd.adirs_property.getValue() == 1 or (adirs_3.getValue() == 1 and att_switch.getValue() == nd.attitude_heading_setting)); var visible = nd.get_switch("toggle_terrain") and
nd.get_switch("toggle_display_mode") != "PLAN" and (nd.rangeNm() <= 40) and !nd.get_switch("toggle_centered") and (nd.adirs_property.getValue() == 1 or (adirs_3.getValue() == 1 and att_switch.getValue() == nd.attitude_heading_setting));
layer.group.setVisible(visible); layer.group.setVisible(visible);
if (visible) { if (visible) {
layer.update(); layer.update();
} }
}, # end of layer update predicate }, # end of layer update predicate
options: { options: {
viewport_radius: 706 viewport_radius: 706,
model: {
parents: [geo.Coord],
id: 999999,
pos: props.globals.getNode("position"),
type: "position",
latlon: func(){
me.pos = props.globals.getNode("position");
return [
me.pos.getValue("latitude-deg"),
me.pos.getValue("longitude-deg"),
me.pos.getValue("altitude-ft")
];
},
equals: func(o){me.id == o.id}
},
}, },
"z-index": -100, "z-index": -100,
}, },
@ -106,11 +122,11 @@ canvas.NDStyles["Airbus"] = {
name:"WXR_live", name:"WXR_live",
isMapStructure:1, isMapStructure:1,
always_update: 1, always_update: 1,
update_on:[ "toggle_range","toggle_weather","toggle_display_mode","toggle_weather_live"], update_on:[ "toggle_range","toggle_weather","toggle_display_mode","toggle_weather_live","toggle_terrain"],
predicate: func(nd, layer) { predicate: func(nd, layer) {
var visible=nd.get_switch("toggle_weather") and var visible=nd.get_switch("toggle_weather") and
nd.get_switch("toggle_weather_live") and nd.get_switch("toggle_weather_live") and
nd.get_switch("toggle_display_mode") != "PLAN" and (nd.adirs_property.getValue() == 1 or (adirs_3.getValue() == 1 and att_switch.getValue() == nd.attitude_heading_setting)); nd.get_switch("toggle_display_mode") != "PLAN" and !nd.get_switch("toggle_terrain") and (nd.adirs_property.getValue() == 1 or (adirs_3.getValue() == 1 and att_switch.getValue() == nd.attitude_heading_setting));
layer.group.setVisible(visible); layer.group.setVisible(visible);
if (visible) { if (visible) {
layer.update(); layer.update();