forked from FOSS/BangleApps
initial commit for Vaporwave Sunset Clock
parent
c99676abcc
commit
6ae4e76b10
|
@ -0,0 +1 @@
|
|||
0.01: New App!
|
|
@ -0,0 +1,4 @@
|
|||
# Vaporwave Sunset Clock
|
||||
This is a simple clock with a Vaporwave Sunset theme.
|
||||
|
||||

|
|
@ -0,0 +1 @@
|
|||
require("heatshrink").decompress(atob("mEwwcAtu27YC/AX4C/AX4C/AVnXroRO3oDBtwRMv9p02atPTCJf7AwgRK74gBEYWmpoRJ7wGF5oRJ8wjFzoRJ+nTps0AQYRI24jGzc2CJAgEAQQREBQc1EAYCDugWDEYe/EZm+/fvAR33799ARwj/EfruIARAj/AQ88+fPARwjRA"))
|
|
@ -0,0 +1,138 @@
|
|||
Graphics.prototype.setFontMadeSunflower = function () {
|
||||
// Actual height 46 (45 - 0)
|
||||
return this.setFontCustom(
|
||||
E.toString(require('heatshrink').decompress(atob('AAmAAwt/AwsP/AHF/4WFj/8AwkB//AB1I7Hg/wBws+O6s4AwsfFgp3Gg//AwkDIQpYH//gUQpQFn4qFNo0P/w4aj44FgKJGjiCOEwIuFAwI9En4GBKYZKBAAI3CDgQeECoQWDCoYWDv4GCOQUPBwZWBEgglCj/+D4SXBgKaCF4IOBeQc/GgMDLod/RQLqDgIOGg4OFgE8BwKjDgIEBn6aFgZ7DBwbeDDoROCFgcfNoUHLIRoHAwYZCBwiVQGgIACKwQlDIwYWCCoQWENgYtCWQIACDwIcDgFAAYUIAQMOO4aaCIwUAjACBjwOFgIpDVIUfCwUfBwJZEboiGEO4gOCO4YOCh6VLBxCzOYR4ADg53CAAZoCAAaGDAAaGCBxYAGBwcfZoQ7Ch/8JwSkCfYV/SohzCSofwCIKGECIN/NAfwg/nO4kA/gOFj+HBwMD8F/bYIOCngIBn0HBwWAAoIRBBwM4BAP8BwgnB4AODMwQOFK4IsDCoJLBHYZmBOAIOBN4J4BBwYGB/wOG4EPNAiWBcAuABwSGC+AODGQIzBj4OCv4zBGAKkDEgSzEwACCEoQVCBwTVCn5MBABZxBAwgzDHYPAAQI2BCQIDBHwLyBNAIOCKgIhDLgIDBBwJrDO4QKBDoKGCIwV/g4OCFALZBXAIODnkBGAIOBhgFBjgOCBYQOEnwXBBwYjBBwomCBwY1CBwfjKYQ7DvpPBg4OC9+f8EBPYJoB+JnBPYUfEoIGBd4fABwRoC/DiCBwaFCSofgQoKVDF4KjBKgUfwDBBGYUBCII0Bc4UeVYbYEZIYADh7nFgF8AwsPFYL2EdwQADfIQADj/cCov5Bwv/VQIVE4IOEg/4BwraDCobmCCofwBwMYCobXBgKkBgE/wAOECoIOBgYOBZofAvAVCWQTCCYATCFBwreCB3AACgPBdAQACNAYODQwgOCQwYOKgAOGdAsfTALhEIQr3Bf4cD/kH//gLIfAv//EIX//inBEoIODO4ngngdBO4X+gYdBg4ODvEHCIIOCBYM8KYQOCAoJiBBwZiDBwN8OIYOCBYIOMLwQODv4OBHYhPBEAQOC8EBP4IOCaIQOEcAgOENAc/AwKGBgZ3BBwQ2Bn/gS4KkCg/+S4X+BwIKBUYIzCh4KBGgIzBgACBEoIVCAAQWBdAovBAwg6DcwbTBfghCDfgZgDDgYWECoQWDCoZDDQoR3CJAQlFAwZhCEgYOCEgWAn40Cn/5GIM/NIMH/jOBgAOCv+DBYSOC8AOCCIcDfwkPwE+fwcA+EDJ4IOCjwxDBwMB8BEBwAgCBILgCfwXARwoOEfwWAcAS0CjBxDQwQQBSoqPDbIjvEVojZEEoLoFv4VEAAsfdgg5CGAgOJDoxVDBxQ/FgJkEBws/AYIODR4IOEPAKVCBwJwCJwIOCWYgOBToQODg4OGWYQODCoQODCoTRCBwIGCHYYVCJwUf8YbCNAaqFj/vSwiGBPAojBWZqkGXQoOBJoIOEVYoALFAkfgBxBEIUPQ4QwCIYPwJoLGD/+BPAIGBDQP8BIIlCBYPnSobOB/9/SoYGB+6kETYUPGgLdCBgMfPYIpBHIV8BwPwSwUDBwM8C4IOBjgJBwA1BGIIOBnEAXYQODCwOABwk/HIIODJgPgBwU8LYQODGIJfBHYU/wBMB+JZFAAIOBNAQABBwJ3CNQYOC/oGBJgKVCz6VF/AGBUgSaBT4QGBOwQJBYQUPJALRDKoQvBcAQACv4VCBgKcBAAbZBIAQACLwYACNwIWEOARICJQYyCd4glBjB3E4EBd4hQBXAIOEXAIzBwYOEVwQOBg4OBBIQOBFwIYCh/Ah5CBBwMAvkBJgIOCEAM/BYLgBAQMHP4LgCgfBNQQRDRwUDBQMH36kCn/+KgRHBcAiXCd4icER4iGCTwiVCVoakCXgizBEgiOEaIi7FCwL1DFoToFgECAQL+DgIVBv4eE8EPHgZ5CcQQlC+EfFwY8BIwJEDB0g7Hj72BOIhPBnxqFAAQ'))),
|
||||
46,
|
||||
atob("DxMiFyAgIiAgICEgDw=="),
|
||||
60 | 65536
|
||||
);
|
||||
};
|
||||
|
||||
var sun_img = require("heatshrink").decompress(atob("2GwwZC/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4A/AH4AUjdt23btuAH/MNHwQCD7CA8AQlsIGsGHwwCD2BAzgI+IAQfAIOVp22bARZAxjaAKAQdsIOGatOmARuAIF02QBgCEIFsBQBwCDQlsNQB4CC7BBsQCACDIFcDQCACDsBBqjSDUtBBq6dtmwCTIFMGQCQCD0BBognTps0AScwINEmQa2mIE8BmmTpICVwBBnQCoCCIM8NknSpoCV6BBmhKDYzRBmfyACJIMyAXQdECpMkyQCXoBBlQbVgIMkSQbVIIMkaQbVoQf6DmyVpkwCZIMqDapJB/IP5BnghB/IL0gIP5B/IP5B/IP5B/IP5B/IP5B/IP5B4gBB/ILxAjIP5B/IP4AGiRBapBB/IP5BogRBaoBB/IP4CCIEgABIP5B/AAcJILGQIM0BILGAIP5BogBBYIE8AghBWkBB/INUAIKxApgESIKlIINUCIKlAINUAIKhArgEJIKWQINkBIKWAINkAIKRAtAAJBQIF8AiRBOpBBwgBBOIGMAhJBMyBBygEEIJUgIGYABiRBIpBA1ZBLC0QxSA4AH4A/AH4A/AGA"));
|
||||
|
||||
const COLOUR_BLACK = 0x0;
|
||||
const COLOUR_WHITE = 0xffff;
|
||||
const COLOUR_DARK_GREY = "#3F3F3F";
|
||||
const COLOUR_GREY = "#7F7F7F";
|
||||
const COLOUR_LIGHT_GREY = "#BFBFBF";
|
||||
const COLOUR_RED = "#FF0000";
|
||||
const COLOUR_BLUE = "#0000FF";
|
||||
const COLOUR_YELLOW = "#FFFF00";
|
||||
const COLOUR_LIGHT_CYAN = "#7FFFFF";
|
||||
const COLOUR_DARK_YELLOW = "#7F7F00";
|
||||
const COLOUR_DARK_CYAN = "#007F7F";
|
||||
const COLOUR_ORANGE = "#FF7F00";
|
||||
const COLOUR_VPW_GREEN = 0xf0f;
|
||||
const COLOUR_MAGENTA = "#ff00ff";
|
||||
|
||||
|
||||
function drawPolygonWithGrid(x1, y1, x2, y2, x3, y3, x4, y4, M, N) {
|
||||
// Draw the polygon
|
||||
g.drawLine(x1, y1, x2, y2);
|
||||
g.drawLine(x2, y2, x3, y3);
|
||||
g.drawLine(x3, y3, x4, y4);
|
||||
g.drawLine(x4, y4, x1, y1);
|
||||
|
||||
for (let i = 1; i < N; i++) {
|
||||
let xi1 = x1 + i * ((x2 - x1) / N);
|
||||
let yi1 = y1 + i * ((y2 - y1) / N);
|
||||
|
||||
let xi2 = x4 - i * ((x4 - x3) / N);
|
||||
let yi2 = y4 - i * ((y4 - y3) / N);
|
||||
|
||||
g.drawLine(xi1, yi1, xi2, yi2);
|
||||
}
|
||||
|
||||
for (let j = 1; j < M; j++) {
|
||||
let xi1 = x1 + j * ((x4 - x1) / M);
|
||||
let yi1 = y1 + j * ((y4 - y1) / M);
|
||||
|
||||
let xi2 = x2 - j * ((x2 - x3) / M);
|
||||
let yi2 = y2 - j * ((y2 - y3) / M);
|
||||
|
||||
g.drawLine(xi1, yi1, xi2, yi2);
|
||||
}
|
||||
}
|
||||
|
||||
var SCREEN_WIDTH = 176;
|
||||
var SCREEN_HEIGHT = 176;
|
||||
var GROUND_HEIGHT = 176 - 45;
|
||||
|
||||
var GRID_BASE_OFFSET = 100;
|
||||
|
||||
// timeout used to update every minute
|
||||
var drawTimeout;
|
||||
|
||||
// schedule a draw for the next minute
|
||||
function queueDraw() {
|
||||
if (drawTimeout) clearTimeout(drawTimeout);
|
||||
drawTimeout = setTimeout(function () {
|
||||
drawTimeout = undefined;
|
||||
draw();
|
||||
}, 60000 - (Date.now() % 60000));
|
||||
}
|
||||
|
||||
function draw() {
|
||||
var x = g.getWidth() / 2;
|
||||
var y = 24 + 20;
|
||||
|
||||
g.reset().clearRect(0, 24, g.getWidth(), g.getHeight());
|
||||
|
||||
//sky
|
||||
g.setColor(COLOUR_VPW_GREEN);
|
||||
g.fillRect(0, 24, SCREEN_WIDTH, GROUND_HEIGHT - 1);
|
||||
|
||||
g.drawImage(sun_img, 0, 0);
|
||||
|
||||
//ground
|
||||
g.setColor("#8000FF");
|
||||
g.fillRect(0, GROUND_HEIGHT, 176, SCREEN_HEIGHT);
|
||||
|
||||
//lines
|
||||
g.setColor(COLOUR_WHITE);
|
||||
drawPolygonWithGrid(0, GROUND_HEIGHT,
|
||||
SCREEN_WIDTH, GROUND_HEIGHT,
|
||||
SCREEN_WIDTH + GRID_BASE_OFFSET, SCREEN_HEIGHT - 1,
|
||||
0 - GRID_BASE_OFFSET, SCREEN_HEIGHT - 1,
|
||||
7, //vertical
|
||||
15); //horizontal
|
||||
|
||||
// work out locale-friendly date/time
|
||||
var date = new Date();
|
||||
var timeStr = require("locale").time(date, 1);
|
||||
var dateStr = require("locale").date(date).toUpperCase();
|
||||
var dowStr = require("locale").dow(date).toUpperCase();
|
||||
// draw time
|
||||
g.setFontAlign(0, 0).setFontMadeSunflower();
|
||||
g.drawString(timeStr, x, y + 20);
|
||||
// draw date
|
||||
y += 35;
|
||||
g.setFontAlign(0, 0, 1).setFont("6x8");
|
||||
g.drawString(dateStr, g.getWidth() - 8, g.getHeight() / 2);
|
||||
// draw the day of the week
|
||||
g.setFontAlign(0, 0, 3).setFont("6x8");
|
||||
g.drawString(dowStr, 8, g.getHeight() / 2);
|
||||
// queue draw in one minute
|
||||
queueDraw();
|
||||
// queue draw in one minute
|
||||
queueDraw();
|
||||
}
|
||||
|
||||
// Clear the screen once, at startup
|
||||
g.setTheme({ bg: COLOUR_VPW_GREEN, fg: "#fff", dark: true }).clear();
|
||||
// draw immediately at first, queue update
|
||||
draw();
|
||||
// Stop updates when LCD is off, restart when on
|
||||
Bangle.on('lcdPower', on => {
|
||||
if (on) {
|
||||
draw(); // draw immediately, queue redraw
|
||||
} else { // stop draw timer
|
||||
if (drawTimeout) clearTimeout(drawTimeout);
|
||||
drawTimeout = undefined;
|
||||
}
|
||||
});
|
||||
// Show launcher when middle button pressed
|
||||
Bangle.setUI("clock");
|
||||
// Load widgets
|
||||
Bangle.loadWidgets();
|
||||
Bangle.drawWidgets();
|
Binary file not shown.
After Width: | Height: | Size: 1.9 KiB |
|
@ -0,0 +1,19 @@
|
|||
{
|
||||
"id": "vpw_clock",
|
||||
"name": "Vaporwave Sunset Clock",
|
||||
"shortName": "Vaporwave Sunset",
|
||||
"type": "clock",
|
||||
"version":"0.01",
|
||||
"description": "A clock with a vaporwave sunset theme.",
|
||||
"tags": "clock",
|
||||
"src": "vpw_clock.app.js",
|
||||
"supports": ["BANGLEJS2"],
|
||||
"storage": [
|
||||
{"name":"vpw_clock.app.js","url":"app.js"},
|
||||
{"name":"vpw_clock.img","url":"app-icon.js","evaluate":true}
|
||||
],
|
||||
"icon": "app.png",
|
||||
"readme": "README.md",
|
||||
"screenshots": [{ "url": "screenshot.png" }],
|
||||
"allow_emulator":true
|
||||
}
|
Binary file not shown.
After Width: | Height: | Size: 3.9 KiB |
Loading…
Reference in New Issue