mirror of https://github.com/espruino/BangleApps
[gpsnav] Add support for b2
Add support for Bangle.js 2: - Change button mapping - Remove custom graphics object and flip function - Use theme colors - Adjust sizes - Add screenshotpull/2111/head
parent
3330257525
commit
8e45725adc
|
@ -4,3 +4,4 @@
|
|||
0.04: Fix great circle formula
|
||||
0.05: Use locale for speed and distance + fix Vector font sizes
|
||||
0.06: Move waypoints.json (and editor) to 'waypoints' app
|
||||
0.07: Add support for b2
|
|
@ -0,0 +1,246 @@
|
|||
const Ypos = 24 - 6; // 6 offset because of the smaller labels font
|
||||
var candraw = true;
|
||||
var brg = 0;
|
||||
var wpindex = 0;
|
||||
const labels = ["N", "NE", "E", "SE", "S", "SW", "W", "NW"];
|
||||
var loc = require("locale");
|
||||
|
||||
function drawCompass(course) {
|
||||
if (!candraw) return;
|
||||
g.setColor(g.theme.fg);
|
||||
g.setFont("Vector", 18);
|
||||
var start = course - 90;
|
||||
if (start < 0) start += 360;
|
||||
g.fillRect(14, Ypos + 45, 162, Ypos + 49);
|
||||
var xpos = 16;
|
||||
var frag = 15 - start % 15;
|
||||
if (frag < 15) xpos += Math.floor((frag * 4) / 5);
|
||||
else frag = 0;
|
||||
for (var i = frag; i <= 180 - frag; i += 15) {
|
||||
var res = start + i;
|
||||
if (res % 90 == 0) {
|
||||
g.drawString(labels[Math.floor(res / 45) % 8], xpos - 6, Ypos + 6);
|
||||
g.fillRect(xpos - 2, Ypos + 25, xpos + 2, Ypos + 45);
|
||||
} else if (res % 45 == 0) {
|
||||
g.drawString(labels[Math.floor(res / 45) % 8], xpos - 9, Ypos + 6);
|
||||
g.fillRect(xpos - 2, Ypos + 30, xpos + 2, Ypos + 45);
|
||||
} else if (res % 15 == 0) {
|
||||
g.fillRect(xpos, Ypos + 36, xpos + 1, Ypos + 45);
|
||||
}
|
||||
xpos += 12;
|
||||
}
|
||||
if (wpindex != 0) {
|
||||
var bpos = brg - course;
|
||||
if (bpos > 180) bpos -= 360;
|
||||
if (bpos < -180) bpos += 360;
|
||||
bpos = Math.round((bpos * 4) / 5) + 88;
|
||||
if (bpos < 16) bpos = 7;
|
||||
if (bpos > 160) bpos = 169;
|
||||
g.setColor(g.theme.bgH);
|
||||
g.fillCircle(bpos, Ypos + 43, 6);
|
||||
}
|
||||
}
|
||||
|
||||
//displayed heading
|
||||
var heading = 0;
|
||||
|
||||
function newHeading(m, h) {
|
||||
var s = Math.abs(m - h);
|
||||
var delta = (m > h) ? 1 : -1;
|
||||
if (s >= 180) {
|
||||
s = 360 - s;
|
||||
delta = -delta;
|
||||
}
|
||||
if (s < 2) return h;
|
||||
var hd = h + delta * (1 + Math.round(s / 5));
|
||||
if (hd < 0) hd += 360;
|
||||
if (hd > 360) hd -= 360;
|
||||
return hd;
|
||||
}
|
||||
|
||||
var course = 0;
|
||||
var speed = 0;
|
||||
var satellites = 0;
|
||||
var wp;
|
||||
var dist = 0;
|
||||
|
||||
function radians(a) {
|
||||
return a * Math.PI / 180;
|
||||
}
|
||||
|
||||
function degrees(a) {
|
||||
var d = a * 180 / Math.PI;
|
||||
return (d + 360) % 360;
|
||||
}
|
||||
|
||||
function bearing(a, b) {
|
||||
var delta = radians(b.lon - a.lon);
|
||||
var alat = radians(a.lat);
|
||||
var blat = radians(b.lat);
|
||||
var y = Math.sin(delta) * Math.cos(blat);
|
||||
var x = Math.cos(alat) * Math.sin(blat) -
|
||||
Math.sin(alat) * Math.cos(blat) * Math.cos(delta);
|
||||
return Math.round(degrees(Math.atan2(y, x)));
|
||||
}
|
||||
|
||||
function distance(a, b) {
|
||||
var x = radians(a.lon - b.lon) * Math.cos(radians((a.lat + b.lat) / 2));
|
||||
var y = radians(b.lat - a.lat);
|
||||
return Math.round(Math.sqrt(x * x + y * y) * 6371000);
|
||||
}
|
||||
|
||||
var selected = false;
|
||||
|
||||
function drawN() {
|
||||
var txt = loc.speed(speed);
|
||||
g.setColor(g.theme.fg);
|
||||
g.setFont("6x8", 2);
|
||||
g.drawString("o", 68, Ypos + 68);
|
||||
g.setFont("6x8", 1);
|
||||
g.drawString(txt.substring(txt.length - 3), 156, Ypos + 70 + 30);
|
||||
g.setFont("Vector", 36);
|
||||
var cs = course.toString().padStart(3, "0");
|
||||
g.drawString(cs, 2, Ypos + 70);
|
||||
g.drawString(txt.substring(0, txt.length - 3), 92, Ypos + 70);
|
||||
g.setColor(g.theme.fg);
|
||||
g.setFont("Vector", 18);
|
||||
var bs = brg.toString().padStart(3, "0");
|
||||
g.setColor(g.theme.fg2);
|
||||
g.drawString("Brg:", 1, Ypos + 110);
|
||||
g.drawString("Dist:", 1, Ypos + 130);
|
||||
g.setColor(selected ? g.theme.bgH : g.theme.bg);
|
||||
g.fillRect(90, Ypos + 109, 175, Ypos + 125);
|
||||
g.setColor(selected ? g.theme.fgH : g.theme.fg);
|
||||
g.drawString(wp.name, 92, Ypos + 110);
|
||||
g.setColor(g.theme.fg);
|
||||
g.drawString(bs, 42, Ypos + 110);
|
||||
g.drawString(loc.distance(dist), 42, Ypos + 130);
|
||||
g.setFont("6x8", 1);
|
||||
g.setColor(satellites ? g.theme.bg : g.theme.bgH);
|
||||
g.fillRect(0, 167, 75, 175);
|
||||
g.setColor(satellites ? g.theme.fg : g.theme.fgH);
|
||||
g.drawString("Sats:", 1, 168);
|
||||
g.drawString(satellites.toString(), 42, 168);
|
||||
}
|
||||
|
||||
var savedfix;
|
||||
|
||||
function onGPS(fix) {
|
||||
savedfix = fix;
|
||||
if (fix !== undefined) {
|
||||
course = isNaN(fix.course) ? course : Math.round(fix.course);
|
||||
speed = isNaN(fix.speed) ? speed : fix.speed;
|
||||
satellites = fix.satellites;
|
||||
}
|
||||
if (candraw) {
|
||||
if (fix !== undefined && fix.fix == 1) {
|
||||
dist = distance(fix, wp);
|
||||
if (isNaN(dist)) dist = 0;
|
||||
brg = bearing(fix, wp);
|
||||
if (isNaN(brg)) brg = 0;
|
||||
}
|
||||
drawN();
|
||||
}
|
||||
}
|
||||
|
||||
var intervalRef;
|
||||
|
||||
function stopdraw() {
|
||||
candraw = false;
|
||||
if (intervalRef) {
|
||||
clearInterval(intervalRef);
|
||||
}
|
||||
}
|
||||
|
||||
function startTimers() {
|
||||
candraw = true;
|
||||
intervalRefSec = setInterval(function() {
|
||||
heading = newHeading(course, heading);
|
||||
if (course != heading) drawCompass(heading);
|
||||
}, 200);
|
||||
}
|
||||
|
||||
function drawAll() {
|
||||
g.setColor(1, 0, 0); //red
|
||||
g.fillPoly([88, Ypos + 48, 78, Ypos + 70, 98, Ypos + 70]);
|
||||
drawN();
|
||||
drawCompass(heading);
|
||||
}
|
||||
|
||||
function startdraw() {
|
||||
g.clear();
|
||||
Bangle.drawWidgets();
|
||||
startTimers();
|
||||
drawAll();
|
||||
}
|
||||
|
||||
function setButtons() {
|
||||
Bangle.setUI("leftright", btn => {
|
||||
if (btn == 0) {
|
||||
doselect();
|
||||
} else {
|
||||
nextwp.bind(null, btn);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
var SCREENACCESS = {
|
||||
withApp: true,
|
||||
request: function() {
|
||||
this.withApp = false;
|
||||
stopdraw();
|
||||
clearWatch();
|
||||
},
|
||||
release: function() {
|
||||
this.withApp = true;
|
||||
startdraw();
|
||||
setButtons();
|
||||
}
|
||||
};
|
||||
|
||||
Bangle.on('lcdPower', function(on) {
|
||||
if (!SCREENACCESS.withApp) return;
|
||||
if (on) {
|
||||
startdraw();
|
||||
} else {
|
||||
stopdraw();
|
||||
}
|
||||
});
|
||||
|
||||
var waypoints = require("waypoints").load();
|
||||
wp = waypoints[0];
|
||||
|
||||
function nextwp(inc) {
|
||||
if (!selected) return;
|
||||
wpindex += inc;
|
||||
if (wpindex >= waypoints.length) wpindex = 0;
|
||||
if (wpindex < 0) wpindex = waypoints.length - 1;
|
||||
wp = waypoints[wpindex];
|
||||
drawN();
|
||||
}
|
||||
|
||||
function doselect() {
|
||||
if (selected && wpindex != 0 && waypoints[wpindex].lat === undefined && savedfix.fix) {
|
||||
waypoints[wpindex] = {
|
||||
name: "@" + wp.name,
|
||||
lat: savedfix.lat,
|
||||
lon: savedfix.lon
|
||||
};
|
||||
wp = waypoints[wpindex];
|
||||
require("waypoints").save(waypoints);
|
||||
}
|
||||
selected = !selected;
|
||||
drawN();
|
||||
}
|
||||
|
||||
g.clear();
|
||||
Bangle.setLCDBrightness(1);
|
||||
Bangle.loadWidgets();
|
||||
Bangle.drawWidgets();
|
||||
// load widgets can turn off GPS
|
||||
Bangle.setGPSPower(1);
|
||||
drawAll();
|
||||
startTimers();
|
||||
Bangle.on('GPS', onGPS);
|
||||
// Toggle selected
|
||||
setButtons();
|
|
@ -1,15 +1,17 @@
|
|||
{
|
||||
"id": "gpsnav",
|
||||
"name": "GPS Navigation",
|
||||
"version": "0.06",
|
||||
"version": "0.07",
|
||||
"description": "Displays GPS Course and Speed, + Directions to waypoint and waypoint recording, now with waypoint editor",
|
||||
"screenshots": [{"url":"screenshot-b2.png"}],
|
||||
"icon": "icon.png",
|
||||
"tags": "tool,outdoors,gps",
|
||||
"supports": ["BANGLEJS"],
|
||||
"supports": ["BANGLEJS","BANGLEJS2"],
|
||||
"readme": "README.md",
|
||||
"dependencies" : { "waypoints":"type" },
|
||||
"storage": [
|
||||
{"name":"gpsnav.app.js","url":"app.min.js"},
|
||||
{"name":"gpsnav.app.js","url":"app.min.js","supports":["BANGLEJS"]},
|
||||
{"name":"gpsnav.app.js","url":"app_b2.js","supports":["BANGLEJS2"]},
|
||||
{"name":"gpsnav.img","url":"app-icon.js","evaluate":true}
|
||||
]
|
||||
}
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 3.1 KiB |
Loading…
Reference in New Issue