/* 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 . */ // SOFLE RGB #include #include QMK_KEYBOARD_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_D_MUTE }; // Left-hand home row mods #define HOME_A LGUI_T(KC_A) #define HOME_S LALT_T(KC_S) #define HOME_D LSFT_T(KC_D) #define HOME_F LCTL_T(KC_F) // Right-hand home row mods #define HOME_J RCTL_T(KC_J) #define HOME_K RSFT_T(KC_K) #define HOME_L LALT_T(KC_L) #define HOME_SCLN RGUI_T(KC_SCLN) // Other multi pourpose keys #define SIDE_TAB LT(_NUMPAD, KC_TAB) // layer on held, tab on tap const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { [_QWERTY] = LAYOUT( KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, SIDE_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, ALGR(KC_QUOT), KC_ESC, HOME_A, HOME_S, HOME_D, HOME_F, KC_G, KC_H, HOME_J, HOME_K, HOME_L, HOME_SCLN, KC_BSPC, KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_MUTE, KC_D_MUTE, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_LALT, KC_LCTL, KC_LGUI, KC_SPC, KC_SYMBOLS, KC_SYSTEM, KC_ENT, KC_RGUI, KC_RCTL, KC_ALGR ), [_SYMBOLS] = LAYOUT( _______, S(KC_1), S(KC_2), S(KC_3), S(KC_4), S(KC_5), S(KC_6), S(KC_7), S(KC_8), S(KC_9), S(KC_0), _______, _______, ALGR(KC_SLSH), S(KC_SLSH), KC_LBRC, KC_RBRC, KC_QUOT, S(KC_EQL), S(KC_8), KC_SLASH, KC_MINS, S(KC_6), _______, _______, S(KC_COMM), S(KC_DOT), S(KC_9), S(KC_0), S(KC_QUOT), S(KC_BSLS), S(KC_4), S(KC_3), KC_EQL, KC_BSLS, _______, _______, RSA(KC_1), S(KC_1), S(KC_LBRC), S(KC_RBRC), KC_GRV, _______, _______, S(KC_7), S(KC_5), XXXXXXX, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ ), [_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, _______, KC_INS, XXXXXXX, S(KC_PSCR), KC_PSCR, XXXXXXX, KC_HOME, KC_PGDN, KC_PGUP, KC_END, KC_RPRN, KC_BSPC, _______, KC_LGUI, KC_LALT, KC_LSFT, KC_LCTL, KC_PGUP, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, XXXXXXX, KC_DEL, _______, KC_UNDO, KC_CUT, KC_COPY, KC_PASTE, XXXXXXX, _______, _______, KC_UNDS, KC_PLUS, KC_LBRC, KC_RBRC, KC_BSLS, KC_TILD, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ ), [_ADJUST] = LAYOUT( EE_CLR, 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_NUM, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_CIRC, KC_P7, KC_P8, KC_P9, KC_ASTR, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, KC_MINS, KC_P4, KC_P5, KC_P6, KC_EQL, KC_PIPE, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, _______, _______, KC_PLUS, KC_P1, KC_P2, KC_P3, KC_SLSH, _______, _______, OSM(MOD_MEH), _______, _______, _______, _______, _______, KC_P0, KC_PDOT, _______ ), }; #ifdef RGBLIGHT_ENABLE char layer_state_str[70]; // Now define the array of layers. Later layers take precedence // QWERTY, // Light on inner column and underglow const rgblight_segment_t PROGMEM layer_qwerty_lights[] = RGBLIGHT_LAYER_SEGMENTS( SET_LAYER_ID(HSV_RED) ); // _NUM, // Light on outer column and underglow const rgblight_segment_t PROGMEM layer_num_lights[] = RGBLIGHT_LAYER_SEGMENTS( SET_NUMROW(HSV_TEAL) ); // _SYMBOL, // Light on inner column and underglow const rgblight_segment_t PROGMEM layer_symbol_lights[] = RGBLIGHT_LAYER_SEGMENTS( SET_LAYER_ID(HSV_PURPLE), SET_THUMB_CLUSTER(HSV_PURPLE) ); // _COMMAND, // Light on inner column and underglow const rgblight_segment_t PROGMEM layer_command_lights[] = RGBLIGHT_LAYER_SEGMENTS( SET_LAYER_ID(HSV_PURPLE), SET_THUMB_CLUSTER(HSV_PURPLE) ); //_NUMPAD const rgblight_segment_t PROGMEM layer_numpad_lights[] = RGBLIGHT_LAYER_SEGMENTS( SET_INDICATORS(HSV_ORANGE), SET_UNDERGLOW(HSV_ORANGE), SET_NUMPAD(HSV_BLUE), {7, 4, HSV_ORANGE}, {25, 2, HSV_ORANGE}, {35+6, 4, HSV_ORANGE}, {35+25, 2, HSV_ORANGE} ); const rgblight_segment_t* const PROGMEM my_rgb_layers[] = RGBLIGHT_LAYERS_LIST( layer_qwerty_lights, layer_num_lights,// overrides layer 1 layer_symbol_lights, layer_numpad_lights, layer_numpad_lights ); layer_state_t layer_state_set_user(layer_state_t state) { rgblight_set_layer_state(0, layer_state_cmp(state, _DEFAULTS) && layer_state_cmp(default_layer_state,_QWERTY)); rgblight_set_layer_state(1, layer_state_cmp(state, _SYMBOLS)); rgblight_set_layer_state(2, layer_state_cmp(state, _SYSTEM)); rgblight_set_layer_state(3, layer_state_cmp(state, _ADJUST)); rgblight_set_layer_state(4, layer_state_cmp(state, _NUMPAD)); return state; } void keyboard_post_init_user(void) { // Enable the LED layers rgblight_layers = my_rgb_layers; rgblight_mode(10);// haven't found a way to set this in a more useful way } #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_P(PSTR("Base\n"), false); break; case _SYSTEM: oled_write_P(PSTR("Sys\n"), false); break; case _SYMBOLS: oled_write_P(PSTR("Symb\n"), false); break; case _ADJUST: oled_write_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_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_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; } #ifdef ENCODER_ENABLE bool encoder_update_user(uint8_t index, bool clockwise) { if (index == 0) { // Uncomment this to use the encoder to control the volume // if (clockwise) { // tap_code(KC_VOLU); // } else { // tap_code(KC_VOLD); // } switch (get_highest_layer(layer_state)) { case _QWERTY: if (clockwise) { tap_code(KC_PGDN); } else { tap_code(KC_PGUP); } break; case _SYSTEM: case _SYMBOLS: if (clockwise) { tap_code(KC_DOWN); } else { tap_code(KC_UP); } break; default: if (clockwise) { tap_code(KC_WH_D); } else { tap_code(KC_WH_U); } break; } } return false; } #endif