forked from mirrors/qmk_userspace
[Keymap] Add oled improvements and cnano keymap for drashna (#16133)
This commit is contained in:
parent
3555ee0555
commit
941b1d35b8
22 changed files with 797 additions and 189 deletions
|
@ -105,16 +105,9 @@ void matrix_scan_user(void) {
|
|||
run_diablo_macro_check();
|
||||
#endif // TAP_DANCE_ENABLE
|
||||
|
||||
#if defined(RGBLIGHT_ENABLE)
|
||||
matrix_scan_rgb_light();
|
||||
#endif // RGBLIGHT_ENABLE
|
||||
#if defined(RGB_MATRIX_ENABLE)
|
||||
matrix_scan_rgb_matrix();
|
||||
#endif
|
||||
#if defined(POINTING_DEVICE_ENABLE)
|
||||
matrix_scan_pointing();
|
||||
#endif
|
||||
|
||||
matrix_scan_secret();
|
||||
|
||||
matrix_scan_keymap();
|
||||
|
|
|
@ -279,7 +279,7 @@
|
|||
# define OLED_DISPLAY_WIDTH 128
|
||||
# define OLED_DISPLAY_HEIGHT 128
|
||||
# define OLED_MATRIX_SIZE (OLED_DISPLAY_HEIGHT / 8 * OLED_DISPLAY_WIDTH)
|
||||
# define OLED_BLOCK_TYPE uint16_t
|
||||
# define OLED_BLOCK_TYPE uint32_t
|
||||
# define OLED_SOURCE_MAP \
|
||||
{ 0, 8, 16, 24, 32, 40, 48, 56 }
|
||||
# define OLED_TARGET_MAP \
|
||||
|
@ -288,4 +288,7 @@
|
|||
# define OLED_BLOCK_SIZE (OLED_MATRIX_SIZE / OLED_BLOCK_COUNT)
|
||||
# define OLED_COM_PINS COM_PINS_ALT
|
||||
# define OLED_IC OLED_IC_SH1107
|
||||
# ifndef OLED_BRIGHTNESS
|
||||
# define OLED_BRIGHTNESS 50
|
||||
# endif
|
||||
#endif
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
# include "autocorrection/autocorrection.h"
|
||||
#endif
|
||||
#ifdef __AVR__
|
||||
#include <avr/wdt.h>
|
||||
# include <avr/wdt.h>
|
||||
#endif
|
||||
|
||||
uint16_t copy_paste_timer;
|
||||
|
@ -36,7 +36,7 @@ __attribute__((weak)) bool process_record_secrets(uint16_t keycode, keyrecord_t
|
|||
* @return true Continue processing keycode and send to host
|
||||
* @return false Stop process keycode and do not send to host
|
||||
*/
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||
bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
||||
// If console is enabled, it will print the matrix position and status of each key pressed
|
||||
#ifdef KEYLOGGER_ENABLE
|
||||
uprintf("KL: kc: 0x%04X, col: %2u, row: %2u, pressed: %b, time: %5u, int: %b, count: %u\n", keycode, record->event.key.col, record->event.key.row, record->event.pressed, record->event.time, record->tap.interrupted, record->tap.count);
|
||||
|
@ -234,7 +234,6 @@ bool process_record_user(uint16_t keycode, keyrecord_t *re
|
|||
software_reset();
|
||||
}
|
||||
return false;
|
||||
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -181,7 +181,6 @@ bool process_record_aussie(uint16_t keycode, keyrecord_t *record) {
|
|||
bool process_record_zalgo(uint16_t keycode, keyrecord_t *record) {
|
||||
if ((KC_A <= keycode) && (keycode <= KC_0)) {
|
||||
if (record->event.pressed) {
|
||||
|
||||
tap_code16_nomods(keycode);
|
||||
|
||||
int number = (rand() % (8 + 1 - 2)) + 2;
|
||||
|
@ -285,13 +284,11 @@ bool process_record_unicode(uint16_t keycode, keyrecord_t *record) {
|
|||
} else if (typing_mode == KC_ZALGO) {
|
||||
return process_record_zalgo(keycode, record);
|
||||
}
|
||||
return process_unicode_common(keycode, record);
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Initialize the default unicode mode on firmware startu
|
||||
*
|
||||
*/
|
||||
void matrix_init_unicode(void) {
|
||||
unicode_input_mode_init();
|
||||
}
|
||||
void matrix_init_unicode(void) { unicode_input_mode_init(); }
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
/* Copyright 2020 Christopher Courtney, aka Drashna Jael're (@drashna) <drashna@live.com>
|
||||
* Copyright 2021 John Ezra - wpm graph
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
|
@ -15,17 +16,17 @@
|
|||
*/
|
||||
|
||||
#include "drashna.h"
|
||||
#ifdef CUSTOM_UNICODE_ENABLE
|
||||
#ifdef UNICODE_COMMON_ENABLE
|
||||
# include "process_unicode_common.h"
|
||||
#endif
|
||||
#include <string.h>
|
||||
|
||||
extern bool host_driver_disabled;
|
||||
|
||||
uint32_t oled_timer = 0;
|
||||
char keylog_str[OLED_KEYLOGGER_LENGTH] = {0};
|
||||
static uint16_t log_timer = 0;
|
||||
static const char PROGMEM display_border[3] = {0x0, 0xFF, 0x0};
|
||||
uint32_t oled_timer = 0;
|
||||
char keylog_str[OLED_KEYLOGGER_LENGTH] = {0};
|
||||
static uint16_t log_timer = 0;
|
||||
static const char PROGMEM display_border[3] = {0x0, 0xFF, 0x0};
|
||||
|
||||
deferred_token kittoken;
|
||||
|
||||
|
@ -112,7 +113,7 @@ void update_log(void) {
|
|||
*/
|
||||
void render_keylogger_status(void) {
|
||||
#ifdef OLED_DISPLAY_VERBOSE
|
||||
oled_set_cursor(1, 7);
|
||||
oled_set_cursor(1, 6);
|
||||
#endif
|
||||
oled_write_P(PSTR(OLED_RENDER_KEYLOGGER), false);
|
||||
oled_write(keylog_str, false);
|
||||
|
@ -127,7 +128,7 @@ void render_keylogger_status(void) {
|
|||
*/
|
||||
void render_default_layer_state(void) {
|
||||
#ifdef OLED_DISPLAY_VERBOSE
|
||||
oled_set_cursor(5, 2);
|
||||
oled_set_cursor(1, 1);
|
||||
#endif
|
||||
oled_write_P(PSTR(OLED_RENDER_LAYOUT_NAME), false);
|
||||
switch (get_highest_layer(default_layer_state)) {
|
||||
|
@ -155,111 +156,166 @@ void render_default_layer_state(void) {
|
|||
*/
|
||||
void render_layer_state(void) {
|
||||
#ifdef OLED_DISPLAY_VERBOSE
|
||||
static const char PROGMEM tri_layer_image[4][3][18] = {
|
||||
// clang-format off
|
||||
static const char PROGMEM tri_layer_image[][3][24] = {
|
||||
// base
|
||||
{
|
||||
{
|
||||
0x80, 0x80, 0x40, 0x40, 0x20, 0x20,
|
||||
0x10, 0x10, 0x08, 0x08, 0x10, 0x10,
|
||||
0x20, 0x20, 0x40, 0x40, 0x80, 0x80
|
||||
0x00, 0x00, 0x00, 0x80, 0x80, 0x40,
|
||||
0x40, 0x20, 0x20, 0x10, 0x10, 0x08,
|
||||
0x08, 0x10, 0x10, 0x20, 0x20, 0x40,
|
||||
0x40, 0x80, 0x80, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x88, 0x88, 0x5D, 0x5D, 0x3E, 0x3E,
|
||||
0x7C, 0x7C, 0xF8, 0xF8, 0x7C, 0x7C,
|
||||
0x3E, 0x3E, 0x5D, 0x5D, 0x88, 0x88
|
||||
0x00, 0x00, 0x00, 0x88, 0x88, 0x5D,
|
||||
0x5D, 0x3E, 0x3E, 0x7C, 0x7C, 0xF8,
|
||||
0xF8, 0x7C, 0x7C, 0x3E, 0x3E, 0x5D,
|
||||
0x5D, 0x88, 0x88, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x00, 0x00, 0x01, 0x01, 0x02, 0x02,
|
||||
0x04, 0x04, 0x08, 0x08, 0x04, 0x04,
|
||||
0x02, 0x02, 0x01, 0x01, 0x00, 0x00
|
||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
||||
0x01, 0x02, 0x02, 0x04, 0x04, 0x08,
|
||||
0x08, 0x04, 0x04, 0x02, 0x02, 0x01,
|
||||
0x01, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
}
|
||||
},
|
||||
// raise
|
||||
{
|
||||
{
|
||||
0x80, 0x80, 0xC0, 0xC0, 0xE0, 0xE0,
|
||||
0xF0, 0xF0, 0xF8, 0xF8, 0xF0, 0xF0,
|
||||
0xE0, 0xE0, 0xC0, 0xC0, 0x80, 0x80
|
||||
0x00, 0x00, 0x00, 0x80, 0x80, 0xC0,
|
||||
0xC0, 0xE0, 0xE0, 0xF0, 0xF0, 0xF8,
|
||||
0xF8, 0xF0, 0xF0, 0xE0, 0xE0, 0xC0,
|
||||
0xC0, 0x80, 0x80, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x88, 0x88, 0x55, 0x55, 0x23, 0x23,
|
||||
0x47, 0x47, 0x8F, 0x8F, 0x47, 0x47,
|
||||
0x23, 0x23, 0x55, 0x55, 0x88, 0x88
|
||||
0x00, 0x00, 0x00, 0x88, 0x88, 0x55,
|
||||
0x55, 0x23, 0x23, 0x47, 0x47, 0x8F,
|
||||
0x8F, 0x47, 0x47, 0x23, 0x23, 0x55,
|
||||
0x55, 0x88, 0x88, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x00, 0x00, 0x01, 0x01, 0x02, 0x02,
|
||||
0x04, 0x04, 0x08, 0x08, 0x04, 0x04,
|
||||
0x02, 0x02, 0x01, 0x01, 0x00, 0x00
|
||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
||||
0x01, 0x02, 0x02, 0x04, 0x04, 0x08,
|
||||
0x08, 0x04, 0x04, 0x02, 0x02, 0x01,
|
||||
0x01, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
}
|
||||
},
|
||||
// lower
|
||||
{
|
||||
{
|
||||
0x80, 0x80, 0x40, 0x40, 0x20, 0x20,
|
||||
0x10, 0x10, 0x08, 0x08, 0x10, 0x10,
|
||||
0x20, 0x20, 0x40, 0x40, 0x80, 0x80
|
||||
0x00, 0x00, 0x00, 0x80, 0x80, 0x40,
|
||||
0x40, 0x20, 0x20, 0x10, 0x10, 0x08,
|
||||
0x08, 0x10, 0x10, 0x20, 0x20, 0x40,
|
||||
0x40, 0x80, 0x80, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x88, 0x88, 0xD5, 0xD5, 0xE2, 0xE2,
|
||||
0xC4, 0xC4, 0x88, 0x88, 0xC4, 0xC4,
|
||||
0xE2, 0xE2, 0xD5, 0xD5, 0x88, 0x88
|
||||
0x00, 0x00, 0x00, 0x88, 0x88, 0xD5,
|
||||
0xD5, 0xE2, 0xE2, 0xC4, 0xC4, 0x88,
|
||||
0x88, 0xC4, 0xC4, 0xE2, 0xE2, 0xD5,
|
||||
0xD5, 0x88, 0x88, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x00, 0x00, 0x01, 0x01, 0x03, 0x03,
|
||||
0x07, 0x07, 0x0F, 0x0F, 0x07, 0x07,
|
||||
0x03, 0x03, 0x01, 0x01, 0x00, 0x00
|
||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
||||
0x01, 0x03, 0x03, 0x07, 0x07, 0x0F,
|
||||
0x0F, 0x07, 0x07, 0x03, 0x03, 0x01,
|
||||
0x01, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
}
|
||||
},
|
||||
// adjust
|
||||
{
|
||||
{
|
||||
0x80, 0x80, 0x40, 0xC0, 0x60, 0xA0,
|
||||
0x50, 0xB0, 0x58, 0xA8, 0x50, 0xB0,
|
||||
0x60, 0xA0, 0x40, 0xC0, 0x80, 0x80
|
||||
0x00, 0x00, 0x00, 0x80, 0x80, 0x40,
|
||||
0xC0, 0x60, 0xA0, 0x50, 0xB0, 0x58,
|
||||
0xA8, 0x50, 0xB0, 0x60, 0xA0, 0x40,
|
||||
0xC0, 0x80, 0x80, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x88, 0x88, 0x5D, 0xD5, 0x6B, 0xB6,
|
||||
0x6D, 0xD6, 0xAD, 0xDA, 0x6D, 0xD6,
|
||||
0x6B, 0xB6, 0x5D, 0xD5, 0x88, 0x88
|
||||
0x00, 0x00, 0x00, 0x88, 0x88, 0x5D,
|
||||
0xD5, 0x6B, 0xB6, 0x6D, 0xD6, 0xAD,
|
||||
0xDA, 0x6D, 0xD6, 0x6B, 0xB6, 0x5D,
|
||||
0xD5, 0x88, 0x88, 0x00, 0x00, 0x00
|
||||
},
|
||||
{
|
||||
0x00, 0x00, 0x01, 0x01, 0x03, 0x02,
|
||||
0x05, 0x06, 0x0D, 0x0A, 0x05, 0x06,
|
||||
0x03, 0x02, 0x01, 0x01, 0x00, 0x00
|
||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
||||
0x01, 0x03, 0x02, 0x05, 0x06, 0x0D,
|
||||
0x0A, 0x05, 0x06, 0x03, 0x02, 0x01,
|
||||
0x01, 0x00, 0x00, 0x00, 0x00, 0x00
|
||||
}
|
||||
},
|
||||
// blank
|
||||
{
|
||||
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
|
||||
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
|
||||
{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }
|
||||
},
|
||||
// better gamepad
|
||||
{
|
||||
{ 0, 0, 0,192,224,224,112,240,240,240,240,144,144,240,240,240,240,112,224,224,192, 0, 0, 0 },
|
||||
{ 128,248,255,255,255,254,252,230,195,195,230,255,255,254,247,227,246,253,254,255,255,255,248,128 },
|
||||
{ 7, 15, 15, 15, 7, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 7, 15, 15, 15, 7 }
|
||||
|
||||
},
|
||||
// mouse
|
||||
{
|
||||
{ 0, 0, 0, 0, 0, 0, 0, 0,192, 32, 32, 32,160, 32, 32, 32,192, 0, 0, 0, 0, 0, 0, 0 },
|
||||
{ 0, 0, 0, 0, 0, 0, 0,240, 15, 0, 0, 0, 3, 0, 0, 0, 15,240, 0, 0, 0, 0, 0, 0 },
|
||||
{ 0, 0, 0, 0, 0, 0, 0, 3, 6, 4, 4, 4, 4, 4, 4, 4, 6, 3, 0, 0, 0, 0, 0, 0 }
|
||||
}
|
||||
};
|
||||
|
||||
uint8_t layer_is = 0;
|
||||
|
||||
// clang-format on
|
||||
uint8_t layer_is[4] = { 0, 4, 4, 4};
|
||||
if (layer_state_is(_ADJUST)) {
|
||||
layer_is = 3;
|
||||
layer_is[0] = 3;
|
||||
} else if (layer_state_is(_RAISE)) {
|
||||
layer_is = 1;
|
||||
layer_is[0] = 1;
|
||||
} else if (layer_state_is(_LOWER)) {
|
||||
layer_is = 2;
|
||||
layer_is[0] = 2;
|
||||
}
|
||||
|
||||
if (layer_state_is(_MOUSE)) {
|
||||
layer_is[1] = 6;
|
||||
}
|
||||
if (layer_state_is(_GAMEPAD)) {
|
||||
layer_is[2] = 5;
|
||||
}
|
||||
|
||||
|
||||
oled_set_cursor(1, 2);
|
||||
oled_write_raw_P(tri_layer_image[layer_is][0], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(5, 3);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[0]][0], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(5, 2);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[1]][0], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(9, 2);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[2]][0], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(14, 2);
|
||||
oled_write_P(PSTR("Diablo2"), layer_state_is(_DIABLOII));
|
||||
oled_write_P(PSTR(" "), false);
|
||||
oled_write_P(PSTR("Diablo3"), layer_state_is(_DIABLO));
|
||||
oled_advance_page(true);
|
||||
|
||||
oled_set_cursor(1, 3);
|
||||
oled_write_raw_P(tri_layer_image[layer_is][1], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(5, 4);
|
||||
oled_write_P(PSTR("GamePad"), layer_state_is(_GAMEPAD));
|
||||
oled_write_P(PSTR(" "), false);
|
||||
oled_write_P(PSTR("Mouse"), layer_state_is(_MOUSE));
|
||||
oled_write_raw_P(tri_layer_image[layer_is[0]][1], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(5, 3);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[1]][1], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(9, 3);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[2]][1], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(14, 3);
|
||||
oled_write_P(PSTR("Diablo3"), layer_state_is(_DIABLO));
|
||||
oled_advance_page(true);
|
||||
|
||||
oled_set_cursor(1, 4);
|
||||
oled_write_raw_P(tri_layer_image[layer_is][2], sizeof(tri_layer_image[0][0]));
|
||||
|
||||
oled_write_raw_P(tri_layer_image[layer_is[0]][2], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(5, 4);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[1]][2], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(9, 4);
|
||||
oled_write_raw_P(tri_layer_image[layer_is[2]][2], sizeof(tri_layer_image[0][0]));
|
||||
oled_set_cursor(14, 4);
|
||||
oled_write_P(PSTR("Media"), layer_state_is(_MEDIA));
|
||||
#else
|
||||
oled_write_P(PSTR(OLED_RENDER_LAYER_NAME), false);
|
||||
oled_write_P(PSTR(OLED_RENDER_LAYER_LOWER), layer_state_is(_LOWER));
|
||||
oled_write_P(PSTR(OLED_RENDER_LAYER_RAISE), layer_state_is(_RAISE));
|
||||
oled_advance_page(true);
|
||||
#endif
|
||||
oled_advance_page(true);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -288,9 +344,14 @@ void render_keylock_status(uint8_t led_usb_state) {
|
|||
* @brief Renders the matrix scan rate to the host system
|
||||
*
|
||||
*/
|
||||
void render_matrix_scan_rate(void) {
|
||||
void render_matrix_scan_rate(uint8_t padding) {
|
||||
#ifdef DEBUG_MATRIX_SCAN_RATE
|
||||
oled_write_P(PSTR("MS:"), false);
|
||||
if (padding) {
|
||||
for (uint8_t n = padding; n > 0; n--) {
|
||||
oled_write_P(PSTR(" "), false);
|
||||
}
|
||||
}
|
||||
oled_write(get_u16_str(get_matrix_scan_rate(), ' '), false);
|
||||
#endif
|
||||
}
|
||||
|
@ -337,7 +398,7 @@ void render_bootmagic_status(void) {
|
|||
|
||||
bool is_bootmagic_on;
|
||||
#ifdef OLED_DISPLAY_VERBOSE
|
||||
oled_set_cursor(7, 4);
|
||||
oled_set_cursor(7, 3);
|
||||
is_bootmagic_on = !keymap_config.swap_lctl_lgui;
|
||||
#else
|
||||
is_bootmagic_on = keymap_config.swap_lctl_lgui;
|
||||
|
@ -366,11 +427,12 @@ void render_bootmagic_status(void) {
|
|||
oled_write_P(PSTR(" "), false);
|
||||
#ifdef AUTOCORRECTION_ENABLE
|
||||
oled_write_P(PSTR("CRCT"), userspace_config.autocorrection);
|
||||
oled_write_P(PSTR(" "), false);
|
||||
#else
|
||||
oled_write_P(PSTR(OLED_RENDER_BOOTMAGIC_NOGUI), keymap_config.no_gui);
|
||||
#endif
|
||||
#ifdef OLED_DISPLAY_VERBOSE
|
||||
oled_set_cursor(7, 5);
|
||||
oled_set_cursor(7, 4);
|
||||
if (keymap_config.swap_lctl_lgui) {
|
||||
oled_write_P(logo[1][1], is_bootmagic_on);
|
||||
} else {
|
||||
|
@ -382,6 +444,7 @@ void render_bootmagic_status(void) {
|
|||
#ifdef SWAP_HANDS_ENABLE
|
||||
oled_write_P(PSTR(" "), false);
|
||||
oled_write_P(PSTR(OLED_RENDER_BOOTMAGIC_SWAP), swap_hands);
|
||||
oled_write_P(PSTR(" "), false);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -402,7 +465,7 @@ void render_user_status(void) {
|
|||
# endif
|
||||
#endif
|
||||
#if defined(OLED_DISPLAY_VERBOSE)
|
||||
oled_set_cursor(1, 6);
|
||||
oled_set_cursor(1, 5);
|
||||
#endif
|
||||
oled_write_P(PSTR(OLED_RENDER_USER_NAME), false);
|
||||
#if !defined(OLED_DISPLAY_VERBOSE)
|
||||
|
@ -434,9 +497,9 @@ void render_user_status(void) {
|
|||
oled_write_P(rgb_layer_status[userspace_config.rgb_layer_change], false);
|
||||
static const char PROGMEM cat_mode[2][3] = {{0xF8, 0xF9, 0}, {0xF6, 0xF7, 0}};
|
||||
oled_write_P(cat_mode[0], host_driver_disabled);
|
||||
#if defined(CUSTOM_UNICODE_ENABLE)
|
||||
static const char PROGMEM uc_mod_status[5][3] = {{0xEA, 0xEB, 0}, {0xEC, 0xED, 0}};
|
||||
oled_write_P(uc_mod_status[get_unicode_input_mode() == UC_MAC], false);
|
||||
#if defined(UNICODE_COMMON_ENABLE)
|
||||
static const char PROGMEM uc_mod_status[5][3] = {{0xEC, 0xED, 0}, {0x20, 0x20, 0}, {0x20, 0x20, 0}, {0x20, 0x20, 0}, {0xEA, 0xEB, 0}};
|
||||
oled_write_P(uc_mod_status[get_unicode_input_mode()], false);
|
||||
#endif
|
||||
if (userspace_config.nuke_switch) {
|
||||
#if !defined(OLED_DISPLAY_VERBOSE)
|
||||
|
@ -466,9 +529,69 @@ void render_wpm(uint8_t padding) {
|
|||
#endif
|
||||
}
|
||||
|
||||
#if defined(KEYBOARD_handwired_tractyl_manuform) || defined(KEYBOARD_bastardkb_charybdis)
|
||||
extern kb_config_data_t kb_config;
|
||||
void render_pointing_dpi_status(uint8_t padding) {
|
||||
//============= USER CONFIG PARAMS ===============
|
||||
// wpm graph originally designed by john-ezra
|
||||
|
||||
// for 128x128:
|
||||
// max_lines_graph = 54;
|
||||
// vertical_offset = 64;
|
||||
// for 128x64:
|
||||
// max_lines_graph = 64;
|
||||
// vertical_offset = 0;
|
||||
|
||||
void render_wpm_graph(uint8_t max_lines_graph, uint8_t vertical_offset) {
|
||||
static uint16_t timer = 0;
|
||||
static uint8_t x = OLED_DISPLAY_HEIGHT - 1;
|
||||
uint8_t currwpm = get_current_wpm();
|
||||
float max_wpm = OLED_WPM_GRAPH_MAX_WPM;
|
||||
|
||||
if (timer_elapsed(timer) > OLED_WPM_GRAPH_REFRESH_INTERVAL) { // check if it's been long enough before refreshing graph
|
||||
x = (max_lines_graph - 1) - ((currwpm / max_wpm) * (max_lines_graph - 1)); // main calculation to plot graph line
|
||||
for (uint8_t i = 0; i <= OLED_WPM_GRAPH_GRAPH_LINE_THICKNESS - 1; i++) { // first draw actual value line
|
||||
oled_write_pixel(3, x + i + vertical_offset, true);
|
||||
}
|
||||
# ifdef OLED_WPM_GRAPH_VERTICAL_LINE
|
||||
static uint8_t vert_count = 0;
|
||||
if (vert_count == OLED_WPM_GRAPH_VERTCAL_LINE_INTERVAL) {
|
||||
vert_count = 0;
|
||||
while (x <= (max_lines_graph - 1)) {
|
||||
oled_write_pixel(3, x + vertical_offset, true);
|
||||
x++;
|
||||
}
|
||||
} else {
|
||||
for (uint8_t i = (max_lines_graph - 1); i > x; i--) {
|
||||
if (i % OLED_WPM_GRAPH_AREA_FILL_INTERVAL == 0) {
|
||||
oled_write_pixel(3, i + vertical_offset, true);
|
||||
}
|
||||
}
|
||||
vert_count++;
|
||||
}
|
||||
# else
|
||||
for (int i = (max_lines_graph - 1); i > x; i--) {
|
||||
if (i % OLED_WPM_GRAPH_AREA_FILL_INTERVAL == 0) {
|
||||
oled_write_pixel(3, i + vertical_offset, true);
|
||||
}
|
||||
}
|
||||
# endif
|
||||
oled_pan(false); // then move the entire graph one pixel to the right
|
||||
static const char PROGMEM display_border[3] = {0x0, 0xFF, 0x0};
|
||||
for (uint8_t i = 0; i < 7; i++) {
|
||||
oled_set_cursor(0, i + 8);
|
||||
oled_write_raw_P(display_border, sizeof(display_border));
|
||||
oled_set_cursor(21, i + 8);
|
||||
oled_write_raw_P(display_border, sizeof(display_border));
|
||||
}
|
||||
static const char PROGMEM footer_image[] = {0, 3, 4, 8, 16, 32, 64, 128, 128, 128, 128, 128, 128, 128, 192, 224, 240, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 240, 224, 192, 128, 128, 128, 128, 128, 128, 128, 64, 32, 16, 8, 4, 3, 0};
|
||||
oled_set_cursor(0, 15);
|
||||
|
||||
oled_write_raw_P(footer_image, sizeof(footer_image));
|
||||
|
||||
timer = timer_read(); // refresh the timer for the next iteration
|
||||
}
|
||||
}
|
||||
|
||||
#if defined(POINTING_DEVICE_ENABLE)
|
||||
void render_pointing_dpi_status(uint16_t cpi, uint8_t padding) {
|
||||
oled_write_P(PSTR("CPI:"), false);
|
||||
if (padding) {
|
||||
for (uint8_t n = padding - 1; n > 0; n--) {
|
||||
|
@ -476,17 +599,15 @@ void render_pointing_dpi_status(uint8_t padding) {
|
|||
}
|
||||
}
|
||||
|
||||
oled_write(get_u16_str(kb_config.device_cpi, ' '), false);
|
||||
oled_write(get_u16_str(cpi, ' '), false);
|
||||
}
|
||||
#endif
|
||||
|
||||
__attribute__((weak)) void oled_driver_render_logo_right(void) {
|
||||
#if defined(OLED_DISPLAY_VERBOSE)
|
||||
oled_set_cursor(0, 2);
|
||||
render_default_layer_state();
|
||||
#else
|
||||
render_default_layer_state();
|
||||
oled_set_cursor(0, 1);
|
||||
#endif
|
||||
render_default_layer_state();
|
||||
}
|
||||
|
||||
// WPM-responsive animation stuff here
|
||||
|
@ -511,8 +632,8 @@ __attribute__((weak)) void oled_driver_render_logo_right(void) {
|
|||
# error frame size too large
|
||||
#endif
|
||||
|
||||
static uint8_t animation_frame = 0;
|
||||
static uint8_t animation_type = 0;
|
||||
static uint8_t animation_frame = 0;
|
||||
static uint8_t animation_type = 0;
|
||||
|
||||
void render_kitty(void) {
|
||||
// Images credit j-inc(/James Incandenza) and pixelbenny.
|
||||
|
@ -771,28 +892,28 @@ void render_kitty(void) {
|
|||
// clang-format on
|
||||
|
||||
for (uint8_t i = 0; i < 4; i++) {
|
||||
oled_set_cursor(1, i + 2);
|
||||
oled_set_cursor(1, i + 1);
|
||||
oled_write_raw_P(animation[animation_type][animation_frame][i], OLED_ANIM_SIZE);
|
||||
}
|
||||
}
|
||||
|
||||
uint32_t kitty_animation_phases(uint32_t triger_time, void *cb_arg) {
|
||||
uint32_t anim_frame_duration = 500;
|
||||
// can't change animation frame duration here, otherwise, it gets stuck.
|
||||
// weirdly, it seems to work fine if it's in keymap.c but not here.
|
||||
// Should move this block to the deferred execution?
|
||||
static uint32_t anim_frame_duration = 500;
|
||||
#ifdef POINTING_DEVICE_ENABLE
|
||||
if (tap_toggling) {
|
||||
animation_frame = (animation_frame + 1) % OLED_RTOGI_FRAMES;
|
||||
animation_type = 3;
|
||||
animation_frame = (animation_frame + 1) % OLED_RTOGI_FRAMES;
|
||||
animation_type = 3;
|
||||
anim_frame_duration = 300;
|
||||
} else
|
||||
#endif
|
||||
{
|
||||
#ifdef WPM_ENABLE
|
||||
if (get_current_wpm() <= OLED_SLEEP_SPEED) {
|
||||
#endif
|
||||
animation_frame = (animation_frame + 1) % OLED_SLEEP_FRAMES;
|
||||
animation_type = 0;
|
||||
anim_frame_duration = 500;
|
||||
#ifdef WPM_ENABLE
|
||||
} else if (get_current_wpm() > OLED_WAKE_SPEED) {
|
||||
animation_frame = (animation_frame + 1) % OLED_WAKE_FRAMES;
|
||||
animation_type = 1;
|
||||
|
@ -802,13 +923,14 @@ uint32_t kitty_animation_phases(uint32_t triger_time, void *cb_arg) {
|
|||
animation_type = 2;
|
||||
anim_frame_duration = 500;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
return anim_frame_duration;
|
||||
}
|
||||
|
||||
void oled_driver_render_logo_left(void) {
|
||||
#if defined(OLED_DISPLAY_VERBOSE)
|
||||
oled_set_cursor(0, 2);
|
||||
oled_set_cursor(0, 1);
|
||||
render_kitty();
|
||||
|
||||
# if defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
|
@ -817,39 +939,82 @@ void oled_driver_render_logo_left(void) {
|
|||
# elif defined(KEYBOARD_bastardkb_charybdis)
|
||||
oled_set_cursor(6, 0);
|
||||
oled_write_P(PSTR("Charybdis"), true);
|
||||
# elif defined(KEYBOARD_splitkb_kyria)
|
||||
oled_set_cursor(7, 0);
|
||||
oled_write_P(PSTR("SplitKB"), true);
|
||||
# else
|
||||
oled_set_cursor(8, 0);
|
||||
oled_write_P(PSTR("Left"), true);
|
||||
# endif
|
||||
oled_set_cursor(7, 2);
|
||||
# if defined(DEBUG_MATRIX_SCAN_RATE)
|
||||
render_matrix_scan_rate();
|
||||
# elif defined(WPM_ENABLE)
|
||||
oled_set_cursor(7, 1);
|
||||
# if defined(WPM_ENABLE)
|
||||
render_wpm(1);
|
||||
# elif defined(DEBUG_MATRIX_SCAN_RATE)
|
||||
render_matrix_scan_rate(2);
|
||||
# endif
|
||||
oled_set_cursor(7, 3);
|
||||
# if defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
render_pointing_dpi_status(0);
|
||||
# elif defined(KEYBOARD_bastardkb_charybdis)
|
||||
render_pointing_dpi_status(1);
|
||||
oled_set_cursor(7, 2);
|
||||
# if defined(KEYBOARD_bastardkb_charybdis)
|
||||
render_pointing_dpi_status(charybdis_get_pointer_sniping_enabled() ? charybdis_get_pointer_sniping_dpi() : charybdis_get_pointer_default_dpi(), 1);
|
||||
|
||||
// credit and thanks to jaspertandy on discord for these images
|
||||
static const char PROGMEM mouse_logo[3][2][16] = {
|
||||
// mouse icon
|
||||
{
|
||||
{ 0, 0, 0, 252, 2, 2, 2, 58, 2, 2, 2, 252, 0, 0, 0, 0 },
|
||||
{ 0, 0, 63, 96, 64, 64, 64, 64, 64, 64, 64, 96, 63, 0, 0, 0 }
|
||||
},
|
||||
// crosshair icon
|
||||
{
|
||||
{ 128, 240, 136, 228, 146, 138, 202, 127, 202, 138, 146, 228, 136, 240, 128, 0 },
|
||||
{ 0, 7, 8, 19, 36, 40, 41, 127, 41, 40, 36, 19, 8, 7, 0, 0 }
|
||||
},
|
||||
// dragscroll icon
|
||||
{
|
||||
{ 0, 0, 112, 136, 156, 2, 15, 1, 15, 2, 140, 68, 56, 0, 0, 0 },
|
||||
{ 0, 0, 2, 6, 15, 28, 60, 124, 60, 28, 15, 6, 2, 0, 0, 0 }
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
uint8_t image_index = 0;
|
||||
# ifdef OLED_DISPLAY_TEST
|
||||
image_index = animation_frame;
|
||||
# else
|
||||
if (charybdis_get_pointer_sniping_enabled()) {
|
||||
image_index = 1;
|
||||
} else if (charybdis_get_pointer_dragscroll_enabled()) {
|
||||
image_index = 2;
|
||||
}
|
||||
# endif
|
||||
|
||||
oled_set_cursor(17, 1);
|
||||
oled_write_raw_P(mouse_logo[image_index][0], 16);
|
||||
oled_set_cursor(17, 2);
|
||||
oled_write_raw_P(mouse_logo[image_index][1], 16);
|
||||
# elif defined(WPM_ENABLE) && defined(DEBUG_MATRIX_SCAN_RATE)
|
||||
render_matrix_scan_rate(2);
|
||||
# endif
|
||||
oled_set_cursor(0, 6);
|
||||
|
||||
oled_set_cursor(0, 5);
|
||||
#else
|
||||
render_default_layer_state();
|
||||
#endif
|
||||
}
|
||||
|
||||
void render_status_secondary(void) {
|
||||
# if defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
void render_status_right(void) {
|
||||
#if defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
oled_set_cursor(7, 0);
|
||||
oled_write_P(PSTR("Manuform"), true);
|
||||
# elif defined(KEYBOARD_bastardkb_charybdis)
|
||||
#elif defined(KEYBOARD_bastardkb_charybdis)
|
||||
oled_set_cursor(6, 0);
|
||||
oled_write_P(PSTR("Charybdis"), true);
|
||||
# else
|
||||
#elif defined(KEYBOARD_splitkb_kyria)
|
||||
oled_set_cursor(8, 0);
|
||||
oled_write_P(PSTR("Kyria"), true);
|
||||
#else
|
||||
oled_set_cursor(8, 0);
|
||||
oled_write_P(PSTR("Right"), true);
|
||||
# endif
|
||||
#endif
|
||||
oled_driver_render_logo_right();
|
||||
/* Show Keyboard Layout */
|
||||
render_layer_state();
|
||||
|
@ -860,16 +1025,18 @@ void render_status_secondary(void) {
|
|||
render_keylock_status(host_keyboard_leds());
|
||||
}
|
||||
|
||||
void render_status_main(void) {
|
||||
void render_status_left(void) {
|
||||
oled_driver_render_logo_left();
|
||||
|
||||
/* Show Keyboard Layout */
|
||||
render_bootmagic_status();
|
||||
render_user_status();
|
||||
|
||||
// render_keylogger_status();
|
||||
render_keylogger_status();
|
||||
}
|
||||
|
||||
__attribute__((weak)) void oled_render_large_display(void) {}
|
||||
|
||||
__attribute__((weak)) oled_rotation_t oled_init_keymap(oled_rotation_t rotation) { return rotation; }
|
||||
|
||||
oled_rotation_t oled_init_user(oled_rotation_t rotation) {
|
||||
|
@ -884,12 +1051,14 @@ oled_rotation_t oled_init_user(oled_rotation_t rotation) {
|
|||
return oled_init_keymap(rotation);
|
||||
}
|
||||
|
||||
__attribute__((weak)) bool oled_task_keymap(void) { return true; }
|
||||
|
||||
bool oled_task_user(void) {
|
||||
update_log();
|
||||
|
||||
if (is_keyboard_master()) {
|
||||
#ifndef OLED_DISPLAY_TEST
|
||||
if (timer_elapsed32(oled_timer) > 30000) {
|
||||
if (timer_elapsed32(oled_timer) > 60000) {
|
||||
oled_off();
|
||||
return false;
|
||||
} else
|
||||
|
@ -898,14 +1067,23 @@ bool oled_task_user(void) {
|
|||
oled_on();
|
||||
}
|
||||
}
|
||||
|
||||
if (!oled_task_keymap()) {
|
||||
return false;
|
||||
}
|
||||
|
||||
#if defined(OLED_DISPLAY_128X128)
|
||||
oled_set_cursor(0, 7);
|
||||
oled_render_large_display();
|
||||
#endif
|
||||
|
||||
#if defined(OLED_DISPLAY_VERBOSE)
|
||||
static const char PROGMEM header_image[] = {
|
||||
0,192, 32, 16, 8, 4, 2, 1, 1, 1, 1, 1, 1, 1, 1, 3, 7, 15, 31, 63,127,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,127, 63, 31, 15, 7, 3, 1, 1, 1, 1, 1, 1, 1, 1, 2, 4, 8, 16, 32,192, 0,
|
||||
0,255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 7, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 7, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 0
|
||||
};
|
||||
static const char PROGMEM footer_image[] = {
|
||||
0, 3, 4, 8, 16, 32, 64,128,128,128,128,128,128,128,192,224,240,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,248,240,224,192,128,128,128,128,128,128,128, 64, 32, 16, 8, 4, 3, 0
|
||||
};
|
||||
static const char PROGMEM header_image[] = {
|
||||
0, 192, 32, 16, 8, 4, 2, 1, 1, 1, 1, 1, 1, 1, 1, 3, 7, 15, 31, 63, 127, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 127, 63, 31, 15, 7, 3, 1, 1, 1, 1, 1, 1, 1, 1, 2, 4, 8, 16, 32, 192, 0,
|
||||
// 0,255, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 7, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 7, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,255, 0
|
||||
};
|
||||
static const char PROGMEM footer_image[] = {0, 3, 4, 8, 16, 32, 64, 128, 128, 128, 128, 128, 128, 128, 192, 224, 240, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 248, 240, 224, 192, 128, 128, 128, 128, 128, 128, 128, 64, 32, 16, 8, 4, 3, 0};
|
||||
oled_set_cursor(0, 0);
|
||||
oled_write_raw_P(header_image, sizeof(header_image));
|
||||
oled_set_cursor(0, 1);
|
||||
#endif
|
||||
|
@ -913,16 +1091,10 @@ bool oled_task_user(void) {
|
|||
#ifndef OLED_DISPLAY_TEST
|
||||
if (is_keyboard_left()) {
|
||||
#endif
|
||||
render_status_main(); // Renders the current keyboard state (layer, lock, caps, scroll, etc)
|
||||
render_status_left();
|
||||
#ifndef OLED_DISPLAY_TEST
|
||||
} else {
|
||||
render_status_secondary();
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(OLED_DISPLAY_128X128)
|
||||
if (is_keyboard_left()) {
|
||||
render_keylogger_status();
|
||||
render_status_right();
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -933,7 +1105,7 @@ bool oled_task_user(void) {
|
|||
# else
|
||||
num_of_rows = 7;
|
||||
# endif
|
||||
for (uint8_t i= 1; i < num_of_rows; i++) {
|
||||
for (uint8_t i = 1; i < num_of_rows; i++) {
|
||||
oled_set_cursor(0, i);
|
||||
oled_write_raw_P(display_border, sizeof(display_border));
|
||||
oled_set_cursor(21, i);
|
||||
|
|
|
@ -28,15 +28,17 @@ void render_keylogger_status(void);
|
|||
void render_default_layer_state(void);
|
||||
void render_layer_state(void);
|
||||
void render_keylock_status(uint8_t led_usb_state);
|
||||
void render_matrix_scan_rate(void);
|
||||
void render_matrix_scan_rate(uint8_t padding);
|
||||
void render_mod_status(uint8_t modifiers);
|
||||
void render_bootmagic_status(void);
|
||||
void render_user_status(void);
|
||||
void oled_driver_render_logo(void);
|
||||
void render_wpm(uint8_t padding);
|
||||
void render_pointing_dpi_status(uint8_t padding);
|
||||
void render_pointing_dpi_status(uint16_t cpi, uint8_t padding);
|
||||
void oled_driver_render_logo_left(void);
|
||||
void oled_driver_render_logo_right(void);
|
||||
void oled_render_large_display(void);
|
||||
void render_wpm_graph(uint8_t max_lines_graph, uint8_t vertical_offset);
|
||||
|
||||
#if defined(OLED_DISPLAY_128X128) || defined(OLED_DISPLAY_128X64)
|
||||
# define OLED_DISPLAY_VERBOSE
|
||||
|
@ -47,7 +49,7 @@ void oled_driver_render_logo_right(void);
|
|||
# endif
|
||||
# define OLED_RENDER_LAYOUT_NAME "Layout: "
|
||||
# define OLED_RENDER_LAYOUT_QWERTY "Qwerty"
|
||||
# define OLED_RENDER_LAYOUT_COLEMAK_DH "ColemkDH"
|
||||
# define OLED_RENDER_LAYOUT_COLEMAK_DH "Colemak DH"
|
||||
# define OLED_RENDER_LAYOUT_COLEMAK "Colemak"
|
||||
# define OLED_RENDER_LAYOUT_DVORAK "Dvorak"
|
||||
# define OLED_RENDER_LAYOUT_WORKMAN "Workman"
|
||||
|
@ -139,3 +141,19 @@ void oled_driver_render_logo_right(void);
|
|||
|
||||
|
||||
extern char keylog_str[OLED_KEYLOGGER_LENGTH];
|
||||
|
||||
#ifndef OLED_WPM_GRAPH_MAX_WPM
|
||||
# define OLED_WPM_GRAPH_MAX_WPM 120
|
||||
#endif
|
||||
#ifndef OLED_WPM_GRAPH_REFRESH_INTERVAL
|
||||
# define OLED_WPM_GRAPH_REFRESH_INTERVAL 300
|
||||
#endif
|
||||
#ifndef OLED_WPM_GRAPH_AREA_FILL_INTERVAL
|
||||
# define OLED_WPM_GRAPH_AREA_FILL_INTERVAL 3
|
||||
#endif
|
||||
#ifndef OLED_WPM_GRAPH_VERTCAL_LINE_INTERVAL
|
||||
# define OLED_WPM_GRAPH_VERTCAL_LINE_INTERVAL 3
|
||||
#endif
|
||||
#ifndef OLED_WPM_GRAPH_GRAPH_LINE_THICKNESS
|
||||
# define OLED_WPM_GRAPH_GRAPH_LINE_THICKNESS 2
|
||||
#endif
|
||||
|
|
|
@ -42,19 +42,15 @@ report_mouse_t pointing_device_task_user(report_mouse_t mouse_report) {
|
|||
layer_on(_MOUSE);
|
||||
}
|
||||
}
|
||||
}
|
||||
return pointing_device_task_keymap(mouse_report);
|
||||
}
|
||||
|
||||
void matrix_scan_pointing(void) {
|
||||
if (timer_elapsed(mouse_timer) > 650 && layer_state_is(_MOUSE) && !mouse_keycode_tracker && !tap_toggling) {
|
||||
} else if (timer_elapsed(mouse_timer) > 650 && layer_state_is(_MOUSE) && !mouse_keycode_tracker && !tap_toggling) {
|
||||
layer_off(_MOUSE);
|
||||
}
|
||||
if (tap_toggling) {
|
||||
} else if (tap_toggling) {
|
||||
if (!layer_state_is(_MOUSE)) {
|
||||
layer_on(_MOUSE);
|
||||
}
|
||||
}
|
||||
|
||||
return pointing_device_task_keymap(mouse_report);
|
||||
}
|
||||
|
||||
bool process_record_pointing(uint16_t keycode, keyrecord_t* record) {
|
||||
|
@ -86,7 +82,7 @@ bool process_record_pointing(uint16_t keycode, keyrecord_t* record) {
|
|||
case MO(_MOUSE):
|
||||
#if defined(KEYBOARD_ploopy) || defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
case DPI_CONFIG:
|
||||
#elif defined(KEYBOARD_bastardkb_charybdis)
|
||||
#elif defined(KEYBOARD_bastardkb_charybdis) && !defined(NO_CHARYBDIS_KEYCODES)
|
||||
case SAFE_RANGE ... (CHARYBDIS_SAFE_RANGE-1):
|
||||
#endif
|
||||
case KC_MS_UP ... KC_MS_WH_RIGHT:
|
||||
|
@ -98,6 +94,12 @@ bool process_record_pointing(uint16_t keycode, keyrecord_t* record) {
|
|||
record->event.pressed ? mouse_keycode_tracker++ : mouse_keycode_tracker--;
|
||||
mouse_timer = timer_read();
|
||||
break;
|
||||
case QK_ONE_SHOT_MOD ... QK_ONE_SHOT_MOD_MAX:
|
||||
break;
|
||||
case QK_MOD_TAP ... QK_MOD_TAP_MAX:
|
||||
if (record->event.pressed || !record->tap.count) {
|
||||
break;
|
||||
}
|
||||
default:
|
||||
if (IS_NOEVENT(record->event)) break;
|
||||
if ((keycode >= QK_LAYER_TAP && keycode <= QK_LAYER_TAP_MAX) && (((keycode >> 0x8) & 0xF) == _MOUSE)) {
|
||||
|
|
|
@ -23,9 +23,29 @@ static bool is_enabled;
|
|||
static bool is_rgblight_startup;
|
||||
static HSV old_hsv;
|
||||
static uint8_t old_mode;
|
||||
static uint16_t rgblight_startup_loop_timer;
|
||||
deferred_token rgb_startup_token;
|
||||
# endif
|
||||
|
||||
uint32_t rgb_startup_animation(uint32_t triger_time, void *cb_arg) {
|
||||
if (is_rgblight_startup && is_keyboard_master()) {
|
||||
static uint8_t counter = 0;
|
||||
counter++;
|
||||
rgblight_sethsv_noeeprom((counter + old_hsv.h) % 255, 255, 255);
|
||||
if (counter >= 255) {
|
||||
is_rgblight_startup = false;
|
||||
if (userspace_config.rgb_layer_change) {
|
||||
layer_state_set_rgb_light(layer_state);
|
||||
} else {
|
||||
rgblight_set_hsv_and_mode(old_hsv.h, old_hsv.s, old_hsv.v, old_mode);
|
||||
}
|
||||
if (!is_enabled) {
|
||||
rgblight_disable_noeeprom();
|
||||
}
|
||||
}
|
||||
}
|
||||
return is_rgblight_startup ? 10 : 0;
|
||||
}
|
||||
|
||||
void keyboard_post_init_rgb_light(void) {
|
||||
# if defined(RGBLIGHT_STARTUP_ANIMATION)
|
||||
is_enabled = rgblight_is_enabled();
|
||||
|
@ -40,30 +60,8 @@ void keyboard_post_init_rgb_light(void) {
|
|||
if (userspace_config.rgb_layer_change) {
|
||||
layer_state_set_rgb_light(layer_state);
|
||||
}
|
||||
}
|
||||
rgb_startup_token = defer_exec(300, rgb_startup_animation, NULL);
|
||||
|
||||
void matrix_scan_rgb_light(void) {
|
||||
# if defined(RGBLIGHT_STARTUP_ANIMATION)
|
||||
if (is_rgblight_startup && is_keyboard_master()) {
|
||||
if (sync_timer_elapsed(rgblight_startup_loop_timer) > 10) {
|
||||
static uint8_t counter;
|
||||
counter++;
|
||||
rgblight_sethsv_noeeprom((counter + old_hsv.h) % 255, 255, 255);
|
||||
rgblight_startup_loop_timer = sync_timer_read();
|
||||
if (counter == 255) {
|
||||
is_rgblight_startup = false;
|
||||
if (userspace_config.rgb_layer_change) {
|
||||
layer_state_set_rgb_light(layer_state);
|
||||
} else {
|
||||
rgblight_set_hsv_and_mode(old_hsv.h, old_hsv.s, old_hsv.v, old_mode);
|
||||
}
|
||||
if (!is_enabled) {
|
||||
rgblight_disable_noeeprom();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
# endif
|
||||
}
|
||||
|
||||
layer_state_t layer_state_set_rgb_light(layer_state_t state) {
|
||||
|
|
|
@ -58,6 +58,7 @@ ifeq ($(strip $(RGBLIGHT_ENABLE)), yes)
|
|||
endif
|
||||
ifeq ($(strip $(RGBLIGHT_STARTUP_ANIMATION)), yes)
|
||||
OPT_DEFS += -DRGBLIGHT_STARTUP_ANIMATION
|
||||
DEFERRED_EXEC_ENABLE = yes
|
||||
endif
|
||||
endif
|
||||
endif
|
||||
|
|
|
@ -8,7 +8,7 @@
|
|||
# include <avr/wdt.h>
|
||||
#endif
|
||||
|
||||
#ifdef CUSTOM_UNICODE_ENABLE
|
||||
#ifdef UNICODE_COMMON_ENABLE
|
||||
# include "process_unicode_common.h"
|
||||
extern unicode_config_t unicode_config;
|
||||
#endif
|
||||
|
@ -58,7 +58,7 @@ void watchdog_handler(uint8_t in_buflen, const void* in_data, uint8_t out_buflen
|
|||
#endif
|
||||
|
||||
#ifdef OLED_ENABLE
|
||||
#include "oled/oled_stuff.h"
|
||||
# include "oled/oled_stuff.h"
|
||||
void keylogger_string_sync(uint8_t initiator2target_buffer_size, const void* initiator2target_buffer, uint8_t target2initiator_buffer_size, void* target2initiator_buffer) {
|
||||
if (initiator2target_buffer_size == OLED_KEYLOGGER_LENGTH) {
|
||||
memcpy(&keylog_str, initiator2target_buffer, initiator2target_buffer_size);
|
||||
|
@ -95,7 +95,7 @@ void user_transport_update(void) {
|
|||
#if defined(POINTING_DEVICE_ENABLE) && defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
user_state.tap_toggling = tap_toggling;
|
||||
#endif
|
||||
#ifdef UNICODE_ENABLE
|
||||
#ifdef UNICODE_COMMON_ENABLE
|
||||
user_state.unicode_mode = unicode_config.input_mode;
|
||||
#endif
|
||||
#ifdef SWAP_HANDS_ENABLE
|
||||
|
@ -108,7 +108,7 @@ void user_transport_update(void) {
|
|||
keymap_config.raw = transport_keymap_config;
|
||||
userspace_config.raw = transport_userspace_config;
|
||||
user_state.raw = transport_user_state;
|
||||
#ifdef UNICODE_ENABLE
|
||||
#ifdef UNICODE_COMMON_ENABLE
|
||||
unicode_config.input_mode = user_state.unicode_mode;
|
||||
#endif
|
||||
#if defined(POINTING_DEVICE_ENABLE) && defined(KEYBOARD_handwired_tractyl_manuform)
|
||||
|
@ -128,7 +128,7 @@ void user_transport_sync(void) {
|
|||
static uint32_t last_config = 0, last_sync[4], last_user_state = 0;
|
||||
bool needs_sync = false;
|
||||
#ifdef OLED_ENABLE
|
||||
static char keylog_temp[OLED_KEYLOGGER_LENGTH] = { 0 };
|
||||
static char keylog_temp[OLED_KEYLOGGER_LENGTH] = {0};
|
||||
#endif
|
||||
|
||||
// Check if the state values are different
|
||||
|
@ -228,7 +228,6 @@ void user_transport_sync(void) {
|
|||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
}
|
||||
|
||||
void housekeeping_task_user(void) {
|
||||
|
|
|
@ -15,7 +15,7 @@ typedef union {
|
|||
bool audio_enable :1;
|
||||
bool audio_clicky_enable :1;
|
||||
bool tap_toggling :1;
|
||||
bool unicode_mode :1;
|
||||
uint8_t unicode_mode :3;
|
||||
bool swap_hands :1;
|
||||
bool host_driver_disabled :1;
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue