keymap.c 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #include QMK_KEYBOARD_H
  2. #include "debug.h"
  3. #include "action_layer.h"
  4. #include "version.h"
  5. enum custom_keycodes {
  6. PLACEHOLDER = SAFE_RANGE, // can always be here
  7. RGB_FF0000,
  8. RGB_00FF00,
  9. RGB_0000FF,
  10. RGB_FFFFFF,
  11. RGB_TOGGLE,
  12. LED1,
  13. LED2,
  14. LED3
  15. };
  16. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  17. [0] = LAYOUT_ergodox(
  18. RGB_TOGGLE, RGB_FF0000, RGB_00FF00, RGB_0000FF, RGB_FFFFFF, KC_5, KC_LPRN,
  19. KC_GRAVE, KC_A, KC_B, KC_C, KC_D, KC_E, KC_EXLM,
  20. KC_HASH, KC_J, KC_K, KC_L, KC_M, KC_N,
  21. KC_AMPR, KC_T, KC_U, KC_V, KC_W, KC_X, KC_DLR,
  22. KC_PIPE, KC_R, KC_PLUS, KC_LCBR, KC_RCBR,
  23. KC_F, KC_G,
  24. KC_H,
  25. KC_P, KC_O, KC_I,
  26. // RIGHT HAND
  27. KC_RPRN, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS,
  28. KC_AT, KC_F, KC_G, KC_H, KC_I, KC_COLN, KC_BSLS,
  29. KC_O, KC_P, KC_Q, KC_R, KC_S, KC_QUOT,
  30. LSFT(KC_COMM), KC_Y, KC_Z, KC_COMM, KC_DOT, KC_SLSH, KC_ASTR,
  31. KC_A, KC_B, KC_C, KC_D, KC_PIPE,
  32. LED1, KC_E,
  33. LED2,
  34. LED3, KC_J, KC_K
  35. )
  36. };
  37. bool status_led1_on = false, status_led2_on = false, status_led3_on = false;
  38. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  39. switch (keycode) {
  40. // dynamically generate these.
  41. case RGB_FF0000:
  42. if (record->event.pressed) {
  43. #ifdef RGBLIGHT_ENABLE
  44. EZ_RGB(0xff0000UL);
  45. register_code(KC_1); unregister_code(KC_1);
  46. #endif
  47. }
  48. return false;
  49. break;
  50. case RGB_00FF00:
  51. if (record->event.pressed) {
  52. #ifdef RGBLIGHT_ENABLE
  53. EZ_RGB(0x00ff00UL);
  54. register_code(KC_2); unregister_code(KC_2);
  55. #endif
  56. }
  57. return false;
  58. break;
  59. case RGB_0000FF:
  60. if (record->event.pressed) {
  61. #ifdef RGBLIGHT_ENABLE
  62. EZ_RGB(0x0000ffUL);
  63. register_code(KC_3); unregister_code(KC_3);
  64. #endif
  65. }
  66. return false;
  67. break;
  68. case RGB_FFFFFF:
  69. if (record->event.pressed) {
  70. #ifdef RGBLIGHT_ENABLE
  71. EZ_RGB(0xffffffUL);
  72. register_code(KC_4); unregister_code(KC_4);
  73. #endif
  74. }
  75. return false;
  76. break;
  77. case RGB_TOGGLE:
  78. if (record->event.pressed) {
  79. #ifdef RGBLIGHT_ENABLE
  80. rgblight_toggle();
  81. register_code(KC_EQL); unregister_code(KC_EQL);
  82. #endif
  83. }
  84. return false;
  85. break;
  86. case LED1:
  87. if (record->event.pressed) {
  88. if(status_led1_on) {
  89. ergodox_right_led_1_off();
  90. status_led1_on = false;
  91. } else {
  92. ergodox_right_led_1_on();
  93. status_led1_on = true;
  94. }
  95. }
  96. return false;
  97. break;
  98. case LED2:
  99. if (record->event.pressed) {
  100. if(status_led2_on) {
  101. ergodox_right_led_2_off();
  102. status_led2_on = false;
  103. } else {
  104. ergodox_right_led_2_on();
  105. status_led2_on = true;
  106. }
  107. }
  108. return false;
  109. break;
  110. case LED3:
  111. if (record->event.pressed) {
  112. if(status_led3_on) {
  113. ergodox_right_led_3_off();
  114. status_led3_on = false;
  115. } else {
  116. ergodox_right_led_3_on();
  117. status_led3_on = true;
  118. }
  119. }
  120. return false;
  121. break;
  122. }
  123. return true;
  124. }