add mouse acceleration.
This commit is contained in:
parent
7e3975e0ef
commit
df5b4ea7d9
53
mykey.c
53
mykey.c
@ -29,7 +29,6 @@
|
|||||||
#include <avr/pgmspace.h>
|
#include <avr/pgmspace.h>
|
||||||
#include <avr/interrupt.h>
|
#include <avr/interrupt.h>
|
||||||
#include <util/delay.h>
|
#include <util/delay.h>
|
||||||
|
|
||||||
#include "usb.h"
|
#include "usb.h"
|
||||||
#include "usb_keyboard.h"
|
#include "usb_keyboard.h"
|
||||||
#include "usb_mouse.h"
|
#include "usb_mouse.h"
|
||||||
@ -38,18 +37,24 @@
|
|||||||
#include "keymap.h"
|
#include "keymap.h"
|
||||||
#include "jump_bootloader.h"
|
#include "jump_bootloader.h"
|
||||||
|
|
||||||
|
|
||||||
|
// for teensy 2.0
|
||||||
#define LED_CONFIG (DDRD |= (1<<6))
|
#define LED_CONFIG (DDRD |= (1<<6))
|
||||||
#define LED_ON (PORTD &= ~(1<<6))
|
#define LED_ON (PORTD |= (1<<6))
|
||||||
#define LED_OFF (PORTD |= (1<<6))
|
#define LED_OFF (PORTD &= ~(1<<6))
|
||||||
#define CPU_PRESCALE(n) (CLKPR = 0x80, CLKPR = (n))
|
#define CPU_PRESCALE(n) (CLKPR = 0x80, CLKPR = (n))
|
||||||
|
|
||||||
|
#define MOUSE_MOVE_UNIT 10
|
||||||
|
#define MOUSE_DELAY_MS 200
|
||||||
|
#define MOUSE_DELAY_ACC 4
|
||||||
|
|
||||||
|
|
||||||
static void print_matrix(void);
|
static void print_matrix(void);
|
||||||
|
|
||||||
|
|
||||||
uint16_t idle_count=0;
|
uint16_t idle_count=0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
// set for 16 MHz clock
|
// set for 16 MHz clock
|
||||||
@ -63,7 +68,14 @@ int main(void)
|
|||||||
|
|
||||||
// Wait an extra second for the PC's operating system to load drivers
|
// Wait an extra second for the PC's operating system to load drivers
|
||||||
// and do whatever it does to actually be ready for input
|
// and do whatever it does to actually be ready for input
|
||||||
_delay_ms(1000);
|
// needs such long time in my PC.
|
||||||
|
for (int i =0; i < 6; i++) {
|
||||||
|
LED_CONFIG;
|
||||||
|
LED_ON;
|
||||||
|
_delay_ms(500);
|
||||||
|
LED_OFF;
|
||||||
|
_delay_ms(500);
|
||||||
|
}
|
||||||
|
|
||||||
// Configure timer 0 to generate a timer overflow interrupt every
|
// Configure timer 0 to generate a timer overflow interrupt every
|
||||||
// 256*1024 clock cycles, or approx 61 Hz when using 16 MHz clock
|
// 256*1024 clock cycles, or approx 61 Hz when using 16 MHz clock
|
||||||
@ -75,7 +87,6 @@ int main(void)
|
|||||||
|
|
||||||
|
|
||||||
matrix_init();
|
matrix_init();
|
||||||
print("firmware 0.3 for t.m.k.\n");
|
|
||||||
|
|
||||||
bool modified = false;
|
bool modified = false;
|
||||||
bool has_ghost = false;
|
bool has_ghost = false;
|
||||||
@ -86,6 +97,9 @@ int main(void)
|
|||||||
uint8_t mouse_btn = 0;
|
uint8_t mouse_btn = 0;
|
||||||
int8_t mouse_wheel = 0;
|
int8_t mouse_wheel = 0;
|
||||||
int8_t mouse_hwheel = 0;
|
int8_t mouse_hwheel = 0;
|
||||||
|
int mouse_repeat = 0;
|
||||||
|
|
||||||
|
print("\nt.m.k. keyboard 1.0\n");
|
||||||
while (1) {
|
while (1) {
|
||||||
matrix_scan();
|
matrix_scan();
|
||||||
modified = matrix_is_modified();
|
modified = matrix_is_modified();
|
||||||
@ -96,9 +110,8 @@ int main(void)
|
|||||||
if (modified) {
|
if (modified) {
|
||||||
print_matrix();
|
print_matrix();
|
||||||
|
|
||||||
// LED flush
|
LED_CONFIG;
|
||||||
DDRD |= 1<<PD6;
|
LED_ON;
|
||||||
PORTD |= 1<<PD6;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
keyboard_modifier_keys = 0;
|
keyboard_modifier_keys = 0;
|
||||||
@ -119,14 +132,14 @@ int main(void)
|
|||||||
if (code == KB_NO) {
|
if (code == KB_NO) {
|
||||||
continue;
|
continue;
|
||||||
} else if (KB_LCTRL <= code && code <= KB_RGUI) {
|
} else if (KB_LCTRL <= code && code <= KB_RGUI) {
|
||||||
// modifier keycode: 0xE0-0xE7
|
// modifier keys(0xE0-0xE7)
|
||||||
keyboard_modifier_keys |= 1<<(code & 0x07);
|
keyboard_modifier_keys |= 1<<(code & 0x07);
|
||||||
} else if (code >= MS_UP) {
|
} else if (code >= MS_UP) {
|
||||||
// mouse
|
// mouse
|
||||||
if (code == MS_UP) mouse_y -= 15;
|
if (code == MS_UP) mouse_y -= MOUSE_MOVE_UNIT;
|
||||||
if (code == MS_DOWN) mouse_y += 15;
|
if (code == MS_DOWN) mouse_y += MOUSE_MOVE_UNIT;
|
||||||
if (code == MS_LEFT) mouse_x -= 15;
|
if (code == MS_LEFT) mouse_x -= MOUSE_MOVE_UNIT;
|
||||||
if (code == MS_RIGHT) mouse_x += 15;
|
if (code == MS_RIGHT) mouse_x += MOUSE_MOVE_UNIT;
|
||||||
if (code == MS_BTN1) mouse_btn |= 1<<0;
|
if (code == MS_BTN1) mouse_btn |= 1<<0;
|
||||||
if (code == MS_BTN2) mouse_btn |= 1<<1;
|
if (code == MS_BTN2) mouse_btn |= 1<<1;
|
||||||
if (code == MS_BTN3) mouse_btn |= 1<<2;
|
if (code == MS_BTN3) mouse_btn |= 1<<2;
|
||||||
@ -137,6 +150,7 @@ int main(void)
|
|||||||
if (code == MS_WH_LEFT) mouse_hwheel -= 1;
|
if (code == MS_WH_LEFT) mouse_hwheel -= 1;
|
||||||
if (code == MS_WH_RIGHT) mouse_hwheel += 1;
|
if (code == MS_WH_RIGHT) mouse_hwheel += 1;
|
||||||
} else {
|
} else {
|
||||||
|
// normal keys
|
||||||
if (key_index < 6)
|
if (key_index < 6)
|
||||||
keyboard_keys[key_index] = code;
|
keyboard_keys[key_index] = code;
|
||||||
key_index++;
|
key_index++;
|
||||||
@ -153,16 +167,19 @@ int main(void)
|
|||||||
usb_keyboard_send();
|
usb_keyboard_send();
|
||||||
|
|
||||||
print("jump to bootloader...\n");
|
print("jump to bootloader...\n");
|
||||||
_delay_ms(1000);
|
_delay_ms(100);
|
||||||
jump_bootloader(); // not return
|
jump_bootloader(); // not return
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mouse_x || mouse_y || mouse_wheel || mouse_hwheel || mouse_btn != mouse_buttons) {
|
if (mouse_x || mouse_y || mouse_wheel || mouse_hwheel || mouse_btn != mouse_buttons) {
|
||||||
mouse_buttons = mouse_btn;
|
mouse_buttons = mouse_btn;
|
||||||
print("mouse_buttons: 0b"); pbin(mouse_buttons); print("\n");
|
|
||||||
print("mouse_wheel: 0x"); phex(mouse_wheel); print("\n");
|
|
||||||
usb_mouse_move(mouse_x, mouse_y, mouse_wheel, mouse_hwheel);
|
usb_mouse_move(mouse_x, mouse_y, mouse_wheel, mouse_hwheel);
|
||||||
_delay_ms(100);
|
|
||||||
|
// acceleration
|
||||||
|
_delay_ms(MOUSE_DELAY_MS >> (mouse_repeat < MOUSE_DELAY_ACC ? mouse_repeat : MOUSE_DELAY_ACC));
|
||||||
|
mouse_repeat++;
|
||||||
|
} else {
|
||||||
|
mouse_repeat = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user