keymap.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  38. {
  39. switch(id) {
  40. case 0:
  41. if (record->event.pressed) {
  42. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION);
  43. }
  44. break;
  45. }
  46. return MACRO_NONE;
  47. };
  48. bool status_led1_on = false, status_led2_on = false, status_led3_on = false;
  49. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  50. switch (keycode) {
  51. // dynamically generate these.
  52. case RGB_FF0000:
  53. if (record->event.pressed) {
  54. #ifdef RGBLIGHT_ENABLE
  55. EZ_RGB(0xff0000UL);
  56. register_code(KC_1); unregister_code(KC_1);
  57. #endif
  58. }
  59. return false;
  60. break;
  61. case RGB_00FF00:
  62. if (record->event.pressed) {
  63. #ifdef RGBLIGHT_ENABLE
  64. EZ_RGB(0x00ff00UL);
  65. register_code(KC_2); unregister_code(KC_2);
  66. #endif
  67. }
  68. return false;
  69. break;
  70. case RGB_0000FF:
  71. if (record->event.pressed) {
  72. #ifdef RGBLIGHT_ENABLE
  73. EZ_RGB(0x0000ffUL);
  74. register_code(KC_3); unregister_code(KC_3);
  75. #endif
  76. }
  77. return false;
  78. break;
  79. case RGB_FFFFFF:
  80. if (record->event.pressed) {
  81. #ifdef RGBLIGHT_ENABLE
  82. EZ_RGB(0xffffffUL);
  83. register_code(KC_4); unregister_code(KC_4);
  84. #endif
  85. }
  86. return false;
  87. break;
  88. case RGB_TOGGLE:
  89. if (record->event.pressed) {
  90. #ifdef RGBLIGHT_ENABLE
  91. rgblight_toggle();
  92. register_code(KC_EQL); unregister_code(KC_EQL);
  93. #endif
  94. }
  95. return false;
  96. break;
  97. case LED1:
  98. if (record->event.pressed) {
  99. if(status_led1_on) {
  100. ergodox_right_led_1_off();
  101. status_led1_on = false;
  102. } else {
  103. ergodox_right_led_1_on();
  104. status_led1_on = true;
  105. }
  106. }
  107. return false;
  108. break;
  109. case LED2:
  110. if (record->event.pressed) {
  111. if(status_led2_on) {
  112. ergodox_right_led_2_off();
  113. status_led2_on = false;
  114. } else {
  115. ergodox_right_led_2_on();
  116. status_led2_on = true;
  117. }
  118. }
  119. return false;
  120. break;
  121. case LED3:
  122. if (record->event.pressed) {
  123. if(status_led3_on) {
  124. ergodox_right_led_3_off();
  125. status_led3_on = false;
  126. } else {
  127. ergodox_right_led_3_on();
  128. status_led3_on = true;
  129. }
  130. }
  131. return false;
  132. break;
  133. }
  134. return true;
  135. }