2
0

keymap.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650
  1. #include "helix.h"
  2. #include "bootloader.h"
  3. #include "action_layer.h"
  4. #include "eeconfig.h"
  5. #ifdef PROTOCOL_LUFA
  6. #include "lufa.h"
  7. #include "split_util.h"
  8. #endif
  9. #include "LUFA/Drivers/Peripheral/TWI.h"
  10. #ifdef AUDIO_ENABLE
  11. #include "audio.h"
  12. #endif
  13. #ifdef SSD1306OLED
  14. #include "ssd1306.h"
  15. #endif
  16. extern keymap_config_t keymap_config;
  17. #ifdef RGBLIGHT_ENABLE
  18. //Following line allows macro to read current RGB settings
  19. extern rgblight_config_t rgblight_config;
  20. #endif
  21. extern uint8_t is_master;
  22. #define DELAY_TIME 75
  23. static uint16_t key_timer;
  24. static uint16_t tap_timer;
  25. static uint16_t delay_registered_code;
  26. static uint8_t delay_mat_row;
  27. static uint8_t delay_mat_col;
  28. static bool delay_key_stat;
  29. static bool delay_key_pressed;
  30. static bool tapping_key;
  31. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  32. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  33. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  34. // entirely and just use numbers.
  35. #define _BASE 0
  36. #define _OPT 1
  37. #define _FUNC 2
  38. #define _SYM 3
  39. #define _NUM 4
  40. bool RGBAnimation = false; //Flag for LED Layer color Refresh.
  41. enum custom_keycodes {
  42. QWERTY = SAFE_RANGE,
  43. EISU,
  44. KANA,
  45. RGBRST,
  46. RGBOFF,
  47. RGB1,
  48. RGB2,
  49. RGB3,
  50. OPT_TAP_SP,
  51. DESKTOP,
  52. MAC,
  53. WIN,
  54. };
  55. enum macro_keycodes {
  56. KC_SAMPLEMACRO,
  57. };
  58. // Fillers to make layering more clear
  59. #define _______ KC_TRNS
  60. #define XXXXXXX KC_NO
  61. //Macros
  62. #define M_SAMPLE M(KC_SAMPLEMACRO)
  63. #if HELIX_ROWS == 5
  64. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  65. /* Base
  66. * ,-----------------------------------------. ,-----------------------------------------.
  67. * | C+z | ; | [ | ( | < | { | | | | | | | |
  68. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  69. * | KANA | P | K | R | A | F | | | | | | | |
  70. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  71. * | BS | D | T | H | E | O | | | | | | | |
  72. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  73. * | Shift| Y | S | N | I | U |Space | | | | | | | |
  74. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  75. * | Ctrl | Alt | win | Sym | Num | OPT | Ent | | | | | | | |
  76. * `-------------------------------------------------------------------------------------------------'
  77. */
  78. [_BASE] = KEYMAP( \
  79. LCTL(KC_Z), KC_SCLN, KC_LBRC, KC_LPRN, KC_LT, KC_LCBR, _______, _______, _______, _______, _______, _______, \
  80. KANA, KC_P, KC_K, KC_R, KC_A, KC_F, _______, _______, _______, _______, _______, _______, \
  81. KC_BSPC, KC_D, KC_T, KC_H, KC_E, KC_O, _______, _______, _______, _______, _______, _______, \
  82. OSM(MOD_LSFT), KC_Y, KC_S, KC_N, KC_I, KC_U, KC_SPC, _______, _______, _______, _______, _______, _______, _______, \
  83. OSM(MOD_LCTL), OSM(MOD_LALT), OSM(MOD_LGUI), MO(_SYM), MO(_NUM), OPT_TAP_SP, KC_ENT, _______, _______, _______, _______, _______, _______, _______ \
  84. ),
  85. /* Opt
  86. * ,-----------------------------------------. ,-----------------------------------------.
  87. * | Esc | : | ] | ) | > | } | | | | | | | |
  88. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  89. * | EISU| J | M | B | ' | Tab | | | | | | | |
  90. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  91. * | . | V | C | L | Z | Q | | | | | | | |
  92. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  93. * | | X | G | W | - | Del | Esc | | | | | | | |
  94. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  95. * | | | | , | DTOP | | | | | | | | | |
  96. * `-------------------------------------------------------------------------------------------------'
  97. */
  98. [_OPT] = KEYMAP( \
  99. KC_ESC, KC_COLN,KC_RBRC, KC_RPRN,KC_GT, KC_RCBR, _______, _______, _______, _______, _______, _______, \
  100. EISU, KC_J, KC_M, KC_B, KC_QUOT, KC_TAB, _______, _______, _______, _______, _______, _______, \
  101. KC_DOT, KC_V, KC_C, KC_L, KC_Z, KC_Q, _______, _______, _______, _______, _______, _______, \
  102. _______, KC_X, KC_G, KC_W, KC_MINUS, KC_DEL, KC_ESC, _______, _______, _______, _______, _______, _______, _______, \
  103. _______, _______,_______, KC_COMM,DESKTOP, _______, _______, _______, _______, _______, _______, _______, _______, _______ \
  104. ),
  105. /* Func
  106. * ,-----------------------------------------. ,-----------------------------------------.
  107. * |RGBRST| Hue | | RST | Mac | Win | | | | | | | |
  108. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  109. * | RGB1 | VAL+ | F7 | F8 | F9 | | | | | | | | |
  110. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  111. * | RGB2 | VAL- | F4 | F5 | F6 | F12 | | | | | | | |
  112. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  113. * | RGB3 | F10 | F1 | F2 | F3 | F11 | | | | | | | | |
  114. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  115. * |RGBOFF| | | | | | | | | | | | | |
  116. * `-------------------------------------------------------------------------------------------------'
  117. */
  118. [_FUNC] = KEYMAP( \
  119. RGBRST,RGB_HUI, _______, RESET, MAC, WIN, _______, _______, _______, _______, _______, _______, \
  120. RGB1, RGB_VAI, KC_F7, KC_F8, KC_F9, _______, _______, _______, _______, _______, _______, _______, \
  121. RGB2, RGB_VAD, KC_F4, KC_F5, KC_F6, KC_F12, _______, _______, _______, _______, _______, _______, \
  122. RGB3, KC_F10, KC_F1, KC_F2, KC_F3, KC_F11, _______, _______, _______, _______, _______, _______, _______, _______, \
  123. RGBOFF,_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ \
  124. ),
  125. /* Sym
  126. * ,-----------------------------------------. ,-----------------------------------------.
  127. * | Ins | GRV | | PU | PD | ^ | | | | | | | |
  128. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  129. * | | \ | # | = | ? | % | | | | | | | |
  130. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  131. * | | $ | upA | @ | ! | | | | | | | | | |
  132. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  133. * | CL | <- | dwA | -> | _ | & | | | | | | | | |
  134. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  135. * | | | PS | | ~ | | | | | | | | | |
  136. * `-------------------------------------------------------------------------------------------------'
  137. */
  138. [_SYM] = KEYMAP( \
  139. KC_INS, KC_GRV, _______, KC_PGUP, KC_PGDN, KC_CIRC, _______, _______, _______, _______, _______, _______, \
  140. _______, KC_BSLS, KC_HASH, KC_EQL, KC_QUES, KC_PERC, _______, _______, _______, _______, _______, _______, \
  141. _______, KC_DLR, KC_UP, KC_AT, KC_EXLM, KC_PIPE, _______, _______, _______, _______, _______, _______, \
  142. KC_CAPS, KC_LEFT, KC_DOWN, KC_RIGHT,KC_UNDS, KC_AMPR, _______, _______, _______, _______, _______, _______, _______, _______, \
  143. _______, _______, KC_PSCR, _______, KC_TILD, _______, _______, _______, _______, _______, _______, _______, _______, _______ \
  144. ),
  145. /* Raise
  146. * ,-----------------------------------------. ,-----------------------------------------.
  147. * | | | Func | home | End | | | | | | | | |
  148. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  149. * | | * | 7 | 8 | 9 | - | | | | | | | |
  150. * |------+------+------+------+------+------| |------+------+------+------+------+------|
  151. * | . | / | 4 | 5 | 6 | + | | | | | | | |
  152. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  153. * | LN | 0 | 1 | 2 | 3 |C+S+F1| | | | | | | | |
  154. * |------+------+------+------+------+------+------+------+------+------+------+------+------+------|
  155. * | | | | , | | | | | | | | | | |
  156. * `-------------------------------------------------------------------------------------------------'
  157. */
  158. [_NUM] = KEYMAP( \
  159. _______, _______, OSL(_FUNC), KC_HOME, KC_END, _______, _______, _______, _______, _______, _______, _______, \
  160. _______, KC_ASTR, KC_P7, KC_P8, KC_P9, KC_MINS, _______, _______, _______, _______, _______, _______, \
  161. KC_PDOT, KC_SLSH, KC_P4, KC_P5, KC_P6, KC_PLUS, _______, _______, _______, _______, _______, _______, \
  162. KC_NLCK, KC_P0, KC_P1, KC_P2, KC_P3, LCTL(S(KC_F1)), _______, _______, _______, _______, _______, _______, _______, _______, \
  163. _______, _______, KC_PDOT, KC_COMM, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ \
  164. )
  165. };
  166. #else
  167. #error "undefined keymaps"
  168. #endif
  169. #ifdef AUDIO_ENABLE
  170. float tone_qwerty[][2] = SONG(QWERTY_SOUND);
  171. float tone_dvorak[][2] = SONG(DVORAK_SOUND);
  172. float tone_colemak[][2] = SONG(COLEMAK_SOUND);
  173. float tone_plover[][2] = SONG(PLOVER_SOUND);
  174. float tone_plover_gb[][2] = SONG(PLOVER_GOODBYE_SOUND);
  175. float music_scale[][2] = SONG(MUSIC_SCALE_SOUND);
  176. #endif
  177. // define variables for reactive RGB
  178. //bool TOG_STATUS = false;
  179. int RGB_current_mode;
  180. void persistent_default_layer_set(uint16_t default_layer) {
  181. eeconfig_update_default_layer(default_layer);
  182. default_layer_set(default_layer);
  183. }
  184. bool find_mairix(uint16_t keycode, uint8_t *row, uint8_t *col){
  185. for(uint8_t i=0; i<MATRIX_ROWS; i++){
  186. for(uint8_t j=0; j<MATRIX_COLS; j++){
  187. if( pgm_read_word(&(keymaps[_BASE][i][j]))==keycode){
  188. *row = i;
  189. *col = j;
  190. return true;
  191. }
  192. }
  193. }
  194. return false;
  195. }
  196. void unregister_delay_code(void){
  197. if(delay_registered_code){
  198. unregister_code(delay_registered_code);
  199. if (delay_registered_code & QK_LSFT){
  200. unregister_code(KC_LSFT);
  201. }
  202. if (delay_registered_code & QK_LCTL){
  203. unregister_code(KC_LCTL);
  204. }
  205. if (delay_registered_code & QK_LALT){
  206. unregister_code(KC_LALT);
  207. }
  208. if (delay_registered_code & QK_LGUI){
  209. unregister_code(KC_LGUI);
  210. }
  211. delay_registered_code=0;
  212. }
  213. }
  214. void register_delay_code(uint8_t layer){
  215. if(delay_key_stat){
  216. unregister_delay_code();
  217. uint16_t code = pgm_read_word(&(keymaps[layer][delay_mat_row][delay_mat_col]));
  218. if (code & QK_LSFT){
  219. register_code(KC_LSFT);
  220. }
  221. if (code & QK_LCTL){
  222. register_code(KC_LCTL);
  223. }
  224. if (code & QK_LALT){
  225. register_code(KC_LALT);
  226. }
  227. if (code & QK_LGUI){
  228. register_code(KC_LGUI);
  229. }
  230. register_code(code);
  231. delay_registered_code = code;
  232. delay_key_stat = false;
  233. tapping_key = true;
  234. }
  235. }
  236. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  237. if(tap_timer&&keycode!=OPT_TAP_SP){
  238. tapping_key = true;
  239. }
  240. if(keycode==delay_registered_code){
  241. if (!record->event.pressed){
  242. unregister_delay_code();
  243. }
  244. }
  245. switch (keycode) {
  246. case KC_SCLN:
  247. case KC_LBRC:
  248. case KC_LPRN:
  249. case KC_LT:
  250. case KC_LCBR:
  251. case KC_P:
  252. case KC_K:
  253. case KC_R:
  254. case KC_A:
  255. case KC_F:
  256. case KC_BSPC:
  257. case KC_D:
  258. case KC_T:
  259. case KC_H:
  260. case KC_E:
  261. case KC_O:
  262. case KC_Y:
  263. case KC_S:
  264. case KC_N:
  265. case KC_I:
  266. case KC_U:
  267. case LCTL(KC_Z):
  268. case KC_SPC:
  269. if (record->event.pressed) {
  270. register_delay_code(_BASE);
  271. if(find_mairix(keycode, &delay_mat_row, &delay_mat_col)){
  272. key_timer = timer_read();
  273. delay_key_stat = true;
  274. delay_key_pressed = true;
  275. }
  276. }else{
  277. delay_key_pressed = false;
  278. }
  279. return false;
  280. break;
  281. case OPT_TAP_SP:
  282. if (record->event.pressed) {
  283. tapping_key = false;
  284. register_delay_code(_OPT);
  285. layer_on(_OPT);
  286. tap_timer = timer_read();
  287. }else{
  288. layer_off(_OPT);
  289. if(tapping_key==false && timer_elapsed(tap_timer) < TAPPING_TERM){
  290. SEND_STRING(" ");
  291. }
  292. tap_timer = 0;
  293. }
  294. return false;
  295. break;
  296. case EISU:
  297. if (record->event.pressed) {
  298. if(keymap_config.swap_lalt_lgui==false){
  299. register_code(KC_LANG2);
  300. }else{
  301. SEND_STRING(SS_LALT("`"));
  302. }
  303. } else {
  304. unregister_code(KC_LANG2);
  305. }
  306. return false;
  307. break;
  308. case KANA:
  309. if (record->event.pressed) {
  310. if(keymap_config.swap_lalt_lgui==false){
  311. register_code(KC_LANG1);
  312. }else{
  313. SEND_STRING(SS_LALT("`"));
  314. }
  315. } else {
  316. unregister_code(KC_LANG1);
  317. }
  318. return false;
  319. break;
  320. case DESKTOP:
  321. if (record->event.pressed) {
  322. if(keymap_config.swap_lalt_lgui==false){
  323. register_code(KC_F11);
  324. }else{
  325. SEND_STRING(SS_LGUI("d"));
  326. }
  327. } else {
  328. unregister_code(KC_F11);
  329. }
  330. return false;
  331. break;
  332. case RGBRST:
  333. #ifdef RGBLIGHT_ENABLE
  334. if (record->event.pressed) {
  335. eeconfig_update_rgblight_default();
  336. rgblight_enable();
  337. RGB_current_mode = rgblight_config.mode;
  338. RGBAnimation = false;
  339. }
  340. #endif
  341. break;
  342. case RGBOFF:
  343. #ifdef RGBLIGHT_ENABLE
  344. if (record->event.pressed) {
  345. rgblight_disable();
  346. }
  347. #endif
  348. break;
  349. case RGB1:
  350. #ifdef RGBLIGHT_ENABLE
  351. if (record->event.pressed) {
  352. RGBAnimation = true;
  353. rgblight_mode(6);
  354. RGB_current_mode = rgblight_config.mode;
  355. }
  356. #endif
  357. break;
  358. case RGB2:
  359. #ifdef RGBLIGHT_ENABLE
  360. if (record->event.pressed) {
  361. RGBAnimation = true;
  362. rgblight_mode(10);
  363. RGB_current_mode = rgblight_config.mode;
  364. }
  365. #endif
  366. break;
  367. case RGB3:
  368. #ifdef RGBLIGHT_ENABLE
  369. if (record->event.pressed) {
  370. RGBAnimation = true;
  371. rgblight_mode(21);
  372. RGB_current_mode = rgblight_config.mode;
  373. }
  374. #endif
  375. break;
  376. case MAC:
  377. if (record->event.pressed) {
  378. keymap_config.swap_lalt_lgui = false;
  379. keymap_config.swap_ralt_rgui = false;
  380. #ifdef AUDIO_ENABLE
  381. PLAY_SONG(ag_norm_song);
  382. #endif
  383. }
  384. break;
  385. case WIN:
  386. if (record->event.pressed) {
  387. keymap_config.swap_lalt_lgui = true;
  388. keymap_config.swap_ralt_rgui = true;
  389. #ifdef AUDIO_ENABLE
  390. PLAY_SONG(ag_swap_song);
  391. #endif
  392. }
  393. break;
  394. }
  395. return true;
  396. }
  397. //keyboard start-up code. Runs once when the firmware starts up.
  398. void matrix_init_user(void) {
  399. #ifdef AUDIO_ENABLE
  400. startup_user();
  401. #endif
  402. #ifdef RGBLIGHT_ENABLE
  403. RGB_current_mode = rgblight_config.mode;
  404. #endif
  405. //SSD1306 OLED init, make sure to add #define SSD1306OLED in config.h
  406. #ifdef SSD1306OLED
  407. TWI_Init(TWI_BIT_PRESCALE_1, TWI_BITLENGTH_FROM_FREQ(1, 800000));
  408. iota_gfx_init(!has_usb()); // turns on the display
  409. #endif
  410. }
  411. #ifdef AUDIO_ENABLE
  412. void startup_user()
  413. {
  414. _delay_ms(20); // gets rid of tick
  415. }
  416. void shutdown_user()
  417. {
  418. _delay_ms(150);
  419. stop_all_notes();
  420. }
  421. void music_on_user(void)
  422. {
  423. music_scale_user();
  424. }
  425. void music_scale_user(void)
  426. {
  427. PLAY_SONG(music_scale);
  428. }
  429. #endif
  430. //assign the right code to your layers for OLED display
  431. #define L_BASE 0
  432. #define L_OPT 2
  433. #define L_FUNC 4
  434. #define L_SYM 8
  435. #define L_NUM 16
  436. #define L_FNLAYER 64
  437. #define L_NUMLAY 128
  438. #define L_NLOWER 136
  439. #define L_NFNLAYER 192
  440. #define L_MOUSECURSOR 256
  441. uint8_t layer_state_old;
  442. //runs every scan cycle (a lot)
  443. void matrix_scan_user(void) {
  444. #ifdef SSD1306OLED
  445. iota_gfx_task(); // this is what updates the display continuously
  446. #endif
  447. if(delay_key_stat && (timer_elapsed(key_timer) > DELAY_TIME)){
  448. register_delay_code(_BASE);
  449. if(!delay_key_pressed){
  450. unregister_delay_code();
  451. }
  452. }
  453. if(layer_state_old != layer_state){
  454. switch (layer_state) {
  455. case L_BASE:
  456. #ifdef RGBLIGHT_ENABLE
  457. if (!RGBAnimation){
  458. rgblight_sethsv(187,255,255);
  459. rgblight_mode(1);
  460. }else{
  461. rgblight_mode(RGB_current_mode);
  462. }
  463. #endif
  464. break;
  465. case L_OPT:
  466. register_delay_code(_OPT);
  467. break;
  468. case L_NUM:
  469. register_delay_code(_NUM);
  470. #ifdef RGBLIGHT_ENABLE
  471. rgblight_sethsv(25,255,255);
  472. rgblight_mode(1);
  473. #endif
  474. break;
  475. case L_SYM:
  476. register_delay_code(_SYM);
  477. #ifdef RGBLIGHT_ENABLE
  478. rgblight_sethsv(96,255,255);
  479. rgblight_mode(1);
  480. #endif
  481. break;
  482. case L_FUNC:
  483. register_delay_code(_FUNC);
  484. #ifdef RGBLIGHT_ENABLE
  485. rgblight_sethsv(331,255,255);
  486. rgblight_mode(1);
  487. #endif
  488. break;
  489. }
  490. layer_state_old = layer_state;
  491. }
  492. }
  493. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  494. #ifdef SSD1306OLED
  495. void matrix_update(struct CharacterMatrix *dest,
  496. const struct CharacterMatrix *source) {
  497. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  498. memcpy(dest->display, source->display, sizeof(dest->display));
  499. dest->dirty = true;
  500. }
  501. }
  502. // Render to OLED
  503. void render_status(struct CharacterMatrix *matrix) {
  504. // froggy logo
  505. static char logo[4][1][17]=
  506. {
  507. {
  508. {0x65,0x66,0x67,0x68,0x69,0x6a,0x6b,0x6c,0x6d,0x6e,0x6f,0x70,0x71,0x72,0x73,0x74,0}
  509. },
  510. {
  511. {0x85,0x86,0x87,0x88,0x89,0x8a,0x8b,0x8c,0x8d,0x8e,0x8f,0x90,0x91,0x92,0x93,0x94,0}
  512. },
  513. {
  514. {0xa5,0xa6,0xa7,0xa8,0xa9,0xaa,0xab,0xac,0xad,0xae,0xaf,0xb0,0xb1,0xb2,0xb3,0xb4,0}
  515. },
  516. {
  517. {0xc5,0xc6,0xc7,0xc8,0xc9,0xca,0xcb,0xcc,0xcd,0xce,0xcf,0xd0,0xd1,0xd2,0xd3,0}
  518. }
  519. };
  520. static char indctr[8][2][4]=
  521. {
  522. // white icon
  523. {
  524. {0x60,0x61,0x62,0},
  525. {0x63,0x64,0}
  526. },
  527. {
  528. {0x80,0x81,0x82,0},
  529. {0x83,0x84,0}
  530. },
  531. {
  532. {0xa0,0xa1,0xa2,0},
  533. {0xa3,0xa4,0}
  534. },
  535. {
  536. {0xc0,0xc1,0xc2,0},
  537. {0xc3,0xc4,0}
  538. },
  539. // Black icon
  540. {
  541. {0x75,0x76,0x77,0},
  542. {0x78,0x79,0}
  543. },
  544. {
  545. {0x95,0x96,0x97,0},
  546. {0x98,0x99,0}
  547. },
  548. {
  549. {0xb5,0xb6,0xb7,0},
  550. {0xb8,0xb9,0}
  551. },
  552. {
  553. {0xd5,0xd6,0xd7,0},
  554. {0xd8,0xd9,0}
  555. },
  556. };
  557. int rown = 0;
  558. int rowf = 0;
  559. int rowa = 0;
  560. int rows = 0;
  561. //Set Indicator icon
  562. if (host_keyboard_leds() & (1<<USB_LED_NUM_LOCK)) { rown = 4; } else { rown = 0; }
  563. if (host_keyboard_leds() & (1<<USB_LED_CAPS_LOCK)) { rowa = 4; } else { rowa = 0; }
  564. if (host_keyboard_leds() & (1<<USB_LED_SCROLL_LOCK)) { rows = 4; } else { rows = 0; }
  565. if (layer_state == L_FUNC) { rowf = 4; }
  566. matrix_write(matrix, indctr[rown] [0]);
  567. matrix_write(matrix, indctr[rowf] [1]);
  568. matrix_write(matrix, logo [0] [0]);
  569. matrix_write(matrix, indctr[rown+1][0]);
  570. matrix_write(matrix, indctr[rowf+1][1]);
  571. matrix_write(matrix, logo [1] [0]);
  572. matrix_write(matrix, indctr[rowa+2][0]);
  573. matrix_write(matrix, indctr[rows+2][1]);
  574. matrix_write(matrix, logo [2] [0]);
  575. matrix_write(matrix, indctr[rowa+3][0]);
  576. matrix_write(matrix, indctr[rows+3][1]);
  577. matrix_write(matrix, logo [3] [0]);
  578. }
  579. void iota_gfx_task_user(void) {
  580. struct CharacterMatrix matrix;
  581. #if DEBUG_TO_SCREEN
  582. if (debug_enable) {
  583. return;
  584. }
  585. #endif
  586. matrix_clear(&matrix);
  587. if(is_master){
  588. render_status(&matrix);
  589. }
  590. matrix_update(&display, &matrix);
  591. }
  592. #endif