Skip to main content

Python library for TouchNetix aXiom Touch Controllers

Project description

aXiom python library

This library provides users the building blocks to communicate with the aXiom touch controllers. By linking these building blocks together, more complex functions can be achieved, such as loading firmware, loading configuration files or building a production test process.

File Overview

axiom.py - Provides the main business logic and interface to aXiom.

Bootloader.py - Manages the logic for handling firmware updates.

I2C_Comms.py - Provides the logic for performing I2C comms to aXiom.

SPI_Comms.py - Provides the logic for performing SPI comms to aXiom.

USB_Comms.py - Provides the logic for performing USB comms to aXiom.

CDU_Common.py - Some usages are CDU (command driven usages). These usages use additional logic to read/write their contents.

u02_SystemManager.py - Provides access to aXiom's system manager. The aXiom device can be reset, jump to bootloader, save config changes to flash etc.

u06_SelfTest.py - Provides access to configure and control the self test settings in aXiom.

u07_LiveView.py - Provides access to read live data from aXiom. For instance GPIO status, acquisition status and self test status.

u32_DeviceCapabilities.py - Reports the capabilities of the aXiom device. For instance, the number CTS nodes, which comms interfaces are supported etc.

u33_CRCData.py - Provides access to the CRCs within aXiom.

u48_GPIOControls.py - Provides access to the GPIO controls for aXiom.

uXX_Template.py - Template file to use when creating more python files for specific usages.

Prerequisites

Requires Python 3.8 to be installed and accessible on the Path variable.

axiom_tc Package

This is the aXiom touch controller python package that provides access to core functionality and communication to the aXiom device. In conjunction with the axiom_tc package, the appropriate interface packages are expected to be available. These are described after this section.

Requires axiom_tc to be installed and accessible to your Python interpreter.

pip install axiom_tc

SPI Interface

Requires spidev to be installed and accessible to your Python interpreter.

pip install spidev

See spidev for more information.

I2C Interface

Requires smbus2 to be installed and accessible to your Python interpreter.

pip install smbus2

See smbus2 for more information.

USB Interface

Requires hid to be installed and accessible to your Python interpreter.

pip install hid==1.0.4

See hid for more information.

Linux

Using the hid package will access the TouchNetix protocol bridges via the /dev/hidrawX interface. This typically requires root access. This means the scripts will need to be run as sudo. Alternatively, udev can be used to give all users permissions to the hidraw devices.

Create the following udev rules file /etc/udev/rules.d/99-axiom-hidraw-permissions.rules:

SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="6f02", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2f04", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2f08", MODE="0666"

SUBSYSTEM=="hidraw", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="6f02", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="2f04", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="0483", ATTRS{idProduct}=="2f08", MODE="0666"

SUBSYSTEM=="hidraw", ATTRS{idVendor}=="28e9", ATTRS{idProduct}=="6f02", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="28e9", ATTRS{idProduct}=="2f04", MODE="0666"
SUBSYSTEM=="hidraw", ATTRS{idVendor}=="28e9", ATTRS{idProduct}=="2f08", MODE="0666"

The changes will apply on the next reboot. To apply the changes immediately:

sudo udevadm control --reload-rules
sudo udevadm trigger

If this error message is observed:

ImportError: Unable to load any of the following libraries:libhidapi-hidraw.so libhidapi-hidraw.so.0 libhidapi-libusb.so libhidapi-libusb.so.0 libhidapi-iohidmanager.so libhidapi-iohidmanager.so.0 libhidapi.dylib hidapi.dll libhidapi-0.dll

Run the following to install the hidapi library.

sudo apt-get install libhidapi-hidraw0 libhidapi-libusb0

Windows

Windows requires the hidapi.dll files to reside in the same directory as python (see more info here) The .dll files can be found here

License

This project is licensed under the MIT License. See the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

axiom_tc-4.8.7.2-py3-none-any.whl (38.1 kB view details)

Uploaded Python 3

File details

Details for the file axiom_tc-4.8.7.2-py3-none-any.whl.

File metadata

  • Download URL: axiom_tc-4.8.7.2-py3-none-any.whl
  • Upload date:
  • Size: 38.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.2

File hashes

Hashes for axiom_tc-4.8.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fa83a491919c646d39a1e6e0a41bdc0658ac5db6b55609fb2966fa0ddda1182f
MD5 e2a7f5deae90e9c0cb6faa8010bda43d
BLAKE2b-256 9369ffb64832cb0b2329506bfeaa9e07d5afb5c876df98716e0c39317560d567

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