Awesome
razer-cli
<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --> <!-- ALL-CONTRIBUTORS-BADGE:END -->Command line interface for controlling Razer devices on Linux
About
With this command line interface you can configure your Razer peripherals, such as keyboard and mouse, set their colors and effects, etc.
The most simple use case (for which this tool was originally developed) is to
use it in symbiosis with pywal
. Then
this tool will set your Razer colors to Pywal's colors. See below for more
information.
Installation
OR
git clone https://github.com/LoLei/razer-cli.git
cd razer-cli
sudo python setup.py install
OR
git clone https://github.com/LoLei/razer-cli.git
cd razer-cli
pip install . --user
Usage
$ razer-cli -h
usage: razer-cli [-h] [-man [MANUAL ...]] [-v] [-d DEVICE [DEVICE ...]]
[-a] [-e EFFECT [EFFECT ...]] [-c COLOR [COLOR ...]]
[-z ZONES [ZONES ...]] [-b BRIGHTNESS [BRIGHTNESS ...]]
[--dpi DPI] [--poll POLL]
[--battery BATTERY [BATTERY ...]] [-l] [-ll] [-ls]
[--sync] [--restore] [--version]
optional arguments:
-h, --help show this help message and exit
-man [MANUAL ...], --manual [MANUAL ...]
Print help details for given feature(s)
-v, --verbose increase output verbosity
-d DEVICE [DEVICE ...], --device DEVICE [DEVICE ...]
only affect these devices, same name as output of
-l
-a, --automatic try to find colors and set them to all devices
without user arguments, uses X or pywal colors
-e EFFECT [EFFECT ...], --effect EFFECT [EFFECT ...]
set effect
-c COLOR [COLOR ...], --color COLOR [COLOR ...]
choose color (default: X color1), use one argument
for hex, or three for base10 rgb
-z ZONES [ZONES ...], --zone ZONES [ZONES ...]
choose zone for color(s)
-b BRIGHTNESS [BRIGHTNESS ...], --brightness BRIGHTNESS [BRIGHTNESS ...]
set brightness of device
--dpi DPI set DPI of device (use print as a value to show
it)
--poll POLL set polling rate of device (use print as a value
to show it)
--battery BATTERY [BATTERY ...]
set low threshold and/or idle delay (use print as
a value to show it)
-l, --list_devices list available devices, settings, and their
supported capabilities/effects
-ll, --list_devices_long
list available devices settings, and list their
supported capabilities/effects
-ls, --list_devices_short
list available devices and their settings
--sync sync lighting effects to all supported Razer
products
--restore Load last used settings
--version Print version number
<sup>This might be out of date, just run it with -h
yourself to see the newest
options.</sup>
Example usage with Pywal
To get your mouse and keyboard to use Pywal's colors, simply start razer-cli
with the -a
flag, after having executed wal
: razer-cli -a
Example in action
here.
Another option is to use razer-cli -e multicolor,xpalette
, which not only
uses a single color from pywal, but uses the entire 16 color palette.
Other examples
$ razer-cli -e ripple -c ff0000
$ razer-cli -e static -c ffffff
You can also leave out the color or the effect:
$ razer-cli -e breath_single
$ razer-cli -c 55ff99
Currently this will imply the -a
flag being used for the missing setting. I
plan on also having the option to reuse the current color/effect, if the
argument is missing, in the future.
Effects
Effects are listed in
razer_cli/settings.py
.
The effects that are supported per device can be listed with razer-cli -l[l]
.
Some of the built-in effects or not implemented yet. If such an effect is
chosen, a notice will be logged. There are also custom effects that do not exist
normally, such as multicolor
, which is described in the same file.
Here's a showcase of that effect:
<p align="center"> <img src="https://raw.githubusercontent.com/LoLei/razer-cli/master/images/randomshowcase.gif"> </p>Other symbiosis tools
Dependencies
openrazer
- :warning: Do not install
openrazer
from pip, which is something else. - Instead install it from one of the various package managers of your distribution.
- :warning: Do not install
xrdb
- Also available on most distros.
Disclaimer
Not all devices have been tested, but basic effects should work everywhere. Some guesswork is being done as to what capabilities are supported on specific devices. If you need more advanced configuration, consider using the GUIs Polychromatic, RazerGenie or RazerCommander which have specific implementations for most devices.
Feel free to open feature request issues or PRs.
Contributors ✨
Thanks goes to these wonderful people (emoji key):
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> <!-- prettier-ignore-start --> <!-- markdownlint-disable --> <table> <tbody> <tr> <td align="center" valign="top" width="14.28%"><a href="https://github.com/Ansis100"><img src="https://avatars2.githubusercontent.com/u/35926716?v=4?s=100" width="100px;" alt="Ansis"/><br /><sub><b>Ansis</b></sub></a><br /><a href="https://github.com/LoLei/razer-cli/commits?author=Ansis100" title="Code">💻</a></td> <td align="center" valign="top" width="14.28%"><a href="https://t1c.dev"><img src="https://avatars0.githubusercontent.com/u/44733677?v=4?s=100" width="100px;" alt="Kainoa Kanter"/><br /><sub><b>Kainoa Kanter</b></sub></a><br /><a href="#ideas-ThatOneCalculator" title="Ideas, Planning, & Feedback">🤔</a></td> <td align="center" valign="top" width="14.28%"><a href="https://www.ifohancroft.com"><img src="https://avatars0.githubusercontent.com/u/3461282?v=4?s=100" width="100px;" alt="IFo Hancroft"/><br /><sub><b>IFo Hancroft</b></sub></a><br /><a href="https://github.com/LoLei/razer-cli/issues?q=author%3Aifohancroft" title="Bug reports">🐛</a> <a href="#userTesting-ifohancroft" title="User Testing">📓</a> <a href="https://github.com/LoLei/razer-cli/commits?author=ifohancroft" title="Documentation">📖</a></td> <td align="center" valign="top" width="14.28%"><a href="https://github.com/GM-Script-Writer-62850"><img src="https://avatars2.githubusercontent.com/u/564653?v=4?s=100" width="100px;" alt="GM-Script-Writer-62850"/><br /><sub><b>GM-Script-Writer-62850</b></sub></a><br /><a href="https://github.com/LoLei/razer-cli/commits?author=GM-Script-Writer-62850" title="Code">💻</a></td> <td align="center" valign="top" width="14.28%"><a href="https://github.com/sk8ersteve"><img src="https://avatars.githubusercontent.com/u/10476999?v=4?s=100" width="100px;" alt="Stephen Thomas-Dorin"/><br /><sub><b>Stephen Thomas-Dorin</b></sub></a><br /><a href="https://github.com/LoLei/razer-cli/commits?author=sk8ersteve" title="Code">💻</a></td> <td align="center" valign="top" width="14.28%"><a href="https://github.com/romainrichard"><img src="https://avatars.githubusercontent.com/u/498307?v=4?s=100" width="100px;" alt="Romain Richard"/><br /><sub><b>Romain Richard</b></sub></a><br /><a href="https://github.com/LoLei/razer-cli/commits?author=romainrichard" title="Code">💻</a></td> </tr> </tbody> </table> <!-- markdownlint-restore --> <!-- prettier-ignore-end --> <!-- ALL-CONTRIBUTORS-LIST:END -->This project follows the all-contributors specification. Contributions of any kind welcome!