diff options
| author | XScorpion2 <rcalt2vt@gmail.com> | 2019-07-25 13:56:29 -0500 |
|---|---|---|
| committer | Drashna Jaelre <drashna@live.com> | 2019-07-25 11:56:29 -0700 |
| commit | 20c0533c4c66b9d222b6ced2fad3ec6be6cad76e (patch) | |
| tree | 2cceb641e573cafeb6ee68f5083fb532ab80cd93 /users/xulkal/custom_oled.c | |
| parent | a747953dfae85d3bdfdfe205fc3d4ae6f8d1fe05 (diff) | |
| download | qmk_firmware-20c0533c4c66b9d222b6ced2fad3ec6be6cad76e.tar.gz qmk_firmware-20c0533c4c66b9d222b6ced2fad3ec6be6cad76e.zip | |
[User] Xulkal Keymaps Update (#6392)
* Xulkal changes
Refactor rgb & encoder menu
Hadron Keymap
Refactor oled menu
* Fixing horizontal OLED data display
* Reverting changes to take to separate prs
Diffstat (limited to 'users/xulkal/custom_oled.c')
| -rw-r--r-- | users/xulkal/custom_oled.c | 207 |
1 files changed, 105 insertions, 102 deletions
diff --git a/users/xulkal/custom_oled.c b/users/xulkal/custom_oled.c index 7280ef701..448e6ca10 100644 --- a/users/xulkal/custom_oled.c +++ b/users/xulkal/custom_oled.c | |||
| @@ -3,12 +3,15 @@ | |||
| 3 | 3 | ||
| 4 | #include <stdio.h> | 4 | #include <stdio.h> |
| 5 | 5 | ||
| 6 | #ifdef OLED_DRIVER_ENABLE | ||
| 7 | |||
| 8 | #ifdef RGBLIGHT_ENABLE | 6 | #ifdef RGBLIGHT_ENABLE |
| 9 | rgblight_config_t rgblight_config; | 7 | rgblight_config_t rgblight_config; |
| 10 | #endif | 8 | #endif |
| 11 | 9 | ||
| 10 | #if KEYBOARD_helix_rev2 | ||
| 11 | extern uint8_t is_master; | ||
| 12 | bool is_keyboard_master(void) { return is_master; } | ||
| 13 | #endif | ||
| 14 | |||
| 12 | static void render_logo(void) | 15 | static void render_logo(void) |
| 13 | { | 16 | { |
| 14 | static const char PROGMEM font_logo[] = { | 17 | static const char PROGMEM font_logo[] = { |
| @@ -18,21 +21,38 @@ static void render_logo(void) | |||
| 18 | oled_write_P(font_logo, false); | 21 | oled_write_P(font_logo, false); |
| 19 | } | 22 | } |
| 20 | 23 | ||
| 21 | #if defined(OLED_90ROTATION) | 24 | static void render_icon(void) |
| 22 | |||
| 23 | // TODO: Need to define this function / extern only for helix based split common keyboards | ||
| 24 | extern uint8_t is_master; | ||
| 25 | bool is_keyboard_master(void) | ||
| 26 | { | 25 | { |
| 27 | return is_master; | 26 | #ifdef OLED_90ROTATION |
| 27 | static const char PROGMEM font_icon[] = { | ||
| 28 | 0x9b,0x9c,0x9d,0x9e,0x9f, | ||
| 29 | 0xbb,0xbc,0xbd,0xbe,0xbf, | ||
| 30 | 0xdb,0xdc,0xdd,0xde,0xdf,0 | ||
| 31 | }; | ||
| 32 | #else | ||
| 33 | static const char PROGMEM font_icon[] = { | ||
| 34 | // Use \r (0x0d) to jump to the next line without clearing the rest of the current line | ||
| 35 | 0x9b,0x9c,0x9d,0x9e,0x9f,0x0d, | ||
| 36 | 0xbb,0xbc,0xbd,0xbe,0xbf,0x0d, | ||
| 37 | 0xdb,0xdc,0xdd,0xde,0xdf,0 | ||
| 38 | }; | ||
| 39 | #endif | ||
| 40 | oled_write_P(font_icon, false); | ||
| 28 | } | 41 | } |
| 29 | 42 | ||
| 30 | static void render_layer(uint8_t layer) | 43 | static void render_layer(void) |
| 31 | { | 44 | { |
| 45 | uint8_t layer = layer_state ? biton(layer_state) : biton32(default_layer_state); | ||
| 46 | #ifdef OLED_90ROTATION | ||
| 47 | oled_write_P(PSTR("Layer"), false); | ||
| 48 | #else | ||
| 49 | oled_write_P(PSTR("Layer: "), false); | ||
| 50 | #endif | ||
| 51 | |||
| 32 | switch (layer) | 52 | switch (layer) |
| 33 | { | 53 | { |
| 34 | case _QWERTY: | 54 | case _QWERTY: |
| 35 | oled_write_P(PSTR("DFLT "), false); | 55 | oled_write_P(PSTR("BASE "), false); |
| 36 | break; | 56 | break; |
| 37 | #ifndef GAMELAYER_DISABLE | 57 | #ifndef GAMELAYER_DISABLE |
| 38 | case _GAME: | 58 | case _GAME: |
| @@ -53,125 +73,110 @@ static void render_layer(uint8_t layer) | |||
| 53 | } | 73 | } |
| 54 | } | 74 | } |
| 55 | 75 | ||
| 56 | static void render_status(void) | 76 | static void render_keyboard_leds(void) |
| 57 | { | 77 | { |
| 58 | // Render to mode icon | 78 | // Host Keyboard LED Status |
| 59 | static const char PROGMEM mode_logo[2][4] = { | 79 | uint8_t led_state = host_keyboard_leds(); |
| 60 | {0x97,0x98,0x0a,0}, | 80 | #ifdef OLED_90ROTATION |
| 61 | {0xb7,0xb8,0x0a,0} }; | 81 | oled_write_P(IS_LED_ON(led_state, USB_LED_NUM_LOCK) ? PSTR("NUMLK") : PSTR(" "), false); |
| 62 | 82 | oled_write_P(IS_LED_ON(led_state, USB_LED_CAPS_LOCK) ? PSTR("CAPLK") : PSTR(" "), false); | |
| 63 | oled_write_P(mode_logo[0], false); | 83 | oled_write_P(IS_LED_ON(led_state, USB_LED_SCROLL_LOCK) ? PSTR("SCRLK") : PSTR(" "), false); |
| 64 | oled_write_P(mode_logo[1], false); | 84 | #else |
| 85 | oled_write_P(IS_LED_ON(led_state, USB_LED_NUM_LOCK) ? PSTR("NUM ") : PSTR(" "), false); | ||
| 86 | oled_write_P(IS_LED_ON(led_state, USB_LED_CAPS_LOCK) ? PSTR("CAPS ") : PSTR(" "), false); | ||
| 87 | oled_write_P(IS_LED_ON(led_state, USB_LED_SCROLL_LOCK) ? PSTR("SCRL") : PSTR(" "), false); | ||
| 88 | #endif | ||
| 89 | } | ||
| 65 | 90 | ||
| 66 | oled_write_P(PSTR("Layer"), false); | 91 | #ifdef RGB_OLED_MENU |
| 67 | uint8_t layer = biton(layer_state); | 92 | extern uint8_t rgb_encoder_state; |
| 68 | if (layer != _QWERTY) | 93 | #endif |
| 69 | render_layer(layer); | ||
| 70 | else | ||
| 71 | render_layer(biton32(default_layer_state)); | ||
| 72 | 94 | ||
| 73 | // Host Keyboard LED Status | 95 | #if defined(OLED_90ROTATION) |
| 74 | uint8_t led_usb_state = host_keyboard_leds(); | ||
| 75 | oled_write_P(led_usb_state & (1<<USB_LED_NUM_LOCK) ? PSTR("-----NUMLK") : PSTR("----- "), false); | ||
| 76 | oled_write_P(led_usb_state & (1<<USB_LED_CAPS_LOCK) ? PSTR("CAPLK") : PSTR(" "), false); | ||
| 77 | oled_write_P(led_usb_state & (1<<USB_LED_SCROLL_LOCK) ? PSTR("SCRLK") : PSTR(" "), false); | ||
| 78 | 96 | ||
| 97 | #ifdef RGB_ENABLE | ||
| 98 | static void render_rgb_state(void) | ||
| 99 | { | ||
| 100 | // TODO: need to do a bit more handling here for horizontal rendering | ||
| 79 | #if defined(RGB_MATRIX_ENABLE) | 101 | #if defined(RGB_MATRIX_ENABLE) |
| 80 | oled_set_cursor(0, oled_max_lines() - 7); | 102 | static char buffer[31] = {0}; |
| 81 | oled_write_P(PSTR("-----"), false); | 103 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d e%3d ", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v, rgb_matrix_config.speed, rgb_matrix_config.mode, rgb_matrix_get_flags()); |
| 104 | #elif defined(RGBLIGHT_ENABLE) | ||
| 82 | static char buffer[26] = {0}; | 105 | static char buffer[26] = {0}; |
| 83 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d\n", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v, rgb_matrix_config.speed, rgb_matrix_config.mode); | 106 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d ", rgblight_config.hue, rgblight_config.sat, rgblight_config.val, rgblight_config.speed, rgblight_config.mode); |
| 107 | #endif | ||
| 108 | |||
| 109 | #ifdef RGB_OLED_MENU | ||
| 110 | buffer[4 + rgb_encoder_state * 5] = '<'; | ||
| 111 | #endif | ||
| 84 | oled_write(buffer, false); | 112 | oled_write(buffer, false); |
| 85 | #elif defined(RGBLIGHT_ENABLE) | 113 | } |
| 86 | oled_set_cursor(0, oled_max_lines() - 7); | 114 | #endif |
| 115 | |||
| 116 | static void render_status(void) | ||
| 117 | { | ||
| 118 | render_icon(); | ||
| 119 | render_layer(); | ||
| 120 | |||
| 121 | // Host Keyboard LED Status | ||
| 87 | oled_write_P(PSTR("-----"), false); | 122 | oled_write_P(PSTR("-----"), false); |
| 88 | static char buffer[31] = {0}; | 123 | render_keyboard_leds(); |
| 89 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d\n", rgblight_config.hue, rgblight_config.sat, rgblight_config.val, rgblight_config.speed, rgblight_config.mode); | 124 | |
| 90 | oled_write(buffer, false); | 125 | oled_write_P(PSTR("-----"), false); |
| 126 | #ifdef RGB_ENABLE | ||
| 127 | render_rgb_state(); | ||
| 91 | #endif | 128 | #endif |
| 92 | } | 129 | } |
| 93 | 130 | ||
| 94 | oled_rotation_t oled_init_user(oled_rotation_t rotation) { | 131 | oled_rotation_t oled_init_user(oled_rotation_t rotation) { |
| 132 | #if KEYBOARD_helix_rev2 | ||
| 95 | if (is_keyboard_master()) | 133 | if (is_keyboard_master()) |
| 96 | return OLED_ROTATION_270; | 134 | return OLED_ROTATION_270; |
| 97 | return OLED_ROTATION_180; | 135 | return rotation; |
| 136 | #else | ||
| 137 | if (is_keyboard_master()) | ||
| 138 | return OLED_ROTATION_90; | ||
| 139 | return rotation; | ||
| 140 | #endif | ||
| 98 | } | 141 | } |
| 99 | 142 | ||
| 100 | #else // OLED_90ROTATION | 143 | #else // OLED_90ROTATION |
| 101 | 144 | ||
| 102 | static void render_layer(uint8_t layer) | 145 | #ifdef RGB_ENABLE |
| 146 | static void render_rgb_state(void) | ||
| 103 | { | 147 | { |
| 104 | switch (layer) | 148 | // TODO: need to do a bit more handling here for horizontal rendering |
| 105 | { | 149 | #if defined(RGB_MATRIX_ENABLE) |
| 106 | case _QWERTY: | 150 | static char buffer[37] = {0}; |
| 107 | oled_write_P(PSTR("Default\n"), false); | 151 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d e%3d ", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v, rgb_matrix_config.speed, rgb_matrix_config.mode, rgb_matrix_get_flags()); |
| 108 | break; | 152 | #elif defined(RGBLIGHT_ENABLE) |
| 109 | #ifndef GAMELAYER_DISABLE | 153 | static char buffer[32] = {0}; |
| 110 | case _GAME: | 154 | snprintf(buffer, sizeof(buffer), "h%3d s%3d v%3d s%3d m%3d ", rgblight_config.hue, rgblight_config.sat, rgblight_config.val, rgblight_config.speed, rgblight_config.mode); |
| 111 | oled_write_P(PSTR("Game\n"), false); | ||
| 112 | break; | ||
| 113 | #endif | 155 | #endif |
| 114 | case _LOWER: | 156 | |
| 115 | oled_write_P(PSTR("Lower\n"), false); | 157 | #ifdef RGB_OLED_MENU |
| 116 | break; | 158 | buffer[4 + rgb_encoder_state * 5] = '<'; |
| 117 | case _RAISE: | ||
| 118 | oled_write_P(PSTR("Raise\n"), false); | ||
| 119 | break; | ||
| 120 | #ifdef TRILAYER_ENABLED | ||
| 121 | case _ADJUST: | ||
| 122 | oled_write_P(PSTR("Adjust\n"), false); | ||
| 123 | break; | ||
| 124 | #endif | 159 | #endif |
| 125 | } | 160 | oled_write(buffer, false); |
| 126 | } | 161 | } |
| 162 | #endif | ||
| 127 | 163 | ||
| 128 | static void render_status(void) | 164 | static void render_status(void) |
| 129 | { | 165 | { |
| 130 | // Render to mode icon | 166 | render_icon(); |
| 131 | static const char PROGMEM mode_logo[2][3] = { | ||
| 132 | {0x97,0x98,0}, | ||
| 133 | {0xb7,0xb8,0} | ||
| 134 | }; | ||
| 135 | 167 | ||
| 136 | oled_write_P(mode_logo[0], false); | 168 | // Host Layer Status |
| 169 | oled_set_cursor(6, 0); | ||
| 170 | render_layer(); | ||
| 137 | 171 | ||
| 138 | #if defined(RGB_MATRIX_ENABLE) | 172 | // Host Keyboard LED Status |
| 139 | static char buffer[20] = {0}; | 173 | oled_set_cursor(6, 1); |
| 140 | snprintf(buffer, sizeof(buffer), " h%3d s%3d v%3d\n", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v); | 174 | render_keyboard_leds(); |
| 141 | oled_write(buffer, false); | ||
| 142 | #elif defined(RGBLIGHT_ENABLE) | ||
| 143 | static char buffer[20] = {0}; | ||
| 144 | snprintf(buffer, sizeof(buffer), " h%3d s%3d v%3d\n", rgblight_config.hue, rgblight_config.sat, rgblight_config.val); | ||
| 145 | oled_write(buffer, false); | ||
| 146 | #else | ||
| 147 | oled_write_P(PSTR("\n")); | ||
| 148 | #endif | ||
| 149 | |||
| 150 | oled_write_P(mode_logo[1], false); | ||
| 151 | 175 | ||
| 152 | #if defined(RGB_MATRIX_ENABLE) | 176 | #ifdef RGB_ENABLE |
| 153 | snprintf(buffer, sizeof(buffer), " s%3d m%3d\n", rgb_matrix_config.speed, rgb_matrix_config.mode); | 177 | oled_set_cursor(6, 2); |
| 154 | oled_write(buffer, false); | 178 | render_rgb_state(); |
| 155 | #elif defined(RGBLIGHT_ENABLE) | ||
| 156 | snprintf(buffer, sizeof(buffer), " s%3d m%3d\n", rgblight_config.speed, rgblight_config.mode); | ||
| 157 | oled_write(buffer, false); | ||
| 158 | #else | ||
| 159 | oled_write_P(PSTR("\n")); | ||
| 160 | #endif | 179 | #endif |
| 161 | |||
| 162 | // Define layers here, Have not worked out how to have text displayed for each layer. Copy down the number you see and add a case for it below | ||
| 163 | oled_write_P(PSTR("Layer: "), false); | ||
| 164 | uint8_t layer = biton(layer_state); | ||
| 165 | if (layer != _QWERTY) | ||
| 166 | render_layer(layer); | ||
| 167 | else | ||
| 168 | render_layer(biton32(default_layer_state)); | ||
| 169 | |||
| 170 | // Host Keyboard LED Status | ||
| 171 | uint8_t led_usb_state = host_keyboard_leds(); | ||
| 172 | oled_write_P(led_usb_state & (1<<USB_LED_NUM_LOCK) ? PSTR("NUMLCK ") : PSTR(" "), false); | ||
| 173 | oled_write_P(led_usb_state & (1<<USB_LED_CAPS_LOCK) ? PSTR("CAPLCK ") : PSTR(" "), false); | ||
| 174 | oled_write_P(led_usb_state & (1<<USB_LED_SCROLL_LOCK) ? PSTR("SCRLCK ") : PSTR(" "), false); | ||
| 175 | } | 180 | } |
| 176 | 181 | ||
| 177 | #endif // OLED_90ROTATION | 182 | #endif // OLED_90ROTATION |
| @@ -186,5 +191,3 @@ void oled_task_user(void) | |||
| 186 | oled_scroll_left(); | 191 | oled_scroll_left(); |
| 187 | } | 192 | } |
| 188 | } | 193 | } |
| 189 | |||
| 190 | #endif | ||
