SomaticLabs / ZorbPy

Python SDK for Zorb Engine

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

ZorbPy

Python library for integrating with the Somatic Zorb Engine

license Twitter

Compatibility

This library only currently supports macOS and Linux, as Windows is not currently supported by the underlying BLE package used for this library.

Supported Linux builds include all those that are compatible with the BluefruitLE package used with this library, including the Raspberry Pi operating system Raspbian.

Troubleshooting & Contributions

  • If you need help, send us an email.
  • If you'd like to ask a general question, send us an email.
  • If you found a bug, open an issue.
  • If you have a feature request, open an issue.
  • If you want to contribute, submit a pull request.

Installation

First install the Adafruit BluefruitLE library.

After installing the BluefruitLE library, installation of ZorbPy using pip is simple:

pip install zorb

Library Usage

For a quick example on how to use the ZorbPy library, please reference example.py.

To use the ZorbPy library, you must wrap the functionality of your program in a function that is passed to the zorb.run() function call.

Any usage of the functions provided by this library outside of the process started by zorb.run() will produce error behavior.

The ZorbPy library provides three main functionalities:

  • connecting to advertising Zorb devices

  • triggering presets on the Zorb device

  • directly controlling actuator intensity on the Zorb device

To connect to an advertising Zorb device:

zorb.connect()

To trigger one of the available presets:

zorb.triggerPattern(zorb.POINT_LEFT)

Note that preset haptic emojis are exist for the following emojis:

๐ŸŽŠ, ๐Ÿ‘ˆ, ๐Ÿ‘‰, ๐Ÿค›, ๐Ÿคœ, โฎ๏ธ, โญ๏ธ, ๐Ÿ™Œ, ๐Ÿ‘‹, ๐Ÿ˜ฏ, ๐Ÿ˜ณ, ๐Ÿ˜ฌ, ๐Ÿ˜Š, ๐Ÿ˜„, ๐Ÿคฃ

To directly set the actuator values:

duration = 100
top_left = 0
top_right = 0
bottom_left = 25
bottom_right = 25

zorb.writeActuators(duration, top_left, top_right, bottom_left, bottom_right)

Below is a more comprehensive example of a simple program that connects to a Zorb device, plays a confetti pattern upon successful connection, and then updates actuator values based on some hypothetical sensor output.

import zorb

def mainloop():
    # perform initial connection to Zorb device
    zorb.connect()

    # trigger confetti effect upon successful connection
    zorb.triggerPattern(zorb.CONFETTI)

    # enter infinte loop for updating Zorb device
    while True:
        top_left = hypothetical_sensor_1.val()
        top_right = hypothetical_sensor_2.val()
        bottom_left = hypothetical_sensor_3.val()
        bottom_right = hypothetical_sensor_4.val()
        zorb.writeActuators(10, top_left, top_right, bottom_left, bottom_right)
        time.sleep(0.01)


def main():
    zorb.run(mainloop)


if __name__ == '__main__':
    main()

Style Guide

Contributions to this project should conform to this Python Style Guide.

License

ZorbPy is released under the GPL license.

Contact us for a commercial license if the GPL does not work well for your use cases.

About

Python SDK for Zorb Engine

License:GNU General Public License v3.0


Languages

Language:Python 100.0%