keymap.c 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. // This is the canonical layout file for the Quantum project. If you want to add another keyboard,
  2. // this is the style you want to emulate.
  3. #include "planck.h"
  4. #include "action_layer.h"
  5. #include "eeconfig.h"
  6. #ifdef BACKLIGHT_ENABLE
  7. #include "backlight.h"
  8. #endif
  9. extern keymap_config_t keymap_config;
  10. // Symbolic names for macro IDs.
  11. #define _QWERTY 0 // QUERTY layer
  12. #define _RAISE 1 // Raise layer
  13. #define _LOWER 2 // Lower layer
  14. #define _CUSTOM 3 // Custom layer
  15. #define _BL 4 // Backlight
  16. #define _MOBILE 5 // Mobile#
  17. #define _CUSTOM1 6 // Custom macro 1
  18. #define _CUSTOM2 7 // Custom macro 2
  19. // Macro shortcuts.
  20. #define RAISE M(_RAISE)
  21. #define LOWER M(_LOWER)
  22. #define CUSTOM M(_CUSTOM) // RAISE + LOWER
  23. #define BL M(_BL)
  24. #define MOBILE M(_MOBILE)
  25. #define CUSTOM1 M(_CUSTOM1)
  26. #define CUSTOM2 M(_CUSTOM2)
  27. // This config can be found at Keyboard layout editor site: http://goo.gl/zjXL2l
  28. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  29. [_QWERTY] = { /* QWERTY */
  30. {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
  31. {KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT},
  32. {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, FUNC(3)},
  33. {KC_LCTL, KC_ESC, KC_LGUI, KC_LALT, RAISE, KC_SPC, KC_SPC, LOWER, KC_LEFT, KC_UP, KC_DOWN, KC_RGHT}
  34. },
  35. [_RAISE] = { /* RAISE */
  36. {KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL},
  37. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LPRN, KC_RPRN, KC_LCBR, KC_RCBR, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS},
  38. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LBRC, KC_RBRC, KC_QUOT, KC_DQT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS},
  39. {BL, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGUP, KC_PGUP, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS}
  40. },
  41. [_LOWER] = { /* LOWER */
  42. {KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12},
  43. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LCBR, KC_LCBR, KC_BSLS, KC_TRNS},
  44. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_GRV, KC_TILD, KC_BSLS, KC_PIPE, KC_LBRC, KC_LBRC, KC_TRNS, KC_TRNS},
  45. {RESET, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_PGDN, KC_PGDN, KC_TRNS, KC_TRNS, KC_VOLD, KC_VOLU, KC_MUTE}
  46. },
  47. [_CUSTOM] = { /* CUSTOM */
  48. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, 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},
  50. {KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, MOBILE, KC_TRNS, CUSTOM1, CUSTOM2, 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, KC_TRNS, KC_TRNS}
  52. }
  53. };
  54. // Enable these functions using FUNC(n) macro. They seem to be buggy mostly.
  55. const uint16_t PROGMEM fn_actions[] = {
  56. [0] = ACTION_LAYER_TAP_KEY(_RAISE, KC_PGUP), // Tap for PgUp, hold for RAISE
  57. [1] = ACTION_LAYER_TAP_KEY(_LOWER, KC_PGDN), // Tap for PgDn, hold for LOWER
  58. [2] = ACTION_MODS_TAP_KEY(MOD_LCTL, KC_CAPS), // Tap for Caps, hold for Ctrl
  59. [3] = ACTION_MODS_TAP_KEY(MOD_RSFT, KC_ENT), // Tap for Enter, hold for Shift
  60. };
  61. // Set a layer persistantly.
  62. void persistant_default_layer_set(uint16_t default_layer) {
  63. eeconfig_update_default_layer(default_layer);
  64. default_layer_set(default_layer);
  65. }
  66. // Macro actions for each corresponding ID.
  67. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  68. {
  69. switch(id) {
  70. case _QWERTY: // Default QWERTY layer. // This case not used for now.
  71. if (record->event.pressed) {
  72. persistant_default_layer_set(1UL<<_QWERTY);
  73. }
  74. break;
  75. case _RAISE: // Raised layer.
  76. if (record->event.pressed) {
  77. layer_on(_RAISE);
  78. update_tri_layer(_LOWER, _RAISE, _CUSTOM);
  79. } else {
  80. layer_off(_RAISE);
  81. update_tri_layer(_LOWER, _RAISE, _CUSTOM);
  82. }
  83. break;
  84. case _LOWER: // Lowered layer.
  85. if (record->event.pressed) {
  86. layer_on(_LOWER);
  87. update_tri_layer(_LOWER, _RAISE, _CUSTOM);
  88. } else {
  89. layer_off(_LOWER);
  90. update_tri_layer(_LOWER, _RAISE, _CUSTOM);
  91. }
  92. break;
  93. case _BL:// Backlight
  94. if (record->event.pressed) {
  95. register_code(KC_RSFT);
  96. #ifdef BACKLIGHT_ENABLE
  97. backlight_step();
  98. #endif
  99. } else {
  100. unregister_code(KC_RSFT);
  101. }
  102. break;
  103. case _MOBILE:// Your mobile# here.
  104. return MACRODOWN(T(1), T(2), T(3), T(MINS),
  105. T(1), T(2), T(3), T(MINS),
  106. T(1), T(2), T(3), T(4),
  107. END);
  108. case _CUSTOM1:// Your custom macro 1
  109. return MACRODOWN(T(E), T(M), T(A), T(C), T(S), T(SPC), END);
  110. case _CUSTOM2:// Your custom macro 2
  111. return MACRODOWN(T(L), T(S), T(SPC), T(MINS), T(L), T(ENT), END);
  112. };
  113. return MACRO_NONE;
  114. }