Skip to main content

A Python Library developed to be used with Mates Studio Commander or Architect Environment and BBM modules connected to a Raspberry Pi using BBM Pi Adaptor or with similar connections

Project description

image

Raspberry Pi Python Mates Controller Library

A Python Library developed to be used with Mates Studio Commander or Architect Environment and BBM modules connected to a Raspberry Pi using BBM Pi Adaptor or with similar connections. This library is aimed to be simple enough to learn for beginners and feature-rich for experienced developers.

It is used for communicating with BBM Devices, over serial port and contains various methods for sending and retrieving data relating to display widgets, their states and parameters and the health of the controller. Helpful classes and datatypes can be found in mates.constants module.

Hardware and Software Support

This library is developed for Python3 and designed to be used with any operating system as long as it is supported by the pyserial library.

Installation

This library can be installed from the Python Packaging Index by running the command:

pip3 install rpi-mates-controller

Library Discussion

Constructor

MatesController(portName, resetPinIndex, resetActiveHigh, debugStream, debugFileLength)

Constructs all the necessary attributes associated with an instance of a Mates Controller Object.

Args:

portName: str

  • the name of the port to be opened. Example: /dev/ttyUSB0 for linux.

resetPinIndex: int, string

  • index of pin connected to reset pin of Mates device.

resetActiveHigh: bool

  • whether the reset pin is driven from logic low or logic high to reset the device.

debugStream: io.TextIOWrapper

  • Text file object to write debugging code to, supply of none will result in no debugging. Examples include sys.stdout, open('log.txt', 'r+')

debugFileLength: int

  • Determines the extent of debug history kept with respect to lines in a file, given a circular log. O indicates full history kept with no circular logging. Users must be careful here to manage storage space effectively.
Example No. 1:
# Creates a new instance named 'mates' which utilizes: 
#  - /dev/ttyS0 as the serial port
#  - with default reset pin (4) and no output stream
MatesController mates = MatesController("/dev/ttyS0") 
Example No. 2:
# Creates a new instance named 'mates' which utilizes: 
#  - /dev/ttyS0 as the serial port
#  - pin 4 as the reset pin
#  - LOW pulse as active pulse
#  - output_file as debug file stream
#  - debugFileLength of zero indicating no circular logging
MatesController mates = MatesController("/dev/ttyS0", resetPinIndex=4, resetActiveHigh=False, debugStream=output_file, debugFileLength=0) 

Note: If a debug file is specified, it should be opened using either 'w+' or 'r+' before running the begin() function of this library.

Methods

begin(baudrate)

Begins the serial connection if portname not supplied in constructor.

Args:

baudrate: int

  • the baudrate of the serial port (default: 9600)

Returns:

  • void
Example No. 1:
# Initializes display serial port 9600 baud
# and resets the display if a reset function is provided
mates.begin(9600) 

close()

Closes opened serial port.

Args:

void.

Returns:

void.

Example:
# Closes serial port
mates.close()

reset(waitPeriod)

Uses hardware driven signal to hard reset companion device.

Args:

wait_period: int

  • determines how long to wait (milliseconds) before checking for connection. Value must be within the uint16 datatype range (default: 5000)

Returns:

  • boolean response of reset.
Example:
# Reset the display and wait for
mates.reset()         # a period of 5 seconds (default)
# Reset the display and wait for
# mates.reset(4000)   # a period of 4 seconds

softReset(waitPeriod)

Sends a serial command to the connected device to trigger a reset.

Args:
waitPeriod: int

  • determines how long (milliseconds) to wait before timing out after no acknowledgement. Value must be within the uint16 datatype range.

Returns:

  • boolean response of reset
Example:
# Reset the display and wait for
mates.softReset()       # a period of 5 seconds (default)
# Reset the display and wait for
mates.softReset(4000)   # a period of 4 seconds

setBacklight(backlightValue)

Sets the intensity of the backlight of connected device.

Args:
backlightValue: int

  • intensity of backlight. Value must be between 0 and 15, and within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
