/avell-unofficial-control-center

This is a Unofficial Control Center for Avell Laptops with Linux System

Primary LanguagePythonMIT LicenseMIT

avell-unofficial-control-center

Gitter

This is a driver to control RGB keyboard in Linux Systems based on Avell Control Center.

This project is at an early stage. The aim is to implement a Linux userspace driver and control tool for RGB LED keyboard backlight controller Integrated Technology Express ITE Device(8291) Rev 0.03. This RGB keyboard controller is used in many gaming laptops around the world. For a list of reseller-branded devices, see below.

Compatibility

Note:

if you have ITE Device(8291) Rev 0.02 see Project StarBeat

Find out about your laptop's keyboard model

sudo hwinfo --short

It should show the ITE Device(8291) in the keyboard section:

keyboard:
                       Integrated Technology Express ITE Device(8291)
  /dev/input/event0    AT Translated Set 2 keyboard

Known compatible devices

ITE Device(8291) is integrated in widely-used Tongfang gaming laptop barebones:

  • Tongfang GK5CN5Z / GK5CN6Z / GK5CQ7Z / GK5CP0Z (Barebone)
  • Avell G1550 FOX, G1513 FOX-7, A65, A52 (BR reseller)
  • Schenker XMG Neo 15 (DE reseller), Versions M18 & M19
  • PCSpecialist Recoil II & III (UK reseller)
  • Scan/3XS LG15 Vengeance Pro (UK reseller)
  • Overpowered 15 and 15+ (US reseller, sold via Walmart)
  • Monster Tulpar T5 (TR reseller)
  • MECHREVO Deep Sea Ghost Z2 (CN reseller)
  • Raionbook GS5 (IT reseller)
  • Illegear Onyx (MY reseller)
  • Hyperbook Pulsar Z15 (PL reseller)
  • SMART7 Kallisto GX15D (PL reseller)
  • Aftershock APEX 15 (SG reseller)
  • Origin-PC EON15-S (USA, Asia, and AU/NZ reseller)
  • Eluktronics Mech 15 G2 (US reseller)
  • HIDevolution EVOC 16GK5 (US reseller)
  • Obsidian GK5CP (PT reseller)
  • Vulcan JinGang GTX Standard

Project status

Working:

  • change color of mechanical rgb-keyboard
  • adjust brightness
  • disable RGB leds
  • set predefined styles

To do:

  • implement a GUI interface in Pyqt/Pyside2
  • save/load profiles
  • set custom color in specific key
  • monitor, cpu/gpu load

Installation

The easy way, using pip3

Install via pip using sudo or with root user:

sudo pip3 install avell-unofficial-control-center

The manual way, using git

  • Clone the repository (git clone https://github.com/rodgomesc/avell-unofficial-control-center.git), or update with git pull if cloned previously.
  • Build an installable package: python3 setup.py build
  • Install the package: sudo python3 setup.py install

Usage

Plain colors

Colors available are: red, green, blue, teal, pink, yellow, orange, white, olive, maroon, brown, gray, skyblue, navy, crimson, darkgreen, lightgreen, gold, violet.
Brightness options are: 1,2,3 and 4.

To set green color in all keys with max brightness:

aucc -c green -b 4

If no brightness parameter -b is provided, max brightness 4 is applied.

Alternating colors

To set alternating row colors:

aucc -H pink teal -b 4

Use -H for horizontal rows of alternating colors. Use -V for vertical columns of alternating colors.

Apply pre-defined styles

To set keyboard predefined custom styles:

aucc -s style

Styles available are aurora, marquee, raindrop, reactive and rainbow.

Disable all keyboard backlight

To disable all keys:

aucc -d

Add aucc to run on System Startup in 3 steps.

The following commands need to be executed with root (superuser), or using sudo "command"

step 1:

create aucc.service in /etc/systemd/system

vi /etc/systemd/system/aucc.service

step 2:

press i to enter in vim edit mode and paste folow (use the command in "ExecStart" line to specify aucc options):

[Unit]
Description=Avell Keyboard Configuration
[Service]
Type=oneshot
ExecStart=/usr/local/bin/aucc -c red -b 1
[Install]
WantedBy=multi-user.target

to write and save the content press ESC and hold Shift+zz

for more options about customize colors, brightness and styles, folow Usage Instructions

step 3:

give permissions enable service and put it to work:

chmod 755 aucc.service # give permissions
systemctl enable aucc.service # enable service
systemctl daemon-reload # reload daemon for apply changes
systemctl start aucc.service # start service
systemctl status aucc.service #check status

reboot and enjoy :)

if you want to change something in service file don't forget to reload the daemon and restart service:

systemctl daemon-reload
systemctl restart aucc.service

Thanks to

  1. Avell - For this amazing Laptop
  2. @kirainmoe - For help-me on bring macOs Support

Contributions

Contributions of any kind are welcome. Please follow pep-8 coding style guides.

Donate ☕ ♥️

This is a project I develop in my free time. If you use avell-unofficial-control-center or simply like the project and want to help please consider donating a coffee.