keymap.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. // This keymap assumes that the keyboard is recognized as JIS keyboard from the OS.
  2. #include "planck.h"
  3. #include "version.h"
  4. // Keycode defines
  5. #define _______ KC_TRNS
  6. #define XXXXXXX KC_NO
  7. #define C(kc) LCTL(kc)
  8. // JIS keyboard
  9. #define JK_CIRC KC_EQL // ^
  10. #define JK_AT KC_LBRC // @
  11. #define JK_LBRC KC_RBRC // [
  12. #define JK_CLN KC_QUOT // :
  13. #define JK_RBRC KC_BSLS // ]
  14. #define JK_BSLS KC_RO // Backslash(\)
  15. #define JK_DQT S(KC_2) // "
  16. #define JK_AMPR S(KC_6) // &
  17. #define JK_SQT S(KC_7) // '
  18. #define JK_LPRN S(KC_8) // (
  19. #define JK_RPRN S(KC_9) // )
  20. #define JK_S0 S(KC_0) // Tilde(~) at IBM 5576-A01 spec
  21. #define JK_EQ S(KC_MINS) // =
  22. #define JK_TLD S(JK_CIRC) // ~
  23. #define JK_PIPE S(KC_JYEN) // |
  24. #define JK_GRV S(JK_AT) // `
  25. #define JK_LCBR S(JK_LBRC) // {
  26. #define JK_PLUS S(KC_SCLN) // +
  27. #define JK_ASTR S(JK_CLN) // *
  28. #define JK_RCBR S(JK_RBRC) // }
  29. #define JK_QUES S(KC_SLSH) // ?
  30. #define JK_UNDS S(JK_BSLS) // _
  31. enum user_macro {
  32. UM_MHEN,
  33. UM_HENK,
  34. UM_DEBUG,
  35. };
  36. #define M_MHEN MACROTAP(UM_MHEN)
  37. #define M_HENK MACROTAP(UM_HENK)
  38. #define M_DEBUG M(UM_DEBUG)
  39. enum keymap_layer {
  40. KL_QWERTY,
  41. KL_LOWER,
  42. KL_RAISE,
  43. };
  44. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  45. [KL_QWERTY] = {
  46. { KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
  47. {KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, JK_CLN},
  48. {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT},
  49. {KC_ZKHK, KC_KANA, KC_LGUI, KC_LALT, M_MHEN, KC_SPC, KC_SPC, M_HENK, KC_RALT, KC_RGUI, KC_APP, KC_ENT}
  50. },
  51. [KL_LOWER] = {
  52. {KC_GESC, KC_EXLM, JK_DQT, KC_HASH, KC_DLR, KC_PERC, JK_AMPR, JK_SQT, JK_LPRN, JK_RPRN, JK_S0, KC_DEL},
  53. {_______, KC_LEFT, KC_UP, KC_DOWN, KC_RGHT, KC_DEL, KC_BSPC, JK_EQ, JK_TLD, JK_GRV, JK_LCBR, JK_PIPE},
  54. {_______, C(KC_Z), C(KC_X), C(KC_C), C(KC_V), C(KC_Y), XXXXXXX, KC_ENT, KC_LABK, KC_RABK, JK_RCBR, JK_UNDS},
  55. { RESET, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}
  56. },
  57. [KL_RAISE] = {
  58. {KC_CAPS, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_DEL},
  59. {_______, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_MINS, JK_CIRC, JK_AT, JK_LBRC, KC_JYEN},
  60. {_______, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, XXXXXXX, KC_COMM, KC_DOT, JK_RBRC, JK_BSLS},
  61. {M_DEBUG, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}
  62. },
  63. };
  64. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  65. {
  66. dprintf( "record.\n"
  67. " event.pressed = %u\n"
  68. " tap.count = %u\n"
  69. " tap.interrupted = %u\n"
  70. , record->event.pressed
  71. , record->tap.count
  72. , record->tap.interrupted );
  73. dprintf( "id = %u\n", id );
  74. dprintf( "opt = %u\n", opt );
  75. switch(id) {
  76. case UM_MHEN: {
  77. return MACRO_TAP_HOLD_LAYER( record, MACRO(TYPE(KC_MHEN), END), KL_LOWER );
  78. } break;
  79. case UM_HENK: {
  80. return MACRO_TAP_HOLD_LAYER( record, MACRO(TYPE(KC_HENK), END), KL_RAISE );
  81. } break;
  82. case UM_DEBUG: {
  83. if (record->event.pressed) {
  84. debug_enable = !debug_enable;
  85. if (debug_enable) {
  86. dprint("\nDEBUG: enabled.\n");
  87. SEND_STRING (QMK_KEYBOARD "/" QMK_KEYMAP " @ " QMK_VERSION);
  88. }
  89. }
  90. } break;
  91. }
  92. return MACRO_NONE;
  93. };