MP3 Playing Sound FX Wall
by BrownDogGadgets in Circuits > Arduino
9581 Views, 158 Favorites, 0 Comments
MP3 Playing Sound FX Wall
Create a fun and interactive sound wall that plays Mp3s with a simple touch!
What do you do with an empty wall? You could add some nice pictures to it? Or cover it with a colorful house plant. We've even seen some people hide bare walls behind book cases. While all those options are valid we wanted to make something a bit more fun for our office visitors, so we designed this silly Sound Wall.
This project uses a Crazy Circuits Invention Board to create a capacitive touch wall that activates an inexpensive MP3 player module. This approach is pretty simple overall and can be reconfigured into a variety of formats. For our display we decided to use Bare Conductive Paint to make our designs permanent, however you don't have to use paint if you want more flexibility.
This activity is great for a school, museum, or library installation where sound effects can be tied to learning objectives or new graphics. It's also quite nice as a fun play room project if you have a small child who constantly wants to hear new Disney songs every week. If you don't have children you could always put up logos of your favorite sports teams that play their theme song, images from classic movies and have them play quotable moments, or do what we did and put up classic video game icons with retro sound effects. Whatever floats your boat.
If you like this project and want to see others try following us on Instagram, Facebook, Twitter, or Youtube! Or just check out our kits and supplies at BrownDogGadgets.com.
Supplies
For this project it's going to be helpful to have some general painting supplies. In a later step we're going to show how to avoid paint and stencil cutting all together, so don't worry if you won't have those supplies.
* Brown Dog Gadgets does in fact sell kits, parts, and components. You in no way need to buy these items from us, and in fact can complete this project without our stuff. We just hope you do.
Electronics:
Crazy Circuits Invention Board
2 x Crazy Circuits Screw Terminal Chip
1/8th Inch nylon Maker Tape (You'll probably want at least two of these)
Micro SD Card (Any old Micro SD will work as the sound files we use are going to be small)
Powered Speakers (You probably have some in your house, otherwise get some cheap USB ones or even one of these 'Hamburger' style speakers.)
Dual USB AC Adaptor (To power the Invention Board and the cheap USB speakers we linked to)
You'll also need a few LEGOs to mount the Crazy Circuits parts to.
Painting and Stencil Supplies:
Bare Conductive Paint (Though you don't need it depending on how to build this)
Clear spray paint
Cameo Silhouette or other paper cutter (even a laser cutter will work)
Painters Tape
Level
Brushes
Optional: Some light adhesive to more easily apply the stencils
Planning Your Project
Before you start building this project, try watching our build video above to get an idea of how the process goes. It's a quick overview of how we built our version with conductive paint, showing both the good and bad of that process.
Planning things out ahead of time will save you a lot of frustration and will help you create a long lasting and fun project. Ask yourself the following questions:
1) Do I want a permanent installation that never changes?
2) Do I want flexibility in my graphics, such as color?
3) How much use is this project going to get?
4) How portable do I want this?
Paint:
If you're looking for something that never changes. Ever. Then going the conductive paint route is probably the best solution for you. It'll handle a lot of abuse, look nice, and is pretty easy to to install. The downside is that you can never change it and you're probably best off sticking it to a wall.
Vinyl Cut Outs:
As you'll see in our code section, you can boost the sensitivity of this project quite a bit. By laying a vinyl cut, or even a paper cutout, over the top of the conductive tape you have something thats easy to change whenever you want. For extra sensitivity place a small blob of conductive paint at the ends of your tape lines. The downside is that it wouldn't be able to handle constant abuse (long term) in a school or library setting. The best use case for this would be at a home or classroom where you want to change out the pictures every now and then.
Portable Project/ Workstation
For classroom learning situations you probably want to make something with a lot of flexibility and portability. Creating an interactive project out of poster board is one solution. Use conductive tape with small blobs of paint at the end as easy triggers. Place new graphics on top whenever you want or have students help design activities and make their own sound files.
Building Your Circuit
Crazy Circuits components are LEGO compatible which means it's really easy to create a mounting plate for the project using a few LEGO pieces.
Use some flat plates and lay out your pieces. We need to connect two screw terminals to the Invention Board in order to hook up ribbon cables. One Screw Terminal needs to connect to the 5V Positive hole as well as the Negative hole on the board, the other Screw Terminal needs to connect to Pins 9 and 10.
We're using 1/8th inch nylon conductive Maker Tape to make these connections.
Once in place, screw in the male sides of your ribbon cables. The connect Pin 9 to the TX and Pin 10 to the RX on the Mp3 Module. The Positive and Negative junctions match up to the Positive and Negative pins on the Mp3 Module.
Why are we using the Crazy Circuits Invention Board and not a cheap Arduino Nano MakeyMakey? The Invention Board is using a Teensy LC at its core which has built in capacitive touch, something the Nano does not. This means that you can just 'touch' a point and activate the board. If we used the Nano we'd have not only touch a point but also have our body touching a 'ground' connection. This isn't very elegant and also removes the ability to activate a touch point THROUGH vinyl or paper.
Design and Cut Stencils
We used a Silhouette Cameo to create simple paper stencils for our project. You could also do something similar by hand or with a laser cutter. If you're so inclined you could also buy stencils off Amazon or Etsy.
While paper stencils worked fine for a couple of our images, they proved to be difficult with our more complicated Space Invader. We really should have sprayed the back with a light adhesive so the stencil would fully stick to the wall. A smarter option would have been to just make a vinyl stencil.
If you're not planning on using conductive paint graphics on your wall you can pretty much just ignore this step.
Measure, Level, and Paint
Before painting make sure you measure everything out for spacing and then check to make sure things are level. Nothing is more annoying than one graphic slightly higher than the others, especially when painted on the wall.
Once everything is in place try your hand at painting!
Bare Conductive Paint can be tricky to work with. It easily smears and is kind of thick. One trick you can try is adding a very small amount of water to it to help thin things out.
Make sure you're applying an even layer, and don't go thick otherwise you'll be waiting hours for it to dry.
Once you've painted you can remove the stencils. If you want to do any touch up wait until after the paint dries.
DO NOT try and use a wet rag or paper towel to clean things up, you'll just smear the paint everywhere. You're better off getting some of the same wall color and painting over it.
Mount Circuit Board and Add Tape
Since we have a laser cutter in our workshop we cut out a small mounting plate that we could stick to the wall. It's also quite easy to just use double sided tape and stick the LEGO plate to a wall as well. We used some self sticking velco in case we ever wanted to move the mounting plate or change things up.
Make sure you pins 15-23 pointing towards your graphics as thats where the majority of the Touch Points are located. (7 of the nine touch points are on that side, with two more opposite)
We decided to mount our board about belt high to the right side of our graphics so we could more easily access power and set our speakers on an end table. If you've got small children you can easily mount this up high or down low.
Run 1/8th inch Maker Tape from your graphics to the appropriate Pin on the Invention Board. Make sure that the tape overlaps your conductive paint at least an inch. When you connect it to the pin (copper circle) of the Invention Board make sure that the tape isn't touching any other pin. While we have no idea of how far we can run tape successfully for this project, we did run ours at least six feet to the furthest graphic.
Since we only have four graphics we decided to use every other Pin as not to crowd things. If we ever wanted to add more graphics we can always rearrange our tape. Maker Tape is extremely strong and conductive on both sides which means you can easily remove a section and then bridge it with another piece of tape.
Note: To make life easier for yourself buy some cheap USB powered speakers that have a headphone jack input, then buy a 2 port USB wall adaptor. Plug both the speakers and Invention Board into that adaptor. Along the same lines, if you mount things up high on a wall use a single USB extension cable and a cheap USB splitter/ hub to power both the Invention Board and Speakers.
Touch Up and Clear Coat
Once your paint is dry touch up everything.
For us this was covering the conductive tape on our graphics with more paint, as well as using some wall colored paint to fix a few errors in our graphics.
Once the touch ups are dry use some clear spray paint to seal up the conductive paint.
One major benefit of Bare Conductive Paint is that it's very water soluble and easy to clean up, however if you have any moisture on your fingers you'll also melt away already dry paint. A clear coat of spray paint solves this problem. As we're using capacitive touch with this project we don't actually have to touch the paint itself for our body to make electrical contact with the circuit.
Years ago we made a small capacitive touch piano that we took to education trade shows with us. Thousands of people touched and played it without any problems or major wear. Every now and then we'd add a new layer of spray paint to it just to be safe.
Modifying the Code
Click this link to download a ZIP file our code, resources, and test sound files.
If that link doesn't work, because we've probably updated something and forgotten to update this link, try the files on our GitHub Repo. At the writing of this guide our code and files are at a 1.0 Version.
Overall you shouldn't have to change anything in it. The code is pretty simple. Touch a Touch Point and it plays an assigned numbered audio file.
Two settings you can and may want to change are:
1) Length of wait time between inputs.
In lines 23 - 31 you can change how much time each pin waits before accepting a new input. For instance if you want to be able to very quickly tap a Touch Point over and over and over again and have the sound file start up again every time you press it, change the length of time to 0.5 seconds.
For the rest of us just leave this setting in the 3-5 second range (or change each one individually to match the sound file length). This way people can't super tap your sound effects, but can easily activate a new Touch Point if they get bored with a long sound effect.
2) Sensitivity of the Capacitive Touch
On line 53 you can change this number to increase or decrease the capacitive touch feature. If you raise the number the sensitivity DECREASES, if you lower the number the sensitive INCREASES. Increased sensitivity means you can (probably) activate a touch point from a couple of inches away.
We keep ours at a sensitivity of 2,000. This means that people have to make physical contact with the paint on the wall and don't randomly activate it when walking by. Even at that low of a sensitivity we can still activate the Touch Points through piece of paper or piece of vinyl.
Uploading Code
Download the free Arduino software if you don't already have it.
Since we're using a Teensy LC inside the Invention Board you'll also need to download some additional resource files for that board. You can grab those for free off the PJRC website. (Mac OS 10.15 users must download a modified version of the full Arduino IDE from the PJRC website that has the built in resource files. The only downside to this is that it's a large file.)
Choose the Teensy LC as your Arduino of choice in the software and upload. (Mac OS 10.15 users will also have to choose the port that the Teensy LC is located at.)
Loading Files Onto the SD Card
We've set things up so that certain pins are connected to certain folders. Change the file in that folder whenever you want a new sound effect. For instance Pin 15 is assigned to Folder 01, Pin 16 to Folder 02, Pin 17 to Folder 03, and so on. (If you ever forget, this is all laid out in the code.)
Windows Users:
Format the micro SD card in FAT. Create folders number 01-09 on the card. Drop the mp3 or wave files into each of those folders. Put the micro SD card into the MP3 module.
Mac OS User:
Open up Disc Utility and format the micro SD card as (MS DOS) FAT. Create folders on the card numbered 01-09. Drop your mp3 or wave files into those folder.
Now for some reason Mac OS create small invisible files that mess up the mp3 module so we created a work around. Download this script we wrote (Called DotClean) and stick it onto the SD card. Highlight all the folder (with the music files in there) and drag them into the script icon. This will remove the invisible files. You'll have to do this every time you change the sound files, which is why it's probably helpful to keep the script on the SD card.
Testing Things Out and Trouble Shooting
Stick the micro SD card into the mp3 module, plug in your speaker, and plug in your Invention Board.
STOP! Before you touch anything wait until the little LED on the Invention Board turns on. The code has a five second capacitive touch 'calibration' that takes place every time it powers up. Once the LED is on you're good to go.
No Sound
Is your speaker plugged in and the volume turned up? This is a mistake we've made before.
Double check your SD card is in. (And you did load up sound files, right?)
Check your connections from the MP3 board to the Invention Board. When you touch a touch point the little LED on the MP3 player module will start flashing, indicating that it's playing a sound file. If it's not flashing that means it's not getting instructions from the Invention Board.
Try running your fingers along the various pins on the Invention Board. Calibration may have failed.
You can only use .mp3 and .wav file types, others will not play.
Are you a child or a smaller person? Your body might not have enough mass to activate a Touch Point. Increase the sensitivity for better results.
Too Much Sound
If sound files are constantly playing, change the sensitivity and the time delays.
Wrong Files Playing (Especially in Mac OS)
You didn't use the script to clean up the invisible files.
Are your tape lines connected to the right pins?
Did you use numbered folders? Try changing the file name of the files in the folders to numbers.
Code Not Uploading
Make sure you downloaded the Teensy plugin for the Arduino IDE.
Make sure Teensy LC is selected.
Sigh... make sure your Arduino is plugged into your computer.
Using Vinyl Stickers Instead of Paint
If you have access to a vinyl cutter, such as Silhouette Cameo, you might as well give yourself the option to change out graphics quickly and easily. As a big bonus you can also do vinyl in a variety of colors or buy remade vinyl stickers off amazon and Etsy.
When you'll want to do is run tape to set points on the wall, lined up nice and level. Use sheets of paper as place holders for spacing everything out.
Next, cut several 1-2 inch pieces of Maker Tape. Make a simple asterix design by overlapping tape across the end point of your main tape line. This provides a larger surface area for a touch point.
Lay your vinyl stickers, or even paper cut outs, over the top of these asterix points.
Alternatively you could also make small circles of conductive paint at the end of your paint lines, or even use a square of aluminum tape (just make sure the Maker Tape goes on top of the aluminum tape, since the bottom of the aluminum tape is not conducive).
Once your graphics are in place you may need to play around with the capacitive touch sensitivity in the code a bit to create a reliable interface. Keep in mind that children have a low body mass and may not be able to as easily set off the touch points at lower sensitivity.
Other Ideas for Having Fun
This project easily scales up and down. Build a big graphic on a wall with conductive paint, or use some chrome plated LEGO bricks to make a small scale sound effect board for kids. It's all pretty easy.
Since our Maker Tape goes onto pretty much anything you could make a sound board on glass entirely out of tape. Maybe a fun Tron inspired circuit board layout that says "Greetings Program!" when you touch it.
You could also try making a wearable out of it! Adding Maker Tape to a shirt or jacket that plays sound effects when you touch certain parts of it. Or, god forbid, an actual working Piano Neck Tie.
Conductive Dough from Squishy Circuits would also make a nice three dimensional touch interface to play around with.
As long as the end points of your tape lines is also conductive, and isolated from the other Touch Points, the sky is the limit. If you were reallllllly keen to be wild you could even use PEOPLE as your Touch Points. Then every 'high five' they received would activate a sound effect!