Approved content
The content below is provided by a partner.
microbit-pxt-timeanddate=github:bsiever/microbit-pxt-timeanddate
This extension allows the micro:bit to keep track of the time and date. It can also be used for primitive stopwatch-like capabilities.
It’s importantant to be aware that:
There are three common approaches to setting the time:
Using a reasonable “startup value”, as described in Synchronize at startup, will make the last two approaches easier.
Synchronizing the time at startup is the easiest approach, but it requires re-programming the micro:bit every time the time needs to be set, like whenever it is restarted. The start up process just needs to include setting the time, like:
timeanddate.setDate(1, 20, 2022)
timeanddate.set24HourTime(13, 30, 0)
Once you’re ready to program the micro:bit:
For the example above, the micro:bit would be reset at 13:29.58s on Jan. 20, 2022. It would set the date and time at almost exactly the time indicated in the set block.
This is the approach used by mechanical clocks, where time is set by moving the minute hand forward (or, possibly, backwards). Moving the minutes forward may cause the hours to change too. And as hours change the date could change, etc.
This is a tedious way to set dates and should probably only be used when the date will never be needed and just the time needs to be set.
Here’s the simplest approach, where the buttons are dedicated to setting the time :
input.onButtonPressed(Button.A, function () {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Minutes)
})
input.onButtonPressed(Button.B, function () {
timeanddate.advanceBy(-1, timeanddate.TimeUnit.Minutes)
})
The buttons change the time one minute at a time (forward or backward). Advancing the minutes beyond 59 or before 0 will cause the hour to change.
Here’s an alternate approach that can be used to set the time at startup by advancing hours and minutes.
input.onButtonPressed(Button.A, function () {
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
})
basic.showString("hr:")
while (!(input.buttonIsPressed(Button.B))) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Hours)
}
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
}
basic.showString("min:")
while (!(input.buttonIsPressed(Button.B))) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Minutes)
}
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
}
If setting the date this way it’s best to use the [timeanddate.setDate()]
to select a year near the current year.
This may not work correctly when the total time is before the year specified in [timeanddate.setDate()]
. That is, if [timeanddate.setDate(1, 20, 2024)]
specifies 2024, then negative values should not “rollback” before Jan 1, 2024.
This approach should be done on each digits of the time (minutes, hours, and if the date is important too, day, month, and year).
Here’s an example that focuses on just the minutes (additional code is needed for hours, etc.):
input.onButtonPressed(Button.B, function () {
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
timeanddate.set24HourTime(hour, minute + -1, second)
})
})
input.onButtonPressed(Button.A, function () {
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
timeanddate.set24HourTime(hour, minute + 1, second)
})
})
Since the time setting commands use modular arithmetic, adding and subtracting to the prior value will “rollover” in the expected way and will not impact the hours, like the advancing approach would.
The following can be used to set the time at startup. It will scroll the time continuously until you are done setting it.
Once the time has been set the additional code that displays the time when “A” is pressed.
input.onButtonPressed(Button.A, function () {
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMMAMPM))
})
timeanddate.setTime(11, 30, 0, timeanddate.MornNight.AM)
basic.showString("Set Hour")
while (!(input.buttonIsPressed(Button.AB))) {
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.set24HourTime(hour + 1, minute, 0)
} else if (input.buttonIsPressed(Button.B)) {
timeanddate.set24HourTime(hour - 1, minute, 0)
}
})
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMMAMPM))
}
basic.showString("Set Min")
while (!(input.buttonIsPressed(Button.AB))) {
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.set24HourTime(hour, minute + 1, 0)
} else if (input.buttonIsPressed(Button.B)) {
timeanddate.set24HourTime(hour, minute - 1, 0)
}
})
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMMAMPM))
}
Use [timeanddate.set24HourTime()]
to set the time using 24-hour format (hours from 0-23, minutes from 0-59, seconds from 0-59). See Setting the Time.
Use [timeanddate.setTime()]
to set the time using am/pm format (hours from 1-12, minutes from 0-59, seconds from 0-59). See Setting the Time.
Use [timeanddate.setDate()]
to set the date (month from 1-12, day from 1-31, year from 0000-9999). See Setting the Time.
timeanddate.time(timeanddate.TimeFormat.HMM)
Provides the current time in the selected format.
If no time has been set, the time will be based on when the micro:bit started (was reset). By default time starts at 00:00.00 on 0000-01-01.
timeanddate.date(timeanddate.DateFormat.MD)
Provides the current date in the specified format.
If no date is set, it will start at 0000-01-01 when the micro:bit starts.
Often a “timestamp” is needed to record events, like when measurements are taken for a science experiment. Use:
timeanddate.dateTime()
It provides the date and time in the format: YYYY-MM-DD HH:MM.SS. This format can easily be “sorted” in spreadsheets. This ensures that the date and time are retrieved at the same time (accessing them separately may lead to a date after the time if the the time is checked at almost exactly the end of the day). See Setting the Time.
Numeric values of time/date can be useful for things like alarm clocks. Use:
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
})
timeanddate.advanceBy(amount: number, unit: TimeUnit)
Can be used to advance or set back the current time. It works by adding time to the current time in the given units, with carries. Adding to minutes may cause an overflow and change the hours. Negative amounts can be used to set the clock backwards, however the clock can not be set back before the beginning of the year originally used to set the date (or year 0 if the date wasn’t set).
It behaves like a mechanical clock: Advancing the minutes causes the hour to advance as well. It may be useful for adjusting the clocks accuracy (adding seconds occasionally if it’s slow) or adjusting for changes in timezone or daylight savings time.
timeanddate.secondsSinceReset()
Reports the time (in seconds) since the micro:bit started.
timeanddate.onMinuteChanged(handler: () => void)
The provided code will run when the minute changes.
timeanddate.onHourChanged(handler: () => void)
The provided code will run when the hour changes.
timeanddate.onDayChanged(handler: () => void)
The provided code will run when the day changes.
Once you have the day, month, and year, you can use them on the:
timeanddate.dateToDayOfWeek()
to determine the day of the week. It returns a numeric code, where 0 is Monday, 1 is Tuesday, etc.
Once you have the day, month, and year, you can use them on the:
timeanddate.dateToDayOfYear()
to determine the ordinal day of the year. 1 is Jan. 1, 2, is Jan 2, etc. Dec. 31 is either 365 or 366 (in a leap year).
Accuracy can be estimated by comparing your micro:bit to an actual, accurate stopwatch.
Use the following program, which will start the time at 00:00.00 (just like a stop watch).
input.onButtonPressed(Button.A, function () {
basic.showString(timeanddate.dateTime())
})
input.onButtonPressed(Button.B, function () {
basic.clearScreen()
})
basic.showIcon(IconNames.Heart)
timeanddate.set24HourTime(0, 0, 0)
Use a stopwatch or stopwatch app on a computer/phone. To start measurement:
The micro:bit should be accurate to within about 1 second per day or better. This experiment depends on your reaction time, which is probably about 0-2 seconds. Consequently you may need to let it run for several days to estimate the accuracy.
To estimate the accuracy:
By use of setting time to 0:0.0 this can be used as a simple stopwatch. For example, for timing things that are less than 24 hours:
input.onButtonPressed(Button.A, function () {
timeanddate.set24HourTime(0, 0, 0)
})
input.onButtonPressed(Button.B, function () {
basic.showString(timeanddate.time(timeanddate.TimeFormat.HHMMSS24hr))
})
timeanddate.set24HourTime(0, 0, 0)
“A” starts counting and “B” shows the time elapsed since “A” was pressed (or the start)
[timeanddate.numericTime()]
)[timeanddate.numericTime()]
uses 24-hour format time, so 3pm is 15:00. [basic.pause()]
.Here’s a simple clock that will show time in binary code. Each column represents a digit of the current 12-hour time. The bottom most LED in each column is the 1’s digit, the second from the bottom is the 2’s, etc. The middle column of the display will blink a pattern off and on to indicate each second.
Click here to open the shared project
function binaryDisplayOf (num: number, col: number) {
for (let index = 0; index <= 4; index++) {
if (Math.idiv(num, 2 ** index) % 2 == 1) {
led.plot(col, 4 - index)
} else {
led.unplot(col, 4 - index)
}
}
}
input.onButtonPressed(Button.B, function () {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Minutes)
})
input.onButtonPressed(Button.A, function () {
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
})
input.onButtonPressed(Button.AB, function () {
timeanddate.advanceBy(15, timeanddate.TimeUnit.Minutes)
})
basic.showString("hr:")
while (!(input.buttonIsPressed(Button.B))) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Hours)
}
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
}
basic.showString("min:")
while (!(input.buttonIsPressed(Button.B))) {
if (input.buttonIsPressed(Button.A)) {
timeanddate.advanceBy(1, timeanddate.TimeUnit.Minutes)
}
basic.showString(timeanddate.time(timeanddate.TimeFormat.HMM))
}
let blink = false
basic.forever(function () {
timeanddate.numericTime(function (hour, minute, second, month, day, year) {
hour = 0 % 12
if (hour == 0) {
hour = 12
}
binaryDisplayOf(Math.idiv(hour, 10), 0)
binaryDisplayOf(hour % 10, 1)
binaryDisplayOf(Math.idiv(minute, 10), 3)
binaryDisplayOf(minute % 10, 4)
})
basic.pause(1000)
blink = !(blink)
if (blink) {
binaryDisplayOf(10, 2)
} else {
binaryDisplayOf(0, 2)
}
})
Here’s a simple stopwatch. “A” starts and stops the count. The count will be automatically displayed when it’s stopped, but pressing “B” will re-display it.
Click here to open the shared project
input.onButtonPressed(Button.A, function () {
running = !(running)
if (running) {
timeanddate.set24HourTime(0, 0, 0)
} else {
captured = timeanddate.time(timeanddate.TimeFormat.HHMMSS24hr)
basic.showString(captured)
}
})
input.onButtonPressed(Button.B, function () {
if (!(running)) {
basic.showString(captured)
}
})
let dotLocation = 0
let xy = 0
let captured = ""
let running = false
running = false
let coords = [11, 21, 31, 32, 33, 23, 13, 12]
basic.forever(function () {
if (running) {
basic.clearScreen()
xy = coords[dotLocation]
led.toggle(Math.idiv(xy, 10), xy % 10)
basic.pause(1000/8)
dotLocation = (dotLocation + 1) % 8
} else {
basic.showIcon(IconNames.No)
}
})
makeCodeRender(“{{ site.makecode.home_url }}”, “{{ site.github.owner_name }}/{{ site.github.repository_name }}”);
microbit-pxt-timeanddate=github:bsiever/microbit-pxt-timeanddate#v2.0.33