diff options
Diffstat (limited to 'keyboards/ploopyco/mouse/mouse.c')
| -rw-r--r-- | keyboards/ploopyco/mouse/mouse.c | 66 |
1 files changed, 53 insertions, 13 deletions
diff --git a/keyboards/ploopyco/mouse/mouse.c b/keyboards/ploopyco/mouse/mouse.c index 788a0a1f0..1a1e5648b 100644 --- a/keyboards/ploopyco/mouse/mouse.c +++ b/keyboards/ploopyco/mouse/mouse.c | |||
| @@ -39,9 +39,15 @@ | |||
| 39 | #ifndef PLOOPY_DPI_DEFAULT | 39 | #ifndef PLOOPY_DPI_DEFAULT |
| 40 | # define PLOOPY_DPI_DEFAULT 0 | 40 | # define PLOOPY_DPI_DEFAULT 0 |
| 41 | #endif | 41 | #endif |
| 42 | #ifndef PLOOPY_DRAGSCROLL_DPI | ||
| 43 | # define PLOOPY_DRAGSCROLL_DPI 100 // Fixed-DPI Drag Scroll | ||
| 44 | #endif | ||
| 45 | #ifndef PLOOPY_DRAGSCROLL_MULTIPLIER | ||
| 46 | # define PLOOPY_DRAGSCROLL_MULTIPLIER 0.75 // Variable-DPI Drag Scroll | ||
| 47 | #endif | ||
| 42 | 48 | ||
| 43 | keyboard_config_t keyboard_config; | 49 | keyboard_config_t keyboard_config; |
| 44 | uint16_t dpi_array[] = PLOOPY_DPI_OPTIONS; | 50 | uint16_t dpi_array[] = PLOOPY_DPI_OPTIONS; |
| 45 | #define DPI_OPTION_SIZE (sizeof(dpi_array) / sizeof(uint16_t)) | 51 | #define DPI_OPTION_SIZE (sizeof(dpi_array) / sizeof(uint16_t)) |
| 46 | 52 | ||
| 47 | // TODO: Implement libinput profiles | 53 | // TODO: Implement libinput profiles |
| @@ -57,6 +63,7 @@ uint16_t lastScroll = 0; // Previous confirmed wheel event | |||
| 57 | uint16_t lastMidClick = 0; // Stops scrollwheel from being read if it was pressed | 63 | uint16_t lastMidClick = 0; // Stops scrollwheel from being read if it was pressed |
| 58 | uint8_t OptLowPin = OPT_ENC1; | 64 | uint8_t OptLowPin = OPT_ENC1; |
| 59 | bool debug_encoder = false; | 65 | bool debug_encoder = false; |
| 66 | bool is_drag_scroll = false; | ||
| 60 | 67 | ||
| 61 | __attribute__((weak)) void process_wheel_user(report_mouse_t* mouse_report, int16_t h, int16_t v) { | 68 | __attribute__((weak)) void process_wheel_user(report_mouse_t* mouse_report, int16_t h, int16_t v) { |
| 62 | mouse_report->h = h; | 69 | mouse_report->h = h; |
| @@ -151,17 +158,34 @@ bool process_record_kb(uint16_t keycode, keyrecord_t* record) { | |||
| 151 | 158 | ||
| 152 | // Update Timer to prevent accidental scrolls | 159 | // Update Timer to prevent accidental scrolls |
| 153 | if ((record->event.key.col == 1) && (record->event.key.row == 0)) { | 160 | if ((record->event.key.col == 1) && (record->event.key.row == 0)) { |
| 154 | lastMidClick = timer_read(); | 161 | lastMidClick = timer_read(); |
| 155 | is_scroll_clicked = record->event.pressed; | 162 | is_scroll_clicked = record->event.pressed; |
| 156 | } | 163 | } |
| 157 | 164 | ||
| 158 | if (!process_record_user(keycode, record)) { return false; } | 165 | if (!process_record_user(keycode, record)) { |
| 166 | return false; | ||
| 167 | } | ||
| 159 | 168 | ||
| 160 | if (keycode == DPI_CONFIG && record->event.pressed) { | 169 | if (keycode == DPI_CONFIG && record->event.pressed) { |
| 161 | keyboard_config.dpi_config = (keyboard_config.dpi_config + 1) % DPI_OPTION_SIZE; | 170 | keyboard_config.dpi_config = (keyboard_config.dpi_config + 1) % DPI_OPTION_SIZE; |
| 162 | eeconfig_update_kb(keyboard_config.raw); | 171 | eeconfig_update_kb(keyboard_config.raw); |
| 163 | pmw_set_cpi(dpi_array[keyboard_config.dpi_config]); | 172 | pmw_set_cpi(dpi_array[keyboard_config.dpi_config]); |
| 164 | } | 173 | } |
| 174 | |||
| 175 | if (keycode == DRAG_SCROLL) { | ||
| 176 | #ifndef PLOOPY_DRAGSCROLL_MOMENTARY | ||
| 177 | if (record->event.pressed) | ||
| 178 | #endif | ||
| 179 | { | ||
| 180 | is_drag_scroll ^= 1; | ||
| 181 | } | ||
| 182 | #ifdef PLOOPY_DRAGSCROLL_FIXED | ||
| 183 | pmw_set_cpi(is_drag_scroll ? PLOOPY_DRAGSCROLL_DPI : dpi_array[keyboard_config.dpi_config]); | ||
| 184 | #else | ||
| 185 | pmw_set_cpi(is_drag_scroll ? (dpi_array[keyboard_config.dpi_config] * PLOOPY_DRAGSCROLL_MULTIPLIER) : dpi_array[keyboard_config.dpi_config]); | ||
| 186 | #endif | ||
| 187 | } | ||
| 188 | |||
| 165 | /* If Mousekeys is disabled, then use handle the mouse button | 189 | /* If Mousekeys is disabled, then use handle the mouse button |
| 166 | * keycodes. This makes things simpler, and allows usage of | 190 | * keycodes. This makes things simpler, and allows usage of |
| 167 | * the keycodes in a consistent manner. But only do this if | 191 | * the keycodes in a consistent manner. But only do this if |
| @@ -223,24 +247,40 @@ void pointing_device_init(void) { | |||
| 223 | opt_encoder_init(); | 247 | opt_encoder_init(); |
| 224 | } | 248 | } |
| 225 | 249 | ||
| 226 | bool has_report_changed (report_mouse_t first, report_mouse_t second) { | 250 | bool has_report_changed(report_mouse_t new, report_mouse_t old) { return (new.buttons != old.buttons) || (new.x && new.x != old.x) || (new.y && new.y != old.y) || (new.h && new.h != old.h) || (new.v && new.v != old.v); } |
| 227 | return !( | ||
| 228 | (!first.buttons && first.buttons == second.buttons) && | ||
| 229 | (!first.x && first.x == second.x) && | ||
| 230 | (!first.y && first.y == second.y) && | ||
| 231 | (!first.h && first.h == second.h) && | ||
| 232 | (!first.v && first.v == second.v) ); | ||
| 233 | } | ||
| 234 | 251 | ||
| 235 | void pointing_device_task(void) { | 252 | void pointing_device_task(void) { |
| 236 | report_mouse_t mouse_report = pointing_device_get_report(); | 253 | report_mouse_t mouse_report = pointing_device_get_report(); |
| 237 | process_wheel(&mouse_report); | 254 | process_wheel(&mouse_report); |
| 238 | process_mouse(&mouse_report); | 255 | process_mouse(&mouse_report); |
| 239 | 256 | ||
| 257 | if (is_drag_scroll) { | ||
| 258 | mouse_report.h = mouse_report.x; | ||
| 259 | mouse_report.v = mouse_report.y; | ||
| 260 | mouse_report.x = 0; | ||
| 261 | mouse_report.y = 0; | ||
| 262 | } | ||
| 263 | |||
| 240 | pointing_device_set_report(mouse_report); | 264 | pointing_device_set_report(mouse_report); |
| 241 | if (has_report_changed(mouse_report, pointing_device_get_report())) { | 265 | pointing_device_send(); |
| 242 | pointing_device_send(); | 266 | } |
| 267 | |||
| 268 | void pointing_device_send(void) { | ||
| 269 | static report_mouse_t old_report = {}; | ||
| 270 | report_mouse_t mouseReport = pointing_device_get_report(); | ||
| 271 | |||
| 272 | // If you need to do other things, like debugging, this is the place to do it. | ||
| 273 | if (has_report_changed(mouseReport, old_report)) { | ||
| 274 | host_mouse_send(&mouseReport); | ||
| 243 | } | 275 | } |
| 276 | |||
| 277 | // send it and 0 it out except for buttons, so those stay until they are explicity over-ridden using update_pointing_device | ||
| 278 | mouseReport.x = 0; | ||
| 279 | mouseReport.y = 0; | ||
| 280 | mouseReport.v = 0; | ||
| 281 | mouseReport.h = 0; | ||
| 282 | pointing_device_set_report(mouseReport); | ||
| 283 | old_report = mouseReport; | ||
| 244 | } | 284 | } |
| 245 | 285 | ||
| 246 | void eeconfig_init_kb(void) { | 286 | void eeconfig_init_kb(void) { |
