Advertisement
Guest User

keymap.c

a guest
Aug 6th, 2024
64
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 6.02 KB | None | 0 0
  1. /* Copyright 2020 Jason Williams (Wilba)
  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 layers {
  18. BASE,
  19. FN1,
  20. FN2,
  21. };
  22.  
  23. enum custom_keycodes {
  24. SOCD_W,
  25. SOCD_A,
  26. SOCD_S,
  27. SOCD_D
  28. };
  29.  
  30. bool w_down = false;
  31. bool a_down = false;
  32. bool s_down = false;
  33. bool d_down = false;
  34.  
  35. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  36.  
  37. // Default layer
  38. [0] = LAYOUT_tkl_nofrow_ansi_tsangan_split_bs_rshift(
  39. 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, KC_INS, KC_HOME, KC_PGUP,
  40. KC_TAB, KC_Q, SOCD_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
  41. KC_CAPS, SOCD_A, SOCD_S, SOCD_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENT,
  42. KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, MO(1), KC_UP,
  43. KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, KC_RALT, MO(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RGHT),
  44.  
  45. // Fn1 Layer
  46. [1] = LAYOUT_tkl_nofrow_ansi_tsangan_split_bs_rshift(
  47. 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_TRNS, KC_TRNS, KC_PSCR, KC_SCRL, KC_PAUS,
  48. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_INS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  49. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  50. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  51. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  52.  
  53. // Fn2 Layer
  54. [2] = LAYOUT_tkl_nofrow_ansi_tsangan_split_bs_rshift(
  55. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  56. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  57. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  58. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  59. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  60.  
  61. // Fn3 Layer
  62. [3] = LAYOUT_tkl_nofrow_ansi_tsangan_split_bs_rshift(
  63. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  64. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  65. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  66. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  67. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  68.  
  69. };
  70.  
  71.  
  72. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  73. switch (keycode) {
  74. case SOCD_W:
  75. if (record->event.pressed) {
  76. if (s_down) {
  77. unregister_code(KC_S);
  78. }
  79. register_code(KC_W);
  80. w_down = true;
  81. } else {
  82. unregister_code(KC_W);
  83. w_down = false;
  84.  
  85. if (s_down) {
  86. register_code(KC_S);
  87. }
  88.  
  89. }
  90. return false;
  91. break;
  92. case SOCD_A:
  93. if (record->event.pressed) {
  94. if (d_down) {
  95. unregister_code(KC_D);
  96. }
  97. register_code(KC_A);
  98. a_down = true;
  99. } else {
  100. unregister_code(KC_A);
  101. a_down = false;
  102.  
  103. if (d_down) {
  104. register_code(KC_D);
  105. }
  106.  
  107. }
  108. return false;
  109. break;
  110. case SOCD_S:
  111. if (record->event.pressed) {
  112. if (w_down) {
  113. unregister_code(KC_W);
  114. }
  115. register_code(KC_S);
  116. s_down = true;
  117. } else {
  118. unregister_code(KC_S);
  119. s_down = false;
  120.  
  121. if (w_down) {
  122. register_code(KC_W);
  123. }
  124.  
  125. }
  126. return false;
  127. break;
  128. case SOCD_D:
  129. if (record->event.pressed) {
  130. if (a_down) {
  131. unregister_code(KC_A);
  132. }
  133. register_code(KC_D);
  134. d_down = true;
  135. } else {
  136. unregister_code(KC_D);
  137. d_down = false;
  138.  
  139. if (a_down) {
  140. register_code(KC_A);
  141. }
  142. }
  143. return false;
  144. break;
  145. }
  146. return true;
  147. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement