keymap.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. #include "mini.h"
  2. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  3. KEYMAP(
  4. LT(3, KC_MSTP), KC_VOLU, KC_MPLY, KC_MPRV, KC_VOLD, KC_MNXT),
  5. KEYMAP(
  6. LT(3, KC_ESC), M(3), M(4), M(5), M(6), M(7)),
  7. KEYMAP(
  8. LT(3, KC_1), KC_2, KC_3, KC_4, M(0), M(1)),
  9. KEYMAP(
  10. KC_TRNS, KC_TRNS, RESET, TO(0), TO(1), TO(2)),
  11. KEYMAP(
  12. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  13. KEYMAP(
  14. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  15. KEYMAP(
  16. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  17. KEYMAP(
  18. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  19. KEYMAP(
  20. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  21. KEYMAP(
  22. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  23. KEYMAP(
  24. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  25. KEYMAP(
  26. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  27. KEYMAP(
  28. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  29. KEYMAP(
  30. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  31. KEYMAP(
  32. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  33. KEYMAP(
  34. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS)
  35. };
  36. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt) {
  37. //keyevent_t event = record->event;
  38. switch (id) {
  39. case 0:
  40. if (record->event.pressed) {
  41. return MACRO( T(T), T(G), T(L), T(H), T(F), T(ENT), END );
  42. }
  43. break;
  44. case 1:
  45. if (record->event.pressed) {
  46. return MACRO( T(T), T(G), T(G), T(ENT), END );
  47. }
  48. break;
  49. case 2:
  50. if (record->event.pressed) {
  51. return MACRO( D(NO), T(L), U(NO), END );
  52. }
  53. break;
  54. case 3:
  55. if (record->event.pressed) {
  56. return MACRO( D(LCTL), T(Z), U(LCTL), END );
  57. }
  58. break;
  59. case 4:
  60. if (record->event.pressed) {
  61. return MACRO( D(LCTL), D(LSFT), T(Z), U(LSFT), U(LCTL), END );
  62. }
  63. break;
  64. case 5:
  65. if (record->event.pressed) {
  66. return MACRO( D(LCTL), T(X), U(LCTL), END );
  67. }
  68. break;
  69. case 6:
  70. if (record->event.pressed) {
  71. return MACRO( D(LCTL), T(C), U(LCTL), END );
  72. }
  73. break;
  74. case 7:
  75. if (record->event.pressed) {
  76. return MACRO( D(LCTL), T(V), U(LCTL), END );
  77. }
  78. break;
  79. }
  80. return MACRO_NONE;
  81. }
  82. void set_switch_led(int ledId, bool state) {
  83. if(state) {
  84. switch(ledId) {
  85. case 1:
  86. PORTD |= (1<<7);
  87. break;
  88. case 2:
  89. PORTC |= (1<<6);
  90. break;
  91. case 3:
  92. PORTD |= (1<<4);
  93. break;
  94. case 4:
  95. PORTE |= (1<<6);
  96. break;
  97. case 5:
  98. PORTB |= (1<<4);
  99. break;
  100. case 6:
  101. PORTD |= (1<<6);
  102. break;
  103. }
  104. } else {
  105. switch(ledId) {
  106. case 1:
  107. PORTD &= ~(1<<7);
  108. break;
  109. case 2:
  110. PORTC &= ~(1<<6);
  111. break;
  112. case 3:
  113. PORTD &= ~(1<<4);
  114. break;
  115. case 4:
  116. PORTE &= ~(1<<6);
  117. break;
  118. case 5:
  119. PORTB &= ~(1<<4);
  120. break;
  121. case 6:
  122. PORTD &= ~(1<<6);
  123. break;
  124. }
  125. }
  126. }
  127. void set_layer_led(int layerId) {
  128. PORTD |= (1<<5);
  129. PORTB &= ~(1<<6);
  130. PORTB |= (1<<0);
  131. switch(layerId) {
  132. case 0:
  133. PORTD &= ~(1<<5);
  134. break;
  135. case 1:
  136. PORTB |= (1<<6);
  137. break;
  138. case 2:
  139. PORTB &= ~(1<<0);
  140. break;
  141. }
  142. }
  143. void matrix_init_user(void) {
  144. led_init_ports();
  145. PORTD |= (1<<7);
  146. PORTC |= (1<<6);
  147. PORTD |= (1<<4);
  148. PORTE |= (1<<6);
  149. PORTB |= (1<<4);
  150. PORTD |= (1<<6);
  151. set_layer_led(0);
  152. }
  153. void matrix_scan_user(void) {
  154. }
  155. void led_init_ports() {
  156. // led voor switch #1
  157. DDRD |= (1<<7);
  158. PORTD &= ~(1<<7);
  159. // led voor switch #2
  160. DDRC |= (1<<6);
  161. PORTC &= ~(1<<6);
  162. // led voor switch #3
  163. DDRD |= (1<<4);
  164. PORTD &= ~(1<<4);
  165. // led voor switch #4
  166. DDRE |= (1<<6);
  167. PORTE &= ~(1<<6);
  168. // led voor switch #5
  169. DDRB |= (1<<4);
  170. PORTB &= ~(1<<4);
  171. // led voor switch #6
  172. DDRD |= (1<<6);
  173. PORTD &= ~(1<<6);
  174. /*
  175. DDRD |= (1<<7);
  176. PORTD |= (1<<7);
  177. DDRC |= (1<<6);
  178. PORTC |= (1<<6);
  179. DDRD |= (1<<4);
  180. PORTD |= (1<<4);
  181. DDRE |= (1<<6);
  182. PORTE |= (1<<6);
  183. DDRB |= (1<<4);
  184. PORTB |= (1<<4);
  185. DDRD |= (1<<6);
  186. PORTD |= (1<<6);
  187. // */
  188. DDRD |= (1<<5);
  189. DDRB |= (1<<6);
  190. DDRB |= (1<<0);
  191. //led_set_layer(0);
  192. }
  193. void led_set_user(uint8_t usb_led) {
  194. if (usb_led & (1 << USB_LED_NUM_LOCK)) {
  195. } else {
  196. }
  197. if (usb_led & (1 << USB_LED_CAPS_LOCK)) {
  198. } else {
  199. }
  200. if (usb_led & (1 << USB_LED_SCROLL_LOCK)) {
  201. } else {
  202. }
  203. if (usb_led & (1 << USB_LED_COMPOSE)) {
  204. } else {
  205. }
  206. if (usb_led & (1 << USB_LED_KANA)) {
  207. } else {
  208. }
  209. }
  210. /*
  211. * NOTE:
  212. *
  213. * In case you don't understand this coding stuff, please
  214. * feel free to mail me or post something
  215. * at the /r/knops subreddit and I will configure the code as
  216. * you wish for your needs to make the LEDs do what you want :-).
  217. *
  218. * Contact me at: support@knops.io
  219. *
  220. *
  221. * Knops Mini LED Numbers:
  222. * _____ _____ _____
  223. * | | | | | |
  224. * | 1 | | 2 | | 3 | <---
  225. * |_____| |_____| |_____| | These LEDs are called 'Switch LEDs'
  226. * _____ _____ _____ |----- To turn on/off these leds, use:
  227. * | | | | | | | set_switch_led( [1-6], [true/false]);
  228. * | 4 | | 5 | | 6 | <---
  229. * |_____| |_____| |_____|
  230. *
  231. * < 0 > < 1 > < 2 > <--- These front-LEDs are called 'Layer LEDs'
  232. * To turn one of them on, use:
  233. * set_layer_led( [0-2] );
  234. *
  235. */
  236. /*
  237. * This function led_set_layer gets called when you switch between layers.
  238. * It allows you to turn on and off leds for each different layer and do
  239. * other cool stuff. Currently the GUI does not have LED support. I am working
  240. * on that, but takes time.
  241. */
  242. void led_set_layer(int layer) {
  243. switch(layer) {
  244. /**
  245. * Here is an example to turn LEDs on and of. By default:
  246. * - the LEDs are turned on in layer 0
  247. * - the LEDs are turned off in layer 1
  248. * - the LEDs don't change from state for layer 2
  249. */
  250. case 0:
  251. set_layer_led(0); // Turn on only the first/left layer indicator
  252. set_switch_led(1, true);
  253. set_switch_led(2, true);
  254. set_switch_led(3, true);
  255. set_switch_led(4, true);
  256. set_switch_led(5, true);
  257. set_switch_led(6, true);
  258. break;
  259. case 1:
  260. set_layer_led(1); // Turn on only the second/middle layer indicator
  261. set_switch_led(1, false);
  262. set_switch_led(2, false);
  263. set_switch_led(3, false);
  264. set_switch_led(4, false);
  265. set_switch_led(5, false);
  266. set_switch_led(6, false);
  267. break;
  268. case 2:
  269. set_layer_led(2); // Turn on only the third/right layer indicator
  270. // Keep leds for layer two in their current state, since we don't use set_switch_led(SWITCH_ID, TRUE_OR_FALSE)
  271. break;
  272. }
  273. }
  274. bool process_record_user (uint16_t keycode, keyrecord_t *record) {
  275. switch(keycode) {
  276. case TO(0):
  277. if (record->event.pressed) {
  278. led_set_layer(0);
  279. }
  280. break;
  281. case TO(1):
  282. if (record->event.pressed) {
  283. led_set_layer(1);
  284. }
  285. break;
  286. case TO(2):
  287. if (record->event.pressed) {
  288. led_set_layer(2);
  289. }
  290. break;
  291. }
  292. return true;
  293. }