You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

191 lines
7.4 KiB

  1. #include QMK_KEYBOARD_H
  2. #include "rgb_matrix_user.h"
  3. enum alt_keycodes {
  4. L_BRI = SAFE_RANGE, //LED Brightness Increase
  5. L_BRD, //LED Brightness Decrease
  6. L_PTN, //LED Pattern Select Next
  7. L_PTP, //LED Pattern Select Previous
  8. L_PSI, //LED Pattern Speed Increase
  9. L_PSD, //LED Pattern Speed Decrease
  10. L_T_MD, //LED Toggle Mode
  11. L_T_ONF, //LED Toggle On / Off
  12. L_ON, //LED On
  13. L_OFF, //LED Off
  14. L_T_BR, //LED Toggle Breath Effect
  15. L_T_PTD, //LED Toggle Scrolling Pattern Direction
  16. U_T_AUTO, //USB Extra Port Toggle Auto Detect / Always Active
  17. U_T_AGCR, //USB Toggle Automatic GCR control
  18. DBG_TOG, //DEBUG Toggle On / Off
  19. DBG_MTRX, //DEBUG Toggle Matrix Prints
  20. DBG_KBD, //DEBUG Toggle Keyboard Prints
  21. DBG_MOU, //DEBUG Toggle Mouse Prints
  22. MD_BOOT, //Restart into bootloader after hold timeout
  23. };
  24. #define TG_NKRO MAGIC_TOGGLE_NKRO //Toggle 6KRO / NKRO mode
  25. #define ______ KC_TRNS
  26. keymap_config_t keymap_config;
  27. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  28. [0] = LAYOUT(
  29. KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_DEL, \
  30. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_HOME, \
  31. KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT, KC_PGUP, \
  32. KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP, KC_PGDN, \
  33. KC_LCTL, KC_LALT, KC_LGUI, KC_SPC, KC_RGUI, MO(1), KC_LEFT, KC_DOWN, KC_RGHT \
  34. ),
  35. [1] = LAYOUT(
  36. KC_GRV, 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_MUTE, \
  37. _______, _______, _______, KC_UP, _______, _______, _______, U_T_AUTO,U_T_AGCR,_______, KC_PSCR, KC_SLCK, KC_PAUS, _______, KC_END, \
  38. _______, _______, KC_LEFT, KC_DOWN, KC_RGHT, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
  39. _______, _______, _______, _______, _______, MD_BOOT, TG_NKRO, _______, _______, _______, _______, _______, KC_VOLU, _______, \
  40. _______, _______, _______, KC_MPLY, MO(2), _______, KC_MRWD, KC_VOLD, KC_MFFD \
  41. ),
  42. [2] = LAYOUT(
  43. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
  44. L_T_BR, L_PSD, L_BRI, L_PSI, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
  45. L_T_PTD, L_PTP, L_BRD, L_PTN, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
  46. _______, L_T_MD, L_T_ONF, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, \
  47. _______, _______, _______, _______, _______, _______, _______, _______, _______ \
  48. ),
  49. };
  50. // Runs just one time when the keyboard initializes.
  51. void matrix_init_user(void) {
  52. };
  53. // Runs constantly in the background, in a loop.
  54. void matrix_scan_user(void) {
  55. };
  56. #define MODS_SHIFT (keyboard_report->mods & MOD_BIT(KC_LSHIFT) || keyboard_report->mods & MOD_BIT(KC_RSHIFT))
  57. #define MODS_CTRL (keyboard_report->mods & MOD_BIT(KC_LCTL) || keyboard_report->mods & MOD_BIT(KC_RCTRL))
  58. #define MODS_ALT (keyboard_report->mods & MOD_BIT(KC_LALT) || keyboard_report->mods & MOD_BIT(KC_RALT))
  59. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  60. static uint32_t key_timer;
  61. rgb_matrix_record_key_press(record);
  62. switch (keycode) {
  63. case L_BRI:
  64. if (record->event.pressed) {
  65. if (LED_GCR_STEP > LED_GCR_MAX - gcr_desired) gcr_desired = LED_GCR_MAX;
  66. else gcr_desired += LED_GCR_STEP;
  67. if (led_animation_breathing) gcr_breathe = gcr_desired;
  68. }
  69. return false;
  70. case L_BRD:
  71. if (record->event.pressed) {
  72. if (LED_GCR_STEP > gcr_desired) gcr_desired = 0;
  73. else gcr_desired -= LED_GCR_STEP;
  74. if (led_animation_breathing) gcr_breathe = gcr_desired;
  75. }
  76. return false;
  77. case L_PTN:
  78. if (record->event.pressed) {
  79. if (led_animation_id == led_setups_count - 1) led_animation_id = 0;
  80. else led_animation_id++;
  81. }
  82. return false;
  83. case L_PTP:
  84. if (record->event.pressed) {
  85. if (led_animation_id == 0) led_animation_id = led_setups_count - 1;
  86. else led_animation_id--;
  87. }
  88. return false;
  89. case L_PSI:
  90. if (record->event.pressed) {
  91. led_animation_speed += ANIMATION_SPEED_STEP;
  92. }
  93. return false;
  94. case L_PSD:
  95. if (record->event.pressed) {
  96. led_animation_speed -= ANIMATION_SPEED_STEP;
  97. if (led_animation_speed < 0) led_animation_speed = 0;
  98. }
  99. return false;
  100. case L_T_MD:
  101. if (record->event.pressed) {
  102. led_lighting_mode++;
  103. if (led_lighting_mode > LED_MODE_MAX_INDEX) led_lighting_mode = LED_MODE_NORMAL;
  104. }
  105. return false;
  106. case L_T_ONF:
  107. if (record->event.pressed) {
  108. led_enabled = !led_enabled;
  109. I2C3733_Control_Set(led_enabled);
  110. }
  111. return false;
  112. case L_ON:
  113. if (record->event.pressed) {
  114. led_enabled = 1;
  115. I2C3733_Control_Set(led_enabled);
  116. }
  117. return false;
  118. case L_OFF:
  119. if (record->event.pressed) {
  120. led_enabled = 0;
  121. I2C3733_Control_Set(led_enabled);
  122. }
  123. return false;
  124. case L_T_BR:
  125. if (record->event.pressed) {
  126. led_animation_breathing = !led_animation_breathing;
  127. if (led_animation_breathing) {
  128. gcr_breathe = gcr_desired;
  129. led_animation_breathe_cur = BREATHE_MIN_STEP;
  130. breathe_dir = 1;
  131. }
  132. }
  133. return false;
  134. case L_T_PTD:
  135. if (record->event.pressed) {
  136. led_animation_direction = !led_animation_direction;
  137. }
  138. return false;
  139. case U_T_AUTO:
  140. if (record->event.pressed && MODS_SHIFT && MODS_CTRL) {
  141. TOGGLE_FLAG_AND_PRINT(usb_extra_manual, "USB extra port manual mode");
  142. }
  143. return false;
  144. case U_T_AGCR:
  145. if (record->event.pressed && MODS_SHIFT && MODS_CTRL) {
  146. TOGGLE_FLAG_AND_PRINT(usb_gcr_auto, "USB GCR auto mode");
  147. }
  148. return false;
  149. case DBG_TOG:
  150. if (record->event.pressed) {
  151. TOGGLE_FLAG_AND_PRINT(debug_enable, "Debug mode");
  152. }
  153. return false;
  154. case DBG_MTRX:
  155. if (record->event.pressed) {
  156. TOGGLE_FLAG_AND_PRINT(debug_matrix, "Debug matrix");
  157. }
  158. return false;
  159. case DBG_KBD:
  160. if (record->event.pressed) {
  161. TOGGLE_FLAG_AND_PRINT(debug_keyboard, "Debug keyboard");
  162. }
  163. return false;
  164. case DBG_MOU:
  165. if (record->event.pressed) {
  166. TOGGLE_FLAG_AND_PRINT(debug_mouse, "Debug mouse");
  167. }
  168. return false;
  169. case MD_BOOT:
  170. if (record->event.pressed) {
  171. key_timer = timer_read32();
  172. } else {
  173. if (timer_elapsed32(key_timer) >= 500) {
  174. reset_keyboard();
  175. }
  176. }
  177. return false;
  178. default:
  179. return true; //Process all other keycodes normally
  180. }
  181. }