commit
13f74e1542
|
|
@ -1 +1,2 @@
|
||||||
0.1: Initial release
|
0.1: Initial release
|
||||||
|
0.2: Draw line for 3d effect, fix number alignment
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,9 @@
|
||||||
# Measure Time
|
# Measure Time
|
||||||
|
|
||||||
Measure time in a fancy way. Inspired by a Watchface I had on my first Pebble Watch.
|
Measure time in a fancy way. Inspired by a Watchface I had on my first Pebble Watch.
|
||||||
|
Icon from [Flaticon created by Smartline]("https://www.flaticon.com/free-icons/scale")
|
||||||
|
|
||||||
Written by [prefectAtEarth](https://www.github.com/prefectAtEarth/)
|
Watchface written by [prefectAtEarth](https://www.github.com/prefectAtEarth/)
|
||||||
|
|
||||||

|

|
||||||
|

|
||||||
|
|
|
||||||
|
|
@ -1 +1 @@
|
||||||
require("heatshrink").decompress(atob("mEw4n/AAIHB/fe8EHrvv333xVS221jnnlFC7//9NP997zXWjHGn+EGJsu9wAC0AHBgugq99C5d0kUq1WtoAHBgnaw8nC5d9mdwgEN7QHBxvQ5nhGwQXNiQHB19A41xC5dy3YXCwAHBwkqx3tI5d3AAV8L4UIDYRkBogADpTOQhWqAAZOLAAuoxAABfyYXXI4pKRO4oACqBHl0QXWAC8IF4QABwpHRkUilALHgutvwvMBY8NoEHKakCqtHR5gAH1FY7wUFcYS/LI5Fwd4r7IqXuJ4uUAYMK1QABKhEKIAQAC1kW7SnDAAUlPxnBiN9xEnu93vx6KAAeHyMdI5wAGox3OS5GAU4oAEoAXJhTXGfigAWhAvWX6QvcT5nog5HJF5QXLX5AAC0levwXId5cNoAvJhWqAAILHgVAhxHMQaZfFwoXQI5YALO5ZHPC6bXDAAmADqYARhBHXkUilC/oA="))
|
require("heatshrink").decompress(atob("mEwgX/6AHCh////hAQIAB4ALCg4GBwF/BZH+gEfBYXBAYQLB/AbDBY3ggEBBZGAqFAGAQLE/0B6HgGAXB1WrBYP4g/QAQJHDgYLB/kf6H+BY//v/Q/+fEYwGBBYJHIBdJHBBcJTvR5anFBaKz/Wf6zhv4LBz4LG/kf6H+DgQjE/EH6ACBHY3+gPQ8EfI4+AqFAv4LH8EAgJfI/EAFwRHCAAIHB/0AFwQLGGAIuCOAILCh4GB8IKC"))
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,5 @@
|
||||||
{
|
{
|
||||||
require("Font7x11Numeric7Seg").add(Graphics);
|
require("Font7x11Numeric7Seg").add(Graphics);
|
||||||
g.setFont("7x11Numeric7Seg");
|
|
||||||
g.setFontAlign(0, 0);
|
|
||||||
|
|
||||||
const centerY = g.getHeight() / 2; //88
|
const centerY = g.getHeight() / 2; //88
|
||||||
const lineStart = 25;
|
const lineStart = 25;
|
||||||
|
|
@ -27,10 +25,10 @@
|
||||||
var steps = [0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1];
|
var steps = [0, 1, 0, 0, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1];
|
||||||
var stepsReversed = steps.slice();
|
var stepsReversed = steps.slice();
|
||||||
stepsReversed.reverse();
|
stepsReversed.reverse();
|
||||||
var polyLeftTop = [];
|
var polyLeftTop = [0, 0];
|
||||||
var polyLeftBottom = [];
|
var polyLeftBottom = [0, g.getHeight()];
|
||||||
var polyRightTop = [];
|
var polyRightTop = [g.getWidth() - 1, 0];
|
||||||
var polyRightBottom = [];
|
var polyRightBottom = [g.getWidth() - 1, g.getHeight()];
|
||||||
let xL = 0;
|
let xL = 0;
|
||||||
let xR = g.getWidth() - 1;
|
let xR = g.getWidth() - 1;
|
||||||
let yT = centerY - 13;
|
let yT = centerY - 13;
|
||||||
|
|
@ -70,6 +68,16 @@
|
||||||
g.fillPolyAA(polyRightBottom, true);
|
g.fillPolyAA(polyRightBottom, true);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let hourStringXOffset = function (hour) {
|
||||||
|
if (hour == 1) {
|
||||||
|
return lineEndFull - 5;
|
||||||
|
}
|
||||||
|
if (hour < 10 || hour >= 20) {
|
||||||
|
return lineEndFull + 5;
|
||||||
|
}
|
||||||
|
return lineEndFull - 5;
|
||||||
|
};
|
||||||
|
|
||||||
let drawTime = function () {
|
let drawTime = function () {
|
||||||
g.clear();
|
g.clear();
|
||||||
var d = new Date();
|
var d = new Date();
|
||||||
|
|
@ -86,19 +94,19 @@
|
||||||
|
|
||||||
var lineEnd = lineEndDefault;
|
var lineEnd = lineEndDefault;
|
||||||
g.setFont("7x11Numeric7Seg", 2);
|
g.setFont("7x11Numeric7Seg", 2);
|
||||||
g.setFontAlign(0, 0);
|
g.setFontAlign(-1, 0);
|
||||||
|
|
||||||
// gone
|
// gone
|
||||||
do {
|
do {
|
||||||
switch (yTopLines - 88 + mins) {
|
switch (yTopLines - 88 + mins) {
|
||||||
case -60:
|
case -60:
|
||||||
lineEnd = lineEndFull;
|
lineEnd = lineEndFull;
|
||||||
g.drawString(d.getHours() - 1, lineEnd + 10, yTopLines, true);
|
g.drawString(d.getHours()-1, hourStringXOffset(d.getHours()-1), yTopLines, true);
|
||||||
break;
|
break;
|
||||||
case 0:
|
case 0:
|
||||||
case 60:
|
case 60:
|
||||||
lineEnd = lineEndFull;
|
lineEnd = lineEndFull;
|
||||||
g.drawString(d.getHours(), lineEnd + 10, yTopLines, true);
|
g.drawString(d.getHours(), hourStringXOffset(d.getHours()), yTopLines, true);
|
||||||
break;
|
break;
|
||||||
case 45:
|
case 45:
|
||||||
case -45:
|
case -45:
|
||||||
|
|
@ -128,11 +136,11 @@
|
||||||
case 0:
|
case 0:
|
||||||
case 60:
|
case 60:
|
||||||
lineEnd = lineEndFull;
|
lineEnd = lineEndFull;
|
||||||
g.drawString(d.getHours() + 1, lineEnd + 10, yBottomLines, true);
|
g.drawString(d.getHours() + 1, hourStringXOffset(d.getHours()+1), yBottomLines, true);
|
||||||
break;
|
break;
|
||||||
case 120:
|
case 120:
|
||||||
lineEnd = lineEndFull;
|
lineEnd = lineEndFull;
|
||||||
g.drawString(d.getHours() + 2, lineEnd + 10, yBottomLines, true);
|
g.drawString(d.getHours() + 2, hourStringXOffset(d.getHours()+2), yBottomLines, true);
|
||||||
break;
|
break;
|
||||||
case 15:
|
case 15:
|
||||||
case 75:
|
case 75:
|
||||||
|
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 4.9 KiB After Width: | Height: | Size: 5.0 KiB |
|
|
@ -1,10 +1,13 @@
|
||||||
{
|
{
|
||||||
"id": "measuretime",
|
"id": "measuretime",
|
||||||
"name": "Measure Time",
|
"name": "Measure Time",
|
||||||
"version": "0.1",
|
"version": "0.2",
|
||||||
"description": "Measure Time in a fancy way.",
|
"description": "Measure Time in a fancy way.",
|
||||||
"icon": "small_measuretime.png",
|
"icon": "measuretime_icon.png",
|
||||||
"screenshots": [{ "url": "measuretime.png" }],
|
"screenshots": [
|
||||||
|
{ "url": "screenshot_light.png" },
|
||||||
|
{ "url": "screenshot_dark.png" }
|
||||||
|
],
|
||||||
"type": "clock",
|
"type": "clock",
|
||||||
"tags": "clock",
|
"tags": "clock",
|
||||||
"supports": ["BANGLEJS2"],
|
"supports": ["BANGLEJS2"],
|
||||||
|
|
|
||||||
Binary file not shown.
|
After Width: | Height: | Size: 896 B |
Binary file not shown.
|
After Width: | Height: | Size: 1.2 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 5.3 KiB |
Loading…
Reference in New Issue