Warning
This procedure could be problematic if the micro:bit is shaken to much while it is used in counting.
||basic:on start|| block will display the title of the project. It will also declare the variables that will be used in the project. The A and B buttons are programmed to add 1 to the count for the trait associated with that button. ||input:on shake|| event can be programmed to erase the data and start over.||basic:on Start|| event will display the title and purpose of the microbit in all caps, “POPULATION TRAIT COUNTER”. The text is put in the ||basic:show string|| block (the title is put in the ||basic:on start|| event so when the microbit is started up it will show what it is programmed to do. It is done in all CAPS because it is easier to read as it is displayed in the LED display).||variables:Variables|| toolbox create variables named trait1, trait2, and total. These will be used as counters to keep track of the for each trait counted. Variables are named to describe what they will be storing. Variables are usually named by using lowercase letters and/or digits. If it is a 2 word name, it is usually named using camelCaps (no spaces but a capital where the second word starts. Examples: totalCount, randNumber, etc.)let trait1 = 0
let trait2 = 0
let total = 0
basic.showString("POPULATION TRAIT COUNTER")The variables are declared in the ||basic:on start|| event and they are assigned a starting value of 0.
||input:on button A|| pressed event will be used to count the first trait by adding 1 to trait1 each time the button is pressed.||variables:change trait1 by 1|| is used to increment the number. In JavaScript this is done with the trait1 += 1 statement. It’s math statement to perform the same calculation could be trait1 = trait1 + 1. This can be read as trait1 gets it value from the current value of trait1 + 1.trait1.let trait1 = 0
// Add 1 to trait1
input.onButtonPressed(Button.A, () => {
    trait1 += 1
    basic.showNumber(trait1)
})trait2.let trait2 = 0
// Add 1 to trait2
input.onButtonPressed(Button.B, () => {
    trait2 += 1
    basic.showNumber(trait2)
})A+B ||input:on button pressed|| event is used to display the name and count for each trait and the total observations made by displaying the information on the LED screen.trait1 and trait2 are added to get a total count. The math for this would look like total = trait1 + trait2 (when calculations are make in computer programs the answer is always written on the left side of the “=” sign and the calculation is done on the right side of the sign. The “=” sign is general read as “gets its value from” rather than “equal”. The “==” is usually used as the equal comparison operator). "TOTAL" and its calculated value. let trait1 = 0
let trait2 = 0
let total = 0
// Display counted traits and total total up the
// traits for a total
input.onButtonPressed(Button.AB, () => {
    total += trait1 + trait2
    basic.showString("TRAIT 1")
    basic.showNumber(trait1)
    basic.showString(" TRAIT 2")
    basic.showNumber(trait2)
    basic.showString(" TOTAL")
    basic.showNumber(total)
})||basic:on shake|| event is used to clear the value of all the variables much like when an “Etch-a-Sketch” is turned upside down and shaken to erase the drawing (the accelerometer sensor can detect when the micro:bit is shaken).0. let trait1 = 0
let trait2 = 0
let total = 0
// Erase count and total
input.onGesture(Gesture.Shake, () => {
    trait1 = 0
    trait2 = 0
    total = 0
})This project could easily be modified to keep track of scores for 2 different teams. What other ideas can you think of that counters could be used for?
| Adapted from “Population Trait Data Counter“ by C Lyman |  |