keymap.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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 "arrow_pad.h"
  4. #include "led.h"
  5. // This is the 21-key keypad to 2x11 element matrix mapping
  6. #define KEYMAP( \
  7. KM_ESC, KM_TAB, KM_BSL, KM_ARR, \
  8. KM_NUM, KM_FSL, KM_AST, KM_MIN, \
  9. KM___7, KM___8, KM___9, ___PLS, \
  10. KM___4, KM___5, KM___6, KM_PLS, \
  11. KM___1, KM___2, KM___3, ___ENT, \
  12. KM___0, _____0, KM_DOT, KM_ENT \
  13. ) { \
  14. { KM_ESC, KM_TAB, KM_BSL, KM_ARR, KM___7, KM___8, KM___9, KM_PLS, KM___1, KM___2, KM___3, }, \
  15. { KM_NUM, KM_FSL, KM_AST, KM_MIN, KM___4, KM___5, KM___6, KM_ENT, KC_NO, KM___0, KM_DOT, }, \
  16. }
  17. #define LAYER_BASE 0
  18. #define LAYER_EDIT 1
  19. #define LAYER_FUNCTION 2
  20. #define MACRO_COPY_CUT 0
  21. #define MACRO_SHIFT_CONTROL 1
  22. #define MACRO_CONTROL_ALT 2
  23. #define M_COPY KC_FN5
  24. #define M_SHFCT KC_FN6
  25. #define M_CTALT KC_FN7
  26. #define SC_UNDO LCTL(KC_Z)
  27. #define SC_REDO LCTL(KC_Y)
  28. #define SC_CUT LCTL(KC_X)
  29. #define SC_COPY LCTL(KC_C)
  30. #define SC_PSTE LCTL(KC_V)
  31. #define SC_SELA LCTL(KC_A)
  32. #define SC_SAVE LCTL(KC_S)
  33. #define SC_OPEN LCTL(KC_O)
  34. #define SC_ACLS LALT(KC_F4)
  35. #define SC_CCLS LCTL(KC_F4)
  36. #define _______ KC_TRNS
  37. #define XXXXXXX KC_NO
  38. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  39. [LAYER_BASE] = KEYMAP( \
  40. KC_ESC, KC_TAB, KC_BSLS, KC_FN0, \
  41. KC_NLCK, KC_PSLS, KC_PAST, KC_PMNS, \
  42. KC_P7, KC_P8, KC_P9, XXXXXXX, \
  43. KC_P4, KC_P5, KC_P6, KC_PPLS, \
  44. KC_P1, KC_P2, KC_P3, XXXXXXX, \
  45. KC_P0, XXXXXXX, KC_PDOT, KC_PENT ),
  46. [LAYER_EDIT] = KEYMAP( \
  47. KC_ESC, KC_TAB, KC_SPC, _______, \
  48. KC_FN1, SC_PSTE, SC_REDO, SC_UNDO, \
  49. KC_HOME, KC_UP, KC_PGUP, XXXXXXX, \
  50. KC_LEFT, M_COPY, KC_RGHT, M_CTALT, \
  51. KC_END, KC_DOWN, KC_PGDN, XXXXXXX, \
  52. KC_BSPC, XXXXXXX, KC_DEL, M_SHFCT),
  53. [LAYER_FUNCTION] = KEYMAP( \
  54. KC_FN2, KC_FN3, KC_FN4, _______, \
  55. KC_FN1, _______, _______, _______, \
  56. _______, _______, _______, XXXXXXX, \
  57. _______, _______, _______, _______, \
  58. _______, _______, _______, XXXXXXX, \
  59. RESET, XXXXXXX, _______, _______ ),
  60. };
  61. const uint16_t PROGMEM fn_actions[] = {
  62. [0] = ACTION_LAYER_MOMENTARY(LAYER_FUNCTION),
  63. [1] = ACTION_LAYER_TOGGLE(LAYER_EDIT),
  64. [2] = ACTION_BACKLIGHT_TOGGLE(),
  65. [3] = ACTION_BACKLIGHT_INCREASE(),
  66. [4] = ACTION_BACKLIGHT_DECREASE(),
  67. [5] = ACTION_MACRO_TAP(MACRO_COPY_CUT),
  68. [6] = ACTION_MACRO_TAP(MACRO_SHIFT_CONTROL),
  69. [7] = ACTION_MACRO_TAP(MACRO_CONTROL_ALT),
  70. };
  71. void action_function(keyrecord_t *record, uint8_t id, uint8_t opt)
  72. {
  73. }
  74. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  75. {
  76. // MACRODOWN only works in this function
  77. switch (id) {
  78. case MACRO_COPY_CUT:
  79. if (record->event.pressed) {
  80. register_code(KC_LCTL);
  81. if (record->tap.count == 1) {
  82. register_code(KC_C);
  83. unregister_code(KC_C);
  84. }
  85. else if (record->tap.count == 2) {
  86. register_code(KC_X);
  87. unregister_code(KC_X);
  88. }
  89. unregister_code(KC_LCTL);
  90. }
  91. break;
  92. case MACRO_SHIFT_CONTROL:
  93. if (record->event.pressed) {
  94. if (record->tap.count <= 2) register_mods(MOD_BIT(KC_LSFT));
  95. if (record->tap.count == 2) register_mods(MOD_BIT(KC_LCTL));
  96. if (record->tap.count == 3) register_code(KC_PENT);;
  97. }
  98. else {
  99. unregister_mods(MOD_BIT(KC_LSFT) | MOD_BIT(KC_LCTL));
  100. unregister_code(KC_PENT);
  101. }
  102. break;
  103. case MACRO_CONTROL_ALT:
  104. if (record->event.pressed) {
  105. if (record->tap.count < 2) register_mods(MOD_BIT(KC_LCTL));
  106. if (record->tap.count >= 2) register_mods(MOD_BIT(KC_LALT));
  107. }
  108. else {
  109. unregister_mods(MOD_BIT(KC_LCTL) | MOD_BIT(KC_LALT));
  110. }
  111. break;
  112. }
  113. return MACRO_NONE;
  114. }
  115. void led_set_user(uint8_t usb_led)
  116. {
  117. if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
  118. // output high
  119. DDRD |= (1<<6);
  120. PORTD |= (1<<6);
  121. } else {
  122. // Hi-Z
  123. DDRD &= ~(1<<6);
  124. PORTD &= ~(1<<6);
  125. }
  126. if (usb_led & (1<<USB_LED_NUM_LOCK)) {
  127. // output low
  128. DDRC |= (1<<7);
  129. PORTC |= ~(1<<7);
  130. } else {
  131. // Hi-Z
  132. DDRC &= ~(1<<7);
  133. PORTC &= ~(1<<7);
  134. }
  135. }