Handles various message types for the Brilliant Labs Frame
Project description
Frame Message Package
A Python package for handling rich application-level messages for the Brilliant Labs Frame, including sprites, text, audio, IMU data, and photos.
Installation
pip install frame-msg
Usage
import asyncio
from pathlib import Path
from frame_msg import FrameMsg, TxSprite
async def main():
"""
Displays sample images on the Frame display.
The images are indexed (palette) PNG images, in 2, 4, and 16 colors (that is, 1-, 2- and 4-bits-per-pixel).
"""
frame = FrameMsg()
try:
await frame.connect()
# Let the user know we're starting
await frame.print_short_text('Loading...')
# send the std lua files to Frame that handle data accumulation and sprite parsing
await frame.upload_stdlua_libs(lib_names=['data', 'sprite'])
# Send the main lua application from this project to Frame that will run the app
await frame.upload_frame_app(local_filename="lua/sprite_frame_app.lua")
# attach the print response handler so we can see stdout from Frame Lua print() statements
frame.attach_print_response_handler()
# "require" the main frame_app lua file to run it, and block until it has started.
await frame.start_frame_app()
# send the 1-bit image to Frame in chunks
sprite = TxSprite.from_indexed_png_bytes(Path("images/logo_1bit.png").read_bytes())
await frame.send_message(0x20, sprite.pack())
# send a 2-bit image
sprite = TxSprite.from_indexed_png_bytes(Path("images/street_2bit.png").read_bytes())
await frame.send_message(0x20, sprite.pack())
# send a 4-bit image
sprite = TxSprite.from_indexed_png_bytes(Path("images/hotdog_4bit.png").read_bytes())
await frame.send_message(0x20, sprite.pack())
await asyncio.sleep(5.0)
# unhook the print handler
frame.detach_print_response_handler()
# break out of the frame app loop and reboot Frame
await frame.stop_frame_app()
except Exception as e:
print(f"An error occurred: {e}")
finally:
# clean disconnection
await frame.disconnect()
if __name__ == "__main__":
asyncio.run(main())
Acknowledgements
- An early port of TxSprite from Flutter to Python was contributed by David Khachatryan - thanks!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
frame_msg-5.0.3.tar.gz
(23.5 kB
view details)
Built Distribution
frame_msg-5.0.3-py3-none-any.whl
(38.6 kB
view details)
File details
Details for the file frame_msg-5.0.3.tar.gz
.
File metadata
- Download URL: frame_msg-5.0.3.tar.gz
- Upload date:
- Size: 23.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1eaaf6dd2b58c69818617b88a973ce1f313dee817637b888b3ae370e21bbdc44 |
|
MD5 | d5ca99867dff08a116387530dc425a36 |
|
BLAKE2b-256 | 74604d4017a9fbefefc13653c47560414e9c453cf0e6733ef995540a2c7aac73 |
File details
Details for the file frame_msg-5.0.3-py3-none-any.whl
.
File metadata
- Download URL: frame_msg-5.0.3-py3-none-any.whl
- Upload date:
- Size: 38.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8f55bd909ff8aa2cbe18bd5a088f4eef8aec180c55fce245ab49eea14a2fcc9e |
|
MD5 | 3b5fa5799877bb70f439ca94a4d8d9ed |
|
BLAKE2b-256 | b1e7293814e51a8e51224db0258663ef8c687f14e066ca77b27970094e77c71f |