Tech version of terrain radar works (at most)
|
@ -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"},
|
||||||
|
|
|
@ -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!
|
||||||
|
|
|
@ -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")
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
|
var heading = getprop("orientation/heading-magnetic-deg");
|
||||||
|
var altitudeagl = getprop("/position/altitude-agl-ft");
|
||||||
|
|
||||||
|
var side = (math.mod(me.radar_beacon,2)==0) ? "L" : "R";
|
||||||
|
var a = int(me.radar_beacon/2);
|
||||||
|
var col = a;
|
||||||
|
|
||||||
|
if (side == "L") {
|
||||||
|
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) {
|
for (var r=0; r < len; r+=1) {
|
||||||
|
|
||||||
var imgx = math.mod(r*a,3);
|
var imgx = elevft[r];
|
||||||
|
if (imgx < 0) trn[r].hide();
|
||||||
me.terrlayer["L" ~ a].setFile(me.imgpath ~ me.tile_list[imgx]).show();
|
else trn[r].setFile(me.imgpath ~ me.tile_list[imgx]).show();
|
||||||
me.terrlayer["R" ~ a].setFile(me.imgpath ~ me.tile_list[2-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);
|
||||||
}
|
#}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
BIN
Models/Instruments/ND/canvas/res/terrain/tile_01.png
Normal file
After Width: | Height: | Size: 3.1 KiB |
BIN
Models/Instruments/ND/canvas/res/terrain/tile_02.png
Normal file
After Width: | Height: | Size: 175 B |
BIN
Models/Instruments/ND/canvas/res/terrain/tile_03.png
Normal file
After Width: | Height: | Size: 3.2 KiB |
BIN
Models/Instruments/ND/canvas/res/terrain/tile_04.png
Normal file
After Width: | Height: | Size: 175 B |
BIN
Models/Instruments/ND/canvas/res/terrain/tile_05.png
Normal file
After Width: | Height: | Size: 3.1 KiB |
BIN
Models/Instruments/ND/canvas/res/terrain/tile_06.png
Normal file
After Width: | Height: | Size: 175 B |
Before Width: | Height: | Size: 149 B |
Before Width: | Height: | Size: 1,011 B |
Before Width: | Height: | Size: 1,017 B |
|
@ -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) {
|
||||||
|
#print("TERRAIN TOGGLE: " ~ nd.get_switch("toggle_terrain"));
|
||||||
var visible = nd.get_switch("toggle_terrain") and
|
var visible = nd.get_switch("toggle_terrain") 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.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();
|
||||||
|
|