| Crates.io | pigg |
| lib.rs | pigg |
| version | 0.6.0 |
| created_at | 2024-06-02 21:55:31.121058+00 |
| updated_at | 2025-01-17 13:57:34.997419+00 |
| description | A Graphical User Interface for interacting with local and remote Raspberry Pi and Pi Pico Hardware |
| homepage | https://github.com/andrewdavidmackenzie/pigg/ |
| repository | https://github.com/andrewdavidmackenzie/pigg/ |
| max_upload_size | |
| id | 1259504 |
| size | 633,117 |
An app for Raspberry Pi GPIO Output control and Input visualization, with GUI and CLI Support for macos, Linux (including Raspberry Pi) and Windows; GPIO CLI agent for Raspberry Pi and embedded applications for Pi Pico (USB) and Pi Pico W (USB, TCP).
The GUI (Pi Gpio GUI - PIGGUI) is affectionately known as "piggy".
|
|
|
|
Full feature support for Pi Pico W and Pi Pico, USB discovery, SSID configuration, GPIO control and mDNS discovery.
Pi Pico support includes:
porky and porky_w for running on the Pi Pico and Pi Pico W.porky or porky_wporky yourself with default SSID information so all devices programmed with that binary connect
automatically to Wi-Fipiggui and porky that allows you to:
porky devicesudev rules file for allowing user access (for piggui application) to USB devices on Linux machinesAdditions to piglet functionality:
piglets on the network and get the details required to connect to them by TCP or
Irohpiggui is connected
to as Pi and Pi Pico pin outs are different.piglets and porkys, or USB for direct connected porkys.piggui) can connect to a Pi (running piglet) over the network, or to a Pi Pico/Pi Pico W (over the
network or USB direct connect) to control and view the GPIO hardware from a distance.nodeid. piglet prints this out for you
if it is started in the foreground. When piglet has been started as a system service, start another instance in the
foreground and this will detect the background instance and display its nodeid for you then exit.nodeid and either supply it as a command line option to piggui (--nodeid $nodeid, prefixed with --
if using cargo run) or enter it into the GUI. To connect to a remote instance from the GUI, click on the
"hardware menu" in the left of the info bar at the bottom of the screen and select the "Connect to remote Pi..."
menu item. Then enter the nodeid into the field provided and hit "Connect"You can see more gifs and videos of features here
piggui is a GUI for configuring pins, observing input levels and controlling output levels.
On Raspberry Pi it has a real GPIO hardware backend (via rppal).
On macOS, Linux and Windows it uses a fake hardware backend (mainly for development) or can connect to a remote
hardware backend that is running piglet.
piglet is a "headless" command line utility that interacts with the GPIO hardware, and can either apply a
config supplied from file and stop, or can listen for config changes from a remote piggui and report input
level changes to the GUI.
If built on the Pi (with the "pi_hw" feature), then it has a real GPIO hardware backend.
It can be built on macOS/Linux/Windows/Pi with the "fake_hw" feature for a fake hardware backend, mainly used for development.
It takes an optional config file as a command line option. It will load the GPIO configuration from the file
(like piggui can) and it will apply it to the hardware then stop.
It offers the ability to interact with the hardware from a remote pigguiinstance.
It will print out connection info at startup and start listing for Iroh network connections from piggui instances,
then the user can interact with it and visualize inputs level changes from the piggui GUI.
porky is an embedded application developer for the Raspberry Pi Pico and Pi Pico W for remote interaction with the
Pico's GPIO hardware. It can be connected to over TCP or USB.
For more details see porky's README.md
pigg has a number of binaries as part of the project (see descriptions above) and they are tested in CI, or
manually or are known to work as follows:
| Application | Arch Supported | Device | OS Supported |
|---|---|---|---|
| piggui | Apple Silicon | macOS 15 | |
| x86_64 | macOS 15 | ||
| x86_64 | macOS 15 | ||
| x86_64 | Ubuntu 24.04 | ||
| x86_64 | Windows 10 | ||
| aarch64 | Pi400 | Pi OS | |
| aarch64 | Pi4 | Pi OS | |
| aarch64 | Pi5 | Pi OS | |
| aarch64 | PiZero 2 | Pi OS | |
| armv7 musl | Pi3B | Ubuntu 18.04.6 LTS | |
| piglet | Apple Silicon | macOS 15 | |
| x86_64 | macOS 15 | ||
| x86_64 | macOS 15 | ||
| x86_64 | Ubuntu 24.04 | ||
| x86_64 | Windows 10 | ||
| aarch64 | Pi400 | Pi OS | |
| aarch64 | Pi4 | Pi OS | |
| aarch64 | Pi5 | Pi OS | |
| aarch64 | PiZero 2 | Pi OS | |
| armv7 musl | Pi3B | Ubuntu 18.04.6 LTS | |
| porky_w | armv7 | Pi Pico W | N/A |
| porky | armv7 | Pi Pico | N/A |
We would like input from Raspberry Pi users to help us decide the order of things to work on in the future, and input on how integrate new functionalities (e.g. I2C buses, SPI, UART, etc.).
Please let us know what you think, and suggestions, via Discussions or GH issues.
We have identified a number of areas to work on in future releases, but we would really appreciate your input on what could be most useful or just the coolest, many have GH issues.
See issues in milestone 0.7.0 for the up-to-date list and progress.
piggui with small displaysSee INSTALLING.md
See HELP.md for help with known issues. We hope to grow this and maybe link with the GUI and reported errors.
See BUILDING.md
For details on running piglet and piggui in the foreground or as a system service, on the same machine or with a
remote GUI to Pi hardware, see RUNNING.md
See CONTRIBUTING.md
See LICENSE
See SECURITY.md