keymap.c 6.2 KB

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