# set backlight value of 15 (max)
mates.setBacklight(15)

setPage(pageIndex)

Sets the page to be displayed on the connected device.

Args:
pageIndex: int

  • index of page to set as current. Value must be within the uint16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setPage(1) # Navigate to Page1

getPage()

Returns the index of the current page displayed by the connected device.

Args:

  • void.

Returns:

  • integer corresponding to current page index.
Example:
activePage = mates.getPage() # Query active page

setWidgetValueById(widgetId, value)

Sets the value of a specific widget based on the provided widgetId.

Args:
widgetId: int - the unique id of the desired widget. Value must exist within the int16 datatype range.

value: int the value the corresponding widget will be set to. Value must exist within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setWidgetValueById(MediaGaugeB0, 50) # Set value of MediaGaugeB0 to 50
# Note: The ID of MediaGaugeB0 can be copied or exported from Mates Studio

getWidgetValueById(widgetId)

Gets the value of a specific widget based on the provided identifier.

Args:
widgetId: int

  • the unique id of the target widget. Value must be within the uint16 datatype range

Returns:

  • integer corresponding to widget value.
Example:
widgetVal = mates.getWidgetValue(MediaLed4) # Query the current value of MediaLed4
# Note: The ID of MediaLed4 can be copied or exported from Mates Studio

setWidgetValueByIndex(widgetType, widgetIndex, value)

Sets the value of a specific widget based on the index within a widget type.

Args:
widgetType: MatesWidget

  • the unique type of widget to be changed.

widgetIndex: int

  • the index of the widget, of a specific type. Value must be within the uint8 datatype range.

value: int

  • the value the corresponding widget will be set to. Value must be within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.

Example:

mates.setWidgetValue(MATES_MEDIA_GAUGE_B, 0, 50) # Set value of MediaGaugeB0 to 50

Note: All applicable widget types are listed in here.


getWidgetValueByIndex(widgetType, widgetIndex)

Gets the value of a specific widget based on the index within a widget type.

Args:

widgetType: MatesWidget

  • the unique type of widget to be changed.

widgetIndex: int

  • the index of the widget, of a specific type. Value must be within the uint8 datatype range.

Returns:

  • integer corresponding to widget value.
Example:
widgetVal = mates.getWidgetValue(MATES_MEDIA_LED, 4) # Query the current value of MediaLed4

Note: This function is not applicable to Int32 and Float LedDigits


setLedDigitsShortValue(widgetIndex, value)

Sets the 16-bit integer value of the Led Digits widget specified by widgetIndex.

Args:

widgetIndex: int

  • the index of the LED Digits widget. Value must be within uint8 datatype range.

value: int, float

  • the value the corresponding widget will be set to. Values must be within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setLedDigitsShortValue(2, 50) # Set value of LedDigits2 to 50

Note: This function is only applicable for Int16 LedDigits


setLedDigitsLongValue(widgetIndex, value)

Sets the 32-bit integer value of the Led Digits widget specified by widgetIndex.

Args:

widgetIndex: int

  • the index of the LED Digits widget. Value must be within uint8 datatype range.

value: int, float

  • the value the corresponding widget will be set to. Values must be within the int32 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setLedDigitsLongValue(2, 50) # Set value of LedDigits2 to 50

Note: This function is only applicable for Int32 LedDigits


setLedDigitsFloatValue(widgetIndex, value):

Sets the 32-bit float value of the Led Digits widget specified by widgetIndex.

Args:

widgetIndex: int

  • the index of the LED Digits widget. Value must be within uint8 datatype range.

value: int, float

  • the value the corresponding widget will be set to. Values must be within the float32 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setLedDigitsFloatValue(2, 9.989) # Set value of LedDigits2 to 9.989

Note: This function is only applicable for float32 LedDigits


setSpectrumValue(spectrumId, gaugeIndex, value)

Sets the value of the column (specified by gaugeIndex) of the spectrum widget (specified by spectrumId).

Args:

spectrumId: int

  • the id of the relevant Spectrum widget. Value must be within the int16 datatype range.

