In the "Displaying Temperature, Humidity & Soil Moisture" tutorial (click here to view) the ZIP LED colour hue was used to display the sensor values. In this tutorial, soil moisture will be displayed in the same way, but the measurement will also be used to trigger an alarm and control when a plant is watered.
This tutorial is going to require the Kitronik Greenhouse, with the planting section filled with soil, and the Mini Prong to be connected to the Environmental Control Board using crocodile clips.
Connect Mini Prong 3V to one of the 3V pads, Mini Prong GND to one of the GND pads and Mini Prong 0 to the Pin1 pad. Stick it into the greenhouse planting section.
The first thing to do is to set up the ZIP LEDs and create the status LEDs range.
From the ||kitronik_smart_greenhouse.ZIP LEDs||
section of the ||kitronik_smart_greenhouse.Greenhouse||
category, add the ||variables:set zipLEDs to||
||kitronik_smart_greenhouse.Smart Greenhouse with 8 ZIP LEDs||
block to the ||basic:on start||
section, followed by the ||variables:set statusLEDs||
block.
let zipLEDs = kitronik_smart_greenhouse.createGreenhouseZIPDisplay(8)
let statusLEDs = zipLEDs.statusLedsRange()
Next, create a new variable called ||variables:soilHue||
. This will be used to set and store the ZIP LED colour hue based on the soil moisture reading from the sensor.
In the ||basic:forever||
loop, ||variables:set tempHue to||
the ||math:map||
block, which can be found in the ||math:Math||
category.
basic.forever(function () {
soilHue = Math.map(0, 0, 1023, 0, 4)
})
In the ||math:map||
block, put the ||kitronik_smart_greenhouse.Analog read P1||
block in the first slot - this can be found in the ||kitronik_smart_greenhouse.Inputs/Outputs||
section of the ||kitronik_smart_greenhouse.Greenhouse||
category. Then, set ||math:from low 0 high 1023 to low 35 high 150||
to give a desert sand colour for a low moisture reading and a watery colour for a high moisture reading.
basic.forever(function () {
soilHue = Math.map(kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1), 0, 1023, 35, 150)
})
Now that the soil moisture hue has been set and stored, the ZIP LED colour can now be set.
After the ||variables:set soilHue||
block, add a ||kitronik_smart_greenhouse.ZIP LED 2 to hue||
||variables:soilHue||
. Finally, put a ||variables:statusLEDs||
||kitronik_smart_greenhouse.show||
block at the end of the ||basic:forever||
loop.
let statusLEDs: kitronik_smart_greenhouse.greenhouseZIPLEDs = null
basic.forever(function () {
soilHue = Math.map(kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1), 0, 1023, 35, 150)
statusLEDs.setZipLedColor(2, kitronik_smart_greenhouse.hueToRGB(soilHue))
statusLEDs.show()
})
Displaying the soil moisture has now been set up, but it isn't being used to control anything yet.
After the ||kitronik_smart_greenhouse.show||
block, add in an ||logic:if else||
block from the ||logic:Logic||
category. Check whether the measured soil moisture value is less than 400 (this value can be changed depending on how much water particular plants need, a lower value means drier soil).
The ||logic:if||
statement should read: ||logic:if||
||kitronik_smart_greenhouse.Analog read P1||
||logic:≤ 400 then||
.
let statusLEDs: kitronik_smart_greenhouse.greenhouseZIPLEDs = null
basic.forever(function () {
soilHue = Math.map(kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1), 0, 1023, 35, 150)
statusLEDs.setZipLedColor(2, kitronik_smart_greenhouse.hueToRGB(soilHue))
statusLEDs.show()
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
} else {
}
})
The ||logic:if||
statement is set up to check whether the soil is too dry, so now an action needs to be taken if this condition is met.
Audio is going to be used, so to set this up, add in the ||kitronik_smart_greenhouse.set music pin for buzzer||
block to the ||basic:on start||
section. This block is in the top level of the ||kitronik_smart_greenhouse.Greenhouse||
cateogry.
From the ||music:Music||
category, add a ||music:start melody||
block inside the ||logic:if||
statement, select a tune from the drop-down list and set the the repeat to ||music:forever||
. After this, place a 2 second ||basic:pause||
, followed by a ||music:stop melody all||
block. The audio alarm is now complete.
kitronik_smart_greenhouse.setBuzzerPin()
let zipLEDs = kitronik_smart_greenhouse.createGreenhouseZIPDisplay(3)
let statusLEDs = zipLEDs.statusLedsRange()
basic.forever(function () {
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
music.startMelody(music.builtInMelody(Melodies.BaDing), MelodyOptions.Forever)
basic.pause(2000)
music.stopMelody(MelodyStopOptions.All)
} else {
}
})
The final stage of the alarm is to add some visual indicators as well. Inside the ||logic:if||
statement, just before the ||music:start melody||
block, add in a ||basic:show icon||
block with a sad face selected, and add another of these blocks inside the ||logic:else||
sectin, but this time with a happy face.
Now, the micro:bit will be happy when the plant has enough water and sad when it's too dry.
basic.forever(function () {
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
basic.showIcon(IconNames.Sad)
music.startMelody(music.builtInMelody(Melodies.BaDing), MelodyOptions.Forever)
basic.pause(2000)
music.stopMelody(MelodyStopOptions.All)
} else {
basic.showIcon(IconNames.Happy)
}
})
The soil moisture alarm is now complete, so click |Download|
and transfer the code to the Environmental Control Board.
Try moving the Mini Prong around the planting area to see when the alarm is triggered.
The Environmental Control Board is now able to determine when the soil is too dry, and can even sound the alarm, but it would be great if it could sort out the watering as well!
This stage of the tutorial is going to require the Mini Prong as before, and also the water pump to be connected to the high power output on P13 on the Environmental Control Board (follow the instructions in the Smart Greenhouse booklet to connect the pump and fill the water tank).
![Picture of Prong and water pump connected to Environmental Control Board]
In order to automate the watering process, all that needs to happen is for the water pump to be switched on in the same place in the code as the alarm is triggered. However, the water water needs to be added to the planting area carefully to stop it spilling. To do this, the pump will actually need to be switched on and off in several short bursts.
Start by adding a ||loops:repeat||
loop to the ||logic:if||
section, just after the ||music:stop melody||
block. Set the number of repeats to 3.
basic.forever(function () {
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
basic.showIcon(IconNames.Sad)
music.startMelody(music.builtInMelody(Melodies.BaDing), MelodyOptions.Forever)
basic.pause(2000)
music.stopMelody(MelodyStopOptions.All)
for (let index = 0; index < 3; index++) {
}
} else {
basic.showIcon(IconNames.Happy)
}
})
Next, from the ||kitronik_smart_greenhouse.Inputs/Outputs||
section of the ||kitronik_smart_greenhouse.Greenhouse||
category, add a ||kitronik_smart_greenhouse.turn high power P13 ON||
block inside the ||loops:repeat||
loop. After this, add a 100ms ||basic:pause||
, then turn OFF ||kitronik_smart_greenhouse.high power P13||
, and finally add a 1 second ||basic:pause||
at the end. This section of code will now turn the water pump on for 100ms, turn it off for 1 second, and repeat this 3 times.
basic.forever(function () {
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
basic.showIcon(IconNames.Sad)
music.startMelody(music.builtInMelody(Melodies.BaDing), MelodyOptions.Forever)
basic.pause(2000)
music.stopMelody(MelodyStopOptions.All)
for (let index = 0; index < 3; index++) {
kitronik_smart_greenhouse.controlHighPowerPin(kitronik_smart_greenhouse.HighPowerPins.pin13, kitronik_smart_greenhouse.onOff(true))
basic.pause(100)
kitronik_smart_greenhouse.controlHighPowerPin(kitronik_smart_greenhouse.HighPowerPins.pin13, kitronik_smart_greenhouse.onOff(false))
basic.pause(1000)
}
} else {
basic.showIcon(IconNames.Happy)
}
})
At the moment, the program checks the soil moisture level constantly, but when water is poured into a pot it doesn't immediately soak through all the soil evenly. To leave time for the mositure level to actually change, the program needs to increase the time between each measurement. To do this, add a 10000ms ||basic:pause||
after the ||logic:if else||
block in the ||basic:forever||
loop.
let statusLEDs: kitronik_smart_greenhouse.greenhouseZIPLEDs = null
basic.forever(function () {
soilHue = Math.map(kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1), 0, 1023, 35, 150)
statusLEDs.setZipLedColor(2, kitronik_smart_greenhouse.hueToRGB(soilHue))
statusLEDs.show()
if (kitronik_smart_greenhouse.readIOPin(kitronik_smart_greenhouse.PinType.analog, kitronik_smart_greenhouse.IOPins.p1) <= 400) {
basic.showIcon(IconNames.Sad)
music.startMelody(music.builtInMelody(Melodies.BaDing), MelodyOptions.Forever)
basic.pause(2000)
music.stopMelody(MelodyStopOptions.All)
for (let index = 0; index < 5; index++) {
kitronik_smart_greenhouse.controlHighPowerPin(kitronik_smart_greenhouse.HighPowerPins.pin13, kitronik_smart_greenhouse.onOff(true))
basic.pause(1000)
kitronik_smart_greenhouse.controlHighPowerPin(kitronik_smart_greenhouse.HighPowerPins.pin13, kitronik_smart_greenhouse.onOff(false))
basic.pause(2000)
}
} else {
basic.showIcon(IconNames.Happy)
}
basic.pause(10000)
})
CODING COMPLETE! Click |Download|
and transfer the code to the Environmental Control Board.
Wait for the soil to dry out and see the pump automatically water the plant.