Time Travel with Circuit Playground Express
My 6 year old daughter has been using her imagination to help make homeschool history more fun. She came up with the idea for a time travel helmet that would transport her to early Egypt, Greece and beyond. This past weekend we used a Circuit Playground Express, Microsoft MakeCode and a cardboard box to bring her time travel helmet design to life! This was a fun project for both of us and also a great introduction to coding for my kiddo.
The Design
We used an old Amazon box and some tape to assemble the helmet, with a length of cardboard run through the middle that serves as the top of the helmet and a shelf for the battery holder. A time travel helmet wouldn't be complete without some noisy, flashy, technical looking time circuits.
Clearly the Back to the Future movies would have failed if not for the flux capacitor ("which makes time travel possible"). That's where the Circuit Playground Express comes in.
The "Robot Computer"
Since Flux Capacitor was taken, my daughter named our time travel electronics "the robot computer". I've had a Circuit Playground Express in my laptop bag since I attended Microsoft Ignite back in November (it was handed out for free). The amount of functionality packed into this small device is really amazing, check out the link above for all the details.
Here is the small subset of features used in our time travel helmet:
|
Supplies
Aside from the cardboard box and some tape, here are the supplies used in the project:
The battery holder we used has both the JST type connector for connecting to the Circuit Playground and an on/off switch which is very useful if you accidentally play an annoying sound on an infinite loop. The Circuit Playground itself is attached to the helmet with some spare CAT6 (my kiddo was happy to have a choice of colors for the wire!)
These aren't affiliate links, and I don't make anything off of them. They ARE Amazon Smile links and if you use them Amazon donates a small amount to charities like She is Safe, an organization that prevents, rescues and restores women and girls from abuse and exploitation.
Block Based Coding with Microsoft MakeCode
Microsoft MakeCode is a (free!) web based code editor. You can use it to write Javascript or Python code for devices from Lego, Cue, Adafruit and others. You can also build using a block based code editor, similar to Scratch, which is great for anyone just learning to code or those of us with little patience.
We opened the MakeCode site in a browser and started a new project for the Circuit Playground Express. MakeCode shows a picture of the device we are coding for - but it's not just a picture, it's a device simulator! We can simulate pushing buttons and shaking the device as we write code and instantly see how it will work on the device.
We added code blocks to do the following:
- Play a sound when powered on
- Start "time traveling" when a button is pushed (she picked the A3 button)
- Play a sound and strobe the lights until time traveling is stopped (she found a cool animation called "comet" for this)
- Stop time travel when the helmet is shaken
MakeCode made this project so easy and very approachable for both of us! My daughter caught on very quickly and it was easy and intuitive for me to answer any questions she had. Actually I think I asked more questions than she did - questions like "what color lights do you want?".
Once we had it working the way we wanted, we tried it out on the device simulator and then clicked download. All we had to do was plug the Circuit Playground into the computer with the included USB cable and drag and drop our code file over to the device. At this point it instantly rebooted and started running the code we created!
Another great feature of MakeCode is it allows you to see the code you created with blocks as Javascript. Here's the code we created:
input.touchA3.onEvent(ButtonEvent.Click, function () {
traveling = 1
while (traveling) {
light.showAnimation(light.cometAnimation, 100)
music.playMelody("C5 B A G F E D C ", 900)
}
})
input.onGesture(Gesture.Shake, function () {
traveling = 0
light.clear()
})
let traveling = 0
music.playMelody("C5 B A G F E D C ", 400)
traveling = 0
An Excellent Adventure
Once the code was completed, we attached the Circuit Playground and battery holder to the helmet, switched it on and it was ready to go. I'm really impressed with the Circuit Playground Express. It has a wealth of features, is totally approachable for beginners, and can also be programmed with Circuit Python and Javascript for more advanced use. My daughter will surely come up with some new feature requests for her time travel helmet soon - and I'm looking forward to it! In the mean time, her homeschool history lessons should be much more entertaining.