You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

162 lines
4.6 KiB

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