Draw objects and run programs in the ARENA using Python!
Project description
arena-py
Draw objects and run programs in the ARENA using Python!
Documentation
The ARENA Python library user guide and tutorials: ARENA Documentation: Python.
Setup
Install package using pip (https://pypi.org/project/arena-py/):
pip3 install arena-py
Hello ARENA Example Program
Run the hello.py
example:
cd examples
python hello.py
hello.py
from arena import *
scene = Scene(host="arenaxr.org", scene="example")
@scene.run_once
def make_box():
scene.add_object(Box())
scene.run_tasks()
arena-py Library
The above is the simplest example of an ARENA Python program. This library sits above the ARENA pub/sub MQTT message protocol: JSON messages described in more detail at https://github.com/arenaxr/ARENA-core which runs in a browser. That forms a layer, in turn, on top of A-Frame and THREE.js javascript libraries.
Authentication
We have added protection to the ARENA MQTT broker to limit access to change your scenes, which requires Python programs to supply authentication through a Google account.
Sign-In Desktop OS
If you have a web browser available, the arena-py library Scene(host="myhost.com")
will launch a web browser the first time and ask you for an account to authenticate you with, before opening a client MQTT connection.
Sign-In Server/Headless OS
For headless environments, the arena-py library Scene(host="myhost.com")
will provide you with a url to cut and paste in a browser anywhere, ask you for an account to authenticate you with, and show you a code you can enter on the command line, before opening a client MQTT connection.
Scripts
Some helper script aliases have been added in this library to help you manage authentication and quick command-line (CLI) publish and subscribe to the ARENA.
Sign-Out
arena-py-signout
Show Permissions
arena-py-permissions
CLI Subscribe to Scene Messages
arena-py-sub -mh arenaxr.org -s example
CLI Subscribe to Custom Topic
arena-py-sub -mh arenaxr.org -t realm/g/a
CLI Publish a Scene Object Message
arena-py-pub -mh arenaxr.org -s example -m '{"object_id": "gltf-model_Earth", "action": "create", "type": "object", "data": {"object_type": "gltf-model", "position": {"x":0, "y": 0.1, "z": 0}, "url": "store/models/Earth.glb", "scale": {"x": 5, "y": 5, "z": 5}}}'
CLI Help
arena-py-pub --help
arena-py-sub --help
Changelog
Changelog can be found here.
arena-py Repository Files
-
arena/: The ARENA Python library.
-
examples/: Canonical examples of ARENA functions from the documentation.
-
examples/objects: Examples on how to create various arena-py objects.
-
examples/attributes: Examples on how to declare an add various arena-py object attributes.
-
examples/legacy/: Deprecated demos for arena-py < 0.1.0.
-
examples/legacy/digital-twins/: Deprecated demo of digital twins of physical spaces for arena-py < 0.1.0.
-
system-tests/: Workouts and tests for arena-py.
-
tools/: Reusable tools for any ARENA scene.
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
Built Distribution
File details
Details for the file arena_py-1.3.0.tar.gz
.
File metadata
- Download URL: arena_py-1.3.0.tar.gz
- Upload date:
- Size: 73.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2430806e4985068eb7456cf2469cb923dbddada53125e99cc2d89a6c2a80c3c3 |
|
MD5 | d4810aef0f559374674d8ab176dec9b7 |
|
BLAKE2b-256 | c62d20635bd0c5c52f621fc3e5c6c5452efa82229b761602088f8e4bf892805e |
File details
Details for the file arena_py-1.3.0-py3-none-any.whl
.
File metadata
- Download URL: arena_py-1.3.0-py3-none-any.whl
- Upload date:
- Size: 107.1 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 | 150854dd8bf49913d492227f686e68ec7bf197121f640995cddc0b0c7f00813d |
|
MD5 | 24c655f32f865cdc6f0cd092a7dff351 |
|
BLAKE2b-256 | 16fe926aaa95d6ce0e18401b4105632cddae3959df69be45949717326ef0b0a1 |