53 lines
1.9 KiB
JavaScript
53 lines
1.9 KiB
JavaScript
{
|
|
// If doing regular loads, not Bangle.load, this is used:
|
|
if (global.__FILE__=="messagegui.new.js") {
|
|
onTwistEmitDrag();
|
|
}
|
|
|
|
// If Fastload Utils is installed this is used:
|
|
Bangle.on("message", (_, msg)=>{if (Bangle.CLOCK && msg.new) {
|
|
setTimeout(()=>{
|
|
if (global.__FILE__=="messagegui.new.js") {
|
|
onTwistEmitDrag();
|
|
}
|
|
},1000)
|
|
// It feels like there's a more elegant solution than checking the filename
|
|
// after 1000 milliseconds. But this at least seems to work w/o sometimes
|
|
// activating when it shouldn't.
|
|
// Maybe we could add events for when fast load and/or Bangle.uiRemove occurs?
|
|
// Then that could be used similarly to boot code and/or the `kill` event.
|
|
}});
|
|
|
|
// twistThreshold How much acceleration to register a twist of the watch strap? Can be negative for opposite direction. default = 800
|
|
// twistMaxY Maximum acceleration in Y to trigger a twist (low Y means watch is facing the right way up). default = -800
|
|
// twistTimeout How little time (in ms) must a twist take from low->high acceleration? default = 1000
|
|
function onTwistEmitDrag() {
|
|
Bangle.setOptions({twistThreshold:2500, twistMaxY:-800, twistTimeout:400});
|
|
let twistHandler = ()=>{
|
|
Bangle.setLocked(false);
|
|
Bangle.setLCDPower(true);
|
|
Bangle.emit("swipe",0,-1);
|
|
let i = 25;
|
|
const int = setInterval(() => {
|
|
Bangle.emit("drag", {dy:-3})
|
|
i--;
|
|
if (i<1) clearInterval(int);
|
|
}, 10);
|
|
}
|
|
Bangle.on("twist", twistHandler);
|
|
// Give messagegui some extra time to add its remove function to
|
|
// Bangle.uiRemove, then attach msgtwscr remove logic.
|
|
setTimeout(
|
|
()=>{if (Bangle.uiRemove) {
|
|
let showMessageUIRemove = Bangle.uiRemove;
|
|
Bangle.uiRemove = function () {
|
|
Bangle.removeListener("twist", twistHandler)
|
|
showMessageUIRemove();
|
|
}
|
|
}},
|
|
500
|
|
)
|
|
|
|
}
|
|
}
|