gaugeIndex: int

  • the gauge index within the target Spectrum widget. Value must be within the uint8 datatype range.

value: int

  • the value the corresponding widget will be set to. Value must be within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setSpectrumValue(MatesLedSpectrum5, 2, 64)
# Set value of gauge index 2 of LedSpectrum5 to 64

setLedSpectrumValue(ledSpectrumIndex, gaugeIndex, value)

Sets the value of the column (specified by gaugeIndex) of the Led Spectrum widget (specified by ledSpectrumIndex).

Args: ledSpectrumIndex: int

  • the index of the desired LED Spectrum widget. Value must be within the uint8 datatype range.

gaugeIndex: int

  • the gauge index within the target LED Spectrum widget. Value must be within the uint8 datatype range.

value: int

  • the value the corresponding widget will be set to. Value must be within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setLedSpectrumValue(5, 2, 64)
# Set value of gauge index 2 of LedSpectrum5 to 64

setMediaSpectrumValue(mediaIndex, gaugeIndex, value)

Sets the value of the column (specified by gaugeIndex) of the Media Spectrum widget (specified by ledSpectrumIndex).

Args: mediaIndex: int

  • the index of the Media Spectrum widget. Value must be within the uint8 datatype range.

gaugeIndex: int

  • the index of the desired gauge. Value must be within the uint8 datatype range.

value: int

  • the value the corresponding widget will be set to. Value must be within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setMediaSpectrumValue(4, 3, 48)
# Set value of gauge index 3 of MediaSpectrum4 to 48

setWidgetParamById(widgetId, param, value)

Sets the value of a widget parameter based on widget id and parameter id.

Args: widgetId: int

  • the unique id of the target widget. Value must be within the int16 datatype range.

param: int

  • the unique id of the target parameter. Value must be within the int16 datatype range.

value: int

  • the value the corresponding parameter will be set to. Value must be within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
# Set GaugeA3's Background color to BLACK
mates.setWidgetParamById(GaugeA3, MATES_GAUGE_A_BG_COLOR, BLACK) 
# Note: The ID of GaugeA3 can be copied or exported from Mates Studio

getWidgetParamById(widgetId, param)

Gets the value of a widget parameter based on widget id and parameter id.

Args: widgetId: int - the unique id of the target widget. Value must be within the int16 datatype range.

param: int - the unique id of the target parameter. Value must be within the int16 datatype range.

Returns:

  • integer response indicating target parameter value.
Example:
# Query the background color of GaugeA3
paramVal = mates.getWidgetParamById(GaugeA3, MATES_GAUGE_A_BG_COLOR) 
# Note: The ID of GaugeA3 can be copied or exported from Mates Studio

setWidgetParamByIndex(widgetType, widgetIndex, param, value)

Sets the value of a widget parameter based on widget index and parameter id.

Args: widgetType: MatesWidget

  • the type of the target widget.

widgetIndex: int

  • the index of the target widget. Value must be within the uint8 datatype range.

param: int

  • the unique id of the target parameter. Value must be within the int16 datatype range.

value: int

  • the value the corresponding parameter will be set to. Value must be within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
# Set GaugeA3's Background color to BLACK
mates.setWidgetParamByIndex(MATES_GAUGE_A, 3, MATES_GAUGE_A_BG_COLOR, BLACK) 

getWidgetParamByIndex(widgetType, widgetIndex, param)

Gets the value of a widget parameter based on widget index and parameter id.

Args:

widgetType: MatesWidget

  • the type of the target widget.

widgetIndex: int

  • the index of the target widget. Value must be within the uint8 datatype range.

param: int

  • the unique id of the target parameter. Value must be within the int16 datatype range.

Returns:

  • integer response indicating target parameter value.
Example:
# Query the background color of GaugeA3
paramVal = mates.getWidgetParamByIndex(MATES_GAUGE_A, 3, MATES_GAUGE_A_BG_COLOR) 

clearTextArea(textAreaIndex)

Clears a targeted Text Area.

Args:

