Merge branch 'Combined' into Base

pull/924/head
t0m1o1 2021-11-22 12:20:57 +00:00 committed by GitHub
commit b51c842297
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 42 additions and 7 deletions

View File

@ -100,7 +100,7 @@
"id": "launch", "id": "launch",
"name": "Launcher", "name": "Launcher",
"shortName": "Launcher", "shortName": "Launcher",
"version": "0.08", "version": "0.09",
"description": "This is needed to display a menu allowing you to choose your own applications. You can replace this with a customised launcher.", "description": "This is needed to display a menu allowing you to choose your own applications. You can replace this with a customised launcher.",
"icon": "app.png", "icon": "app.png",
"type": "launch", "type": "launch",
@ -108,8 +108,13 @@
"supports": ["BANGLEJS","BANGLEJS2"], "supports": ["BANGLEJS","BANGLEJS2"],
"storage": [ "storage": [
{"name":"launch.app.js","url":"app-bangle1.js","supports":["BANGLEJS"]}, {"name":"launch.app.js","url":"app-bangle1.js","supports":["BANGLEJS"]},
{"name":"launch.app.js","url":"app-bangle2.js","supports":["BANGLEJS2"]} {"name":"launch.app.js","url":"app-bangle2.js","supports":["BANGLEJS2"]},
{"name":"launch.settings.js","url":"settings.js","supports":["BANGLEJS2"]}
], ],
"data": [
{"name":"launch.json"}
]
,
"sortorder": -10 "sortorder": -10
}, },
{ {
@ -4316,7 +4321,9 @@
{"name":"binwatch.img","url":"app-icon.js","evaluate":true} {"name":"binwatch.img","url":"app-icon.js","evaluate":true}
] ]
}, },
{ {
"id": "hidmsicswipe", "id": "hidmsicswipe",
"name": "Bluetooth Music Swipe Controls", "name": "Bluetooth Music Swipe Controls",
"shortName": "Swipe Control", "shortName": "Swipe Control",
@ -4329,6 +4336,7 @@
{"name":"hidmsicswipe.app.js","url":"hidmsicswipe.js"}, {"name":"hidmsicswipe.app.js","url":"hidmsicswipe.js"},
{"name":"hidmsicswipe.img","url":"hidmsicswipe-icon.js","evaluate":true} {"name":"hidmsicswipe.img","url":"hidmsicswipe-icon.js","evaluate":true}
] ]
}, },
{ {
"id": "authentiwatch", "id": "authentiwatch",
@ -4348,5 +4356,7 @@
{"name":"authentiwatch.img","url":"app-icon.js","evaluate":true} {"name":"authentiwatch.img","url":"app-icon.js","evaluate":true}
], ],
"data": [{"name":"authentiwatch.json"}] "data": [{"name":"authentiwatch.json"}]
} }
] ]

View File

@ -6,3 +6,4 @@
0.06: Use Bangle.setUI for buttons 0.06: Use Bangle.setUI for buttons
0.07: Theme colours fix 0.07: Theme colours fix
0.08: Merge Bangle.js 1 and 2 launchers 0.08: Merge Bangle.js 1 and 2 launchers
0.09: Added Scaling factor to settings and changed to vector font for Bangle.js2

View File

@ -1,4 +1,9 @@
var s = require("Storage"); var s = require("Storage");
var scaleval = 1;
let settings = require('Storage').readJSON("launch.json", true) || {};
if ("scaleval" in settings) {
scaleval = settings.scaleval;
}
var apps = s.list(/\.info$/).map(app=>{var a=s.readJSON(app,1);return a&&{name:a.name,type:a.type,icon:a.icon,sortorder:a.sortorder,src:a.src};}).filter(app=>app && (app.type=="app" || app.type=="clock" || !app.type)); var apps = s.list(/\.info$/).map(app=>{var a=s.readJSON(app,1);return a&&{name:a.name,type:a.type,icon:a.icon,sortorder:a.sortorder,src:a.src};}).filter(app=>app && (app.type=="app" || app.type=="clock" || !app.type));
apps.sort((a,b)=>{ apps.sort((a,b)=>{
var n=(0|a.sortorder)-(0|b.sortorder); var n=(0|a.sortorder)-(0|b.sortorder);
@ -12,7 +17,8 @@ apps.forEach(app=>{
app.icon = s.read(app.icon); // should just be a link to a memory area app.icon = s.read(app.icon); // should just be a link to a memory area
}); });
// FIXME: not needed after 2v11 // FIXME: not needed after 2v11
var font = g.getFonts().includes("12x20") ? "12x20" : "6x8:2"; //var font = g.getFonts().includes("12x20") ? "12x20" : "6x8:2";
var font = "Vector"+(20*scaleval).toString();
// FIXME: check not needed after 2v11 // FIXME: check not needed after 2v11
if (g.wrapString) { if (g.wrapString) {
g.setFont(font); g.setFont(font);
@ -22,9 +28,9 @@ if (g.wrapString) {
function drawApp(i, r) { function drawApp(i, r) {
var app = apps[i]; var app = apps[i];
if (!app) return; if (!app) return;
g.clearRect(r.x,r.y,r.x+r.w-1, r.y+r.h-1); g.clearRect((r.x),(r.y),(r.x+r.w-1), (r.y+r.h-1));
g.setFont(font).setFontAlign(-1,0).drawString(app.name,64,r.y+32); g.setFont(font).setFontAlign(-1,0).drawString(app.name,64*scaleval,r.y+(32*scaleval));
if (app.icon) try {g.drawImage(app.icon,8,r.y+8);} catch(e){} if (app.icon) try {g.drawImage(app.icon,8*scaleval, r.y+(8*scaleval), {scale: scaleval});} catch(e){}
} }
g.clear(); g.clear();
@ -32,7 +38,7 @@ Bangle.loadWidgets();
Bangle.drawWidgets(); Bangle.drawWidgets();
E.showScroller({ E.showScroller({
h : 64, c : apps.length, h : 64*scaleval, c : apps.length,
draw : drawApp, draw : drawApp,
select : i => { select : i => {
var app = apps[i]; var app = apps[i];

18
apps/launch/settings.js Normal file
View File

@ -0,0 +1,18 @@
// make sure to enclose the function in parentheses
(function(back) {
let settings = require('Storage').readJSON('launch.json',1)||{};
function save(key, value) {
settings[key] = value;
require('Storage').write('launch.json',settings);
}
const appMenu = {
'': {'title': 'Launcher Settings'},
'< Back': back,
'Scale Value': {
value: settings.scaleval || 1,
min:0.1,max:2,step:0.05,wrap:true,
onchange: (m) => {save('scaleval', m)}
}
};
E.showMenu(appMenu)
})