forked from FOSS/BangleApps
Color depending on value (green -> red, red -> green)
parent
b02c2f4de8
commit
93fb41dfe0
|
@ -17,3 +17,4 @@
|
||||||
Fix sunprogress calculation during night
|
Fix sunprogress calculation during night
|
||||||
Refactor settings menu
|
Refactor settings menu
|
||||||
Colors of circles can be configured
|
Colors of circles can be configured
|
||||||
|
Color depending on value (green -> red, red -> green) option
|
||||||
|
|
|
@ -17,7 +17,10 @@ It can show the following information (this can be configured):
|
||||||
* Temperature, air pressure or altitude from internal pressure sensor
|
* Temperature, air pressure or altitude from internal pressure sensor
|
||||||
|
|
||||||
|
|
||||||
The color of each circle can be configured.
|
The color of each circle can be configured. The following colors are available:
|
||||||
|
* Basic colors (red, green, blue, yellow, magenta, cyan, black, white)
|
||||||
|
* Color depending on value (green -> red, red -> green)
|
||||||
|
|
||||||
|
|
||||||
## Screenshots
|
## Screenshots
|
||||||

|

|
||||||
|
|
|
@ -231,16 +231,33 @@ function getCircleColor(type) {
|
||||||
if (color && color != "") return color;
|
if (color && color != "") return color;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCircleIconColor(type, color) {
|
function getCircleIconColor(type, color, percent) {
|
||||||
const pos = getCirclePosition(type);
|
const pos = getCirclePosition(type);
|
||||||
const colorizeIcon = settings["circle" + (pos + 1) + "colorizeIcon"] == true;
|
const colorizeIcon = settings["circle" + (pos + 1) + "colorizeIcon"] == true;
|
||||||
if (colorizeIcon) {
|
if (colorizeIcon) {
|
||||||
return color;
|
return getGradientColor(color, percent);
|
||||||
} else {
|
} else {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getGradientColor(color, percent) {
|
||||||
|
if (isNaN(percent)) percent = 0;
|
||||||
|
if (percent > 1) percent = 1;
|
||||||
|
const colorList = [
|
||||||
|
'#00FF00', '#80FF00', '#FFFF00', '#FF8000', '#FF0000'
|
||||||
|
];
|
||||||
|
if (color == "green-red") {
|
||||||
|
const colorIndex = Math.round(colorList.length * percent);
|
||||||
|
return colorList[Math.min(colorIndex, colorList.length) - 1] || "#00ff00";
|
||||||
|
}
|
||||||
|
if (color == "red-green") {
|
||||||
|
const colorIndex = colorList.length - Math.round(colorList.length * percent);
|
||||||
|
return colorList[Math.min(colorIndex, colorList.length)] || "#ff0000";
|
||||||
|
}
|
||||||
|
return color;
|
||||||
|
}
|
||||||
|
|
||||||
function getImage(graphic, color) {
|
function getImage(graphic, color) {
|
||||||
if (!color || color == "") {
|
if (!color || color == "") {
|
||||||
return graphic;
|
return graphic;
|
||||||
|
@ -264,9 +281,10 @@ function drawSteps(w) {
|
||||||
|
|
||||||
const color = getCircleColor("steps") || colorBlue;
|
const color = getCircleColor("steps") || colorBlue;
|
||||||
|
|
||||||
|
let percent;
|
||||||
const stepGoal = settings.stepGoal || 10000;
|
const stepGoal = settings.stepGoal || 10000;
|
||||||
if (stepGoal > 0) {
|
if (stepGoal > 0) {
|
||||||
let percent = steps / stepGoal;
|
percent = steps / stepGoal;
|
||||||
if (stepGoal < steps) percent = 1;
|
if (stepGoal < steps) percent = 1;
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
@ -275,7 +293,7 @@ function drawSteps(w) {
|
||||||
|
|
||||||
writeCircleText(w, shortValue(steps));
|
writeCircleText(w, shortValue(steps));
|
||||||
|
|
||||||
g.drawImage(getImage(shoesIcon, getCircleIconColor("steps", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(shoesIcon, getCircleIconColor("steps", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawStepsDistance(w) {
|
function drawStepsDistance(w) {
|
||||||
|
@ -288,9 +306,10 @@ function drawStepsDistance(w) {
|
||||||
|
|
||||||
const color = getCircleColor("stepsDistance") || colorGreen;
|
const color = getCircleColor("stepsDistance") || colorGreen;
|
||||||
|
|
||||||
|
let percent;
|
||||||
const stepDistanceGoal = settings.stepDistanceGoal || 8000;
|
const stepDistanceGoal = settings.stepDistanceGoal || 8000;
|
||||||
if (stepDistanceGoal > 0) {
|
if (stepDistanceGoal > 0) {
|
||||||
let percent = stepsDistance / stepDistanceGoal;
|
percent = stepsDistance / stepDistanceGoal;
|
||||||
if (stepDistanceGoal < stepsDistance) percent = 1;
|
if (stepDistanceGoal < stepsDistance) percent = 1;
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
@ -299,7 +318,7 @@ function drawStepsDistance(w) {
|
||||||
|
|
||||||
writeCircleText(w, shortValue(stepsDistance));
|
writeCircleText(w, shortValue(stepsDistance));
|
||||||
|
|
||||||
g.drawImage(getImage(shoesIcon, getCircleIconColor("stepsDistance", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(shoesIcon, getCircleIconColor("stepsDistance", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawHeartRate(w) {
|
function drawHeartRate(w) {
|
||||||
|
@ -309,10 +328,12 @@ function drawHeartRate(w) {
|
||||||
|
|
||||||
const color = getCircleColor("hr") || colorRed;
|
const color = getCircleColor("hr") || colorRed;
|
||||||
|
|
||||||
|
let percent;
|
||||||
if (hrtValue != undefined) {
|
if (hrtValue != undefined) {
|
||||||
const minHR = settings.minHR || 40;
|
const minHR = settings.minHR || 40;
|
||||||
const maxHR = settings.maxHR || 200;
|
const maxHR = settings.maxHR || 200;
|
||||||
const percent = (hrtValue - minHR) / (maxHR - minHR);
|
percent = (hrtValue - minHR) / (maxHR - minHR);
|
||||||
|
if (isNaN(percent)) percent = 0;
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -320,7 +341,7 @@ function drawHeartRate(w) {
|
||||||
|
|
||||||
writeCircleText(w, hrtValue != undefined ? hrtValue : "-");
|
writeCircleText(w, hrtValue != undefined ? hrtValue : "-");
|
||||||
|
|
||||||
g.drawImage(getImage(heartIcon, getCircleIconColor("hr", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(heartIcon, getCircleIconColor("hr", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawBattery(w) {
|
function drawBattery(w) {
|
||||||
|
@ -331,8 +352,9 @@ function drawBattery(w) {
|
||||||
|
|
||||||
let color = getCircleColor("battery") || colorYellow;
|
let color = getCircleColor("battery") || colorYellow;
|
||||||
|
|
||||||
|
let percent;
|
||||||
if (battery > 0) {
|
if (battery > 0) {
|
||||||
const percent = battery / 100;
|
percent = battery / 100;
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -347,7 +369,7 @@ function drawBattery(w) {
|
||||||
}
|
}
|
||||||
writeCircleText(w, battery + '%');
|
writeCircleText(w, battery + '%');
|
||||||
|
|
||||||
g.drawImage(getImage(powerIcon, getCircleIconColor("battery", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(powerIcon, getCircleIconColor("battery", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawWeather(w) {
|
function drawWeather(w) {
|
||||||
|
@ -359,13 +381,14 @@ function drawWeather(w) {
|
||||||
drawCircleBackground(w);
|
drawCircleBackground(w);
|
||||||
|
|
||||||
const color = getCircleColor("weather") || colorYellow;
|
const color = getCircleColor("weather") || colorYellow;
|
||||||
|
let percent;
|
||||||
const data = settings.weatherCircleData || "humidity";
|
const data = settings.weatherCircleData || "humidity";
|
||||||
switch (data) {
|
switch (data) {
|
||||||
case "humidity":
|
case "humidity":
|
||||||
const humidity = weather ? weather.hum : undefined;
|
const humidity = weather ? weather.hum : undefined;
|
||||||
if (humidity >= 0) {
|
if (humidity >= 0) {
|
||||||
drawGauge(w, h3, humidity / 100, color);
|
percent = humidity / 100;
|
||||||
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "wind":
|
case "wind":
|
||||||
|
@ -376,7 +399,8 @@ function drawWeather(w) {
|
||||||
wind[1] = windAsBeaufort(wind[1]);
|
wind[1] = windAsBeaufort(wind[1]);
|
||||||
}
|
}
|
||||||
// wind goes from 0 to 12 (see https://en.wikipedia.org/wiki/Beaufort_scale)
|
// wind goes from 0 to 12 (see https://en.wikipedia.org/wiki/Beaufort_scale)
|
||||||
drawGauge(w, h3, wind[1] / 12, color);
|
percent = wind[1] / 12;
|
||||||
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -390,7 +414,7 @@ function drawWeather(w) {
|
||||||
|
|
||||||
if (code > 0) {
|
if (code > 0) {
|
||||||
const icon = getWeatherIconByCode(code);
|
const icon = getWeatherIconByCode(code);
|
||||||
if (icon) g.drawImage(getImage(icon, getCircleIconColor("weather", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
if (icon) g.drawImage(getImage(icon, getCircleIconColor("weather", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
} else {
|
} else {
|
||||||
g.drawString("?", w, h3 + radiusOuter);
|
g.drawString("?", w, h3 + radiusOuter);
|
||||||
}
|
}
|
||||||
|
@ -403,21 +427,13 @@ function drawSunProgress(w) {
|
||||||
|
|
||||||
drawCircleBackground(w);
|
drawCircleBackground(w);
|
||||||
|
|
||||||
const color = getCircleColor("sunpgrogress") || colorYellow;
|
const color = getCircleColor("sunprogress") || colorYellow;
|
||||||
|
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
|
|
||||||
drawInnerCircleAndTriangle(w);
|
drawInnerCircleAndTriangle(w);
|
||||||
|
|
||||||
let icon = sunSetDown;
|
let icon = sunSetDown;
|
||||||
if (isDay()) {
|
|
||||||
// day
|
|
||||||
icon = sunSetDown;
|
|
||||||
} else {
|
|
||||||
// night
|
|
||||||
icon = sunSetUp;
|
|
||||||
}
|
|
||||||
|
|
||||||
let text = "?";
|
let text = "?";
|
||||||
const times = getSunData();
|
const times = getSunData();
|
||||||
if (times != undefined) {
|
if (times != undefined) {
|
||||||
|
@ -432,15 +448,17 @@ function drawSunProgress(w) {
|
||||||
} else {
|
} else {
|
||||||
text = formatSeconds(sunRise - now);
|
text = formatSeconds(sunRise - now);
|
||||||
}
|
}
|
||||||
|
icon = sunSetUp;
|
||||||
} else {
|
} else {
|
||||||
// day, approx sunrise tomorrow:
|
// day, approx sunrise tomorrow:
|
||||||
text = formatSeconds(sunSet - now);
|
text = formatSeconds(sunSet - now);
|
||||||
|
icon = sunSetDown;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
writeCircleText(w, text);
|
writeCircleText(w, text);
|
||||||
|
|
||||||
g.drawImage(getImage(icon, getCircleIconColor("sunprogress", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(icon, getCircleIconColor("sunprogress", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawTemperature(w) {
|
function drawTemperature(w) {
|
||||||
|
@ -452,18 +470,18 @@ function drawTemperature(w) {
|
||||||
const color = getCircleColor("temperature") || colorGreen;
|
const color = getCircleColor("temperature") || colorGreen;
|
||||||
|
|
||||||
drawInnerCircleAndTriangle(w);
|
drawInnerCircleAndTriangle(w);
|
||||||
|
let percent;
|
||||||
if (temperature) {
|
if (temperature) {
|
||||||
const min = -40;
|
const min = -40;
|
||||||
const max = 85;
|
const max = 85;
|
||||||
const percent = (temperature - min) / (max - min);
|
percent = (temperature - min) / (max - min);
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (temperature)
|
if (temperature)
|
||||||
writeCircleText(w, locale.temp(temperature));
|
writeCircleText(w, locale.temp(temperature));
|
||||||
|
|
||||||
g.drawImage(getImage(temperatureIcon, getCircleIconColor("temperature", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(temperatureIcon, getCircleIconColor("temperature", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
|
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
|
@ -482,17 +500,18 @@ function drawPressure(w) {
|
||||||
|
|
||||||
drawInnerCircleAndTriangle(w);
|
drawInnerCircleAndTriangle(w);
|
||||||
|
|
||||||
|
let percent;
|
||||||
if (pressure && pressure > 0) {
|
if (pressure && pressure > 0) {
|
||||||
const minPressure = 950;
|
const minPressure = 950;
|
||||||
const maxPressure = 1050;
|
const maxPressure = 1050;
|
||||||
const percent = (pressure - minPressure) / (maxPressure - minPressure);
|
percent = (pressure - minPressure) / (maxPressure - minPressure);
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pressure)
|
if (pressure)
|
||||||
writeCircleText(w, Math.round(pressure));
|
writeCircleText(w, Math.round(pressure));
|
||||||
|
|
||||||
g.drawImage(getImage(temperatureIcon, getCircleIconColor("pressure", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(temperatureIcon, getCircleIconColor("pressure", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
|
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
|
@ -511,17 +530,18 @@ function drawAltitude(w) {
|
||||||
|
|
||||||
drawInnerCircleAndTriangle(w);
|
drawInnerCircleAndTriangle(w);
|
||||||
|
|
||||||
|
let percent;
|
||||||
if (altitude) {
|
if (altitude) {
|
||||||
const min = 0;
|
const min = 0;
|
||||||
const max = 10000;
|
const max = 10000;
|
||||||
const percent = (altitude - min) / (max - min);
|
percent = (altitude - min) / (max - min);
|
||||||
drawGauge(w, h3, percent, color);
|
drawGauge(w, h3, percent, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (altitude)
|
if (altitude)
|
||||||
writeCircleText(w, locale.distance(Math.round(altitude)));
|
writeCircleText(w, locale.distance(Math.round(altitude)));
|
||||||
|
|
||||||
g.drawImage(getImage(temperatureIcon, getCircleIconColor("altitude", color)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
g.drawImage(getImage(temperatureIcon, getCircleIconColor("altitude", color, percent)), w - iconOffset, h3 + radiusOuter - iconOffset);
|
||||||
|
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
|
@ -691,6 +711,7 @@ function drawGauge(cx, cy, percent, color) {
|
||||||
const startRotation = -offset;
|
const startRotation = -offset;
|
||||||
const endRotation = startRotation - ((end - offset) * percent);
|
const endRotation = startRotation - ((end - offset) * percent);
|
||||||
|
|
||||||
|
color = getGradientColor(color, percent);
|
||||||
g.setColor(color);
|
g.setColor(color);
|
||||||
|
|
||||||
for (let i = startRotation; i > endRotation - size; i -= size) {
|
for (let i = startRotation; i > endRotation - size; i -= size) {
|
||||||
|
|
|
@ -10,8 +10,8 @@
|
||||||
const valuesCircleTypes = ["steps", "stepsDist", "hr", "battery", "weather", "sunprogress", "empty", "temperature", "pressure", "altitude"];
|
const valuesCircleTypes = ["steps", "stepsDist", "hr", "battery", "weather", "sunprogress", "empty", "temperature", "pressure", "altitude"];
|
||||||
const namesCircleTypes = ["steps", "distance", "heart", "battery", "weather", "sun progress", "empty", "temperature", "pressure", "altitude"];
|
const namesCircleTypes = ["steps", "distance", "heart", "battery", "weather", "sun progress", "empty", "temperature", "pressure", "altitude"];
|
||||||
|
|
||||||
const valuesColors = ["", "#ff0000", "#00ff00", "#0000ff", "#ffff00", "#ff00ff", "#00ffff", "#fff", "#000"];
|
const valuesColors = ["", "#ff0000", "#00ff00", "#0000ff", "#ffff00", "#ff00ff", "#00ffff", "#fff", "#000", "green-red", "red-green"];
|
||||||
const namesColors = ["default", "red", "green", "blue", "yellow", "magenta", "cyan", "white", "black"];
|
const namesColors = ["default", "red", "green", "blue", "yellow", "magenta", "cyan", "white", "black", "green->red", "red->green"];
|
||||||
|
|
||||||
const weatherData = ["humidity", "wind", "empty"];
|
const weatherData = ["humidity", "wind", "empty"];
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue