-
• #2
Agreed, maybe even Block them? I am working on a fullscreen LCARS watchface that just does not look good with the widgets. Alternatively if i could at least chose what Y the widgets were at I might be able to integrate them somewhat.
-
• #3
there is an App that let you hide/unhide the widgets, maybe it could help
-
• #4
Oh I hadn't seen that - I must study the API docs more
-
• #5
You can also chose not to draw the widgets on your watch face.
-
• #6
well I read that from the docs as well but the widgets get drawn by some external process regardless. So I removed all of them for now.
The watchface will integrate the function of the most important ones anyway. -
• #7
Agreed, maybe even Block them?
Just don't call
Bangle.loadWidgets
in your clock and you won't get them.In terms of moving them, the biggest issue is whether the app itself is aware that they have moved, but if you're writing the app then there's no problem :)
So... This is what the current drawWidgets function looks like: https://github.com/espruino/Espruino/blob/master/libs/js/banglejs/Bangle_drawWidgets_Q3.js
If you want to render them all down the left-hand side of the watch screen you can just add this to your watch face:
Bangle.drawWidgets = (function() { if (global.WIDGETS) { var y=0, maxw=0; for (var wd of WIDGETS) { wd.x = 0; wd.y = y; y += 24; maxw = Math.max(wd.width, maxw); } g.reset(); g.clearRect(0,0,maxw-1,g.getHeight()-1); try { for (wd of WIDGETS) wd.draw(wd); } catch(e) {print(e);} } })
I guess there's also the question of widget width since they can all be varying widths, and it is possible to rotate all the widgets too - you just have to override each widget's draw function so it renders to a buffer which you then rotate.
Bangle.drawWidgets = (function() { if (global.WIDGETS) { var y=0; for (var wd of WIDGETS) { wd.x = 0; wd.y = y; y += wd.width; } g.reset().clearRect(0,0,23,g.getHeight()-1); try { for (wd of WIDGETS) wd.draw(wd); } catch(e) {print(e);} } }); Bangle.loadWidgets(); Object.keys(WIDGETS).forEach(k => { var wd = WIDGETS[k]; wd._draw = wd.draw; wd.draw = function() { if (!wd.width) return; var og = g, oy=wd.y; g = Graphics.createArrayBuffer(24,wd.width,16,{msb:true}); g._reset = g.reset; g.reset = () => g._reset().setColor(og.theme.fg).setBgColor(og.theme.bg); g.setRotation(1).setBgColor(og.theme.bg).clear(); wd.y = 0; wd._draw(wd); wd.y = oy; og.drawImage(g,0,wd.y); g = og; }; }); Bangle.drawWidgets();
Would like to move the entire row of widgets to the left side, but I understand that widgets have their own positioning, is it possible to have a global override to move the entire bar to either side of the screen?