Skip to content

Commit

Permalink
add VIA support for LED Matrix (#21281)
Browse files Browse the repository at this point in the history
  • Loading branch information
mechlovin authored Jul 7, 2023
1 parent f466fb8 commit 2264e6d
Show file tree
Hide file tree
Showing 2 changed files with 111 additions and 2 deletions.
99 changes: 97 additions & 2 deletions quantum/via.c
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
#include "eeprom.h"
#include "version.h" // for QMK_BUILDDATE used in EEPROM magic

#if defined(RGB_MATRIX_ENABLE)
#if (defined(RGB_MATRIX_ENABLE) || defined(LED_MATRIX_ENABLE))
# include <lib/lib8tion/lib8tion.h>
#endif

Expand Down Expand Up @@ -141,6 +141,9 @@ __attribute__((weak)) void via_set_device_indication(uint8_t value) {
#if defined(RGB_MATRIX_ENABLE)
rgb_matrix_toggle_noeeprom();
#endif // RGB_MATRIX_ENABLE
#if defined(LED_MATRIX_ENABLE)
led_matrix_toggle_noeeprom();
#endif // LED_MATRIX_ENABLE
#if defined(AUDIO_ENABLE)
if (value == 0) {
wait_ms(10);
Expand Down Expand Up @@ -194,6 +197,7 @@ __attribute__((weak)) void via_custom_value_command_kb(uint8_t *data, uint8_t le
// id_qmk_backlight_channel -> via_qmk_backlight_command()
// id_qmk_rgblight_channel -> via_qmk_rgblight_command()
// id_qmk_rgb_matrix_channel -> via_qmk_rgb_matrix_command()
// id_qmk_led_matrix_channel -> via_qmk_led_matrix_command()
// id_qmk_audio_channel -> via_qmk_audio_command()
//
__attribute__((weak)) void via_custom_value_command(uint8_t *data, uint8_t length) {
Expand All @@ -219,7 +223,14 @@ __attribute__((weak)) void via_custom_value_command(uint8_t *data, uint8_t lengt
via_qmk_rgb_matrix_command(data, length);
return;
}
#endif // RGBLIGHT_ENABLE
#endif // RGB_MATRIX_ENABLE

#if defined(LED_MATRIX_ENABLE)
if (*channel_id == id_qmk_led_matrix_channel) {
via_qmk_led_matrix_command(data, length);
return;
}
#endif // LED_MATRIX_ENABLE

#if defined(AUDIO_ENABLE)
if (*channel_id == id_qmk_audio_channel) {
Expand Down Expand Up @@ -692,6 +703,90 @@ void via_qmk_rgb_matrix_save(void) {

#endif // RGB_MATRIX_ENABLE

#if defined(LED_MATRIX_ENABLE)

# if !defined(LED_MATRIX_MAXIMUM_BRIGHTNESS) || LED_MATRIX_MAXIMUM_BRIGHTNESS > UINT8_MAX
# undef LED_MATRIX_MAXIMUM_BRIGHTNESS
# define LED_MATRIX_MAXIMUM_BRIGHTNESS UINT8_MAX
# endif

void via_qmk_led_matrix_command(uint8_t *data, uint8_t length) {
// data = [ command_id, channel_id, value_id, value_data ]
uint8_t *command_id = &(data[0]);
uint8_t *value_id_and_data = &(data[2]);

switch (*command_id) {
case id_custom_set_value: {
via_qmk_led_matrix_set_value(value_id_and_data);
break;
}
case id_custom_get_value: {
via_qmk_led_matrix_get_value(value_id_and_data);
break;
}
case id_custom_save: {
via_qmk_led_matrix_save();
break;
}
default: {
*command_id = id_unhandled;
break;
}
}
}

void via_qmk_led_matrix_get_value(uint8_t *data) {
// data = [ value_id, value_data ]
uint8_t *value_id = &(data[0]);
uint8_t *value_data = &(data[1]);

switch (*value_id) {
case id_qmk_led_matrix_brightness: {
value_data[0] = ((uint16_t)led_matrix_get_val() * UINT8_MAX) / LED_MATRIX_MAXIMUM_BRIGHTNESS;
break;
}
case id_qmk_led_matrix_effect: {
value_data[0] = led_matrix_is_enabled() ? led_matrix_get_mode() : 0;
break;
}
case id_qmk_led_matrix_effect_speed: {
value_data[0] = led_matrix_get_speed();
break;
}
}
}

void via_qmk_led_matrix_set_value(uint8_t *data) {
// data = [ value_id, value_data ]
uint8_t *value_id = &(data[0]);
uint8_t *value_data = &(data[1]);
switch (*value_id) {
case id_qmk_led_matrix_brightness: {
led_matrix_set_val_noeeprom(scale8(value_data[0], LED_MATRIX_MAXIMUM_BRIGHTNESS));
break;
}
case id_qmk_led_matrix_effect: {
if (value_data[0] == 0) {
led_matrix_disable_noeeprom();
} else {
led_matrix_enable_noeeprom();
led_matrix_mode_noeeprom(value_data[0]);
}
break;
}
case id_qmk_led_matrix_effect_speed: {
led_matrix_set_speed_noeeprom(value_data[0]);
break;
}
}
}

void via_qmk_led_matrix_save(void) {
eeconfig_update_led_matrix();
}

#endif // LED_MATRIX_ENABLE

#if defined(AUDIO_ENABLE)

extern audio_config_t audio_config;
Expand Down
14 changes: 14 additions & 0 deletions quantum/via.h
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@ enum via_channel_id {
id_qmk_rgblight_channel = 2,
id_qmk_rgb_matrix_channel = 3,
id_qmk_audio_channel = 4,
id_qmk_led_matrix_channel = 5,
};

enum via_qmk_backlight_value {
Expand All @@ -130,6 +131,12 @@ enum via_qmk_rgb_matrix_value {
id_qmk_rgb_matrix_color = 4,
};

enum via_qmk_led_matrix_value {
id_qmk_led_matrix_brightness = 1,
id_qmk_led_matrix_effect = 2,
id_qmk_led_matrix_effect_speed = 3,
};

enum via_qmk_audio_value {
id_qmk_audio_enable = 1,
id_qmk_audio_clicky_enable = 2,
Expand Down Expand Up @@ -182,6 +189,13 @@ void via_qmk_rgb_matrix_get_value(uint8_t *data);
void via_qmk_rgb_matrix_save(void);
#endif

#if defined(LED_MATRIX_ENABLE)
void via_qmk_led_matrix_command(uint8_t *data, uint8_t length);
void via_qmk_led_matrix_set_value(uint8_t *data);
void via_qmk_led_matrix_get_value(uint8_t *data);
void via_qmk_led_matrix_save(void);
#endif

#if defined(AUDIO_ENABLE)
void via_qmk_audio_command(uint8_t *data, uint8_t length);
void via_qmk_audio_set_value(uint8_t *data);
Expand Down

0 comments on commit 2264e6d

Please sign in to comment.