Skip to main content

LCD + button hardware interface

Project description

SquishBox

The SquishBox is a compact add-on board and enclosure for Raspberry Pi (primarily Pi 3B+ and Pi 4) that combines:

  • high-quality stereo DAC with 1/4" outputs
  • MIDI in/out via TRS minijacks
  • 16x2 character LCD
  • pushbutton rotary encoder
  • breakout GPIO for extra controls, LEDs, and peripherals

This creates a portable embedded platform for audio projects such as synths, sound modules, pedalboard utilities, sequencers, and music players.

The software package includes ready-to-run applications plus a simple Python API for building your own.

Building/Obtaining

This repository includes schematics, PCB fabrication files, BOMs, and enclosure models for users who want to build their own hardware.

Kits and pre-built units are also available from the Geek Funk Labs store.

Installing

The SquishBox software targets Raspberry Pi OS 13 (Trixie) on Pi 3B+/4. Other platforms may work but are not officially tested.

To install on a fresh or existing system, log in as a regular user and run:

curl -sL geekfunklabs.com/squishbox | bash

Answer the prompts, wait for install to complete, and reboot the Pi to activate the LCD/button interface.

Using the SquishBox

On first boot, the SquishBox starts a launcher that lets the user choose an app to run or modify system settings. Selections can be made by turning the rotary encoder. Tapping the rotary encoder confirms a choice. Pressing and holding the encoder will cancel or return to the previous screen in most situations. To safely shut down the SquishBox before disconnecting power, use the "Shutdown" option in the "Exit" menu.

Writing SquishBox Apps

The squishbox python package provides access to the LCD, controls (buttons/encoders), outputs, and a set of menu-driven interaction helpers. Here is a simple example app:

import squishbox

sb = squishbox.SquishBox()

sb.lcd.clear()
sb.lcd.write("Audio Test", row=0)

while True:
    i, option = sb.menu_choose(["Noise", "Sine", "Exit"], row=1)

    if option == "Noise":
        sb.shell_cmd("speaker-test -l2 -c2")

    elif option == "Sine":
        sb.shell_cmd("speaker-test -l2 -c2 -tsine")

    elif option == "Exit":
        break

Support and Feature Requests

The SquishBox is under active development, and feature requests are welcome.

Please post requests/questions to Discussions on GitHub, and open issues or pull requests for bugs.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

squishbox-1.0.0.tar.gz (34.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

squishbox-1.0.0-py3-none-any.whl (40.9 kB view details)

Uploaded Python 3

File details

Details for the file squishbox-1.0.0.tar.gz.

File metadata

  • Download URL: squishbox-1.0.0.tar.gz
  • Upload date:
  • Size: 34.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for squishbox-1.0.0.tar.gz
Algorithm Hash digest
SHA256 e5ea0c2fd150cbbe3a3e788613e0b13d369e8c21fb9c237bea3da445204b7f0d
MD5 4a9034708d175039845b198724884869
BLAKE2b-256 f88d98c0d26cf5c112fb9278056ed72fcbf49b2e93385851f96c98d35705105b

See more details on using hashes here.

Provenance

The following attestation bundles were made for squishbox-1.0.0.tar.gz:

Publisher: python-publish.yml on GeekFunkLabs/squishbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file squishbox-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: squishbox-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 40.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for squishbox-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28e00e99efe638561ef53786c2d009236e0814526d61537dbc5b6b5890837507
MD5 2173f0841e558081b1122cd884d93304
BLAKE2b-256 5e022d003f4a66f1f52a09476428dbff6fba5e71696544eadb782e5b9bd1eff3

See more details on using hashes here.

Provenance

The following attestation bundles were made for squishbox-1.0.0-py3-none-any.whl:

Publisher: python-publish.yml on GeekFunkLabs/squishbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page