textAreaIndex: int

  • the index of the target Text Area widget. Value must be within the uint16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.clearTextArea(6) # Clear TextArea6

updateTextArea(textAreaIndex, textFormat, *formatArgs)

Updates the text displayed within Text Area widget.

Args:

textAreaIndex: int

  • the index of the target Text Area widget. Value must be within the uint16 datatype range.

textFormat: str

  • the string format to be displayed.

formatArgs:

  • zero or more values to be formatted into the provided text format string.

Returns:

  • boolean response indicating command success or failure.
Example No. 1:
mates.updateTextArea(2, "Mates") # Update TextArea2 to "Mates"
Example No. 2:
int value = 76
mates.updateTextArea(3, "Value is {}", 76) # Print value to TextArea3

def clearPrintArea(printAreaIndex: int)

Clears a targeted Print Area.

Args:

printAreaIndex: int

  • the index of the target Print Area widget. Value must be within the uint16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.clearPrintArea(5) # Clear PrintArea5

setPrintAreaColor565(printAreaIndex, rgb565)

Sets the color of a PrintArea Widget based on an rgb565 value.

Args:

printAreaIndex: int

  • index of widget, value must be within uint16 datatype range.

rgb565: int

  • colour to set widget to, value must be within uint16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setPrintAreaColor(4, 0xF800) # Set print color of PrintArea4 to RED (0xF800)

setPrintAreaColorRGB(printAreaIndex, red, green, blue)

Sets the colour of a targeted Print Area.

Args:

printAreaIndex: int

  • the index of the target Print Area widget. Value must be within the uint16 datatype range.

red: int

  • Unsigned 8 bit integer value of red concentration. Value must be within the uint8 datatype range.

blue: int

  • Unsigned 8 bit integer value of green concentration. Value must be within the uint8 datatype range.

green: int

  • Unsigned 8 bit integer value of blue concentration. Value must be within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
mates.setPrintAreaColor(7, 0, 255, 0) # Set print color of PrintArea7 to GREEN

appendArrayToPrintArea(printAreaIndex, array)

Appends an array of 8-bit integers to a targeted Print Area.

Args:

printAreaIndex: int

  • the index of the target Print Area widget. Value must be within the uint16 datatype range.

buffer: [int]

  • the list of datapoints to be appended to scope widget. Values must be within the uint8 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
arr = [0xAB, 0xCD, 0xEF]
mates.appendArrayToPrintArea(6, arr) # Append "0xAB, 0xCD, 0xEF" to PrintArea6

appendStringToPrintArea(printAreaIndex, textFormat, *formatArgs)

Appends text to a targeted Print Area.

Args:

printAreaIndex: int

  • the index of the target Print Area widget. Value must be within the uint16 datatype range.

textFormat: str

  • the string to be appended to the Print Area with zero or more format specifiers to be formatted.

formatArgs:

  • zero or more args that can be formatted into the textFormat string.

Returns:

  • boolean response indicating command success or failure.
Example No. 1:
mates.appendStringToPrintArea(8, "Mates") # Append "Mates" to PrintArea8
Example No. 2:
int value = 108
mates.appendStringToPrintArea(9, "Value: {}", 108) # Append value as text to PrintArea9

def appendToScopeWidget(scopeIndex, buffer)

Appends a list of integers to a Scope widget.

Args:

scopeIndex: int

  • the index of the target Scope widget. Value must be within the uint16 datatype range.

buffer: [int]

  • the list of datapoints to be appended to scope widget. Values must be within the int16 datatype range.

Returns:

  • boolean response indicating command success or failure.
Example:
data = {0xF8, 0x7F, 0x1F}
mates.appendToScopeWidget(7, data, 3) # Append data to Scope Widget 7

updateDotMatrixWidget(matrixIndex, textFormat, *formatArgs)

Changes the text displayed by the target Dot Matrix widget.

Args:

matrixIndex (int): matrix index.

  • The index of the target Scope widget. Value must be within the uint16 datatype range.

