/keyboards/keebio/iris/keymaps/ave-63/keymap.c

https://github.com/qmk/qmk_firmware · C · 120 lines · 101 code · 8 blank · 11 comment · 16 complexity · ed485bc4ea6e53636aaeef4262a7f410 MD5 · raw file

  1. /* Features of this keymap:
  2. --Lots of functionality on left hand for conjunction with mouse or pen in right hand
  3. --_COMMAND layer ESDF arrow keys
  4. --_MEH layer ESDF is super handy for switching tabs (SF) and apps (ED)
  5. --_MEH layer other keys are linked with my AutoHotKey script
  6. --macro for handling parentheses is very nice (credit: u/drashna)
  7. Some things are very non-standard, like position of number keys, etc.
  8. Will require heavy modification for most people.
  9. */
  10. #include QMK_KEYBOARD_H
  11. extern keymap_config_t keymap_config;
  12. #define MODS_SHIFT_MASK (MOD_BIT(KC_LSHIFT)|MOD_BIT(KC_RSHIFT))
  13. enum my_layers {
  14. _QWERTY,
  15. _SYMBOL,
  16. _COMMAND,
  17. _MEH
  18. };
  19. enum custom_keycodes {
  20. KC_MPRN = SAFE_RANGE,
  21. KC_MBRC,
  22. KC_MCBR,
  23. KC_MABK
  24. };
  25. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  26. [_QWERTY] = LAYOUT(
  27. KC_ESC, KC_GRV, KC_AT, KC_BSLS, KC_NO, TG(_SYMBOL), KC_NO, KC_LGUI, KC_MBRC, KC_RBRC, KC_NO, KC_DEL,
  28. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC,
  29. KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, MO(_SYMBOL),
  30. KC_LALT, KC_Z, KC_X, KC_C, KC_V, KC_B, MO(_MEH), KC_QUOT, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT,
  31. KC_NO, KC_LSFT, MO(_COMMAND), KC_ENT, KC_SPC, KC_NO
  32. ),
  33. [_SYMBOL] = LAYOUT(
  34. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  35. KC_TRNS, KC_EQL, KC_9, KC_8, KC_7, KC_PLUS, KC_HASH, KC_UNDS, KC_MCBR, KC_RCBR, KC_TRNS, KC_TRNS,
  36. KC_TRNS, KC_0, KC_6, KC_5, KC_4, KC_MINS, KC_CIRC, KC_AMPR, KC_MPRN, KC_RPRN, KC_RBRC, KC_TRNS,
  37. KC_TRNS, KC_SLSH, KC_3, KC_2, KC_1, KC_ASTR, KC_TRNS, KC_TRNS, KC_EXLM, KC_DLR, KC_MABK, KC_TRNS, KC_TRNS, KC_TRNS,
  38. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
  39. ),
  40. [_COMMAND] = LAYOUT(
  41. KC_APP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  42. KC_TRNS, KC_PGUP, KC_HOME, KC_UP, KC_END, KC_VOLU, KC_SLCK, KC_F9, KC_F10, KC_F11, KC_F12, KC_TRNS,
  43. KC_TRNS, KC_PGDN, KC_LEFT, KC_DOWN, KC_RGHT, KC_VOLD, KC_CAPS, KC_F5, KC_F6, KC_F7, KC_F8, KC_TRNS,
  44. KC_TRNS, KC_TRNS, KC_TRNS, KC_PSCR, KC_TRNS, KC_MUTE, KC_TRNS, KC_TRNS, KC_PAUS, KC_F1, KC_F2, KC_F3, KC_F4, KC_TRNS,
  45. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
  46. ),
  47. [_MEH] = LAYOUT(
  48. LALT(KC_F4), KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, RESET,
  49. KC_TRNS, MEH(KC_Q), LCTL(KC_W), LSFT(KC_TAB), KC_DEL, MEH(KC_T), KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  50. KC_TRNS, MEH(KC_A),LSFT(LCTL(KC_TAB)),KC_TAB,LCTL(KC_TAB),MEH(KC_G), KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  51. KC_TRNS,MEH(KC_Z),MEH(KC_X),MEH(KC_C),MEH(KC_V),MEH(KC_B),KC_TRNS,KC_TRNS,KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  52. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
  53. )
  54. };
  55. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  56. static uint16_t code_timer;
  57. switch (keycode) {
  58. case KC_MCBR:
  59. if(record->event.pressed){
  60. code_timer= timer_read();
  61. SEND_STRING("{");
  62. } else {
  63. if (timer_elapsed(code_timer) > TAPPING_TERM) {
  64. SEND_STRING("}" SS_TAP(X_LEFT));
  65. }
  66. }
  67. return false;
  68. break;
  69. case KC_MBRC:
  70. if(record->event.pressed){
  71. code_timer= timer_read();
  72. SEND_STRING("[");
  73. } else {
  74. if (timer_elapsed(code_timer) > TAPPING_TERM) {
  75. SEND_STRING("]" SS_TAP(X_LEFT));
  76. }
  77. }
  78. return false;
  79. break;
  80. case KC_MPRN:
  81. if(record->event.pressed){
  82. code_timer= timer_read();
  83. SEND_STRING("(");
  84. } else {
  85. if (timer_elapsed(code_timer) > TAPPING_TERM) {
  86. SEND_STRING(")" SS_TAP(X_LEFT));
  87. }
  88. }
  89. return false;
  90. break;
  91. case KC_MABK:
  92. if(record->event.pressed){
  93. code_timer= timer_read();
  94. if (get_mods() & MODS_SHIFT_MASK){
  95. SEND_STRING("<");
  96. } else {
  97. SEND_STRING(",");
  98. }
  99. } else {
  100. if (timer_elapsed(code_timer) > TAPPING_TERM) {
  101. if (get_mods() & MODS_SHIFT_MASK){
  102. SEND_STRING(">" SS_TAP(X_LEFT));
  103. }
  104. }
  105. }
  106. return false;
  107. break;
  108. }
  109. return true;
  110. }