Here are a series of activities to learn about TinyGo by using Gopherbot.
If you have not done it yet, follow the installation instructions here:
https://github.com/hybridgroup/gopherbot#installation
This tests that you can compile and flash your Gopherbot with TinyGo code, by blinking the built-in LED.
- Plug your Circuit Playground Express into your computer's USB port.
- Build your TinyGo program to the board in
.uf2
format using this command:
tinygo flash -target=gopherbot ./learn/step0/main.go
- The Circuit Playground Express board should restart and then begin running your program. This program just causes the small LED labelled "D13" on the Circuit Playground Express board to start blinking on and off.
Now, instead of just using the low-level TinyGo functions, we are going to use the more advanced "Gopherbot" API to program our furrie robotic friend. Gopherbot has more pre-defined behaviors, but of course all of these are built on top of the lower-level TinyGo "machine" API.
Want to see complete documentation of the Gopherbot API? Check out our GoDocs here at: https://godoc.org/github.com/hybridgroup/gopherbot
First thing we are going to do is to program the left button on the backpack. Let's make it so when the button is pressed, the small built-in LED on the board turns on. Also, the code will make it so that when the button is released that the LED turns off.
tinygo flash -target=gopherbot ./learn/step1/main.go
Next, let's do the same thing for the right button that we did for the left one. When the button is pressed, the small built-in LED on the board turns on. Also, the code will make it so that when the button is released that the LED turns off.
tinygo flash -target=gopherbot ./learn/step2/main.go
Now we will get brightly colored, by adding the ring of Red Green Blue (RGB) LEDs that are on the Circuit Playground Express board on the Backpack
.
The Gopherbot Backpack
has several built-in functions for these LEDs to set colors and patterns. We will add three of these color settings to the program.
We will also use the buttons to select which of the Backpack
colors to display. Pushing the right or left button will scroll thru these three color presets.
tinygo flash -target=gopherbot ./learn/step3/main.go
The RGB LEDs are really bright! Let's add the ability to turn them on and off using the built-in slider switch.
tinygo flash -target=gopherbot ./learn/step4/main.go
Now we need to get the LED on the end of the Antenna
blinking. We can do this so that it automatically blinks over and over by using a goroutine to call the Antenna.Blink()
function.
tinygo flash -target=gopherbot ./learn/step5/main.go
Time to fully activate Gopherbot by controlling the RGB LEDs that are in the helmet's Visor
.
Similarly to the Backpack
does, the Visor
has several built-in functions for the LEDs to set colors and patterns. We will add three of these color settings to the program.
We will also use the buttons to select which of the Visor
colors to display. Pushing the right or left button will scroll thru these three color presets at the same time that it chooses the presets for the Backpack
.
One difference will be that we will program Gopherbot so that the Visor
stays on regardless of state of the Slider
switch.
tinygo flash -target=gopherbot ./learn/step6/main.go
step7.go - LED, Button A, Button B, Backpack LEDs, Slider switch, Antenna LED, Visor LEDs, Thermistor
Now that we have all the LEDs working all at the same time, let's explore one of the sensors that is built-in. The Circuit Playground Express board has an onboard Thermometer
which is actually a kind of analog temperature sensor known as a thermistor.
We will add to our program an additional mode
which will read the current temperature, and then modify the Visor
depending on the reading from the Thermometer
.
tinygo flash -target=gopherbot ./learn/step7/main.go
step8.go - LED, Button A, Button B, Backpack LEDs, Slider switch, Antenna LED, Visor LEDs, Thermistor, Accelerometer
Let try another of the built-in sensors on the Circuit Playground Express board. It has an onboard Accelerometer
which is a sensor that can detect motion on any of 3 different axes.
We will add to our program another mode
which will read the Accelerometer
, and then based on the tilt position of the Gopherbot, modify the Visor
to make it act like a "level".
tinygo flash -target=gopherbot ./learn/step8/main.go
step9.go - LED, Button A, Button B, Backpack LEDs, Slider switch, Antenna LED, Visor LEDs, Thermistor, Accelerometer, Buzzer
Out final modification to the program will add the built-in Speaker
to make a bleeping sound when the tilt()
function detects that the Gopherbot is laying entirely on its side.
tinygo flash -target=gopherbot ./learn/step9/main.go