keymap.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. #include "ergodox.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. };
  13. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  14. [0] = KEYMAP(
  15. RGB_TOGGLE,RGB_FF0000,RGB_00FF00,RGB_0000FF,RGB_FFFFFF,RGB_TOGGLE,KC_6,
  16. KC_A,KC_Q,KC_W,KC_E,KC_R,KC_T,KC_E,KC_A,KC_A,KC_S,KC_D,KC_F,KC_G,KC_A,KC_Z,KC_X,KC_C,KC_V,KC_B,KC_L,KC_Z,KC_QUOTE,KC_N,KC_U,KC_C,KC_E,KC_8,KC_9,KC_Y,KC_COMMA,KC_6,KC_7,KC_6,KC_7,KC_8,KC_9,KC_0,KC_MINUS,KC_J,KC_Y,KC_U,KC_I,KC_O,KC_P,KC_BSLASH,KC_H,KC_J,KC_K,KC_L,KC_J,KC_K,KC_Z,KC_N,KC_M,KC_COMMA,KC_DOT,KC_E,KC_QUOTE,KC_8,KC_7,KC_LBRACKET,KC_RBRACKET,KC_H,KC_9,KC_7,KC_8,KC_7,KC_6,KC_9),
  17. };
  18. const uint16_t PROGMEM fn_actions[] = {
  19. [1] = ACTION_LAYER_TAP_TOGGLE(1)
  20. };
  21. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  22. {
  23. switch(id) {
  24. case 0:
  25. if (record->event.pressed) {
  26. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION);
  27. }
  28. break;
  29. }
  30. return MACRO_NONE;
  31. };
  32. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  33. switch (keycode) {
  34. // dynamically generate these.
  35. case RGB_FF0000:
  36. if (record->event.pressed) {
  37. #ifdef RGBLIGHT_ENABLE
  38. EZ_RGB(0xff0000);
  39. register_code(KC_A); unregister_code(KC_A);
  40. #endif
  41. }
  42. return false;
  43. break;
  44. case RGB_00FF00:
  45. if (record->event.pressed) {
  46. #ifdef RGBLIGHT_ENABLE
  47. EZ_RGB(0x00ff00);
  48. register_code(KC_B); unregister_code(KC_B);
  49. #endif
  50. }
  51. return false;
  52. break;
  53. case RGB_0000FF:
  54. if (record->event.pressed) {
  55. #ifdef RGBLIGHT_ENABLE
  56. EZ_RGB(0x0000ff);
  57. register_code(KC_C); unregister_code(KC_C);
  58. #endif
  59. }
  60. return false;
  61. break;
  62. case RGB_FFFFFF:
  63. if (record->event.pressed) {
  64. #ifdef RGBLIGHT_ENABLE
  65. EZ_RGB(0xffffff);
  66. register_code(KC_D); unregister_code(KC_D);
  67. #endif
  68. }
  69. return false;
  70. break;
  71. case RGB_TOGGLE:
  72. if (record->event.pressed) {
  73. #ifdef RGBLIGHT_ENABLE
  74. rgblight_toggle();
  75. register_code(KC_F); unregister_code(KC_F);
  76. #endif
  77. }
  78. return false;
  79. break;
  80. }
  81. return true;
  82. }
  83. void matrix_scan_user(void) {
  84. uint8_t layer = biton32(layer_state);
  85. ergodox_board_led_off();
  86. ergodox_right_led_1_off();
  87. ergodox_right_led_2_off();
  88. ergodox_right_led_3_off();
  89. switch (layer) {
  90. case 1:
  91. ergodox_right_led_1_on();
  92. break;
  93. case 2:
  94. ergodox_right_led_2_on();
  95. break;
  96. case 3:
  97. ergodox_right_led_3_on();
  98. break;
  99. case 4:
  100. ergodox_right_led_1_on();
  101. ergodox_right_led_2_on();
  102. break;
  103. case 5:
  104. ergodox_right_led_1_on();
  105. ergodox_right_led_3_on();
  106. break;
  107. case 6:
  108. ergodox_right_led_2_on();
  109. ergodox_right_led_3_on();
  110. break;
  111. case 7:
  112. ergodox_right_led_1_on();
  113. ergodox_right_led_2_on();
  114. ergodox_right_led_3_on();
  115. break;
  116. default:
  117. break;
  118. }
  119. };