forked from mirrors/qmk_firmware
87 lines
2.2 KiB
C
87 lines
2.2 KiB
C
#ifdef OLED_ENABLE
|
|
#include QMK_KEYBOARD_H
|
|
#ifdef PROTOCOL_LUFA
|
|
#include "lufa.h"
|
|
#include "split_util.h"
|
|
#endif
|
|
|
|
// When add source files to SRC in rules.mk, you can use functions.
|
|
const char *read_logo(void);
|
|
const char *read_keylog(void);
|
|
const char *read_keylogs(void);
|
|
void set_keylog(uint16_t keycode, keyrecord_t *record);
|
|
|
|
void matrix_scan_user(void) { iota_gfx_task(); }
|
|
|
|
typedef struct {
|
|
uint8_t state;
|
|
char name[8];
|
|
} LAYER_DISPLAY_NAME;
|
|
|
|
#define LAYER_DISPLAY_MAX 5
|
|
const LAYER_DISPLAY_NAME layer_display_name[LAYER_DISPLAY_MAX] = {
|
|
{0, "Base"},
|
|
{2, "Code"},
|
|
{4, "Fn"},
|
|
{6, "Fn+Code"},
|
|
{__UINT8_MAX__, "?"},
|
|
};
|
|
static uint8_t layer_name_idx;
|
|
static char layer_status_buf[24] = "Layer: Base\n";
|
|
|
|
#ifdef RGBLIGHT_ENABLE
|
|
// Following line allows macro to read current RGB settings
|
|
extern rgblight_config_t rgblight_config;
|
|
void update_keymap_status(void) {
|
|
snprintf(layer_status_buf, sizeof(layer_status_buf) - 1, "Layer:%s RGB: %d\n",
|
|
layer_display_name[layer_name_idx].name, rgblight_config.mode);
|
|
}
|
|
#else
|
|
void update_keymap_status(void) {
|
|
snprintf(layer_status_buf, sizeof(layer_status_buf) - 1, "Layer:%s\n",
|
|
layer_display_name[layer_name_idx].name);
|
|
}
|
|
#endif
|
|
|
|
void matrix_init_user(void) {
|
|
update_keymap_status();
|
|
}
|
|
|
|
// declared in users/rs/rs.c
|
|
void rgb_mod_changed_keymap(void) {
|
|
update_keymap_status();
|
|
}
|
|
|
|
// declared in users/rs/rs.c
|
|
void keylog_set_keymap(uint16_t keycode, keyrecord_t *record) {
|
|
set_keylog(keycode, record);
|
|
}
|
|
|
|
layer_state_t layer_state_set_user(layer_state_t state) {
|
|
for (layer_name_idx = 0; layer_name_idx < LAYER_DISPLAY_MAX; ++layer_name_idx) {
|
|
if (state == 0 && layer_display_name[layer_name_idx].state == default_layer_state) {
|
|
break;
|
|
} else if (state != 0 && layer_display_name[layer_name_idx].state == state) {
|
|
break;
|
|
}
|
|
}
|
|
update_keymap_status();
|
|
return state;
|
|
}
|
|
|
|
static inline void render_keymap_status(struct CharacterMatrix *matrix) {
|
|
oled_write(layer_status_buf);
|
|
}
|
|
|
|
bool oled_task_user(void) {
|
|
if (is_keyboard_master()) {
|
|
render_keymap_status(matrix);
|
|
oled_write_ln(read_keylog(), false);
|
|
oled_write_ln(read_keylogs(), false);
|
|
} else {
|
|
oled_write(read_logo(), false);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
#endif
|