keymap.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. /* Copyright 2022 @ Adam Lickel
  2. *
  3. * This program is free software: you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation, either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #include QMK_KEYBOARD_H
  17. enum encoder_names {
  18. _LEFT,
  19. _RIGHT,
  20. _MIDDLE,
  21. };
  22. enum bdn9_layers {
  23. _MEDIA = 0,
  24. _XCODE,
  25. _CUST1,
  26. _CUST2,
  27. };
  28. #define KC_XCRUN LGUI(KC_R)
  29. #define KC_XCPAUSE LCTL(LGUI(KC_Y))
  30. #define KC_XCSTOP LGUI(KC_DOT)
  31. // clang-format off
  32. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  33. [_MEDIA] = LAYOUT(
  34. TO(_XCODE), RGB_SPD, RGB_SPI,
  35. RGB_MOD, KC_MPLY, KC_MSTP,
  36. RGB_RMOD, KC_MNXT, KC_MPRV
  37. ),
  38. [_XCODE] = LAYOUT(
  39. TG(_XCODE), KC_NO, KC_NO,
  40. KC_XCRUN, KC_XCPAUSE, KC_XCSTOP,
  41. KC_F6, KC_F7, KC_F8
  42. ),
  43. [_CUST1] = LAYOUT(
  44. TG(_CUST1), _______, _______,
  45. _______, _______, _______,
  46. _______, _______, _______
  47. ),
  48. [_CUST2] = LAYOUT(
  49. TG(_CUST2), _______, _______,
  50. _______, _______, _______,
  51. _______, _______, _______
  52. ),
  53. };
  54. // clang-format on
  55. layer_state_t layer_state_set_user(layer_state_t state) {
  56. #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
  57. uint8_t layer = get_highest_layer(state);
  58. switch (layer) {
  59. case _MEDIA: // Reset
  60. rgblight_reload_from_eeprom();
  61. break;
  62. case _XCODE:
  63. rgblight_sethsv_noeeprom(HSV_BLUE);
  64. # if defined(RGB_MATRIX_ENABLE) && defined(ENABLE_RGB_MATRIX_BREATHING)
  65. rgb_matrix_mode_noeeprom(RGB_MATRIX_BREATHING);
  66. # elif defined(RGBLIGHT_ENABLE) && defined(RGBLIGHT_EFFECT_BREATHING)
  67. rgblight_mode_noeeprom(RGBLIGHT_MODE_BREATHING + 1);
  68. # endif
  69. break;
  70. case _CUST1:
  71. rgblight_sethsv_noeeprom(HSV_GREEN);
  72. # if defined(RGB_MATRIX_ENABLE) && defined(ENABLE_RGB_MATRIX_BREATHING)
  73. rgb_matrix_mode_noeeprom(RGB_MATRIX_BREATHING);
  74. # elif defined(RGBLIGHT_ENABLE) && defined(RGBLIGHT_EFFECT_BREATHING)
  75. rgblight_mode_noeeprom(RGBLIGHT_MODE_BREATHING + 1);
  76. # endif
  77. break;
  78. case _CUST2:
  79. rgblight_sethsv_noeeprom(HSV_PURPLE);
  80. # if defined(RGB_MATRIX_ENABLE) && defined(ENABLE_RGB_MATRIX_BREATHING)
  81. rgb_matrix_mode_noeeprom(RGB_MATRIX_BREATHING);
  82. # elif defined(RGBLIGHT_ENABLE) && defined(RGBLIGHT_EFFECT_BREATHING)
  83. rgblight_mode_noeeprom(RGBLIGHT_MODE_BREATHING + 1);
  84. # endif
  85. break;
  86. default:
  87. break;
  88. }
  89. #endif
  90. return state;
  91. }
  92. #ifdef ENCODER_MAP_ENABLE
  93. const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
  94. #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
  95. [_MEDIA] = { ENCODER_CCW_CW(RGB_HUD, RGB_HUI), ENCODER_CCW_CW(RGB_SAD, RGB_SAI), ENCODER_CCW_CW(RGB_VAD, RGB_VAI) },
  96. [_XCODE] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(KC_UP, KC_DOWN), ENCODER_CCW_CW(KC_PGUP, KC_PGDN) },
  97. #else
  98. [_MEDIA] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU), ENCODER_CCW_CW(KC_UP, KC_DOWN), ENCODER_CCW_CW(KC_PGUP, KC_PGDN) },
  99. [_XCODE] = { ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______) },
  100. #endif
  101. [_CUST1] = { ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______) },
  102. [_CUST2] = { ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______), ENCODER_CCW_CW(_______, _______) },
  103. };
  104. #else
  105. bool encoder_update_user(uint8_t index, bool clockwise) {
  106. uint8_t layer = get_highest_layer(layer_state);
  107. switch (layer) {
  108. #if defined(RGBLIGHT_ENABLE) || defined(RGB_MATRIX_ENABLE)
  109. case 0: // Reset
  110. if (index == _LEFT) {
  111. if (clockwise) {
  112. rgblight_increase_hue();
  113. } else {
  114. rgblight_decrease_hue();
  115. }
  116. } else if (index == _MIDDLE) {
  117. if (clockwise) {
  118. rgblight_increase_sat();
  119. } else {
  120. rgblight_decrease_sat();
  121. }
  122. } else if (index == _RIGHT) {
  123. if (clockwise) {
  124. rgblight_increase_val();
  125. } else {
  126. rgblight_decrease_val();
  127. }
  128. }
  129. break;
  130. #endif
  131. default:
  132. if (index == _LEFT) {
  133. if (clockwise) {
  134. tap_code(KC_VOLU);
  135. } else {
  136. tap_code(KC_VOLD);
  137. }
  138. } else if (index == _MIDDLE) {
  139. if (clockwise) {
  140. tap_code(KC_DOWN);
  141. } else {
  142. tap_code(KC_UP);
  143. }
  144. } else if (index == _RIGHT) {
  145. if (clockwise) {
  146. tap_code(KC_PGDN);
  147. } else {
  148. tap_code(KC_PGUP);
  149. }
  150. }
  151. break;
  152. }
  153. return true;
  154. }
  155. #endif