Various improvements for the AnnePro2 (#16579)

This commit is contained in:
jpe230 2022-03-08 23:49:29 -06:00 committed by GitHub
parent 6ab5a7d048
commit dc67fd9b87
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 526 additions and 304 deletions

View File

@ -24,7 +24,7 @@
#define RAM_MAGIC_LOCATION 0x20001ffc #define RAM_MAGIC_LOCATION 0x20001ffc
#define IAP_MAGIC_VALUE 0x0000fab2 #define IAP_MAGIC_VALUE 0x0000fab2
static const SerialConfig ledUartInitConfig = { static const SerialConfig led_uart_init_config = {
.speed = 115200, .speed = 115200,
}; };
@ -32,21 +32,25 @@ static const SerialConfig ledUartInitConfig = {
# define LED_UART_BAUD_RATE 115200 # define LED_UART_BAUD_RATE 115200
#endif // LED_UART_BAUD_RATE #endif // LED_UART_BAUD_RATE
static const SerialConfig ledUartRuntimeConfig = { static const SerialConfig led_uart_runtine_config = {
.speed = LED_UART_BAUD_RATE, .speed = LED_UART_BAUD_RATE,
}; };
static const SerialConfig bleUartConfig = { static const SerialConfig ble_uart_config = {
.speed = 115200, .speed = 115200,
}; };
static uint8_t ledMcuWakeup[11] = {0x7b, 0x10, 0x43, 0x10, 0x03, 0x00, 0x00, 0x7d, 0x02, 0x01, 0x02}; static uint8_t led_mcu_wakeup[11] = {0x7b, 0x10, 0x43, 0x10, 0x03, 0x00, 0x00, 0x7d, 0x02, 0x01, 0x02};
ble_capslock_t BLECapsLock = {._dummy = {0}, .caps_lock = false}; ble_capslock_t ble_capslock = {._dummy = {0}, .caps_lock = false};
#ifdef RGB_MATRIX_ENABLE
static uint8_t current_rgb_row = 0;
#endif
void bootloader_jump(void) { void bootloader_jump(void) {
// Send msg to shine to boot into IAP // Send msg to shine to boot into IAP
annepro2SetIAP(); ap2_set_IAP();
// wait for shine to boot into IAP // wait for shine to boot into IAP
wait_ms(15); wait_ms(15);
@ -67,27 +71,27 @@ void bootloader_jump(void) {
void keyboard_pre_init_kb(void) { void keyboard_pre_init_kb(void) {
// Start LED UART // Start LED UART
sdStart(&SD0, &ledUartInitConfig); sdStart(&SD0, &led_uart_init_config);
/* Let the LED chip settle a bit before switching the mode. /* Let the LED chip settle a bit before switching the mode.
* That helped at least one person. */ * That helped at least one person. */
wait_ms(15); wait_ms(15);
sdWrite(&SD0, ledMcuWakeup, sizeof(ledMcuWakeup)); sdWrite(&SD0, led_mcu_wakeup, sizeof(led_mcu_wakeup));
// wait to receive response from wakeup // wait to receive response from wakeup
wait_ms(15); wait_ms(15);
protoInit(&proto, ledCommandCallback); proto_init(&proto, led_command_callback);
// loop to clear out receive buffer from shine wakeup // loop to clear out receive buffer from shine wakeup
while (!sdGetWouldBlock(&SD0)) sdGet(&SD0); while (!sdGetWouldBlock(&SD0)) sdGet(&SD0);
sdStart(&SD0, &ledUartRuntimeConfig); sdStart(&SD0, &led_uart_runtine_config);
keyboard_pre_init_user(); keyboard_pre_init_user();
} }
void keyboard_post_init_kb(void) { void keyboard_post_init_kb(void) {
// Start BLE UART // Start BLE UART
sdStart(&SD1, &bleUartConfig); sdStart(&SD1, &ble_uart_config);
annepro2_ble_startup(); annepro2_ble_startup();
// Give the send uart thread some time to // Give the send uart thread some time to
@ -97,7 +101,11 @@ void keyboard_post_init_kb(void) {
// loop to clear out receive buffer from ble wakeup // loop to clear out receive buffer from ble wakeup
while (!sdGetWouldBlock(&SD1)) sdGet(&SD1); while (!sdGetWouldBlock(&SD1)) sdGet(&SD1);
annepro2LedGetStatus(); ap2_led_get_status();
#ifdef RGB_MATRIX_ENABLE
ap2_led_enable();
#endif
keyboard_post_init_user(); keyboard_post_init_user();
} }
@ -106,25 +114,35 @@ void matrix_scan_kb() {
// if there's stuff on the ble serial buffer // if there's stuff on the ble serial buffer
// read it into the capslock struct // read it into the capslock struct
while (!sdGetWouldBlock(&SD1)) { while (!sdGetWouldBlock(&SD1)) {
sdReadTimeout(&SD1, (uint8_t *)&BLECapsLock, sizeof(ble_capslock_t), 10); sdReadTimeout(&SD1, (uint8_t *)&ble_capslock, sizeof(ble_capslock_t), 10);
} }
/* While there's data from LED keyboard sent - read it. */ /* While there's data from LED keyboard sent - read it. */
while (!sdGetWouldBlock(&SD0)) { while (!sdGetWouldBlock(&SD0)) {
uint8_t byte = sdGet(&SD0); uint8_t byte = sdGet(&SD0);
protoConsume(&proto, byte); proto_consume(&proto, byte);
} }
#ifdef RGB_MATRIX_ENABLE
/* If there's data ready to be sent to LED MCU - send it. */
if(rgb_row_changed[current_rgb_row])
{
rgb_row_changed[current_rgb_row] = 0;
ap2_led_mask_set_row(current_rgb_row);
}
current_rgb_row = (current_rgb_row + 1) % NUM_ROW;
#endif
matrix_scan_user(); matrix_scan_user();
} }
bool process_record_kb(uint16_t keycode, keyrecord_t *record) { bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
if (record->event.pressed) { if (record->event.pressed) {
if (annepro2LedStatus.matrixEnabled && annepro2LedStatus.isReactive) { if (ap2_led_status.matrix_enabled && ap2_led_status.is_reactive) {
annepro2LedForwardKeypress(record->event.key.row, record->event.key.col); ap2_led_forward_keypress(record->event.key.row, record->event.key.col);
} }
const annepro2Led_t blue = { const ap2_led_t blue = {
.p.blue = 0xff, .p.blue = 0xff,
.p.red = 0x00, .p.red = 0x00,
.p.green = 0x00, .p.green = 0x00,
@ -135,22 +153,22 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
case KC_AP2_BT1: case KC_AP2_BT1:
annepro2_ble_broadcast(0); annepro2_ble_broadcast(0);
/* FIXME: This hardcodes col/row position */ /* FIXME: This hardcodes col/row position */
annepro2LedBlink(0, 1, blue, 8, 50); ap2_led_blink(0, 1, blue, 8, 50);
return false; return false;
case KC_AP2_BT2: case KC_AP2_BT2:
annepro2_ble_broadcast(1); annepro2_ble_broadcast(1);
annepro2LedBlink(0, 2, blue, 8, 50); ap2_led_blink(0, 2, blue, 8, 50);
return false; return false;
case KC_AP2_BT3: case KC_AP2_BT3:
annepro2_ble_broadcast(2); annepro2_ble_broadcast(2);
annepro2LedBlink(0, 3, blue, 8, 50); ap2_led_blink(0, 3, blue, 8, 50);
return false; return false;
case KC_AP2_BT4: case KC_AP2_BT4:
annepro2_ble_broadcast(3); annepro2_ble_broadcast(3);
annepro2LedBlink(0, 4, blue, 8, 50); ap2_led_blink(0, 4, blue, 8, 50);
return false; return false;
case KC_AP2_USB: case KC_AP2_USB:
@ -162,37 +180,43 @@ bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
return false; return false;
case KC_AP_LED_OFF: case KC_AP_LED_OFF:
annepro2LedDisable(); ap2_led_disable();
break; break;
case KC_AP_LED_ON: case KC_AP_LED_ON:
if (annepro2LedStatus.matrixEnabled) { if (ap2_led_status.matrix_enabled) {
annepro2LedNextProfile(); ap2_led_next_profile();
} else { } else {
annepro2LedEnable(); ap2_led_enable();
} }
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
break; break;
case KC_AP_LED_NEXT_PROFILE: case KC_AP_LED_NEXT_PROFILE:
annepro2LedNextProfile(); ap2_led_next_profile();
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
break; break;
case KC_AP_LED_PREV_PROFILE: case KC_AP_LED_PREV_PROFILE:
annepro2LedPrevProfile(); ap2_led_prev_profile();
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
break; break;
case KC_AP_LED_NEXT_INTENSITY: case KC_AP_LED_NEXT_INTENSITY:
annepro2LedNextIntensity(); ap2_led_next_intensity();
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
return false; return false;
case KC_AP_LED_SPEED: case KC_AP_LED_SPEED:
annepro2LedNextAnimationSpeed(); ap2_led_next_animation_speed();
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
return false; return false;
#ifdef RGB_MATRIX_ENABLE
case RGB_TOG:
if(rgb_matrix_is_enabled()) ap2_led_disable();
else ap2_led_enable();
return true;
#endif
default: default:
break; break;

View File

@ -24,16 +24,16 @@ typedef struct __attribute__((__packed__)) {
uint8_t _dummy[10]; uint8_t _dummy[10];
bool caps_lock; bool caps_lock;
} ble_capslock_t; } ble_capslock_t;
extern ble_capslock_t BLECapsLock; extern ble_capslock_t ble_capslock;
// Matrix keymap // Matrix keymap
// clang-format off // clang-format off
#define LAYOUT( \ #define LAYOUT_60_ansi( \
K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, \ K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D, \
K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, \ K10, K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, K1D, \
K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, \ K20, K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, \
K30, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, \ K30, K32, K33, K34, K35, K36, K37, K38, K39, K3A, K3B, K3C, \
K40, K42, K43, K46, K49, K4A, K4B, K4C \ K40, K42, K43, K46, K49, K4A, K4B, K4C \
) { \ ) { \
/* COL1 COL2 COL3 COL4 COL5 COL6 COL7 COL8 COL9 COL10 COL11 COL12 COL13 COL14*/ \ /* COL1 COL2 COL3 COL4 COL5 COL6 COL7 COL8 COL9 COL10 COL11 COL12 COL13 COL14*/ \
/* ROW1 */ { K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D }, \ /* ROW1 */ { K00, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, K0D }, \

View File

@ -35,47 +35,47 @@ static host_driver_t ap2_ble_driver = {
ap2_ble_leds, ap2_ble_keyboard, ap2_ble_mouse, ap2_ble_system, ap2_ble_consumer, ap2_ble_leds, ap2_ble_keyboard, ap2_ble_mouse, ap2_ble_system, ap2_ble_consumer,
}; };
static uint8_t bleMcuWakeup[11] = {0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x01, 0x7d, 0x02, 0x01, 0x02}; static uint8_t ble_mcu_wakeup[11] = {0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x01, 0x7d, 0x02, 0x01, 0x02};
static uint8_t bleMcuStartBroadcast[11] = { static uint8_t ble_mcu_start_broadcast[11] = {
0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x00, 0x7d, 0x40, 0x01, 0x00 // Broadcast ID[0-3] 0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x00, 0x7d, 0x40, 0x01, 0x00 // Broadcast ID[0-3]
}; };
static uint8_t bleMcuConnect[11] = { static uint8_t ble_mcu_connect[11] = {
0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x00, 0x7d, 0x40, 0x04, 0x00 // Connect ID [0-3] 0x7b, 0x12, 0x53, 0x00, 0x03, 0x00, 0x00, 0x7d, 0x40, 0x04, 0x00 // Connect ID [0-3]
}; };
static uint8_t bleMcuSendReport[10] = { static uint8_t ble_mcu_send_report[10] = {
0x7b, 0x12, 0x53, 0x00, 0x0A, 0x00, 0x00, 0x7d, 0x10, 0x04, 0x7b, 0x12, 0x53, 0x00, 0x0A, 0x00, 0x00, 0x7d, 0x10, 0x04,
}; };
static uint8_t bleMcuSendConsumerReport[10] = { static uint8_t ble_mcu_send_consumer_report[10] = {
0x7b, 0x12, 0x53, 0x00, 0x06, 0x00, 0x00, 0x7d, 0x10, 0x08, 0x7b, 0x12, 0x53, 0x00, 0x06, 0x00, 0x00, 0x7d, 0x10, 0x08,
}; };
static uint8_t bleMcuUnpair[10] = { static uint8_t ble_mcu_unpair[10] = {
0x7b, 0x12, 0x53, 0x00, 0x02, 0x00, 0x00, 0x7d, 0x40, 0x05, 0x7b, 0x12, 0x53, 0x00, 0x02, 0x00, 0x00, 0x7d, 0x40, 0x05,
}; };
static uint8_t bleMcuBootload[11] = {0x7b, 0x10, 0x51, 0x10, 0x03, 0x00, 0x00, 0x7d, 0x02, 0x01, 0x01}; static uint8_t ble_mcu_bootload[11] = {0x7b, 0x10, 0x51, 0x10, 0x03, 0x00, 0x00, 0x7d, 0x02, 0x01, 0x01};
static host_driver_t *lastHostDriver = NULL; static host_driver_t *last_host_driver = NULL;
#ifdef NKRO_ENABLE #ifdef NKRO_ENABLE
static bool lastNkroStatus = false; static bool lastNkroStatus = false;
#endif // NKRO_ENABLE #endif // NKRO_ENABLE
/* -------------------- Public Function Implementation ---------------------- */ /* -------------------- Public Function Implementation ---------------------- */
void annepro2_ble_bootload(void) { sdWrite(&SD1, bleMcuBootload, sizeof(bleMcuBootload)); } void annepro2_ble_bootload(void) { sdWrite(&SD1, ble_mcu_bootload, sizeof(ble_mcu_bootload)); }
void annepro2_ble_startup(void) { sdWrite(&SD1, bleMcuWakeup, sizeof(bleMcuWakeup)); } void annepro2_ble_startup(void) { sdWrite(&SD1, ble_mcu_wakeup, sizeof(ble_mcu_wakeup)); }
void annepro2_ble_broadcast(uint8_t port) { void annepro2_ble_broadcast(uint8_t port) {
if (port > 3) { if (port > 3) {
port = 3; port = 3;
} }
// sdPut(&SD1, 0x00); // sdPut(&SD1, 0x00);
sdWrite(&SD1, bleMcuStartBroadcast, sizeof(bleMcuStartBroadcast)); sdWrite(&SD1, ble_mcu_start_broadcast, sizeof(ble_mcu_start_broadcast));
sdPut(&SD1, port); sdPut(&SD1, port);
static int lastBroadcast = -1; static int lastBroadcast = -1;
if (lastBroadcast == port) { if (lastBroadcast == port) {
@ -88,7 +88,7 @@ void annepro2_ble_connect(uint8_t port) {
if (port > 3) { if (port > 3) {
port = 3; port = 3;
} }
sdWrite(&SD1, bleMcuConnect, sizeof(bleMcuConnect)); sdWrite(&SD1, ble_mcu_connect, sizeof(ble_mcu_connect));
sdPut(&SD1, port); sdPut(&SD1, port);
ap2_ble_swtich_ble_driver(); ap2_ble_swtich_ble_driver();
} }
@ -103,12 +103,12 @@ void annepro2_ble_disconnect(void) {
#ifdef NKRO_ENABLE #ifdef NKRO_ENABLE
keymap_config.nkro = lastNkroStatus; keymap_config.nkro = lastNkroStatus;
#endif #endif
host_set_driver(lastHostDriver); host_set_driver(last_host_driver);
} }
void annepro2_ble_unpair(void) { void annepro2_ble_unpair(void) {
// sdPut(&SD1, 0x0); // sdPut(&SD1, 0x0);
sdWrite(&SD1, bleMcuUnpair, sizeof(bleMcuUnpair)); sdWrite(&SD1, ble_mcu_unpair, sizeof(ble_mcu_unpair));
} }
/* ------------------- Static Function Implementation ----------------------- */ /* ------------------- Static Function Implementation ----------------------- */
@ -117,7 +117,7 @@ static void ap2_ble_swtich_ble_driver(void) {
return; return;
} }
clear_keyboard(); clear_keyboard();
lastHostDriver = host_get_driver(); last_host_driver = host_get_driver();
#ifdef NKRO_ENABLE #ifdef NKRO_ENABLE
lastNkroStatus = keymap_config.nkro; lastNkroStatus = keymap_config.nkro;
#endif #endif
@ -154,7 +154,7 @@ static inline uint16_t CONSUMER2AP2(uint16_t usage) {
static void ap2_ble_consumer(uint16_t data) { static void ap2_ble_consumer(uint16_t data) {
sdPut(&SD1, 0x0); sdPut(&SD1, 0x0);
sdWrite(&SD1, bleMcuSendConsumerReport, sizeof(bleMcuSendConsumerReport)); sdWrite(&SD1, ble_mcu_send_consumer_report, sizeof(ble_mcu_send_consumer_report));
sdPut(&SD1, CONSUMER2AP2(data)); sdPut(&SD1, CONSUMER2AP2(data));
static const uint8_t dummy[3] = {0}; static const uint8_t dummy[3] = {0};
sdWrite(&SD1, dummy, sizeof(dummy)); sdWrite(&SD1, dummy, sizeof(dummy));
@ -165,6 +165,6 @@ static void ap2_ble_consumer(uint16_t data) {
*/ */
static void ap2_ble_keyboard(report_keyboard_t *report) { static void ap2_ble_keyboard(report_keyboard_t *report) {
sdPut(&SD1, 0x0); sdPut(&SD1, 0x0);
sdWrite(&SD1, bleMcuSendReport, sizeof(bleMcuSendReport)); sdWrite(&SD1, ble_mcu_send_report, sizeof(ble_mcu_send_report));
sdWrite(&SD1, &report->raw[0], KEYBOARD_REPORT_SIZE); sdWrite(&SD1, &report->raw[0], KEYBOARD_REPORT_SIZE);
} }

View File

@ -21,28 +21,29 @@
#include "ap2_led.h" #include "ap2_led.h"
#include "protocol.h" #include "protocol.h"
annepro2Led_t ledMask[KEY_COUNT]; ap2_led_t led_mask[KEY_COUNT];
annepro2LedStatus_t annepro2LedStatus; ap2_led_status_t ap2_led_status;
uint8_t rgb_row_changed[NUM_ROW];
void ledCommandCallback(const message_t *msg) { void led_command_callback(const message_t *msg) {
switch (msg->command) { switch (msg->command) {
case CMD_LED_STATUS: case CMD_LED_STATUS:
annepro2LedStatus.amountOfProfiles = msg->payload[0]; ap2_led_status.amount_of_profiles = msg->payload[0];
annepro2LedStatus.currentProfile = msg->payload[1]; ap2_led_status.current_profile = msg->payload[1];
annepro2LedStatus.matrixEnabled = msg->payload[2]; ap2_led_status.matrix_enabled = msg->payload[2];
annepro2LedStatus.isReactive = msg->payload[3]; ap2_led_status.is_reactive = msg->payload[3];
annepro2LedStatus.ledIntensity = msg->payload[4]; ap2_led_status.led_intensity = msg->payload[4];
annepro2LedStatus.errors = msg->payload[5]; ap2_led_status.errors = msg->payload[5];
break; break;
#ifdef CONSOLE_ENABLE #ifdef CONSOLE_ENABLE
case CMD_LED_DEBUG: case CMD_LED_DEBUG:
/* TODO: Don't use printf. */ /* TODO: Don't use printf. */
printf("LED:"); printf("LED:");
for (int i = 0; i < msg->payloadSize; i++) { for (int i = 0; i < msg->payload_size; i++) {
printf("%02x ", msg->payload[i]); printf("%02x ", msg->payload[i]);
} }
for (int i = 0; i < msg->payloadSize; i++) { for (int i = 0; i < msg->payload_size; i++) {
printf("%c", msg->payload[i]); printf("%c", msg->payload[i]);
} }
printf("\n"); printf("\n");
@ -51,63 +52,63 @@ void ledCommandCallback(const message_t *msg) {
} }
} }
void annepro2SetIAP(void) { protoTx(CMD_LED_IAP, NULL, 0, 3); } void ap2_set_IAP(void) { proto_tx(CMD_LED_IAP, NULL, 0, 3); }
void annepro2LedDisable(void) { protoTx(CMD_LED_OFF, NULL, 0, 3); } void ap2_led_disable(void) { proto_tx(CMD_LED_OFF, NULL, 0, 3); }
void annepro2LedEnable(void) { protoTx(CMD_LED_ON, NULL, 0, 3); } void ap2_led_enable(void) { proto_tx(CMD_LED_ON, NULL, 0, 3); }
void annepro2LedSetProfile(uint8_t prof) { protoTx(CMD_LED_SET_PROFILE, &prof, sizeof(prof), 3); } void ap2_led_set_profile(uint8_t prof) { proto_tx(CMD_LED_SET_PROFILE, &prof, sizeof(prof), 3); }
void annepro2LedGetStatus() { protoTx(CMD_LED_GET_STATUS, NULL, 0, 3); } void ap2_led_get_status() { proto_tx(CMD_LED_GET_STATUS, NULL, 0, 3); }
void annepro2LedNextProfile() { protoTx(CMD_LED_NEXT_PROFILE, NULL, 0, 3); } void ap2_led_next_profile() { proto_tx(CMD_LED_NEXT_PROFILE, NULL, 0, 3); }
void annepro2LedNextIntensity() { protoTx(CMD_LED_NEXT_INTENSITY, NULL, 0, 3); } void ap2_led_next_intensity() { proto_tx(CMD_LED_NEXT_INTENSITY, NULL, 0, 3); }
void annepro2LedNextAnimationSpeed() { protoTx(CMD_LED_NEXT_ANIMATION_SPEED, NULL, 0, 3); } void ap2_led_next_animation_speed() { proto_tx(CMD_LED_NEXT_ANIMATION_SPEED, NULL, 0, 3); }
void annepro2LedPrevProfile() { protoTx(CMD_LED_PREV_PROFILE, NULL, 0, 3); } void ap2_led_prev_profile() { proto_tx(CMD_LED_PREV_PROFILE, NULL, 0, 3); }
void annepro2LedMaskSetKey(uint8_t row, uint8_t col, annepro2Led_t color) { void ap2_led_mask_set_key(uint8_t row, uint8_t col, ap2_led_t color) {
uint8_t payload[] = {row, col, color.p.blue, color.p.green, color.p.red, color.p.alpha}; uint8_t payload[] = {row, col, color.p.blue, color.p.green, color.p.red, color.p.alpha};
protoTx(CMD_LED_MASK_SET_KEY, payload, sizeof(payload), 1); proto_tx(CMD_LED_MASK_SET_KEY, payload, sizeof(payload), 1);
} }
/* Push a whole local row to the shine */ /* Push a whole local row to the shine */
void annepro2LedMaskSetRow(uint8_t row) { void ap2_led_mask_set_row(uint8_t row) {
uint8_t payload[NUM_COLUMN * sizeof(annepro2Led_t) + 1]; uint8_t payload[NUM_COLUMN * sizeof(ap2_led_t) + 1];
payload[0] = row; payload[0] = row;
memcpy(payload + 1, &ledMask[ROWCOL2IDX(row, 0)], sizeof(*ledMask) * NUM_COLUMN); memcpy(payload + 1, &led_mask[ROWCOL2IDX(row, 0)], sizeof(*led_mask) * NUM_COLUMN);
protoTx(CMD_LED_MASK_SET_ROW, payload, sizeof(payload), 1); proto_tx(CMD_LED_MASK_SET_ROW, payload, sizeof(payload), 1);
} }
/* Synchronize all rows */ /* Synchronize all rows */
void annepro2LedMaskSetAll(void) { void ap2_led_mask_set_all(void) {
for (int row = 0; row < 5; row++) annepro2LedMaskSetRow(row); for (int row = 0; row < 5; row++) ap2_led_mask_set_row(row);
} }
/* Set all keys to a given color */ /* Set all keys to a given color */
void annepro2LedMaskSetMono(const annepro2Led_t color) { protoTx(CMD_LED_MASK_SET_MONO, (uint8_t *)&color, sizeof(color), 1); } void ap2_led_mask_set_mono(const ap2_led_t color) { proto_tx(CMD_LED_MASK_SET_MONO, (uint8_t *)&color, sizeof(color), 1); }
void annepro2LedBlink(uint8_t row, uint8_t col, annepro2Led_t color, uint8_t count, uint8_t hundredths) { void ap2_led_blink(uint8_t row, uint8_t col, ap2_led_t color, uint8_t count, uint8_t hundredths) {
uint8_t payload[] = {row, col, color.p.blue, color.p.green, color.p.red, color.p.alpha, count, hundredths}; uint8_t payload[] = {row, col, color.p.blue, color.p.green, color.p.red, color.p.alpha, count, hundredths};
protoTx(CMD_LED_KEY_BLINK, payload, sizeof(payload), 1); proto_tx(CMD_LED_KEY_BLINK, payload, sizeof(payload), 1);
} }
void annepro2LedSetForegroundColor(uint8_t red, uint8_t green, uint8_t blue) { void ap2_led_set_foreground_color(uint8_t red, uint8_t green, uint8_t blue) {
annepro2Led_t color = {.p.red = red, .p.green = green, .p.blue = blue, .p.alpha = 0xff}; ap2_led_t color = {.p.red = red, .p.green = green, .p.blue = blue, .p.alpha = 0xff};
annepro2LedMaskSetMono(color); ap2_led_mask_set_mono(color);
} }
void annepro2LedResetForegroundColor() { void ap2_led_reset_foreground_color() {
annepro2Led_t color = { ap2_led_t color = {
.p.red = 0, .p.red = 0,
.p.green = 0, .p.green = 0,
.p.blue = 0, .p.blue = 0,
.p.alpha = 0, .p.alpha = 0,
}; };
annepro2LedMaskSetMono(color); ap2_led_mask_set_mono(color);
} }
/* /*
@ -128,7 +129,7 @@ void annepro2LedResetForegroundColor() {
* Following it are 3 bits of row and 4 bits of col. * Following it are 3 bits of row and 4 bits of col.
* 1 + 3 + 4 = 8 bits - only a single byte is sent for every keypress. * 1 + 3 + 4 = 8 bits - only a single byte is sent for every keypress.
*/ */
void annepro2LedForwardKeypress(uint8_t row, uint8_t col) { void ap2_led_forward_keypress(uint8_t row, uint8_t col) {
const uint8_t payload = row << 4 | col; const uint8_t payload = row << 4 | col;
protoTx(CMD_LED_KEY_DOWN, &payload, 1, 1); proto_tx(CMD_LED_KEY_DOWN, &payload, 1, 1);
} }

View File

@ -1,18 +1,18 @@
/* Copyright 2021 OpenAnnePro community /* Copyright 2021 OpenAnnePro community
* *
* This program is free software: you can redistribute it and/or modify * This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or * the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#pragma once #pragma once
@ -31,54 +31,63 @@ typedef union {
uint8_t pv[4]; uint8_t pv[4];
/* 0xrgb in mem is b g r a */ /* 0xrgb in mem is b g r a */
uint32_t rgb; uint32_t rgb;
} annepro2Led_t; } ap2_led_t;
#define ROWCOL2IDX(row, col) (NUM_COLUMN * (row) + (col)) #define ROWCOL2IDX(row, col) (NUM_COLUMN * (row) + (col))
#define NUM_COLUMN 14 #define NUM_COLUMN 14
#define NUM_ROW 5 #define NUM_ROW 5
#define KEY_COUNT 70 #define KEY_COUNT 70
/* Local copy of ledMask, used to override colors on the board */ /* Local copy of led_mask, used to override colors on the board */
extern annepro2Led_t ledMask[KEY_COUNT]; extern ap2_led_t led_mask[KEY_COUNT];
extern uint8_t rgb_row_changed[NUM_ROW];
/* Handle incoming messages */ /* Handle incoming messages */
extern void ledCommandCallback(const message_t *msg); extern void led_command_callback(const message_t *msg);
void annepro2SetIAP(void); void ap2_set_IAP(void);
void annepro2LedDisable(void); void ap2_led_disable(void);
void annepro2LedEnable(void); void ap2_led_enable(void);
void annepro2LedSetProfile(uint8_t prof); void ap2_led_set_profile(uint8_t prof);
void annepro2LedGetStatus(void); void ap2_led_get_status(void);
void annepro2LedNextProfile(void); void ap2_led_next_profile(void);
void annepro2LedPrevProfile(void); void ap2_led_prev_profile(void);
void annepro2LedNextIntensity(void); void ap2_led_next_intensity(void);
void annepro2LedNextAnimationSpeed(void); void ap2_led_next_animation_speed(void);
void annepro2LedForwardKeypress(uint8_t row, uint8_t col); void ap2_led_forward_keypress(uint8_t row, uint8_t col);
/* Set single key to a given color; alpha controls which is displayed */ /* Set single key to a given color; alpha controls which is displayed */
void annepro2LedMaskSetKey(uint8_t row, uint8_t col, annepro2Led_t color); void ap2_led_mask_set_key(uint8_t row, uint8_t col, ap2_led_t color);
/* Push a whole local row to the shine */ /* Push a whole local row to the shine */
void annepro2LedMaskSetRow(uint8_t row); void ap2_led_mask_set_row(uint8_t row);
/* Synchronize all rows */ /* Synchronize all rows */
void annepro2LedMaskSetAll(void); void ap2_led_mask_set_all(void);
/* Set all keys to a given color */ /* Set all keys to a given color */
void annepro2LedMaskSetMono(annepro2Led_t color); void ap2_led_mask_set_mono(ap2_led_t color);
/* Blink given key `count` times by masking it with a `color`. Blink takes `hundredths` of a second */ /* Blink given key `count` times by masking it with a `color`. Blink takes `hundredths` of a second */
void annepro2LedBlink(uint8_t row, uint8_t col, annepro2Led_t color, uint8_t count, uint8_t hundredths); void ap2_led_blink(uint8_t row, uint8_t col, ap2_led_t color, uint8_t count, uint8_t hundredths);
/* Kept for compatibility, but implemented using masks */ /* Kept for compatibility, but implemented using masks */
void annepro2LedSetForegroundColor(uint8_t red, uint8_t green, uint8_t blue); void ap2_led_set_foreground_color(uint8_t red, uint8_t green, uint8_t blue);
void annepro2LedResetForegroundColor(void); void ap2_led_reset_foreground_color(void);
typedef struct { typedef struct {
uint8_t amountOfProfiles; uint8_t amount_of_profiles;
uint8_t currentProfile; uint8_t current_profile;
uint8_t matrixEnabled; uint8_t matrix_enabled;
uint8_t isReactive; uint8_t is_reactive;
uint8_t ledIntensity; uint8_t led_intensity;
uint8_t errors; uint8_t errors;
} annepro2LedStatus_t; } ap2_led_status_t;
extern annepro2LedStatus_t annepro2LedStatus; extern ap2_led_status_t ap2_led_status;
#ifdef RGB_MATRIX_ENABLE
/* RGB driver functions */
void init(void);
void flush(void);
void set_color(int index, uint8_t r, uint8_t g, uint8_t b);
void set_color_all(uint8_t r, uint8_t g, uint8_t b);
#endif

View File

@ -18,6 +18,7 @@
#pragma once #pragma once
#include "pin_defs.h" #include "pin_defs.h"
#include "config_led.h"
/* USB Device descriptor parameter */ /* USB Device descriptor parameter */
#define VENDOR_ID 0xfeed #define VENDOR_ID 0xfeed

View File

@ -3,7 +3,9 @@ SRC = \
matrix.c \ matrix.c \
annepro2_ble.c \ annepro2_ble.c \
ap2_led.c \ ap2_led.c \
protocol.c protocol.c \
rgb_driver.c \
config_led.c
# MCU # MCU
MCU = cortex-m0plus MCU = cortex-m0plus
@ -24,6 +26,7 @@ NKRO_ENABLE = no
MOUSEKEY_ENABLE = no MOUSEKEY_ENABLE = no
EXTRAKEY_ENABLE = yes EXTRAKEY_ENABLE = yes
KEY_LOCK_ENABLE = no KEY_LOCK_ENABLE = no
LAYOUTS = 60_ansi
# Other featues # Other featues
BOOTMAGIC_ENABLE = no BOOTMAGIC_ENABLE = no

View File

@ -18,6 +18,7 @@
#pragma once #pragma once
#include "pin_defs.h" #include "pin_defs.h"
#include "config_led.h"
/* USB Device descriptor parameter */ /* USB Device descriptor parameter */
#define VENDOR_ID 0xfeed #define VENDOR_ID 0xfeed

View File

@ -3,7 +3,9 @@ SRC = \
matrix.c \ matrix.c \
annepro2_ble.c \ annepro2_ble.c \
ap2_led.c \ ap2_led.c \
protocol.c protocol.c \
rgb_driver.c \
config_led.c
# MCU # MCU
MCU = cortex-m0plus MCU = cortex-m0plus
@ -24,6 +26,7 @@ NKRO_ENABLE = no
MOUSEKEY_ENABLE = no MOUSEKEY_ENABLE = no
EXTRAKEY_ENABLE = yes EXTRAKEY_ENABLE = yes
KEY_LOCK_ENABLE = no KEY_LOCK_ENABLE = no
LAYOUTS = 60_ansi
# Other featues # Other featues
BOOTMAGIC_ENABLE = yes BOOTMAGIC_ENABLE = yes

View File

@ -0,0 +1,43 @@
/* Copyright 2022 Jose Pablo Ramirez <jp.ramangulo@gmail.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifdef RGB_MATRIX_ENABLE
#include "rgb_matrix.h"
#include "config_led.h"
#define NA NO_LED
led_config_t g_led_config = { {
{ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13 },
{ 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27 },
{ 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, NA },
{ 41, NA, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, NA },
{ 53, NA, 54, 55, NA, NA, 56, NA, NA, 57, 58, 59, 60, NA }
}, {
{ 0 , 0 }, { 16, 0 }, { 32, 0 }, { 48, 0 }, { 65, 0 }, { 81, 0 }, { 97 , 0 }, { 113, 0 }, { 129, 0 }, { 145, 0 }, { 161, 0 }, { 178, 0 }, { 194, 0 }, { 218, 0 },
{ 4 , 16 }, { 24, 16 }, { 40, 16 }, { 57, 16 }, { 73, 16 }, { 89, 16 }, { 105, 16 }, { 121, 16 }, { 137, 16 }, { 153, 16 }, { 170, 16 }, { 186, 16 }, { 202, 16 }, { 222, 16 },
{ 6 , 32 }, { 28, 32 }, { 44, 32 }, { 61, 32 }, { 77, 32 }, { 93, 32 }, { 109, 32 }, { 125, 32 }, { 141, 32 }, { 157, 32 }, { 174, 32 }, { 190, 32 }, { 216, 32 },
{ 10, 48 }, { 36, 48 }, { 52, 48 }, { 69, 48 }, { 85, 48 }, { 101, 48 }, { 117, 48 }, { 133, 48 }, { 149, 48 }, { 165, 48 }, { 182, 48 }, { 212, 48 },
{ 2 , 64 }, { 22, 64 }, { 42, 64 }, { 103, 64 }, { 163, 64 }, { 184, 64 }, { 204, 64 }, { 224, 64 },
}, {
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 1,
1, 1, 1, 4, 1, 1, 1, 1,
} };
#endif

View File

@ -0,0 +1,72 @@
/* Copyright 2022 Jose Pablo Ramirez <jp.ramangulo@gmail.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#ifdef RGB_MATRIX_ENABLE
#define DRIVER_LED_TOTAL 61
/* Limit animations to 62.5 FPS to avoid tearing. (1/.016 = 62.5 FPS). */
#define RGB_MATRIX_LED_FLUSH_LIMIT 16
#define RGB_MATRIX_FRAMEBUFFER_EFFECTS
#define RGB_MATRIX_KEYPRESSES
#define ENABLE_RGB_MATRIX_ALPHAS_MODS
#define ENABLE_RGB_MATRIX_GRADIENT_UP_DOWN
#define ENABLE_RGB_MATRIX_GRADIENT_LEFT_RIGHT
#define ENABLE_RGB_MATRIX_BREATHING
#define ENABLE_RGB_MATRIX_BAND_SAT
#define ENABLE_RGB_MATRIX_BAND_VAL
#define ENABLE_RGB_MATRIX_BAND_PINWHEEL_SAT
#define ENABLE_RGB_MATRIX_BAND_PINWHEEL_VAL
#define ENABLE_RGB_MATRIX_BAND_SPIRAL_SAT
#define ENABLE_RGB_MATRIX_BAND_SPIRAL_VAL
#define ENABLE_RGB_MATRIX_CYCLE_ALL
#define ENABLE_RGB_MATRIX_CYCLE_LEFT_RIGHT
#define ENABLE_RGB_MATRIX_CYCLE_UP_DOWN
#define ENABLE_RGB_MATRIX_RAINBOW_MOVING_CHEVRON
#define ENABLE_RGB_MATRIX_CYCLE_OUT_IN
#define ENABLE_RGB_MATRIX_CYCLE_OUT_IN_DUAL
#define ENABLE_RGB_MATRIX_CYCLE_PINWHEEL
#define ENABLE_RGB_MATRIX_CYCLE_SPIRAL
#define ENABLE_RGB_MATRIX_DUAL_BEACON
#define ENABLE_RGB_MATRIX_RAINBOW_BEACON
#define ENABLE_RGB_MATRIX_RAINBOW_PINWHEELS
#define ENABLE_RGB_MATRIX_RAINDROPS
#define ENABLE_RGB_MATRIX_JELLYBEAN_RAINDROPS
#define ENABLE_RGB_MATRIX_HUE_BREATHING
#define ENABLE_RGB_MATRIX_HUE_PENDULUM
#define ENABLE_RGB_MATRIX_HUE_WAVE
#define ENABLE_RGB_MATRIX_PIXEL_FRACTAL
#define ENABLE_RGB_MATRIX_PIXEL_FLOW
#define ENABLE_RGB_MATRIX_PIXEL_RAIN
#define ENABLE_RGB_MATRIX_TYPING_HEATMAP
#define ENABLE_RGB_MATRIX_DIGITAL_RAIN
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_SIMPLE
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_WIDE
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTIWIDE
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_CROSS
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTICROSS
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_NEXUS
#define ENABLE_RGB_MATRIX_SOLID_REACTIVE_MULTINEXUS
#define ENABLE_RGB_MATRIX_SPLASH
#define ENABLE_RGB_MATRIX_MULTISPLASH
#define ENABLE_RGB_MATRIX_SOLID_SPLASH
#define ENABLE_RGB_MATRIX_SOLID_MULTISPLASH
#endif

View File

@ -3,7 +3,7 @@
"url": "https://openannepro.github.io/", "url": "https://openannepro.github.io/",
"maintainer": "community", "maintainer": "community",
"layouts": { "layouts": {
"LAYOUT": { "LAYOUT_60_ansi": {
"layout": [ "layout": [
{ {
"label": "~", "label": "~",

View File

@ -1,32 +1,31 @@
/* Copyright 2021 OpenAnnePro community /* Copyright 2021 OpenAnnePro community
* *
* This program is free software: you can redistribute it and/or modify * This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or * the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#include QMK_KEYBOARD_H #include QMK_KEYBOARD_H
enum anne_pro_layers { enum anne_pro_layers {
_BASE_LAYER, BASE,
_FN1_LAYER, FN1,
_FN2_LAYER, FN2,
}; };
// clang-format off // clang-format off
// Key symbols are based on QMK. Use them to remap your keyboard // Key symbols are based on QMK. Use them to remap your keyboard
/* /*
* Layer _BASE_LAYER * Layer BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp | * | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -38,7 +37,7 @@ enum anne_pro_layers {
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
* | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl | * | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl |
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* Layer TAP in _BASE_LAYER * Layer TAP in BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | | | | | | | | | | | | | | | * | | | | | | | | | | | | | | |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -52,15 +51,15 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
*/ */
const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[_BASE_LAYER] = LAYOUT( /* Base */ [BASE] = LAYOUT_60_ansi( /* Base */
KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC,
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS,
LT(_FN1_LAYER,KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, LT(FN1, KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT,
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP), KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP),
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(_FN1_LAYER,KC_LEFT), LT(_FN2_LAYER,KC_DOWN), RCTL_T(KC_RGHT) KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(FN1, KC_LEFT), LT(FN2, KC_DOWN), RCTL_T(KC_RGHT)
), ),
/* /*
* Layer _FN1_LAYER * Layer FN1
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE | * | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -74,15 +73,15 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN1_LAYER] = LAYOUT( /* Base */ [FN1] = LAYOUT_60_ansi( /* FN1 */
KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL,
KC_TRNS, KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, _______, _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_VOLU, KC_VOLD, KC_MUTE, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, KC_VOLU, KC_VOLD, KC_MUTE, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, _______, MO(FN2), _______
), ),
/* /*
* Layer _FN2_LAYER * Layer FN2
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | F7 |LEDOF|LEDON| F10 | F11 | F12 | Bksp | * | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | F7 |LEDOF|LEDON| F10 | F11 | F12 | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -96,24 +95,23 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN2_LAYER] = LAYOUT( /* Base */ [FN2] = LAYOUT_60_ansi( /* FN2 */
KC_TRNS, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, KC_TRNS, KC_TRNS, KC_TRNS, KC_AP_LED_OFF, KC_AP_LED_ON, KC_AP_LED_NEXT_INTENSITY, KC_AP_LED_SPEED, KC_TRNS, KC_TRNS, _______, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, _______, _______, _______, KC_AP_LED_OFF, KC_AP_LED_ON, _______, _______, _______, _______,
MO(_FN2_LAYER), KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, MO(FN2), _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN1_LAYER), MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, MO(FN1), MO(FN2), _______
), ),
}; };
// clang-format on // clang-format on
// The function to handle the caps lock logic // The function to handle the caps lock logic
bool led_update_user(led_t leds) { bool led_update_user(led_t leds) {
if (leds.caps_lock) { if (leds.caps_lock) {
// Set the leds to red // Set the leds to red
annepro2LedSetForegroundColor(0xFF, 0x00, 0x00); ap2_led_set_foreground_color(0xFF, 0x00, 0x00);
} else { } else {
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
} }
return true; return true;

View File

@ -1,32 +1,31 @@
/* Copyright 2021 OpenAnnePro community /* Copyright 2021 OpenAnnePro community
* *
* This program is free software: you can redistribute it and/or modify * This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or * the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#include QMK_KEYBOARD_H #include QMK_KEYBOARD_H
enum anne_pro_layers { enum anne_pro_layers {
_BASE_LAYER, BASE,
_FN1_LAYER, FN1,
_FN2_LAYER, FN2,
}; };
// clang-format off // clang-format off
// Key symbols are based on QMK. Use them to remap your keyboard // Key symbols are based on QMK. Use them to remap your keyboard
/* /*
* Layer _BASE_LAYER * Layer BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp | * | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -38,7 +37,7 @@ enum anne_pro_layers {
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
* | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl | * | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl |
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* Layer TAP in _BASE_LAYER * Layer TAP in BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | | | | | | | | | | | | | | | * | | | | | | | | | | | | | | |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -52,15 +51,15 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
*/ */
const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[_BASE_LAYER] = LAYOUT( /* Base */ [BASE] = LAYOUT_60_ansi( /* Base */
KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC,
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS,
LT(_FN1_LAYER,KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, LT(FN1, KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT,
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP), KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP),
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(_FN1_LAYER,KC_LEFT), LT(_FN2_LAYER,KC_DOWN), RCTL_T(KC_RGHT) KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(FN1, KC_LEFT), LT(FN2, KC_DOWN), RCTL_T(KC_RGHT)
), ),
/* /*
* Layer _FN1_LAYER * Layer FN1
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE | * | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -74,15 +73,15 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN1_LAYER] = LAYOUT( /* Base */ [FN1] = LAYOUT_60_ansi( /* FN1 */
KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL,
KC_TRNS, KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, _______, _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_VOLU, KC_VOLD, KC_MUTE, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, KC_VOLU, KC_VOLD, KC_MUTE, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, _______, MO(FN2), _______
), ),
/* /*
* Layer _FN2_LAYER * Layer FN2
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | F7 |LEDOF|LEDON| F10 | F11 | F12 | Bksp | * | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | F7 |LEDOF|LEDON| F10 | F11 | F12 | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -96,30 +95,29 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN2_LAYER] = LAYOUT( /* Base */ [FN2] = LAYOUT_60_ansi( /* FN2 */
KC_TRNS, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, KC_TRNS, KC_TRNS, KC_TRNS, KC_AP_LED_OFF, KC_AP_LED_ON, KC_AP_LED_NEXT_INTENSITY, KC_AP_LED_SPEED, KC_TRNS, KC_TRNS, _______, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, _______, _______, _______, KC_AP_LED_OFF, KC_AP_LED_ON, _______, _______, _______, _______,
MO(_FN2_LAYER), KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, MO(FN2), _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN1_LAYER), MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, MO(FN1), MO(FN2), _______
), ),
}; };
// clang-format on // clang-format on
layer_state_t layer_state_set_user(layer_state_t state) { layer_state_t layer_state_set_user(layer_state_t state) {
switch (get_highest_layer(state)) { switch (get_highest_layer(state)) {
case _FN1_LAYER: case FN1:
// Set the leds to green // Set the leds to green
annepro2LedSetForegroundColor(0x00, 0xFF, 0x00); ap2_led_set_foreground_color(0x00, 0xFF, 0x00);
break; break;
case _FN2_LAYER: case FN2:
// Set the leds to blue // Set the leds to blue
annepro2LedSetForegroundColor(0x00, 0x00, 0xFF); ap2_led_set_foreground_color(0x00, 0x00, 0xFF);
break; break;
default: default:
// Reset back to the current profile // Reset back to the current profile
annepro2LedResetForegroundColor(); ap2_led_reset_foreground_color();
break; break;
} }
return state; return state;
@ -130,16 +128,16 @@ layer_state_t layer_state_set_user(layer_state_t state) {
bool led_update_user(led_t leds) { bool led_update_user(led_t leds) {
if (leds.caps_lock) { if (leds.caps_lock) {
// Set the caps-lock to red // Set the caps-lock to red
const annepro2Led_t color = {.p.red = 0xff, .p.green = 0x00, .p.blue = 0x00, .p.alpha = 0xff}; const ap2_led_t color = {.p.red = 0xff, .p.green = 0x00, .p.blue = 0x00, .p.alpha = 0xff};
annepro2LedMaskSetKey(2, 0, color); ap2_led_mask_set_key(2, 0, color);
/* NOTE: Instead of colouring the capslock only, you can change the whole /* NOTE: Instead of colouring the capslock only, you can change the whole
keyboard with annepro2LedSetForegroundColor */ keyboard with ap2_led_set_foreground_color */
} else { } else {
// Reset the capslock if there is no layer active // Reset the capslock if there is no layer active
if (!layer_state_is(_FN1_LAYER) && !layer_state_is(_FN2_LAYER)) { if (!layer_state_is(FN1) && !layer_state_is(FN2)) {
const annepro2Led_t color = {.p.red = 0xff, .p.green = 0x00, .p.blue = 0x00, .p.alpha = 0x00}; const ap2_led_t color = {.p.red = 0xff, .p.green = 0x00, .p.blue = 0x00, .p.alpha = 0x00};
annepro2LedMaskSetKey(2, 0, color); ap2_led_mask_set_key(2, 0, color);
} }
} }

View File

@ -1,31 +1,31 @@
/* Copyright 2021 OpenAnnePro community /* Copyright 2021 OpenAnnePro community
* *
* This program is free software: you can redistribute it and/or modify * This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or * the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#include QMK_KEYBOARD_H #include QMK_KEYBOARD_H
enum anne_pro_layers { enum anne_pro_layers {
_BASE_LAYER, BASE,
_FN1_LAYER, FN1,
_FN2_LAYER, FN2,
}; };
// clang-format off // clang-format off
// Key symbols are based on QMK. Use them to remap your keyboard // Key symbols are based on QMK. Use them to remap your keyboard
/* /*
* Layer _BASE_LAYER * Layer BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp | * | esc | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 0 | - | = | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -37,7 +37,7 @@ enum anne_pro_layers {
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
* | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl | * | Ctrl | L1 | Alt | space | Alt | FN1 | FN2 | Ctrl |
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* Layer TAP in _BASE_LAYER * Layer TAP in BASE
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | | | | | | | | | | | | | | | * | | | | | | | | | | | | | | |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -51,15 +51,15 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
*/ */
const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[_BASE_LAYER] = LAYOUT( /* Base */ [BASE] = LAYOUT_60_ansi( /* Base */
KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC,
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS,
LT(_FN1_LAYER,KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, LT(FN1, KC_CAPS), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT,
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP), KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, RSFT_T(KC_UP),
KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(_FN1_LAYER,KC_LEFT), LT(_FN2_LAYER,KC_DOWN), RCTL_T(KC_RGHT) KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, LT(FN1, KC_LEFT), LT(FN2, KC_DOWN), RCTL_T(KC_RGHT)
), ),
/* /*
* Layer _FN1_LAYER * Layer FN1
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE | * | ` | F1 | F2 | F3 | F4 | F5 | F6 | F7 | F8 | F9 | F10 | F11 | F12 | DELETE |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -73,17 +73,17 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN1_LAYER] = LAYOUT( /* Base */ [FN1] = LAYOUT_60_ansi( /* FN1 */
KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL, KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL,
KC_TRNS, KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, _______, _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_VOLU, KC_VOLD, KC_MUTE, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, KC_VOLU, KC_VOLD, KC_MUTE, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, _______, MO(FN2), _______
), ),
/* /*
* Layer _FN2_LAYER * Layer FN2
* ,-----------------------------------------------------------------------------------------. * ,-----------------------------------------------------------------------------------------.
* | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | F7 |LEDOF|LEDON| F10 | F11 | F12 | Bksp | * | ~ | BT1 | BT2 | BT3 | BT4 | F5 | F6 | HUE | SAT | BRI | SPD | MOD | TOG | Bksp |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
* | Tab | q | UP | e | r | t | y | u | i | o | PS | HOME | END | \ | * | Tab | q | UP | e | r | t | y | u | i | o | PS | HOME | END | \ |
* |-----------------------------------------------------------------------------------------+ * |-----------------------------------------------------------------------------------------+
@ -95,12 +95,12 @@ enum anne_pro_layers {
* \-----------------------------------------------------------------------------------------/ * \-----------------------------------------------------------------------------------------/
* *
*/ */
[_FN2_LAYER] = LAYOUT( /* Base */ [FN2] = LAYOUT_60_ansi( /* FN2 */
KC_TRNS, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, KC_TRNS, KC_TRNS, KC_TRNS, KC_AP_LED_OFF, KC_AP_LED_ON, KC_AP_LED_NEXT_INTENSITY, KC_AP_LED_SPEED, KC_TRNS, KC_TRNS, _______, KC_AP2_BT1, KC_AP2_BT2, KC_AP2_BT3, KC_AP2_BT4, _______, _______, RGB_HUI, RGB_SAI, RGB_VAI, RGB_SPI, RGB_MOD, RGB_TOG, _______,
MO(_FN2_LAYER), KC_TRNS, KC_UP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_HOME, KC_END, KC_TRNS, MO(FN2), _______, KC_UP, _______, _______, _______, _______, _______, _______, _______, KC_PSCR, KC_HOME, KC_END, _______,
KC_TRNS, KC_LEFT, KC_DOWN, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGDN, KC_TRNS, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, KC_PGUP, KC_PGDN, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_DEL, KC_TRNS, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_INS, KC_DEL, _______,
KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MO(_FN1_LAYER), MO(_FN2_LAYER), KC_TRNS _______, _______, _______, _______, _______, MO(FN1), MO(FN2), _______
), ),
}; };
// clang-format on // clang-format on

View File

@ -0,0 +1,3 @@
# Custom RGB matrix handling
RGB_MATRIX_ENABLE = yes
RGB_MATRIX_DRIVER = custom

View File

@ -20,38 +20,38 @@
/* UART communication protocol state */ /* UART communication protocol state */
protocol_t proto; protocol_t proto;
void protoInit(protocol_t *proto, void (*callback)(const message_t *)) { void proto_init(protocol_t *proto, void (*callback)(const message_t *)) {
proto->previousId = 0; proto->previous_id = 0;
proto->callback = callback; proto->callback = callback;
proto->state = STATE_SYNC_1; proto->state = STATE_SYNC_1;
proto->errors = 0; proto->errors = 0;
} }
static uint8_t msgId = 0; static uint8_t msg_id = 0;
void protoTx(uint8_t cmd, const unsigned char *buf, int payloadSize, int retries) { void proto_tx(uint8_t cmd, const unsigned char *buf, int payload_size, int retries) {
chDbgCheck(payloadSize <= MAX_PAYLOAD_SIZE); chDbgCheck(payload_size <= MAX_PAYLOAD_SIZE);
const uint8_t header[5] = { const uint8_t header[5] = {
0x7A, 0x1D, cmd, ++msgId, payloadSize, 0x7A, 0x1D, cmd, ++msg_id, payload_size,
}; };
/* We don't implement ACKs, yet some messages should not be lost. */ /* We don't implement ACKs, yet some messages should not be lost. */
for (int i = 0; i < retries; i++) { for (int i = 0; i < retries; i++) {
sdWrite(&PROTOCOL_SD, header, sizeof(header)); sdWrite(&PROTOCOL_SD, header, sizeof(header));
if (payloadSize) sdWrite(&PROTOCOL_SD, buf, payloadSize); if (payload_size) sdWrite(&PROTOCOL_SD, buf, payload_size);
} }
} }
static inline void messageReceived(protocol_t *proto) { static inline void messageReceived(protocol_t *proto) {
if (proto->buffer.msgId != proto->previousId) { if (proto->buffer.msg_id != proto->previous_id) {
/* It's not a resend / duplicate */ /* It's not a resend / duplicate */
proto->callback(&proto->buffer); proto->callback(&proto->buffer);
proto->previousId = proto->buffer.msgId; proto->previous_id = proto->buffer.msg_id;
} }
proto->state = STATE_SYNC_1; proto->state = STATE_SYNC_1;
} }
void protoConsume(protocol_t *proto, uint8_t byte) { void proto_consume(protocol_t *proto, uint8_t byte) {
switch (proto->state) { switch (proto->state) {
case STATE_SYNC_1: case STATE_SYNC_1:
if (byte == 0x7A) { if (byte == 0x7A) {
@ -76,18 +76,18 @@ void protoConsume(protocol_t *proto, uint8_t byte) {
return; return;
case STATE_ID: case STATE_ID:
proto->buffer.msgId = byte; proto->buffer.msg_id = byte;
proto->state = STATE_PAYLOAD_SIZE; proto->state = STATE_PAYLOAD_SIZE;
return; return;
case STATE_PAYLOAD_SIZE: case STATE_PAYLOAD_SIZE:
proto->buffer.payloadSize = byte; proto->buffer.payload_size = byte;
if (proto->buffer.payloadSize > MAX_PAYLOAD_SIZE) { if (proto->buffer.payload_size > MAX_PAYLOAD_SIZE) {
proto->buffer.payloadSize = MAX_PAYLOAD_SIZE; proto->buffer.payload_size = MAX_PAYLOAD_SIZE;
proto->errors++; proto->errors++;
} }
proto->payloadPosition = 0; proto->payload_position = 0;
if (proto->buffer.payloadSize == 0) { if (proto->buffer.payload_size == 0) {
/* No payload - whole message received */ /* No payload - whole message received */
messageReceived(proto); messageReceived(proto);
} else { } else {
@ -98,9 +98,9 @@ void protoConsume(protocol_t *proto, uint8_t byte) {
case STATE_PAYLOAD: case STATE_PAYLOAD:
/* NOTE: This could be read with sdReadTimeout probably, but that breaks /* NOTE: This could be read with sdReadTimeout probably, but that breaks
* abstraction */ * abstraction */
proto->buffer.payload[proto->payloadPosition] = byte; proto->buffer.payload[proto->payload_position] = byte;
proto->payloadPosition++; proto->payload_position++;
if (proto->payloadPosition == proto->buffer.payloadSize) { if (proto->payload_position == proto->buffer.payload_size) {
/* Payload read - message received */ /* Payload read - message received */
messageReceived(proto); messageReceived(proto);
} }
@ -108,7 +108,7 @@ void protoConsume(protocol_t *proto, uint8_t byte) {
} }
} }
void protoSilence(protocol_t *proto) { void proto_silence(protocol_t *proto) {
if (proto->state != STATE_SYNC_1) { if (proto->state != STATE_SYNC_1) {
proto->state = STATE_SYNC_1; proto->state = STATE_SYNC_1;
proto->errors++; proto->errors++;

View File

@ -55,7 +55,7 @@ enum {
#define MAX_PAYLOAD_SIZE 64 #define MAX_PAYLOAD_SIZE 64
/** Enum of the states used for the serial protocol finite-state automaton */ /** Enum of the states used for the serial protocol finite-state automaton */
enum protoState { enum proto_state {
/* 2-byte initial start-of-message sync */ /* 2-byte initial start-of-message sync */
STATE_SYNC_1, STATE_SYNC_1,
STATE_SYNC_2, STATE_SYNC_2,
@ -65,15 +65,15 @@ enum protoState {
STATE_ID, STATE_ID,
/* Waiting for payload size */ /* Waiting for payload size */
STATE_PAYLOAD_SIZE, STATE_PAYLOAD_SIZE,
/* Reading payload until payloadPosition == payloadSize */ /* Reading payload until payload_position == payload_size */
STATE_PAYLOAD, STATE_PAYLOAD,
}; };
/* Buffer holding a single message */ /* Buffer holding a single message */
typedef struct { typedef struct {
uint8_t command; uint8_t command;
uint8_t msgId; uint8_t msg_id;
uint8_t payloadSize; uint8_t payload_size;
uint8_t payload[MAX_PAYLOAD_SIZE]; uint8_t payload[MAX_PAYLOAD_SIZE];
} message_t; } message_t;
@ -83,12 +83,12 @@ typedef struct {
void (*callback)(const message_t *); void (*callback)(const message_t *);
/* Number of read payload bytes */ /* Number of read payload bytes */
uint8_t payloadPosition; uint8_t payload_position;
/* Current finite-state-automata state */ /* Current finite-state-automata state */
enum protoState state; enum proto_state state;
uint8_t previousId; uint8_t previous_id;
uint8_t errors; uint8_t errors;
/* Currently received message */ /* Currently received message */
@ -99,13 +99,13 @@ typedef struct {
extern protocol_t proto; extern protocol_t proto;
/* Init state */ /* Init state */
extern void protoInit(protocol_t *proto, void (*callback)(const message_t *)); extern void proto_init(protocol_t *proto, void (*callback)(const message_t *));
/* Consume one byte and push state forward - might call the callback */ /* Consume one byte and push state forward - might call the callback */
extern void protoConsume(protocol_t *proto, uint8_t byte); extern void proto_consume(protocol_t *proto, uint8_t byte);
/* Prolonged silence - reset state */ /* Prolonged silence - reset state */
extern void protoSilence(protocol_t *proto); extern void proto_silence(protocol_t *proto);
/* Transmit message */ /* Transmit message */
extern void protoTx(uint8_t cmd, const unsigned char *buf, int payloadSize, int retries); extern void proto_tx(uint8_t cmd, const unsigned char *buf, int payload_size, int retries);

View File

@ -0,0 +1,66 @@
/* Copyright 2022 Jose Pablo Ramirez <jp.ramangulo@gmail.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifdef RGB_MATRIX_ENABLE
#include "rgb_matrix.h"
#include "ap2_led.h"
uint8_t led_pos[DRIVER_LED_TOTAL];
void init(void) {
unsigned int i = 0;
for (unsigned int y = 0; y < NUM_ROW; y++) {
for (unsigned int x = 0; x < NUM_COLUMN; x++) {
if (g_led_config.matrix_co[y][x] != NO_LED) {
led_pos[g_led_config.matrix_co[y][x]] = i;
}
i++;
}
}
}
void flush(void) {}
void set_color(int index, uint8_t r, uint8_t g, uint8_t b) {
if (r != led_mask[led_pos[index]].p.red ||
g != led_mask[led_pos[index]].p.green ||
b != led_mask[led_pos[index]].p.blue)
{
led_mask[led_pos[index]] = (ap2_led_t){
.p.blue = b,
.p.red = r,
.p.green = g,
.p.alpha = 0xff,
};
int row = led_pos[index] / NUM_COLUMN;
rgb_row_changed[row] = 1;
}
}
void set_color_all(uint8_t r, uint8_t g, uint8_t b) {
for (int i=0; i<DRIVER_LED_TOTAL; i++)
set_color(i, r, g, b);
}
const rgb_matrix_driver_t rgb_matrix_driver = {
.init = init,
.flush = flush,
.set_color = set_color,
.set_color_all = set_color_all,
};
#endif