169 lines
5.5 KiB
C
169 lines
5.5 KiB
C
/* arcane - keyboard firmware
|
|
* Copyright (C) 2022-2024 Olive <hello@grasswren.net>
|
|
* see LICENCE file for licensing information */
|
|
|
|
#include QMK_KEYBOARD_H
|
|
#include "version.h"
|
|
|
|
#define BASE(val, ind, mid) ((uint32_t)(val) * (val) * (val) / 255 / 255) * \
|
|
5 / (((ind) > (mid) ? (ind) - (mid) : (mid) - (ind)) + 5)
|
|
#define MKDANCE(num, key1, key2, key3) \
|
|
enum { DANCE ## num = num - 1 }; \
|
|
static void dance ## num ## _fin(qk_tap_dance_state_t *state, void *data); \
|
|
static void dance ## num ## _set(qk_tap_dance_state_t *state, void *data); \
|
|
\
|
|
static void \
|
|
dance ## num ## _fin(qk_tap_dance_state_t *state, void *data) \
|
|
{ \
|
|
if (state->count == 1) \
|
|
register_code16(key1); \
|
|
else if (state->count == 2) \
|
|
register_code16(key2); \
|
|
else if (state->count == 3) \
|
|
register_code16(key3); \
|
|
} \
|
|
\
|
|
static void \
|
|
dance ## num ## _set(qk_tap_dance_state_t *state, void *data) \
|
|
{ \
|
|
if (state->count == 1) \
|
|
unregister_code16(key1); \
|
|
else if (state->count == 2) \
|
|
unregister_code16(key2); \
|
|
else if (state->count == 3) \
|
|
unregister_code16(key3); \
|
|
}
|
|
|
|
MKDANCE(1, KC_F1, KC_F2, KC_F3)
|
|
MKDANCE(2, KC_F4, KC_F5, KC_F6)
|
|
MKDANCE(3, KC_F7, KC_F8, KC_F9)
|
|
MKDANCE(4, KC_F10, KC_F11, KC_F12)
|
|
|
|
qk_tap_dance_action_t tap_dance_actions[] = {
|
|
ACTION_TAP_DANCE_FN_ADVANCED(NULL, dance1_fin, dance1_set),
|
|
ACTION_TAP_DANCE_FN_ADVANCED(NULL, dance2_fin, dance2_set),
|
|
ACTION_TAP_DANCE_FN_ADVANCED(NULL, dance3_fin, dance3_set),
|
|
ACTION_TAP_DANCE_FN_ADVANCED(NULL, dance4_fin, dance4_set)
|
|
};
|
|
|
|
enum { MACRO = EZ_SAFE_RANGE, DISCO };
|
|
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
|
|
[0] = LAYOUT_ergodox_pretty(
|
|
KC_TRNS, KC_1, KC_2, KC_3, KC_4, KC_5, KC_TRNS,
|
|
KC_TRNS, KC_6, KC_7, KC_8, KC_9, KC_0, KC_TRNS,
|
|
|
|
KC_GRV, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_EQL,
|
|
KC_MINS, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSLS,
|
|
|
|
KC_TAB, KC_A, KC_S, KC_D, KC_F, KC_G,
|
|
KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT,
|
|
|
|
KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_LBRC,
|
|
KC_RBRC, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT,
|
|
|
|
KC_LCTL, KC_LALT, DISCO, KC_CAPS, KC_LGUI,
|
|
KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_RCTL,
|
|
|
|
TD(DANCE1), TD(DANCE2), TD(DANCE3), TD(DANCE4),
|
|
KC_TRNS, KC_TRNS,
|
|
KC_SPC, KC_ESC, KC_UNDS, MACRO, KC_BSPC, KC_ENT
|
|
)
|
|
};
|
|
|
|
bool disco = false, last = false;
|
|
uint8_t lhue, lval = 0, lkeys = 0, lmid, rhue, rval = 0, rkeys = 0, rmid;
|
|
uint16_t timer;
|
|
|
|
void
|
|
keyboard_post_init_user(void)
|
|
{
|
|
rgblight_enable_noeeprom();
|
|
rgblight_sethsv_noeeprom(0, 0, 0);
|
|
}
|
|
|
|
void
|
|
led_set_user(uint8_t usb_led)
|
|
{
|
|
if (usb_led & (1 << USB_LED_CAPS_LOCK))
|
|
ergodox_right_led_3_on(), ergodox_right_led_3_set(150);
|
|
else
|
|
ergodox_right_led_3_off();
|
|
}
|
|
|
|
bool
|
|
process_record_user(uint16_t keycode, keyrecord_t *record)
|
|
{
|
|
if (!record->event.pressed)
|
|
return true;
|
|
|
|
switch (keycode) {
|
|
case KC_BSPC:
|
|
if (last)
|
|
unregister_code(KC_BSPC), register_code(KC_BSPC);
|
|
break;
|
|
case MACRO:
|
|
SEND_STRING(SS_TAP(X_MINUS) SS_LSFT(SS_TAP(X_DOT)));
|
|
break;
|
|
case DISCO:
|
|
disco = !disco, lkeys = rkeys = 0;
|
|
}
|
|
last = (keycode == MACRO);
|
|
return true;
|
|
}
|
|
|
|
void
|
|
post_process_record_user(uint16_t keycode, keyrecord_t *record)
|
|
{
|
|
if (!disco)
|
|
return;
|
|
|
|
if (!record->event.pressed) {
|
|
if (record->event.key.row < 7 && lkeys > 0)
|
|
--lkeys;
|
|
else if (record->event.key.row >= 7 && rkeys > 0)
|
|
--rkeys;
|
|
return;
|
|
}
|
|
|
|
if (record->event.key.row < 7) {
|
|
lhue = rand() % 255, lval = 255, ++lkeys, lmid = 15;
|
|
if (record->event.key.col != 5)
|
|
lmid = 28 - 2 * record->event.key.row;
|
|
for (uint8_t i = RGBLED_NUM / 2; i < RGBLED_NUM; ++i)
|
|
sethsv(lhue, 255, BASE(lval, i, lmid), &led[i]);
|
|
} else {
|
|
rhue = rand() % 255, rval = 255, ++rkeys, rmid = 14;
|
|
if (record->event.key.col != 5)
|
|
rmid = 27 - 2 * record->event.key.row;
|
|
for (uint8_t i = 0; i < RGBLED_NUM / 2; ++i)
|
|
sethsv(rhue, 255, BASE(rval, i, rmid), &led[i]);
|
|
}
|
|
rgblight_set();
|
|
}
|
|
|
|
void
|
|
matrix_init_user(void)
|
|
{
|
|
timer = timer_read();
|
|
}
|
|
|
|
void
|
|
matrix_scan_user(void)
|
|
{
|
|
if ((lval == 0 && rval == 0) || timer_elapsed(timer) < 20)
|
|
return;
|
|
timer = timer_read();
|
|
|
|
if (lkeys == 0 && lval > 0) {
|
|
lval -= 5;
|
|
for (uint8_t i = RGBLED_NUM / 2; i < RGBLED_NUM; ++i)
|
|
sethsv(lhue, 255, BASE(lval, i, lmid), &led[i]);
|
|
}
|
|
if (rkeys == 0 && rval > 0) {
|
|
rval -= 5;
|
|
for (uint8_t i = 0; i < RGBLED_NUM / 2; ++i)
|
|
sethsv(rhue, 255, BASE(rval, i, rmid), &led[i]);
|
|
}
|
|
rgblight_set();
|
|
}
|