textFormat: str

  • the string to be appended to the Scope widget with zero or more format specifiers to be formatted.

formatArgs:

  • zero or more args that can be formatted into the text_format string.

Returns:

  • boolean response indicating command success or failure.
Example No. 1:
mates.updateDotMatrix(8, "Mates") # Update DotMatrix0 to "Mates"
Example No. 2:
value = 108
mates.updateDotMatrix(9, "Value: {}", 108) # Update DotMatrix0 to show value

getButtonEventCount()

Gets the number of events recorded from applicable button widgets.

Args:

  • void.

Returns:

  • integer corresponding to the number of events.
Example:
# Get the number of logged button events
buttonEvents = mates.getButtonEventCount()

getNextButtonEvent()

Gets the next event source logged from applicable buttons.

Args:

  • void.

Returns:

  • integer corresponding to the button widget ID
Example:
// If there is any event recorded
if mates.getButtonEventCount() > 0: 
    button = mates.getNextButtonEvent()
    if (button == MediaButton1):
        // if the button pressed is MediaButton1
        // do something
    // add more possible cases here...

getSwipeEventCount()

Gets the number of events recorded from swipe gestures.

Args:

  • void.

Returns:

  • integer corresponding to the number of events.
Example:
# Get the number of logged swipe events
swipeEvents = mates.getSwipeEventCount()

getNextSwipeEvent()

Gets the next swipe event value.

Args:

  • void.

Returns:

  • integer corresponding to the swipe event.
Example:
// If there is any event recorded
if mates.getSwipeEventCount() > 0:
    swipe = mates.getNextSwipeEvent()
    if ((swipe & MATES_SWIPE_SOUTH) == MATES_SWIPE_SOUTH):
        // if swipe is towards from top to bottom
    if ((swipe & MATES_SWIPE_EAST) == MATES_SWIPE_EAST):
        // if swipe is towards from left to right
    if ((swipe & MATES_SWIPE_TLBR) == MATES_SWIPE_TLBR):
        // if swipe is towards from top left to bottom right

getVersion()

Helper function to obtain the version of the Python Mates Controller library.

Args:

  • void.

Returns:

  • string response of library version.
Example:
# Get the library version number as string
matesVersion = mates.getVersion()

def getCompatibility()

Helper function to obtain the version of the Mates Studio compatible with this library version.

Args:

  • void.

Returns:

  • string response of Mates Studio version compatible with this library.
Example:
# Get the library version number as string
matesVersion = mates.getCompatibility()

printVersion()

Debugging function to print the version of the Mates Studio compatible along with this specific library version.

Args:

  • void.

Returns:

  • void.
Example:
# Prints library version and compatible Mates Studio version to debug serial
mates.printVersion()

getError()

Function to return the current error state of the Mates Controller.

Args:

  • void.

Returns:

  • MatesError response of current error.
Example:
# Checks the last error that occurred
error = mates.getError()
if error == MATES_ERROR_NONE:
    # Last command was successful

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

rpi_mates_controller-1.0.3.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

rpi_mates_controller-1.0.3-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file rpi_mates_controller-1.0.3.tar.gz.

File metadata

  • Download URL: rpi_mates_controller-1.0.3.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for rpi_mates_controller-1.0.3.tar.gz
Algorithm Hash digest
SHA256 633b4ef43166c78bddd5474eb5189e8bf052bd712d7b848772603e1e4056d8ae
MD5 0dc29050e728d0be016d4b043ef5959f
BLAKE2b-256 dfa213d219f32c405c41c27a573c0b67b5cda8c81fd014df9c5f911a0b4f58f8

See more details on using hashes here.

File details

Details for the file rpi_mates_controller-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for rpi_mates_controller-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d2d4061e6c0e92692a1abad291b8de6c32e1e447023bb08f97e79bf2b9adf200
MD5 0d11e9b21c2cced43ae86d855744ce3b
BLAKE2b-256 dbcbfbc20c0ebf15c839e600e5eee210dc80c4d35216b6181e94f588a6813407

See more details on using hashes here.

Supported by

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