launcher 0.16: Use a cache of app.info files to speed up loading the launcher
parent
13fd18ff8c
commit
f5e113d50f
|
|
@ -15,3 +15,4 @@
|
||||||
0.13: Add fullscreen mode
|
0.13: Add fullscreen mode
|
||||||
0.14: Use default Bangle formatter for booleans
|
0.14: Use default Bangle formatter for booleans
|
||||||
0.15: Support for unload and quick return to the clock on 2v16
|
0.15: Support for unload and quick return to the clock on 2v16
|
||||||
|
0.16: Use a cache of app.info files to speed up loading the launcher
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
{ // must be inside our own scope here so that when we are unloaded everything disappears
|
{ // must be inside our own scope here so that when we are unloaded everything disappears
|
||||||
let s = require("Storage");
|
let s = require("Storage");
|
||||||
|
// handle customised launcher
|
||||||
let scaleval = 1;
|
let scaleval = 1;
|
||||||
let vectorval = 20;
|
let vectorval = 20;
|
||||||
let font = g.getFonts().includes("12x20") ? "12x20" : "6x8:2";
|
let font = g.getFonts().includes("12x20") ? "12x20" : "6x8:2";
|
||||||
|
|
@ -7,56 +8,51 @@ let settings = Object.assign({
|
||||||
showClocks: true,
|
showClocks: true,
|
||||||
fullscreen: false
|
fullscreen: false
|
||||||
}, s.readJSON("launch.json", true) || {});
|
}, s.readJSON("launch.json", true) || {});
|
||||||
|
if ("vectorsize" in settings)
|
||||||
if ("vectorsize" in settings) {
|
|
||||||
vectorval = parseInt(settings.vectorsize);
|
vectorval = parseInt(settings.vectorsize);
|
||||||
}
|
|
||||||
if ("font" in settings){
|
if ("font" in settings){
|
||||||
if(settings.font == "Vector"){
|
if(settings.font == "Vector"){
|
||||||
scaleval = vectorval/20;
|
scaleval = vectorval/20;
|
||||||
font = "Vector"+(vectorval).toString();
|
font = "Vector"+(vectorval).toString();
|
||||||
}
|
} else{
|
||||||
else{
|
|
||||||
font = settings.font;
|
font = settings.font;
|
||||||
scaleval = (font.split("x")[1])/20;
|
scaleval = (font.split("x")[1])/20;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let 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" && settings.showClocks) || !app.type));
|
// cache app list so launcher loads more quickly
|
||||||
apps.sort((a,b)=>{
|
let launchCache = s.readJSON("launch.cache.json", true)||{};
|
||||||
|
let launchHash = require("Storage").hash(/\.info/);
|
||||||
|
if (launchCache.hash!=launchHash) {
|
||||||
|
launchCache = {
|
||||||
|
hash : launchHash,
|
||||||
|
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" && settings.showClocks) || !app.type))
|
||||||
|
.sort((a,b)=>{
|
||||||
var n=(0|a.sortorder)-(0|b.sortorder);
|
var n=(0|a.sortorder)-(0|b.sortorder);
|
||||||
if (n) return n; // do sortorder first
|
if (n) return n; // do sortorder first
|
||||||
if (a.name<b.name) return -1;
|
if (a.name<b.name) return -1;
|
||||||
if (a.name>b.name) return 1;
|
if (a.name>b.name) return 1;
|
||||||
return 0;
|
return 0;
|
||||||
});
|
}) };
|
||||||
apps.forEach(app=>{
|
s.writeJSON("launch.cache.json", launchCache);
|
||||||
if (app.icon)
|
|
||||||
app.icon = s.read(app.icon); // should just be a link to a memory area
|
|
||||||
});
|
|
||||||
// FIXME: check not needed after 2v11
|
|
||||||
if (g.wrapString) {
|
|
||||||
g.setFont(font);
|
|
||||||
apps.forEach(app=>app.name = g.wrapString(app.name, g.getWidth()-64).join("\n"));
|
|
||||||
}
|
}
|
||||||
|
let apps = launchCache.apps;
|
||||||
function drawApp(i, r) {
|
// Now apps list is loaded - render
|
||||||
|
if (!settings.fullscreen)
|
||||||
|
Bangle.loadWidgets();
|
||||||
|
E.showScroller({
|
||||||
|
h : 64*scaleval, c : apps.length,
|
||||||
|
draw : (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*scaleval,r.y+(32*scaleval));
|
g.setFont(font).setFontAlign(-1,0).drawString(app.name,64*scaleval,r.y+(32*scaleval));
|
||||||
if (app.icon) try {g.drawImage(app.icon,8*scaleval, r.y+(8*scaleval), {scale: scaleval});} catch(e){}
|
if (app.icon) {
|
||||||
|
if (!app.img) app.img = s.read(app.icon); // load icon if it wasn't loaded
|
||||||
|
try {g.drawImage(app.img,8*scaleval, r.y+(8*scaleval), {scale: scaleval});} catch(e){}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
g.clear();
|
|
||||||
|
|
||||||
if (!settings.fullscreen) {
|
|
||||||
Bangle.loadWidgets();
|
|
||||||
Bangle.drawWidgets();
|
|
||||||
}
|
|
||||||
|
|
||||||
E.showScroller({
|
|
||||||
h : 64*scaleval, c : apps.length,
|
|
||||||
draw : drawApp,
|
|
||||||
select : i => {
|
select : i => {
|
||||||
var app = apps[i];
|
var app = apps[i];
|
||||||
if (!app) return;
|
if (!app) return;
|
||||||
|
|
@ -69,6 +65,7 @@ E.showScroller({
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
g.flip(); // force a render before widgets have finished drawing
|
||||||
|
|
||||||
function returnToClock() {
|
function returnToClock() {
|
||||||
// unload everything manually
|
// unload everything manually
|
||||||
|
|
@ -96,4 +93,6 @@ function lockHandler(locked) {
|
||||||
lockTimeout = setTimeout(returnToClock, 10000);
|
lockTimeout = setTimeout(returnToClock, 10000);
|
||||||
}
|
}
|
||||||
Bangle.on("lock", lockHandler);
|
Bangle.on("lock", lockHandler);
|
||||||
|
if (!settings.fullscreen) // finally draw widgets
|
||||||
|
Bangle.drawWidgets();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,7 @@
|
||||||
"id": "launch",
|
"id": "launch",
|
||||||
"name": "Launcher",
|
"name": "Launcher",
|
||||||
"shortName": "Launcher",
|
"shortName": "Launcher",
|
||||||
"version": "0.15",
|
"version": "0.16",
|
||||||
"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.",
|
||||||
"readme": "README.md",
|
"readme": "README.md",
|
||||||
"icon": "app.png",
|
"icon": "app.png",
|
||||||
|
|
@ -13,6 +13,6 @@
|
||||||
{"name":"launch.app.js","url":"app.js"},
|
{"name":"launch.app.js","url":"app.js"},
|
||||||
{"name":"launch.settings.js","url":"settings.js"}
|
{"name":"launch.settings.js","url":"settings.js"}
|
||||||
],
|
],
|
||||||
"data": [{"name":"launch.json"}],
|
"data": [{"name":"launch.json"},{"name":"launch.cache.json"}],
|
||||||
"sortorder": -10
|
"sortorder": -10
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue