Merge pull request #22 from zsa/mouse_keys

Improvements to Mousekey's Constant speed mode
pull/5990/head
Florian Didron 6 years ago committed by GitHub
commit 7ca465911d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -5,6 +5,7 @@
04-16-2019 - Fix info.json for Ergodox EZ 04-16-2019 - Fix info.json for Ergodox EZ
04-16-2019 - Add support for WS2812 based RGB Matrix 04-16-2019 - Add support for WS2812 based RGB Matrix
04-18-2019 - Fix Eager Per Row Debouncing bug 04-18-2019 - Fix Eager Per Row Debouncing bug
04-22-2019 - Improve Mousekey constant speed mode
04-22-2019 - Add new reactive modes (wide, cross, nexus) for RGB Matrix 04-22-2019 - Add new reactive modes (wide, cross, nexus) for RGB Matrix
04-22-2019 - OLED Driver Features 04-22-2019 - OLED Driver Features
04-22-2019 - Add Split RGB support 04-22-2019 - Add Split RGB support

@ -171,28 +171,31 @@ void mousekey_off(uint8_t code) {
enum { enum {
mkspd_slow, mkspd_unmod,
mkspd_med, mkspd_0,
mkspd_fast, mkspd_1,
mkspd_2,
mkspd_COUNT mkspd_COUNT
}; };
static uint8_t mk_speed = mkspd_med; #ifndef MK_MOMENTARY_ACCEL
#ifdef MK_MOMENTARY_ACCEL static uint8_t mk_speed = mkspd_1;
static uint8_t mkspd_DEFAULT = mkspd_med; #else
static uint8_t mk_speed = mkspd_unmod;
static uint8_t mkspd_DEFAULT = mkspd_unmod;
#endif #endif
static uint16_t last_timer_c = 0; static uint16_t last_timer_c = 0;
static uint16_t last_timer_w = 0; static uint16_t last_timer_w = 0;
uint16_t c_offsets[mkspd_COUNT] = { uint16_t c_offsets[mkspd_COUNT] = {
MK_C_OFFSET_SLOW, MK_C_OFFSET_MED, MK_C_OFFSET_FAST MK_C_OFFSET_UNMOD, MK_C_OFFSET_0, MK_C_OFFSET_1, MK_C_OFFSET_2
}; };
uint16_t c_intervals[mkspd_COUNT] = { uint16_t c_intervals[mkspd_COUNT] = {
MK_C_INTERVAL_SLOW, MK_C_INTERVAL_MED, MK_C_INTERVAL_FAST MK_C_INTERVAL_UNMOD, MK_C_INTERVAL_0, MK_C_INTERVAL_1, MK_C_INTERVAL_2
}; };
uint16_t w_offsets[mkspd_COUNT] = { uint16_t w_offsets[mkspd_COUNT] = {
MK_W_OFFSET_SLOW, MK_W_OFFSET_MED, MK_W_OFFSET_FAST MK_W_OFFSET_UNMOD, MK_W_OFFSET_0, MK_W_OFFSET_1, MK_W_OFFSET_2
}; };
uint16_t w_intervals[mkspd_COUNT] = { uint16_t w_intervals[mkspd_COUNT] = {
MK_W_INTERVAL_SLOW, MK_W_INTERVAL_MED, MK_W_INTERVAL_FAST MK_W_INTERVAL_UNMOD, MK_W_INTERVAL_0, MK_W_INTERVAL_1, MK_W_INTERVAL_2
}; };
@ -254,9 +257,9 @@ void mousekey_on(uint8_t code) {
else if (code == KC_MS_BTN3) mouse_report.buttons |= MOUSE_BTN3; else if (code == KC_MS_BTN3) mouse_report.buttons |= MOUSE_BTN3;
else if (code == KC_MS_BTN4) mouse_report.buttons |= MOUSE_BTN4; else if (code == KC_MS_BTN4) mouse_report.buttons |= MOUSE_BTN4;
else if (code == KC_MS_BTN5) mouse_report.buttons |= MOUSE_BTN5; else if (code == KC_MS_BTN5) mouse_report.buttons |= MOUSE_BTN5;
else if (code == KC_MS_ACCEL0) mk_speed = mkspd_slow; else if (code == KC_MS_ACCEL0) mk_speed = mkspd_0;
else if (code == KC_MS_ACCEL1) mk_speed = mkspd_med; else if (code == KC_MS_ACCEL1) mk_speed = mkspd_1;
else if (code == KC_MS_ACCEL2) mk_speed = mkspd_fast; else if (code == KC_MS_ACCEL2) mk_speed = mkspd_2;
if (mk_speed != old_speed) adjust_speed(); if (mk_speed != old_speed) adjust_speed();
} }

@ -64,42 +64,54 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#else /* #ifndef MK_3_SPEED */ #else /* #ifndef MK_3_SPEED */
#ifndef MK_C_OFFSET_SLOW #ifndef MK_C_OFFSET_UNMOD
#define MK_C_OFFSET_SLOW 1 #define MK_C_OFFSET_UNMOD 16
#endif #endif
#ifndef MK_C_INTERVAL_SLOW #ifndef MK_C_INTERVAL_UNMOD
#define MK_C_INTERVAL_SLOW 100 #define MK_C_INTERVAL_UNMOD 16
#endif #endif
#ifndef MK_C_OFFSET_MED #ifndef MK_C_OFFSET_0
#define MK_C_OFFSET_MED 4 #define MK_C_OFFSET_0 1
#endif #endif
#ifndef MK_C_INTERVAL_MED #ifndef MK_C_INTERVAL_0
#define MK_C_INTERVAL_MED 16 #define MK_C_INTERVAL_0 32
#endif #endif
#ifndef MK_C_OFFSET_FAST #ifndef MK_C_OFFSET_1
#define MK_C_OFFSET_FAST 12 #define MK_C_OFFSET_1 4
#endif #endif
#ifndef MK_C_INTERVAL_FAST #ifndef MK_C_INTERVAL_1
#define MK_C_INTERVAL_FAST 16 #define MK_C_INTERVAL_1 16
#endif
#ifndef MK_C_OFFSET_2
#define MK_C_OFFSET_2 32
#endif
#ifndef MK_C_INTERVAL_2
#define MK_C_INTERVAL_2 16
#endif #endif
#ifndef MK_W_OFFSET_SLOW #ifndef MK_W_OFFSET_UNMOD
#define MK_W_OFFSET_SLOW 1 #define MK_W_OFFSET_UNMOD 1
#endif
#ifndef MK_W_INTERVAL_UNMOD
#define MK_W_INTERVAL_UNMOD 40
#endif
#ifndef MK_W_OFFSET_0
#define MK_W_OFFSET_0 1
#endif #endif
#ifndef MK_W_INTERVAL_SLOW #ifndef MK_W_INTERVAL_0
#define MK_W_INTERVAL_SLOW 400 #define MK_W_INTERVAL_0 360
#endif #endif
#ifndef MK_W_OFFSET_MED #ifndef MK_W_OFFSET_1
#define MK_W_OFFSET_MED 1 #define MK_W_OFFSET_1 1
#endif #endif
#ifndef MK_W_INTERVAL_MED #ifndef MK_W_INTERVAL_1
#define MK_W_INTERVAL_MED 200 #define MK_W_INTERVAL_1 120
#endif #endif
#ifndef MK_W_OFFSET_FAST #ifndef MK_W_OFFSET_2
#define MK_W_OFFSET_FAST 1 #define MK_W_OFFSET_2 1
#endif #endif
#ifndef MK_W_INTERVAL_FAST #ifndef MK_W_INTERVAL_2
#define MK_W_INTERVAL_FAST 100 #define MK_W_INTERVAL_2 20
#endif #endif
#endif /* #ifndef MK_3_SPEED */ #endif /* #ifndef MK_3_SPEED */

Loading…
Cancel
Save