Fix action of system and consumer usage.
This commit is contained in:
parent
8a709c2750
commit
4324e16336
|
@ -415,89 +415,6 @@ static void register_code(uint8_t code)
|
||||||
host_add_mods(MOD_BIT(code));
|
host_add_mods(MOD_BIT(code));
|
||||||
host_send_keyboard_report();
|
host_send_keyboard_report();
|
||||||
}
|
}
|
||||||
#ifdef MOUSEKEY_ENABLE
|
|
||||||
else if IS_MOUSEKEY(code) {
|
|
||||||
mousekey_on(code);
|
|
||||||
mousekey_send();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#ifdef EXTRAKEY_ENABLE
|
|
||||||
else if IS_CONSUMER(code) {
|
|
||||||
uint16_t usage = 0;
|
|
||||||
switch (code) {
|
|
||||||
case KC_AUDIO_MUTE:
|
|
||||||
usage = AUDIO_MUTE;
|
|
||||||
break;
|
|
||||||
case KC_AUDIO_VOL_UP:
|
|
||||||
usage = AUDIO_VOL_UP;
|
|
||||||
break;
|
|
||||||
case KC_AUDIO_VOL_DOWN:
|
|
||||||
usage = AUDIO_VOL_DOWN;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_NEXT_TRACK:
|
|
||||||
usage = TRANSPORT_NEXT_TRACK;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_PREV_TRACK:
|
|
||||||
usage = TRANSPORT_PREV_TRACK;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_STOP:
|
|
||||||
usage = TRANSPORT_STOP;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_PLAY_PAUSE:
|
|
||||||
usage = TRANSPORT_PLAY_PAUSE;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_SELECT:
|
|
||||||
usage = AL_CC_CONFIG;
|
|
||||||
break;
|
|
||||||
case KC_MAIL:
|
|
||||||
usage = AL_EMAIL;
|
|
||||||
break;
|
|
||||||
case KC_CALCULATOR:
|
|
||||||
usage = AL_CALCULATOR;
|
|
||||||
break;
|
|
||||||
case KC_MY_COMPUTER:
|
|
||||||
usage = AL_LOCAL_BROWSER;
|
|
||||||
break;
|
|
||||||
case KC_WWW_SEARCH:
|
|
||||||
usage = AC_SEARCH;
|
|
||||||
break;
|
|
||||||
case KC_WWW_HOME:
|
|
||||||
usage = AC_HOME;
|
|
||||||
break;
|
|
||||||
case KC_WWW_BACK:
|
|
||||||
usage = AC_BACK;
|
|
||||||
break;
|
|
||||||
case KC_WWW_FORWARD:
|
|
||||||
usage = AC_FORWARD;
|
|
||||||
break;
|
|
||||||
case KC_WWW_STOP:
|
|
||||||
usage = AC_STOP;
|
|
||||||
break;
|
|
||||||
case KC_WWW_REFRESH:
|
|
||||||
usage = AC_REFRESH;
|
|
||||||
break;
|
|
||||||
case KC_WWW_FAVORITES:
|
|
||||||
usage = AC_BOOKMARKS;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
host_consumer_send(usage);
|
|
||||||
}
|
|
||||||
else if IS_SYSTEM(code) {
|
|
||||||
uint16_t usage = 0;
|
|
||||||
switch (code) {
|
|
||||||
case KC_SYSTEM_POWER:
|
|
||||||
usage = SYSTEM_POWER_DOWN;
|
|
||||||
break;
|
|
||||||
case KC_SYSTEM_SLEEP:
|
|
||||||
usage = SYSTEM_SLEEP;
|
|
||||||
break;
|
|
||||||
case KC_SYSTEM_WAKE:
|
|
||||||
usage = SYSTEM_WAKE_UP;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
host_system_send(usage);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void unregister_code(uint8_t code)
|
static void unregister_code(uint8_t code)
|
||||||
|
@ -510,20 +427,6 @@ static void unregister_code(uint8_t code)
|
||||||
host_del_mods(MOD_BIT(code));
|
host_del_mods(MOD_BIT(code));
|
||||||
host_send_keyboard_report();
|
host_send_keyboard_report();
|
||||||
}
|
}
|
||||||
#ifdef MOUSEKEY_ENABLE
|
|
||||||
else if IS_MOUSEKEY(code) {
|
|
||||||
mousekey_off(code);
|
|
||||||
mousekey_send();
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#ifdef EXTRAKEY_ENABLE
|
|
||||||
else if IS_CONSUMER(code) {
|
|
||||||
host_consumer_send(0x0000);
|
|
||||||
}
|
|
||||||
else if IS_SYSTEM(code) {
|
|
||||||
host_system_send(0x0000);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void register_mods(uint8_t mods)
|
static void register_mods(uint8_t mods)
|
||||||
|
|
119
common/report.h
119
common/report.h
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
Copyright 2011 Jun Wako <wakojun@gmail.com>
|
Copyright 2011,2012 Jun Wako <wakojun@gmail.com>
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
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
|
it under the terms of the GNU General Public License as published by
|
||||||
|
@ -19,7 +19,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define REPORT_H
|
#define REPORT_H
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <keycode.h>
|
#include "keycode.h"
|
||||||
|
|
||||||
|
|
||||||
/* report id */
|
/* report id */
|
||||||
|
@ -34,8 +34,9 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define MOUSE_BTN4 (1<<3)
|
#define MOUSE_BTN4 (1<<3)
|
||||||
#define MOUSE_BTN5 (1<<4)
|
#define MOUSE_BTN5 (1<<4)
|
||||||
|
|
||||||
// Consumer Page(0x0C)
|
/* Consumer Page(0x0C)
|
||||||
// following are supported by Windows: http://msdn.microsoft.com/en-us/windows/hardware/gg463372.aspx
|
* following are supported by Windows: http://msdn.microsoft.com/en-us/windows/hardware/gg463372.aspx
|
||||||
|
*/
|
||||||
#define AUDIO_MUTE 0x00E2
|
#define AUDIO_MUTE 0x00E2
|
||||||
#define AUDIO_VOL_UP 0x00E9
|
#define AUDIO_VOL_UP 0x00E9
|
||||||
#define AUDIO_VOL_DOWN 0x00EA
|
#define AUDIO_VOL_DOWN 0x00EA
|
||||||
|
@ -43,10 +44,12 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define TRANSPORT_PREV_TRACK 0x00B6
|
#define TRANSPORT_PREV_TRACK 0x00B6
|
||||||
#define TRANSPORT_STOP 0x00B7
|
#define TRANSPORT_STOP 0x00B7
|
||||||
#define TRANSPORT_PLAY_PAUSE 0x00CD
|
#define TRANSPORT_PLAY_PAUSE 0x00CD
|
||||||
|
/* application launch */
|
||||||
#define AL_CC_CONFIG 0x0183
|
#define AL_CC_CONFIG 0x0183
|
||||||
#define AL_EMAIL 0x018A
|
#define AL_EMAIL 0x018A
|
||||||
#define AL_CALCULATOR 0x0192
|
#define AL_CALCULATOR 0x0192
|
||||||
#define AL_LOCAL_BROWSER 0x0194
|
#define AL_LOCAL_BROWSER 0x0194
|
||||||
|
/* application control */
|
||||||
#define AC_SEARCH 0x0221
|
#define AC_SEARCH 0x0221
|
||||||
#define AC_HOME 0x0223
|
#define AC_HOME 0x0223
|
||||||
#define AC_BACK 0x0224
|
#define AC_BACK 0x0224
|
||||||
|
@ -54,20 +57,20 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#define AC_STOP 0x0226
|
#define AC_STOP 0x0226
|
||||||
#define AC_REFRESH 0x0227
|
#define AC_REFRESH 0x0227
|
||||||
#define AC_BOOKMARKS 0x022A
|
#define AC_BOOKMARKS 0x022A
|
||||||
// supplement for Bluegiga iWRAP HID(not supported by Windows?)
|
/* supplement for Bluegiga iWRAP HID(not supported by Windows?) */
|
||||||
#define AL_LOCK 0x019E
|
#define AL_LOCK 0x019E
|
||||||
#define TRANSPORT_RECORD 0x00B2
|
#define TRANSPORT_RECORD 0x00B2
|
||||||
#define TRANSPORT_REWIND 0x00B4
|
#define TRANSPORT_REWIND 0x00B4
|
||||||
#define TRANSPORT_EJECT 0x00B8
|
#define TRANSPORT_EJECT 0x00B8
|
||||||
#define AC_MINIMIZE 0x0206
|
#define AC_MINIMIZE 0x0206
|
||||||
|
|
||||||
// Generic Desktop Page(0x01)
|
/* Generic Desktop Page(0x01) - system power control */
|
||||||
#define SYSTEM_POWER_DOWN 0x0081
|
#define SYSTEM_POWER_DOWN 0x0081
|
||||||
#define SYSTEM_SLEEP 0x0082
|
#define SYSTEM_SLEEP 0x0082
|
||||||
#define SYSTEM_WAKE_UP 0x0083
|
#define SYSTEM_WAKE_UP 0x0083
|
||||||
|
|
||||||
|
|
||||||
// key report size(NKRO or boot mode)
|
/* key report size(NKRO or boot mode) */
|
||||||
#if defined(HOST_PJRC)
|
#if defined(HOST_PJRC)
|
||||||
# include "usb.h"
|
# include "usb.h"
|
||||||
# if defined(KBD2_REPORT_KEYS) && KBD2_REPORT_KEYS > KBD_REPORT_KEYS
|
# if defined(KBD2_REPORT_KEYS) && KBD2_REPORT_KEYS > KBD_REPORT_KEYS
|
||||||
|
@ -99,84 +102,32 @@ typedef struct {
|
||||||
} __attribute__ ((packed)) report_mouse_t;
|
} __attribute__ ((packed)) report_mouse_t;
|
||||||
|
|
||||||
|
|
||||||
static uint16_t key2system(uint8_t key)
|
/* keycode to system usage */
|
||||||
{
|
#define KEYCODE2SYSTEM(key) \
|
||||||
uint16_t usage = 0;
|
(key == KC_SYSTEM_POWER ? SYSTEM_POWER_DOWN : \
|
||||||
switch (key) {
|
(key == KC_SYSTEM_SLEEP ? SYSTEM_SLEEP : \
|
||||||
case KC_SYSTEM_POWER:
|
(key == KC_SYSTEM_WAKE ? SYSTEM_WAKE_UP : 0)))
|
||||||
usage = SYSTEM_POWER_DOWN;
|
|
||||||
break;
|
|
||||||
case KC_SYSTEM_SLEEP:
|
|
||||||
usage = SYSTEM_SLEEP;
|
|
||||||
break;
|
|
||||||
case KC_SYSTEM_WAKE:
|
|
||||||
usage = SYSTEM_WAKE_UP;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return usage;
|
|
||||||
}
|
|
||||||
|
|
||||||
static uint16_t key2consumer(uint8_t key)
|
/* keycode to consumer usage */
|
||||||
{
|
#define KEYCODE2CONSUMER(key) \
|
||||||
uint16_t usage = 0;
|
(key == KC_AUDIO_MUTE ? AUDIO_MUTE : \
|
||||||
switch (key) {
|
(key == KC_AUDIO_VOL_UP ? AUDIO_VOL_UP : \
|
||||||
case KC_AUDIO_MUTE:
|
(key == KC_AUDIO_VOL_DOWN ? AUDIO_VOL_DOWN : \
|
||||||
usage = AUDIO_MUTE;
|
(key == KC_MEDIA_NEXT_TRACK ? TRANSPORT_NEXT_TRACK : \
|
||||||
break;
|
(key == KC_MEDIA_PREV_TRACK ? TRANSPORT_PREV_TRACK : \
|
||||||
case KC_AUDIO_VOL_UP:
|
(key == KC_MEDIA_STOP ? TRANSPORT_STOP : \
|
||||||
usage = AUDIO_VOL_UP;
|
(key == KC_MEDIA_PLAY_PAUSE ? TRANSPORT_PLAY_PAUSE : \
|
||||||
break;
|
(key == KC_MEDIA_SELECT ? AL_CC_CONFIG : \
|
||||||
case KC_AUDIO_VOL_DOWN:
|
(key == KC_MAIL ? AL_EMAIL : \
|
||||||
usage = AUDIO_VOL_DOWN;
|
(key == KC_CALCULATOR ? AL_CALCULATOR : \
|
||||||
break;
|
(key == KC_MY_COMPUTER ? AL_LOCAL_BROWSER : \
|
||||||
case KC_MEDIA_NEXT_TRACK:
|
(key == KC_WWW_SEARCH ? AC_SEARCH : \
|
||||||
usage = TRANSPORT_NEXT_TRACK;
|
(key == KC_WWW_HOME ? AC_HOME : \
|
||||||
break;
|
(key == KC_WWW_BACK ? AC_BACK : \
|
||||||
case KC_MEDIA_PREV_TRACK:
|
(key == KC_WWW_FORWARD ? AC_FORWARD : \
|
||||||
usage = TRANSPORT_PREV_TRACK;
|
(key == KC_WWW_STOP ? AC_STOP : \
|
||||||
break;
|
(key == KC_WWW_REFRESH ? AC_REFRESH : \
|
||||||
case KC_MEDIA_STOP:
|
(key == KC_WWW_FAVORITES ? AC_BOOKMARKS : 0))))))))))))))))))
|
||||||
usage = TRANSPORT_STOP;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_PLAY_PAUSE:
|
|
||||||
usage = TRANSPORT_PLAY_PAUSE;
|
|
||||||
break;
|
|
||||||
case KC_MEDIA_SELECT:
|
|
||||||
usage = AL_CC_CONFIG;
|
|
||||||
break;
|
|
||||||
case KC_MAIL:
|
|
||||||
usage = AL_EMAIL;
|
|
||||||
break;
|
|
||||||
case KC_CALCULATOR:
|
|
||||||
usage = AL_CALCULATOR;
|
|
||||||
break;
|
|
||||||
case KC_MY_COMPUTER:
|
|
||||||
usage = AL_LOCAL_BROWSER;
|
|
||||||
break;
|
|
||||||
case KC_WWW_SEARCH:
|
|
||||||
usage = AC_SEARCH;
|
|
||||||
break;
|
|
||||||
case KC_WWW_HOME:
|
|
||||||
usage = AC_HOME;
|
|
||||||
break;
|
|
||||||
case KC_WWW_BACK:
|
|
||||||
usage = AC_BACK;
|
|
||||||
break;
|
|
||||||
case KC_WWW_FORWARD:
|
|
||||||
usage = AC_FORWARD;
|
|
||||||
break;
|
|
||||||
case KC_WWW_STOP:
|
|
||||||
usage = AC_STOP;
|
|
||||||
break;
|
|
||||||
case KC_WWW_REFRESH:
|
|
||||||
usage = AC_REFRESH;
|
|
||||||
break;
|
|
||||||
case KC_WWW_FAVORITES:
|
|
||||||
usage = AC_BOOKMARKS;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return usage;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -186,10 +186,10 @@ action_t keymap_get_action(uint8_t layer, uint8_t row, uint8_t col) {
|
||||||
action = (action_t)ACTION_KEY(key);
|
action = (action_t)ACTION_KEY(key);
|
||||||
break;
|
break;
|
||||||
case KC_SYSTEM_POWER ... KC_SYSTEM_WAKE:
|
case KC_SYSTEM_POWER ... KC_SYSTEM_WAKE:
|
||||||
action = (action_t)ACTION_USAGE_SYSTEM(key2system(key));
|
action = (action_t)ACTION_USAGE_SYSTEM(KEYCODE2SYSTEM(key));
|
||||||
break;
|
break;
|
||||||
case KC_AUDIO_MUTE ... KC_WWW_FAVORITES:
|
case KC_AUDIO_MUTE ... KC_WWW_FAVORITES:
|
||||||
action = (action_t)ACTION_USAGE_CONSUMER(key2consumer(key));
|
action = (action_t)ACTION_USAGE_CONSUMER(KEYCODE2CONSUMER(key));
|
||||||
break;
|
break;
|
||||||
case KC_MS_UP ... KC_MS_ACCEL2:
|
case KC_MS_UP ... KC_MS_ACCEL2:
|
||||||
action = (action_t)ACTION_MOUSEKEY(key);
|
action = (action_t)ACTION_MOUSEKEY(key);
|
||||||
|
|
Loading…
Reference in New Issue