keymap.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. /**
  2. * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly)
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 2 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. */
  17. #include QMK_KEYBOARD_H
  18. #ifdef CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  19. # include "timer.h"
  20. #endif // CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  21. enum charybdis_keymap_layers {
  22. LAYER_BASE = 0,
  23. LAYER_FUNCTION,
  24. LAYER_NAVIGATION,
  25. LAYER_MEDIA,
  26. LAYER_POINTER,
  27. LAYER_NUMERAL,
  28. LAYER_SYMBOLS,
  29. };
  30. // Automatically enable sniping-mode on the pointer layer.
  31. #define CHARYBDIS_AUTO_SNIPING_ON_LAYER LAYER_POINTER
  32. #ifdef CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  33. static uint16_t auto_pointer_layer_timer = 0;
  34. # ifndef CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_TIMEOUT_MS
  35. # define CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_TIMEOUT_MS 1000
  36. # endif // CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_TIMEOUT_MS
  37. # ifndef CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_THRESHOLD
  38. # define CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_THRESHOLD 8
  39. # endif // CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_THRESHOLD
  40. #endif // CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  41. #define ESC_MED LT(LAYER_MEDIA, KC_ESC)
  42. #define SPC_NAV LT(LAYER_NAVIGATION, KC_SPC)
  43. #define TAB_FUN LT(LAYER_FUNCTION, KC_TAB)
  44. #define ENT_SYM LT(LAYER_SYMBOLS, KC_ENT)
  45. #define BSP_NUM LT(LAYER_NUMERAL, KC_BSPC)
  46. #define _L_PTR(KC) LT(LAYER_POINTER, KC)
  47. #ifndef POINTING_DEVICE_ENABLE
  48. # define DRGSCRL KC_NO
  49. # define DPI_MOD KC_NO
  50. # define S_D_MOD KC_NO
  51. # define SNIPING KC_NO
  52. #endif // !POINTING_DEVICE_ENABLE
  53. // clang-format off
  54. /** \brief QWERTY layout (3 rows, 10 columns). */
  55. #define LAYOUT_LAYER_BASE \
  56. KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, \
  57. KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_QUOT, \
  58. KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, \
  59. ESC_MED, SPC_NAV, TAB_FUN, ENT_SYM, BSP_NUM
  60. /** Convenience row shorthands. */
  61. #define _______________DEAD_HALF_ROW_______________ XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX
  62. #define ______________HOME_ROW_GACS_L______________ KC_LGUI, KC_LALT, KC_LCTL, KC_LSFT, XXXXXXX
  63. #define ______________HOME_ROW_GACS_R______________ XXXXXXX, KC_LSFT, KC_LCTL, KC_LALT, KC_LGUI
  64. /*
  65. * Layers used on the Charybdis Nano.
  66. *
  67. * These layers started off heavily inspired by the Miryoku layout, but trimmed
  68. * down and tailored for a stock experience that is meant to be fundation for
  69. * further personalization.
  70. *
  71. * See https://github.com/manna-harbour/miryoku for the original layout.
  72. */
  73. /**
  74. * \brief Function layer.
  75. *
  76. * Secondary right-hand layer has function keys mirroring the numerals on the
  77. * primary layer with extras on the pinkie column, plus system keys on the inner
  78. * column. App is on the tertiary thumb key and other thumb keys are duplicated
  79. * from the base layer to enable auto-repeat.
  80. */
  81. #define LAYOUT_LAYER_FUNCTION \
  82. _______________DEAD_HALF_ROW_______________, KC_PSCR, KC_F7, KC_F8, KC_F9, KC_F12, \
  83. ______________HOME_ROW_GACS_L______________, KC_SCRL, KC_F4, KC_F5, KC_F6, KC_F11, \
  84. _______________DEAD_HALF_ROW_______________, KC_PAUS, KC_F1, KC_F2, KC_F3, KC_F10, \
  85. XXXXXXX, XXXXXXX, _______, XXXXXXX, XXXXXXX
  86. /**
  87. * \brief Media layer.
  88. *
  89. * Tertiary left- and right-hand layer is media and RGB control. This layer is
  90. * symmetrical to accomodate the left- and right-hand trackball.
  91. */
  92. #define LAYOUT_LAYER_MEDIA \
  93. XXXXXXX,RGB_RMOD, RGB_TOG, RGB_MOD, XXXXXXX, XXXXXXX,RGB_RMOD, RGB_TOG, RGB_MOD, XXXXXXX, \
  94. KC_MPRV, KC_VOLD, KC_MUTE, KC_VOLU, KC_MNXT, KC_MPRV, KC_VOLD, KC_MUTE, KC_VOLU, KC_MNXT, \
  95. XXXXXXX, XXXXXXX, XXXXXXX, EE_CLR, QK_BOOT, QK_BOOT, EE_CLR, XXXXXXX, XXXXXXX, XXXXXXX, \
  96. _______, KC_MPLY, KC_MSTP, KC_MSTP, KC_MPLY
  97. /** \brief Mouse emulation and pointer functions. */
  98. #define LAYOUT_LAYER_POINTER \
  99. XXXXXXX, XXXXXXX, XXXXXXX, DPI_MOD, S_D_MOD, S_D_MOD, DPI_MOD, XXXXXXX, XXXXXXX, XXXXXXX, \
  100. ______________HOME_ROW_GACS_L______________, ______________HOME_ROW_GACS_R______________, \
  101. _______, DRGSCRL, SNIPING, EE_CLR, QK_BOOT, QK_BOOT, EE_CLR, SNIPING, DRGSCRL, _______, \
  102. KC_BTN2, KC_BTN1, KC_BTN3, KC_BTN3, KC_BTN1
  103. /**
  104. * \brief Navigation layer.
  105. *
  106. * Primary right-hand layer (left home thumb) is navigation and editing. Cursor
  107. * keys are on the home position, line and page movement below, clipboard above,
  108. * caps lock and insert on the inner column. Thumb keys are duplicated from the
  109. * base layer to avoid having to layer change mid edit and to enable auto-repeat.
  110. */
  111. #define LAYOUT_LAYER_NAVIGATION \
  112. _______________DEAD_HALF_ROW_______________, _______________DEAD_HALF_ROW_______________, \
  113. ______________HOME_ROW_GACS_L______________, KC_CAPS, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, \
  114. _______________DEAD_HALF_ROW_______________, KC_INS, KC_HOME, KC_PGDN, KC_PGUP, KC_END, \
  115. XXXXXXX, _______, XXXXXXX, KC_ENT, KC_BSPC
  116. /**
  117. * \brief Numeral layout.
  118. *
  119. * Primary left-hand layer (right home thumb) is numerals and symbols. Numerals
  120. * are in the standard numpad locations with symbols in the remaining positions.
  121. * `KC_DOT` is duplicated from the base layer.
  122. */
  123. #define LAYOUT_LAYER_NUMERAL \
  124. KC_LBRC, KC_7, KC_8, KC_9, KC_RBRC, _______________DEAD_HALF_ROW_______________, \
  125. KC_SCLN, KC_4, KC_5, KC_6, KC_EQL, ______________HOME_ROW_GACS_R______________, \
  126. KC_GRV, KC_1, KC_2, KC_3, KC_BSLS, _______________DEAD_HALF_ROW_______________, \
  127. KC_DOT, KC_0, KC_MINS, XXXXXXX, _______
  128. /**
  129. * \brief Symbols layer.
  130. *
  131. * Secondary left-hand layer has shifted symbols in the same locations to reduce
  132. * chording when using mods with shifted symbols. `KC_LPRN` is duplicated next to
  133. * `KC_RPRN`.
  134. */
  135. #define LAYOUT_LAYER_SYMBOLS \
  136. KC_LCBR, KC_AMPR, KC_ASTR, KC_LPRN, KC_RCBR, _______________DEAD_HALF_ROW_______________, \
  137. KC_COLN, KC_DLR, KC_PERC, KC_CIRC, KC_PLUS, ______________HOME_ROW_GACS_R______________, \
  138. KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_PIPE, _______________DEAD_HALF_ROW_______________, \
  139. KC_LPRN, KC_RPRN, KC_UNDS, _______, XXXXXXX
  140. /**
  141. * \brief Add Home Row mod to a layout.
  142. *
  143. * Expects a 10-key per row layout. Adds support for GACS (Gui, Alt, Ctl, Shift)
  144. * home row. The layout passed in parameter must contain at least 20 keycodes.
  145. *
  146. * This is meant to be used with `LAYER_ALPHAS_QWERTY` defined above, eg.:
  147. *
  148. * HOME_ROW_MOD_GACS(LAYER_ALPHAS_QWERTY)
  149. */
  150. #define _HOME_ROW_MOD_GACS( \
  151. L00, L01, L02, L03, L04, R05, R06, R07, R08, R09, \
  152. L10, L11, L12, L13, L14, R15, R16, R17, R18, R19, \
  153. ...) \
  154. L00, L01, L02, L03, L04, \
  155. R05, R06, R07, R08, R09, \
  156. LGUI_T(L10), LALT_T(L11), LCTL_T(L12), LSFT_T(L13), L14, \
  157. R15, RSFT_T(R16), RCTL_T(R17), LALT_T(R18), RGUI_T(R19), \
  158. __VA_ARGS__
  159. #define HOME_ROW_MOD_GACS(...) _HOME_ROW_MOD_GACS(__VA_ARGS__)
  160. /**
  161. * \brief Add pointer layer keys to a layout.
  162. *
  163. * Expects a 10-key per row layout. The layout passed in parameter must contain
  164. * at least 30 keycodes.
  165. *
  166. * This is meant to be used with `LAYER_ALPHAS_QWERTY` defined above, eg.:
  167. *
  168. * POINTER_MOD(LAYER_ALPHAS_QWERTY)
  169. */
  170. #define _POINTER_MOD( \
  171. L00, L01, L02, L03, L04, R05, R06, R07, R08, R09, \
  172. L10, L11, L12, L13, L14, R15, R16, R17, R18, R19, \
  173. L20, L21, L22, L23, L24, R25, R26, R27, R28, R29, \
  174. ...) \
  175. L00, L01, L02, L03, L04, \
  176. R05, R06, R07, R08, R09, \
  177. L10, L11, L12, L13, L14, \
  178. R15, R16, R17, R18, R19, \
  179. _L_PTR(L20), L21, L22, L23, L24, \
  180. R25, R26, R27, R28, _L_PTR(R29), \
  181. __VA_ARGS__
  182. #define POINTER_MOD(...) _POINTER_MOD(__VA_ARGS__)
  183. #define LAYOUT_wrapper(...) LAYOUT_charybdis_3x5(__VA_ARGS__)
  184. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  185. [LAYER_BASE] = LAYOUT_wrapper(
  186. POINTER_MOD(HOME_ROW_MOD_GACS(LAYOUT_LAYER_BASE))
  187. ),
  188. [LAYER_FUNCTION] = LAYOUT_wrapper(LAYOUT_LAYER_FUNCTION),
  189. [LAYER_NAVIGATION] = LAYOUT_wrapper(LAYOUT_LAYER_NAVIGATION),
  190. [LAYER_MEDIA] = LAYOUT_wrapper(LAYOUT_LAYER_MEDIA),
  191. [LAYER_NUMERAL] = LAYOUT_wrapper(LAYOUT_LAYER_NUMERAL),
  192. [LAYER_POINTER] = LAYOUT_wrapper(LAYOUT_LAYER_POINTER),
  193. [LAYER_SYMBOLS] = LAYOUT_wrapper(LAYOUT_LAYER_SYMBOLS),
  194. };
  195. // clang-format on
  196. #ifdef POINTING_DEVICE_ENABLE
  197. # ifdef CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  198. report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
  199. if (abs(mouse_report.x) > CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_THRESHOLD || abs(mouse_report.y) > CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_THRESHOLD) {
  200. if (auto_pointer_layer_timer == 0) {
  201. layer_on(LAYER_POINTER);
  202. # ifdef RGB_MATRIX_ENABLE
  203. rgb_matrix_mode_noeeprom(RGB_MATRIX_NONE);
  204. rgb_matrix_sethsv_noeeprom(HSV_GREEN);
  205. # endif // RGB_MATRIX_ENABLE
  206. }
  207. auto_pointer_layer_timer = timer_read();
  208. }
  209. return mouse_report;
  210. }
  211. void matrix_scan_user(void) {
  212. if (auto_pointer_layer_timer != 0 && TIMER_DIFF_16(timer_read(), auto_pointer_layer_timer) >= CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_TIMEOUT_MS) {
  213. auto_pointer_layer_timer = 0;
  214. layer_off(LAYER_POINTER);
  215. # ifdef RGB_MATRIX_ENABLE
  216. rgb_matrix_mode_noeeprom(RGB_MATRIX_STARTUP_MODE);
  217. # endif // RGB_MATRIX_ENABLE
  218. }
  219. }
  220. # endif // CHARYBDIS_AUTO_POINTER_LAYER_TRIGGER_ENABLE
  221. # ifdef CHARYBDIS_AUTO_SNIPING_ON_LAYER
  222. layer_state_t layer_state_set_user(layer_state_t state) {
  223. charybdis_set_pointer_sniping_enabled(layer_state_cmp(state, CHARYBDIS_AUTO_SNIPING_ON_LAYER));
  224. return state;
  225. }
  226. # endif // CHARYBDIS_AUTO_SNIPING_ON_LAYER
  227. #endif // POINTING_DEVICE_ENABLE
  228. #ifdef RGB_MATRIX_ENABLE
  229. // Forward-declare this helper function since it is defined in
  230. // rgb_matrix.c.
  231. void rgb_matrix_update_pwm_buffers(void);
  232. #endif
  233. void shutdown_user(void) {
  234. #ifdef RGBLIGHT_ENABLE
  235. rgblight_enable_noeeprom();
  236. rgblight_mode_noeeprom(RGBLIGHT_MODE_STATIC_LIGHT);
  237. rgblight_setrgb(RGB_RED);
  238. #endif // RGBLIGHT_ENABLE
  239. #ifdef RGB_MATRIX_ENABLE
  240. rgb_matrix_set_color_all(RGB_RED);
  241. rgb_matrix_update_pwm_buffers();
  242. #endif // RGB_MATRIX_ENABLE
  243. }