2
0

keymap.c 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. #include "frosty_flake.h"
  2. #include "action_layer.h"
  3. #include "eeconfig.h"
  4. #include "process_unicode.h"
  5. #include "process_unicodemap.h"
  6. #include "quantum.h"
  7. #define _______ KC_TRNS
  8. #define MAXEMOJITAPS 80
  9. //declarations for tap dancing emojis
  10. void register_hex32(uint32_t hex);
  11. void cycleEmojis(qk_tap_dance_state_t *state, void *user_data);
  12. void cycleAnimals(qk_tap_dance_state_t *state, void *user_data);
  13. void cycleFoods(qk_tap_dance_state_t *state, void *user_data);
  14. void cycleEtc(qk_tap_dance_state_t *state, void *user_data);
  15. void cycleAll(qk_tap_dance_state_t *state, void *user_data);
  16. void tap(uint16_t keycode){
  17. register_code(keycode);
  18. unregister_code(keycode);
  19. };
  20. //Tap Dance Declarations
  21. enum taps{
  22. TD_CTCPS = 0,
  23. EMOJIS,
  24. ANIMAL,
  25. HAND,
  26. MEMES,
  27. COPA,
  28. ALLS
  29. };
  30. enum unicode_name {
  31. EMOTIS = 1,//80, //1F60x - 1F64x
  32. ANIMALS, //64, //1F40x - 1F43x
  33. SYMBOLS,// = 45, //1F300 - 1F32C
  34. FOODS,// = 87 , //1F32D -
  35. ETC,// = 192, //1F44x -1F4Fx
  36. VEHICLES,// = 83, //1F68x - 1F6Dx
  37. SUPPLEMENT,// = 32, //1F91x-1F92x
  38. ALCHEMY,// = 116 //1F70x - 1F773
  39. };
  40. enum my_macros {
  41. NEWDESK = 0,
  42. LEFTDESK,
  43. RIGHTDESK,
  44. CLOSEDESK
  45. };
  46. // Tap Dance Definitions
  47. qk_tap_dance_action_t tap_dance_actions[] = {
  48. // Tap once for CTRL, twice for Caps Lock
  49. [TD_CTCPS] = ACTION_TAP_DANCE_DOUBLE(KC_LCTL, KC_CAPS),
  50. [COPA] = ACTION_TAP_DANCE_DOUBLE(LCTL(KC_C), LCTL(KC_V)),
  51. [EMOJIS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleEmojis, NULL, NULL, 800),
  52. [ANIMAL] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleAnimals, NULL, NULL, 800),
  53. //[SYMBOLS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleSymbols, NULL, NULL, 800),
  54. [FOODS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleFoods, NULL, NULL, 800),
  55. [ETC] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleEtc, NULL, NULL, 800),
  56. //[VEHICLES] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleVehicles, NULL, NULL, 800),
  57. //[SUPPLEMENT] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleSupplement, NULL, NULL, 800),
  58. [ALLS] = ACTION_TAP_DANCE_FN_ADVANCED_TIME(cycleAll, NULL, NULL, 800)
  59. // Other declarations would go here, separated by commas, if you have them
  60. };
  61. // macros
  62. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
  63. switch(id) {
  64. case NEWDESK: // this would trigger when you hit a key mapped as M(0)
  65. if (record->event.pressed) {
  66. return MACRO( I(1), D(LGUI), D(LCTL), D(D), U(LGUI), U(LCTL), U(D), END ); // NEW DESKTOP
  67. }
  68. break;
  69. case LEFTDESK: // this would trigger when you hit a key mapped as M(0)
  70. if (record->event.pressed) {
  71. return MACRO( I(1), D(LGUI), D(LCTL), D(LEFT), U(LGUI), U(LCTL), U(LEFT), END ); // LEFT DESKTOP
  72. }
  73. break;
  74. case RIGHTDESK: // this would trigger when you hit a key mapped as M(0)
  75. if (record->event.pressed) {
  76. return MACRO( I(1), D(LGUI), D(LCTL), D(RGHT), U(LGUI), U(LCTL), U(RGHT), END ); // RIGHT DESKTOP
  77. }
  78. break;
  79. case CLOSEDESK: // this would trigger when you hit a key mapped as M(0)
  80. if (record->event.pressed) {
  81. return MACRO( I(1), D(LGUI), D(LCTL), D(F4), U(LGUI), U(LCTL), U(F4), END ); // CLOSE DESKTOP
  82. }
  83. break;
  84. }
  85. return MACRO_NONE;
  86. };
  87. // emojis in unicode
  88. const uint32_t PROGMEM unicode_map[] = {
  89. [EMOTIS] = 0x1F600,
  90. [ANIMALS] = 0x1F400,
  91. [SYMBOLS] = 0x1F300,
  92. [FOODS] = 0x1F32D,
  93. [ETC] = 0x1F440,
  94. [VEHICLES] = 0x1F680,
  95. [SUPPLEMENT] = 0x1F910,
  96. [ALCHEMY] = 0x1F700
  97. };
  98. // Layouts
  99. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  100. [0] = KEYMAP(\
  101. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  102. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,KC_MINS, KC_EQL,KC_BSPC, KC_INS,KC_HOME,KC_PGUP, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  103. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,KC_LBRC,KC_RBRC,KC_BSLS, KC_DEL, KC_END,KC_PGDN, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  104. KC_LCTL, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L,KC_SCLN,KC_QUOT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  105. KC_LSPO,KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_SLSH, KC_RSPC, KC_UP, KC_P1, KC_P2, KC_P3,KC_PENT, \
  106. TD(TD_CTCPS),KC_LGUI,KC_LALT, KC_SPC, KC_LEAD,KC_RGUI, KC_APP,MO(1) , KC_LEFT,KC_DOWN,KC_RGHT, KC_P0,KC_PDOT),
  107. [1] = KEYMAP(\
  108. TD(ALLS), KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  109. KC_GRV, TD(EMOJIS),TD(ANIMAL),TD(ETC),TD(FOODS), KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,KC_MINS, KC_EQL,KC_BSPC, KC_MPRV,KC_MPLY,KC_MNXT, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  110. KC_TAB, KC_Q, M(0), KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_UP ,KC_RBRC,KC_BSLS, KC_MUTE,KC_VOLD,KC_VOLU, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  111. KC_LCTL, M(1), M(3), M(2), KC_F, KC_G, KC_H, KC_J, KC_K, KC_L,KC_LEFT,KC_RGHT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  112. KC_LSFT,KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_DOWN, KC_RSFT, KC_MS_U, KC_P1, KC_P2, KC_P3,KC_PENT, \
  113. KC_BTN1,KC_BTN3,KC_BTN2, KC_SPC, KC_RALT,KC_RGUI, TG(2),_______ , KC_MS_L,KC_MS_D,KC_MS_R, KC_P0,KC_PDOT),
  114. [2] = KEYMAP(\
  115. KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_PSCR,KC_SLCK,KC_PAUS, \
  116. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,KC_MINS, KC_EQL,KC_BSPC, KC_MPRV,KC_MPLY,KC_MNXT, KC_NLCK,KC_PSLS,KC_PAST,KC_PMNS, \
  117. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,KC_LBRC,KC_RBRC,KC_BSLS, KC_MUTE,KC_VOLD,KC_VOLU, KC_P7, KC_P8, KC_P9,KC_PPLS, \
  118. KC_LCTL, KC_D, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L,KC_SCLN,KC_QUOT, KC_ENT, KC_P4, KC_P5, KC_P6, \
  119. KC_LSFT,KC_NUBS, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_SLSH, KC_RSFT, KC_MS_U, KC_P1, KC_P2, KC_P3,KC_PENT, \
  120. KC_BTN1,KC_BTN3,KC_BTN2, KC_SPC, KC_RALT,KC_RGUI, TG(2) , KC_NO , KC_MS_L,KC_MS_D,KC_MS_R, KC_P0,KC_PDOT),
  121. };
  122. LEADER_EXTERNS();
  123. void matrix_scan_user(void) {
  124. LEADER_DICTIONARY() {
  125. leading = false;
  126. leader_end();
  127. SEQ_TWO_KEYS(KC_A, KC_A) { // select all and copy
  128. register_code(KC_LCTL);
  129. tap(KC_A);
  130. tap(KC_C);
  131. unregister_code(KC_LCTL);
  132. }
  133. }
  134. }
  135. void matrix_init_user(void) {
  136. _delay_ms(500);
  137. set_unicode_input_mode(UC_WINC);
  138. };
  139. void cycleAll(qk_tap_dance_state_t *state, void *user_data) {
  140. if(state->count == 1) {
  141. unicode_input_start();
  142. register_hex32(pgm_read_dword(&unicode_map[EMOTIS]));
  143. unicode_input_finish();
  144. }
  145. else if(state->count <= 1642) {
  146. tap(KC_BSPC);
  147. unicode_input_start();
  148. register_hex32(pgm_read_dword(&unicode_map[1])+state->count);
  149. unicode_input_finish();
  150. }
  151. };
  152. void cycleEmojis(qk_tap_dance_state_t *state, void *user_data) {
  153. if(state->count == 1) {
  154. unicode_input_start();
  155. register_hex32(pgm_read_dword(&unicode_map[EMOTIS]));
  156. unicode_input_finish();
  157. }
  158. else if(state->count <= 80) {
  159. tap(KC_BSPC);
  160. unicode_input_start();
  161. register_hex32(pgm_read_dword(&unicode_map[EMOTIS])+state->count);
  162. unicode_input_finish();
  163. }
  164. };
  165. void cycleAnimals(qk_tap_dance_state_t *state, void *user_data) {
  166. if(state->count == 1) {
  167. unicode_input_start();
  168. register_hex32(pgm_read_dword(&unicode_map[ANIMALS]));
  169. unicode_input_finish();
  170. }
  171. else if(state->count <= MAXEMOJITAPS) {
  172. tap(KC_BSPC);
  173. unicode_input_start();
  174. register_hex32(pgm_read_dword(&unicode_map[ANIMALS])+state->count);
  175. unicode_input_finish();
  176. }
  177. };
  178. void cycleFoods(qk_tap_dance_state_t *state, void *user_data) {
  179. if(state->count == 1) {
  180. unicode_input_start();
  181. register_hex32(pgm_read_dword(&unicode_map[FOODS]));
  182. unicode_input_finish();
  183. }
  184. else if(state->count <= 87) {
  185. tap(KC_BSPC);
  186. unicode_input_start();
  187. register_hex32(pgm_read_dword(&unicode_map[FOODS])+state->count);
  188. unicode_input_finish();
  189. }
  190. };
  191. void cycleEtc(qk_tap_dance_state_t *state, void *user_data) {
  192. if(state->count == 1) {
  193. unicode_input_start();
  194. register_hex32(pgm_read_dword(&unicode_map[ETC]));
  195. unicode_input_finish();
  196. }
  197. else if(state->count <= MAXEMOJITAPS) {
  198. tap(KC_BSPC);
  199. unicode_input_start();
  200. register_hex32(pgm_read_dword(&unicode_map[ETC])+state->count);
  201. unicode_input_finish();
  202. }
  203. };