Skip to content

philipbeber/karaoke

Repository files navigation

Campfire Karaoke

The campfire karaoke machine is a small device which displays lyrics and chords to aid singalongs around a fire.

Turning the dial scrolls the page up and down. Clicking the button enters the song selection mode. Keep clicking and turning the dial to select a new song.

To run locally for testing purposes

Install NPM: https://www.npmjs.com/

git clone <urlofkaraoke> cd karaoke npm install -g bower grunt-cli npm install bower install grunt serve

Press 'X' to simulate clicking the hardware button. Press 'N' to simulate anti-clockwise scroll. Press 'M' to simulate clockwise scroll.

Actual setup

You will need:

On the rotary encoder one side has three legs and the other has two. On the side with three legs connect the middle leg to ground. Connect the left leg to pin 8 (Broadcom numbering) and the right leg to pin 7.

On the side with two legs connect one leg to ground and the other to pin 2. Doesn't matter which way round they are connected.

Clone the karaoke repo.

Run pi/setup-pi.sh

This will install the necessary packages and set the Pi to run on-startup.sh when booting up.

Now run on-startup.sh or reboot to start the app. It has three parts:

  1. A simple python program which runs as sudo which monitors the GPIO and translates movement of the wheel into key presses. Emulating key presses seemed like the easiest way to communicate from sudo to non-sudo without opening any security holes.

  2. A simple webserver which serves the content in the dist folder to http://localhost:8000.

  3. A browser running full-screen, pointed at http://localhost:8000.

Now connect the Pi to the projector, stretch the sheet between a couple trees, grab the guitar and start singing, while your friends make a nice fire to sit around.

About

Web app for pop-up karaoke machine

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published