Skip to content

morswin22/pychroma

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pychroma

Python library for accessing the Razer Chroma SDK

pychroma provides general-purpose access to the Razer Chroma SDK REST API for control over the LEDs of Razer devices. The work environment is easy to set up and it features a sketch and (optionally) a controller. The sketch code structure is heavily inspired from p5js.org conventions. The controller allows having multiple sketches.

Features

  • Full controll over the LEDs via Chroma SDK
  • Low barrier to entry for educators and practitioners

Made for everyone

  • Simply use the sketch! This library is accessible and inclusive for artists, designers, educators and beginners
  • Gain more access by using the controller or handling the connection and devices all by yourself
  • If you want to have full control then fork this repository and edit the source code

Installation

This repo is tested on Python 3.8.3, requests 2.23.0 and pynput 1.6.8

With pip

pychroma can be installed using pip as follows:

pip install pychroma

From source

You can install from source by cloning the repository and running:

git clone https://github.com/morswin22/pychroma
cd pychroma
pip install .

When you update the repository, you should upgrade the pychroma installation and its dependencies as follows:

git pull
pip install --upgrade .

Run the examples

You can download the examples from the examples repo

Look at the README included with examples for more information

Tests

A series of tests are included for the library. Library tests can be found in the tests folder.

Here's the easiest way to run tests for the library:

python -m unittest discover -v -s ./tests -p test*.py

If you are using Visual Studio Code then you can use it's built in testing with python add-on

Quick Tour

Check out the wiki for detailed documentation.

Creating a sketch

from pychroma import Sketch

class MySketch(Sketch):
  def setup(self):
    pass # This will run once as first
    
  def update(self):
    pass # This will run every frame before render
    
  def render(self):
    pass # This will run every frame after update

Example animation code

from pychroma import Sketch

class MySketch(Sketch):
  def setup(self):
    self.frame_rate = 30
    self.color_mode('hsv')
    self.hue = 0
    
  def update(self):
    self.hue += 1
    if self.hue > 360:
      self.stop()
    
  def render(self):
    self.set_static((self.hue, 100, 100))

First run

Save your code into a file and run:

python path/to/file.py

You will be prompted for Chroma SDK application information. If you choose to save it into a file, it will be loaded automatically next time you run your script.

Next steps

Write your own animation and use the wiki for more information on how to use this library.

You can post your sketch using this issue template to the examples repo

About

Python library for accessing the Razer Chroma SDK

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages