qmk/keyboards/sofle/rev1/keymaps/aleidk/keymap.c
aleidk 4df385f9e1
Some checks failed
Build QMK firmware / QMK Userspace Build (push) Failing after 0s
Build QMK firmware / QMK Userspace Publish (push) Failing after 0s
feat: update sofle keyboard
- use encoder to volume
- move home row mod to middle row
- unset QUICK_TAP_TERM
- minor symbols adjustments
2025-05-12 11:34:16 -04:00

284 lines
10 KiB
C

/* Copyright 2021 Dane Evans
*
* 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/>.
*/
// SOFLE RGB
#include <stdio.h>
#include QMK_KEYBOARD_H
// Keycodes: https://github.com/qmk/qmk_firmware/blob/master/quantum/keymap_extras/keymap_spanish_latin_america.h
#include "keymap_spanish_latin_america.h"
#define INDICATOR_BRIGHTNESS 30
#define HSV_OVERRIDE_HELP(h, s, v, Override) h, s , Override
#define HSV_OVERRIDE(hsv, Override) HSV_OVERRIDE_HELP(hsv,Override)
// Light combinations
#define SET_INDICATORS(hsv) \
{0, 1, HSV_OVERRIDE_HELP(hsv, INDICATOR_BRIGHTNESS)}, \
{35+0, 1, hsv}
#define SET_UNDERGLOW(hsv) \
{1, 6, hsv}, \
{35+1, 6,hsv}
#define SET_NUMPAD(hsv) \
{35+15, 5, hsv},\
{35+22, 3, hsv},\
{35+27, 3, hsv}
#define SET_NUMROW(hsv) \
{10, 2, hsv}, \
{20, 2, hsv}, \
{30, 2, hsv}, \
{35+ 10, 2, hsv}, \
{35+ 20, 2, hsv}, \
{35+ 30, 2, hsv}
#define SET_INNER_COL(hsv) \
{33, 4, hsv}, \
{35+ 33, 4, hsv}
#define SET_OUTER_COL(hsv) \
{7, 4, hsv}, \
{35+ 7, 4, hsv}
#define SET_THUMB_CLUSTER(hsv) \
{25, 2, hsv}, \
{35+ 25, 2, hsv}
#define SET_LAYER_ID(hsv) \
{0, 1, HSV_OVERRIDE_HELP(hsv, INDICATOR_BRIGHTNESS)}, \
{35+0, 1, HSV_OVERRIDE_HELP(hsv, INDICATOR_BRIGHTNESS)}, \
{1, 6, hsv}, \
{35+1, 6, hsv}, \
{7, 4, hsv}, \
{35+ 7, 4, hsv}, \
{25, 2, hsv}, \
{35+ 25, 2, hsv}
enum sofle_layers {
_DEFAULTS = 0,
_QWERTY = 0,
_SYMBOLS,
_SYSTEM,
_ADJUST,
_NUMPAD,
};
enum custom_keycodes {
KC_SYMBOLS = SAFE_RANGE,
KC_SYSTEM,
KC_ADJUST,
// KC_ENC_MODE,
KC_D_MUTE,
};
// Left-hand home row mods
#define HOME_A LGUI_T(ES_A)
#define HOME_S LALT_T(ES_S)
#define HOME_D LSFT_T(ES_D)
#define HOME_F LCTL_T(ES_F)
// Right-hand home row mods
#define HOME_J RCTL_T(ES_J)
#define HOME_K RSFT_T(ES_K)
#define HOME_L LALT_T(ES_L)
#define HOME_NTIL RGUI_T(ES_NTIL)
// Other multi pourpose keys
#define SIDE_TAB LT(_NUMPAD, KC_TAB) // layer on held, tab on tap
#define CTRL_ESC RCTL_T(KC_ESC)
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
[_QWERTY] = LAYOUT(
ES_PIPE, ES_1, ES_2, ES_3, ES_4, ES_5, ES_6, ES_7, ES_8, ES_9, ES_0, ES_QUOT,
SIDE_TAB, ES_Q, ES_W, ES_E, ES_R, ES_T, ES_Y, ES_U, ES_I, ES_O, ES_P, ES_ACUT,
CTRL_ESC, HOME_A, HOME_S, HOME_D, HOME_F, ES_G, ES_H, HOME_J, HOME_K, HOME_L, HOME_NTIL,KC_BSPC,
KC_LSFT, ES_Z, ES_X, ES_C, ES_V, ES_B, KC_MUTE, XXXXXXX, ES_N, ES_M, ES_COMM,ES_DOT, ES_MINS, KC_RSFT,
KC_LALT, KC_LCTL, KC_LGUI, KC_SPC, KC_SYMBOLS, KC_SYSTEM, KC_ENT, KC_RGUI, KC_RCTL, KC_ALGR
),
[_SYMBOLS] = LAYOUT(
ES_MORD, S(ES_1), S(ES_2), S(ES_3), S(ES_4), S(ES_5), S(ES_6), S(ES_7), S(ES_8), S(ES_9), S(ES_0), S(ES_QUOT),
_______, ES_IQUE, ES_QUES, ES_LBRC, ES_RBRC, ES_QUOT, ES_ASTR, ES_SLSH, ES_PLUS, ES_MINS, ES_BSLS, ES_CIRC,
_______, ES_LABK, ES_RABK, ES_LPRN, ES_RPRN, ES_DQUO, ES_PIPE, ES_DLR, ES_NUMB, ES_EQL, ES_TILD, _______,
_______, ES_IEXL, ES_EXLM, ES_LCBR, ES_RCBR, ES_GRV, _______, _______, ES_AMPR, ES_PERC, ES_SCLN, ES_COLN, ES_UNDS, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
),
[_SYSTEM] = LAYOUT(
KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12,
_______, XXXXXXX, XXXXXXX, S(KC_PSCR), KC_PSCR, XXXXXXX, KC_HOME, KC_PGDN, KC_PGUP, KC_END, KC_LGUI, KC_BSPC,
_______, KC_LGUI, KC_LALT, KC_LSFT, KC_LCTL, XXXXXXX, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_VOLU, KC_DEL,
_______, KC_UNDO, KC_CUT, KC_COPY, KC_PASTE,XXXXXXX, _______, _______, KC_HOME, KC_MPRV, KC_MPLY, KC_MNXT, KC_VOLD, XXXXXXX,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
),
[_ADJUST] = LAYOUT(
XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
QK_BOOT, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX,
UG_TOGG, UG_HUEU, UG_SATU, UG_VALU, _______, _______, C(G(KC_LEFT)), XXXXXXX, XXXXXXX,C(G(KC_RGHT)),XXXXXXX,XXXXXXX,
UG_NEXT, UG_HUED, UG_SATD, UG_VALD, XXXXXXX, _______,XXXXXXX, XXXXXXX, XXXXXXX, KC_MPRV, KC_MPLY, KC_MNXT, XXXXXXX, XXXXXXX,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______
),
[_NUMPAD] = LAYOUT(
_______, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, KC_P7, KC_P8, KC_P9, XXXXXXX, XXXXXXX,
XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_CIRC, KC_P4, KC_P5, KC_P6, KC_ASTR, XXXXXXX,
XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_MINS, KC_P1, KC_P2, KC_P3, KC_EQL, KC_BSPC,
XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, _______, KC_PLUS, KC_P0, KC_P0, KC_PDOT, KC_SLSH, _______,
_______, OSM(MOD_MEH), _______, _______, _______, _______, _______, _______, _______, _______
),
};
//enum ENCODER_MODE {
// _ENCODER_PAGE = 0,
// _ENCODER_CHARACTER,
//};
//enum ENCODER_MODE CURRENT_ENCODER_MODE = _ENCODER_CHARACTER;
#ifdef ENCODER_ENABLE
bool encoder_update_user(uint8_t index, bool clockwise) {
// Uncomment this to use the encoder to control the volume
if (index == 0) {
if (clockwise) {
tap_code(KC_VOLU);
} else {
tap_code(KC_VOLD);
}
// bool is_default_layer = get_highest_layer(layer_state) == _DEFAULTS;
//
// if (CURRENT_ENCODER_MODE == _ENCODER_PAGE && clockwise) {
// tap_code(is_default_layer ? KC_PGDN : KC_END);
// } else if (CURRENT_ENCODER_MODE == _ENCODER_PAGE && !clockwise) {
// tap_code(is_default_layer ? KC_PGUP : KC_HOME);
// } else if (CURRENT_ENCODER_MODE == _ENCODER_CHARACTER && clockwise) {
// tap_code(is_default_layer ? KC_DOWN : KC_RGHT);
// } else if (CURRENT_ENCODER_MODE == _ENCODER_CHARACTER && !clockwise) {
// tap_code(is_default_layer ? KC_UP : KC_LEFT);
// }
}
return false;
}
#endif
#ifdef OLED_ENABLE
static void render_logo(void) {
static const char PROGMEM qmk_logo[] = {
0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8A, 0x8B, 0x8C, 0x8D, 0x8E, 0x8F, 0x90, 0x91, 0x92, 0x93, 0x94,
0xA0, 0xA1, 0xA2, 0xA3, 0xA4, 0xA5, 0xA6, 0xA7, 0xA8, 0xA9, 0xAA, 0xAB, 0xAC, 0xAD, 0xAE, 0xAF, 0xB0, 0xB1, 0xB2, 0xB3, 0xB4,
0xC0, 0xC1, 0xC2, 0xC3, 0xC4, 0xC5, 0xC6, 0xC7, 0xC8, 0xC9, 0xCA, 0xCB, 0xCC, 0xCD, 0xCE, 0xCF, 0xD0, 0xD1, 0xD2, 0xD3, 0xD4, 0x00
};
oled_write_P(qmk_logo, false);
}
static void print_status_narrow(void) {
// Print current layer
oled_write_ln_P(PSTR("LAYER"), false);
switch (get_highest_layer(layer_state)) {
case _QWERTY:
oled_write_ln_P(PSTR("Base\n"), false);
break;
case _SYSTEM:
oled_write_ln_P(PSTR("Sys\n"), false);
break;
case _SYMBOLS:
oled_write_ln_P(PSTR("Symb\n"), false);
break;
case _ADJUST:
oled_write_ln_P(PSTR("Adj\n"), false);
break;
case _NUMPAD:
oled_write_P(PSTR("Nump\n"), false);
break;
default:
oled_write_ln_P(PSTR("Undef\n"), false);
}
// oled_write_ln_P(PSTR("\nENCDR"), false);
//
// switch (CURRENT_ENCODER_MODE) {
// case _ENCODER_PAGE:
// oled_write_ln_P(PSTR("Page"), false);
// break;
// case _ENCODER_CHARACTER:
// oled_write_ln_P(PSTR("Char"), false);
// break;
// default:
// oled_write_ln_P(PSTR("Undef\n"), false);
// }
}
oled_rotation_t oled_init_user(oled_rotation_t rotation) {
if (is_keyboard_master()) {
return OLED_ROTATION_270;
}
return rotation;
}
bool oled_task_user(void) {
if (is_keyboard_master()) {
print_status_narrow();
} else {
render_logo();
}
return false;
}
#endif
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
switch (keycode) {
// case KC_ENC_MODE:
// if (record->event.pressed) {
// CURRENT_ENCODER_MODE = (CURRENT_ENCODER_MODE+1) % (_ENCODER_CHARACTER+1);
// }
// return false;
case KC_SYMBOLS:
if (record->event.pressed) {
layer_on(_SYMBOLS);
update_tri_layer(_SYMBOLS, _SYSTEM, _ADJUST);
} else {
layer_off(_SYMBOLS);
update_tri_layer(_SYMBOLS, _SYSTEM, _ADJUST);
}
return false;
case KC_SYSTEM:
if (record->event.pressed) {
layer_on(_SYSTEM);
update_tri_layer(_SYMBOLS, _SYSTEM, _ADJUST);
} else {
layer_off(_SYSTEM);
update_tri_layer(_SYMBOLS, _SYSTEM, _ADJUST);
}
return false;
case KC_ADJUST:
if (record->event.pressed) {
layer_on(_ADJUST);
} else {
layer_off(_ADJUST);
}
return false;
case KC_D_MUTE:
if (record->event.pressed) {
register_mods(mod_config(MOD_MEH));
register_code(KC_UP);
} else {
unregister_mods(mod_config(MOD_MEH));
unregister_code(KC_UP);
}
}
return true;
}