Add timer app
parent
7647c03a95
commit
edd1c0c7bb
12
apps.json
12
apps.json
|
|
@ -939,5 +939,17 @@
|
||||||
"storage": [
|
"storage": [
|
||||||
{"name":"widtbat.wid.js","url":"widget.js"}
|
{"name":"widtbat.wid.js","url":"widget.js"}
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{ "id": "timer",
|
||||||
|
"name": "Timer",
|
||||||
|
"shortName":"Timer",
|
||||||
|
"icon": "app.png",
|
||||||
|
"version":"0.01",
|
||||||
|
"description": "BTN1 => +5min, BTN2 => +30sec, BTN3 => +5sec, TOUCH => pause,play, BTN1(double click) => reset",
|
||||||
|
"tags": "Tools",
|
||||||
|
"storage": [
|
||||||
|
{"name":"timer.app.js","url":"app.js"},
|
||||||
|
{"name":"timer.img","url":"app-icon.js","evaluate":true}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1 @@
|
||||||
|
var img = require("heatshrink").decompress(atob("mEwwglihGIxAWUwADBDCYTDhAXSFwQEGIxowBL4QXTx///AXWF6qnBwCTDO6EIF4KnEDwLWO/4QFx7FNdwQQEGwP4GBYUB/4QBDIYXMIgQAEDIIKCVwItJFggFEx4uKCAQUBX4QDC/B2KhASCAQP/AQQcDLpQlCLgQsCCoIGBC5IkCFon/xwxCDgIXJFwYxFHIR3ILwIkBCIeIFwQHBHgReIJAgCBOoP+MYZIHhB1EDgIRBA4ZIJC4LrEMYvoAgQXJxHvI4gtDC5OIF4QSDbYY3EC5QAKG4QXNPwg0BSBAJCIQhLCDwgXKIAwXUMo4XPFwrwKC4YOCUooVCR453DIxIXJU4IqDxwXJa45FDdgxnEC40IC4TbINQYXIRQZwDAAXv/xuBCwoXBVAgXDA4wXGSARcEC4o7BRwx4DOon+C4YiCLwxIDDAobDEYJGIGAYYBxDAD9AJDC5IwCDIYACJARGIDAapDaooWLDAZhEAoIWNMggADCqAAPA"))
|
||||||
|
|
@ -0,0 +1,73 @@
|
||||||
|
function msToTime(duration) {
|
||||||
|
var milliseconds = parseInt((duration % 1000) / 100),
|
||||||
|
seconds = Math.floor((duration / 1000) % 60),
|
||||||
|
minutes = Math.floor((duration / (1000 * 60)) % 60),
|
||||||
|
hours = Math.floor((duration / (1000 * 60 * 60)) % 24);
|
||||||
|
|
||||||
|
hours = (hours < 10) ? "0" + hours : hours;
|
||||||
|
minutes = (minutes < 10) ? "0" + minutes : minutes;
|
||||||
|
seconds = (seconds < 10) ? "0" + seconds : seconds;
|
||||||
|
|
||||||
|
return hours + ":" + minutes + ":" + seconds;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var counter = 0;
|
||||||
|
var started = false;
|
||||||
|
|
||||||
|
function drawInterface() {
|
||||||
|
g.clear();
|
||||||
|
g.setFontAlign(0,0);
|
||||||
|
g.setFont("6x8",2);
|
||||||
|
g.drawString("+5m", g.getWidth()-30, 30);
|
||||||
|
g.drawString("+30s", g.getWidth()-30, g.getHeight()/2);
|
||||||
|
g.drawString("+5s", g.getWidth()-30, g.getHeight() - 30);
|
||||||
|
|
||||||
|
g.setFontAlign(0,0); // center font
|
||||||
|
g.setFont("6x8",3);
|
||||||
|
// draw the current counter value
|
||||||
|
|
||||||
|
g.drawString(msToTime(counter*1000), g.getWidth()/2 - 30, g.getHeight()/2);
|
||||||
|
// optional - this keeps the watch LCD lit up
|
||||||
|
g.flip();
|
||||||
|
}
|
||||||
|
|
||||||
|
function countDown() {
|
||||||
|
if(counter > 0) {
|
||||||
|
if (started) {
|
||||||
|
counter--;
|
||||||
|
drawInterface();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (started) {
|
||||||
|
Bangle.buzz();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
setWatch((p) => {
|
||||||
|
if (p.time - p.lastTime < 0.1) {
|
||||||
|
counter = 0;
|
||||||
|
started = false;
|
||||||
|
} else {
|
||||||
|
counter+=60*5;
|
||||||
|
}
|
||||||
|
drawInterface();
|
||||||
|
}, BTN1, {repeat:true});
|
||||||
|
|
||||||
|
setWatch(() => {
|
||||||
|
counter+=30;
|
||||||
|
drawInterface();
|
||||||
|
}, BTN2, {repeat:true});
|
||||||
|
|
||||||
|
setWatch(() => {
|
||||||
|
counter+=5;
|
||||||
|
drawInterface();
|
||||||
|
}, BTN3, {repeat:true});
|
||||||
|
|
||||||
|
Bangle.on('touch', function(button) {
|
||||||
|
started = !started;
|
||||||
|
});
|
||||||
|
|
||||||
|
var interval = setInterval(countDown, 1000);
|
||||||
|
drawInterface();
|
||||||
Loading…
Reference in New Issue