From a2ce68fea4cffac5ad97503cb12f6897ac3a8cdc Mon Sep 17 00:00:00 2001 From: Anton Date: Wed, 11 Sep 2024 13:37:41 +0200 Subject: [PATCH 1/2] Use 'locale` in clock tutorial --- tutorials/Bangle.js Clock.md | 48 +++++++++++++++++++++--------------- 1 file changed, 28 insertions(+), 20 deletions(-) diff --git a/tutorials/Bangle.js Clock.md b/tutorials/Bangle.js Clock.md index 58379b61..02191524 100644 --- a/tutorials/Bangle.js Clock.md +++ b/tutorials/Bangle.js Clock.md @@ -23,8 +23,9 @@ Copy the following code to the right of the IDE and click Upload ![](data:image/ function draw() { // work out how to display the current time var d = new Date(); - var h = d.getHours(), m = d.getMinutes(); - var time = h + ":" + m.toString().padStart(2,0); + var clock = require("locale").time(d); + var meridian = require("locale").meridian(d); + var time = clock + " " + meridian; // Reset the state of the graphics library g.reset(); @@ -44,7 +45,7 @@ var secondInterval = setInterval(draw, 1000); You'll now have some tiny text in the middle of the screen which displays the time. -The `m.toString().padStart(2,0)` code zero-pads the minutes for us (so 1 minute past 12 gets written as `"12:01"` rather than `"12:1"`). +The `locale` module will print the clock in different formats depending on each user's language and area. **Why is the code formatted like this?** Check out the [Code Style](/Code+Style) page for some tips and the reasoning behind it. @@ -69,17 +70,21 @@ const X = g.getWidth()/2 + 45, function draw() { // work out how to display the current time var d = new Date(); - var h = d.getHours(), m = d.getMinutes(); - var time = (" "+h).substr(-2) + ":" + m.toString().padStart(2,0); + var clock = require("locale").time(d, 1 /*omit seconds*/); + var seconds = d.getSeconds().toString().padStart(2,0); + var meridian = require("locale").meridian(d); // Reset the state of the graphics library g.reset(); // draw the current time (4x size 7 segment) - g.setFont("7x11Numeric7Seg",4); g.setFontAlign(1,1); // align bottom right - g.drawString(time, X, Y, true /*clear background*/); + g.setFont("7x11Numeric7Seg:4"); + g.drawString(clock, X, Y, true /*clear background*/); // draw the seconds (2x size 7 segment) - g.setFont("7x11Numeric7Seg",2); - g.drawString(("0"+d.getSeconds()).substr(-2), X+30, Y, true /*clear background*/); + g.setFontAlign(-1,1); // align bottom left + g.setFont("6x8:2"); + g.drawString(meridian, X+4, Y-26, true /*clear background*/); + g.setFont("7x11Numeric7Seg:2"); + g.drawString(seconds, X+2, Y, true /*clear background*/); } // Clear the screen once, at startup @@ -90,16 +95,15 @@ draw(); var secondInterval = setInterval(draw, 1000); ``` -![]() +![]() + +The `.toString().padStart(2,0)` code zero-pads the seconds for us (so 1 second gets written as `"01"` rather than `"1"`). **Note:** To avoid clearing the whole area here we're using the 4th argument to `drawString`, which clears the background (by default only the text itself is drawn). This only works because we know our text will always be the same length! -Finally, let's add the date. For this, we can use the `locale` library -which means that the data will be in the correct language for each user. - -Just add the following at the bottom of the `draw` function: +Finally, let's add the date. Just add the following at the bottom of the `draw` function: ```JS // draw the date, in a normal font @@ -195,17 +199,21 @@ const X = g.getWidth()/2 + 45, function draw() { // work out how to display the current time var d = new Date(); - var h = d.getHours(), m = d.getMinutes(); - var time = (" "+h).substr(-2) + ":" + m.toString().padStart(2,0); + var clock = require("locale").time(d, 1 /*omit seconds*/); + var seconds = d.getSeconds().toString().padStart(2,0); + var meridian = require("locale").meridian(d); // Reset the state of the graphics library g.reset(); // draw the current time (4x size 7 segment) - g.setFont("7x11Numeric7Seg",4); g.setFontAlign(1,1); // align bottom right - g.drawString(time, X, Y, true /*clear background*/); + g.setFont("7x11Numeric7Seg:4"); + g.drawString(clock, X, Y, true /*clear background*/); // draw the seconds (2x size 7 segment) - g.setFont("7x11Numeric7Seg",2); - g.drawString(("0"+d.getSeconds()).substr(-2), X+30, Y, true /*clear background*/); + g.setFontAlign(-1,1); // align bottom left + g.setFont("6x8:2"); + g.drawString(meridian, X+4, Y-26, true /*clear background*/); + g.setFont("7x11Numeric7Seg:2"); + g.drawString(seconds, X+2, Y, true /*clear background*/); // draw the date, in a normal font g.setFont("6x8"); g.setFontAlign(0,1); // align center bottom From ac8df6a35b0ce932961e3faffa16841eb3de1064 Mon Sep 17 00:00:00 2001 From: Gordon Williams Date: Wed, 11 Sep 2024 13:11:25 +0100 Subject: [PATCH 2/2] mention meridian in comments --- tutorials/Bangle.js Clock.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tutorials/Bangle.js Clock.md b/tutorials/Bangle.js Clock.md index 02191524..b04c5b9c 100644 --- a/tutorials/Bangle.js Clock.md +++ b/tutorials/Bangle.js Clock.md @@ -79,7 +79,7 @@ function draw() { g.setFontAlign(1,1); // align bottom right g.setFont("7x11Numeric7Seg:4"); g.drawString(clock, X, Y, true /*clear background*/); - // draw the seconds (2x size 7 segment) + // draw the meridian(am/pm) and seconds (2x size 7 segment) g.setFontAlign(-1,1); // align bottom left g.setFont("6x8:2"); g.drawString(meridian, X+4, Y-26, true /*clear background*/); @@ -208,7 +208,7 @@ function draw() { g.setFontAlign(1,1); // align bottom right g.setFont("7x11Numeric7Seg:4"); g.drawString(clock, X, Y, true /*clear background*/); - // draw the seconds (2x size 7 segment) + // draw the meridian(am/pm) and seconds (2x size 7 segment) g.setFontAlign(-1,1); // align bottom left g.setFont("6x8:2"); g.drawString(meridian, X+4, Y-26, true /*clear background*/);