mirror of
https://github.com/clockworkpi/uConsole.git
synced 2025-12-12 18:18:50 +01:00
commit
c309e150e7
@ -67,7 +67,7 @@ const uint16_t keyboard_maps[][MATRIX_KEYS] = {
|
||||
},
|
||||
|
||||
[FN_LAYER] = {
|
||||
_PRINT_KEY, _PAUSE_KEY, _VOLUME_P, '`', '[', ']', KEY_F11, KEY_F12, \
|
||||
_PRINT_KEY, _PAUSE_KEY, _VOLUME_MUTE, '`', '[', ']', KEY_F11, KEY_F12, \
|
||||
KEY_F1, KEY_F2, KEY_F3, KEY_F4, KEY_F5, KEY_F6, KEY_F7, KEY_F8, \
|
||||
KEY_F9, KEY_F10, _FN_LOCK_KEYBOARD, KEY_CAPS_LOCK, EMP, EMP, EMP, EMP, \
|
||||
'q', 'w', 'e', 'r', 't', 'y', KEY_PAGE_UP, KEY_INSERT, \
|
||||
@ -251,18 +251,20 @@ void keyboard_action(DEVTERM*dv, uint8_t row, uint8_t col, uint8_t mode) {
|
||||
|
||||
case _VOLUME_P: {
|
||||
if (mode == KEY_PRESSED) {
|
||||
if (dv->Keyboard_state.sf_on > 0) {
|
||||
dv->Consumer->press(HIDConsumer::MUTE);
|
||||
} else {
|
||||
dv->Consumer->press(HIDConsumer::VOLUME_UP);
|
||||
}
|
||||
dv->Consumer->press(HIDConsumer::VOLUME_UP);
|
||||
} else {
|
||||
keyboard_release(dv, addr, k);
|
||||
}
|
||||
} break;
|
||||
case _VOLUME_M: {
|
||||
if (mode == KEY_PRESSED) {
|
||||
dv->Consumer->press(HIDConsumer::VOLUME_DOWN);
|
||||
if (dv->Keyboard_state.sf_on > 0) {
|
||||
dv->Keyboard->release(_LEFT_SHIFT_KEY);
|
||||
dv->Keyboard->release(KEY_RIGHT_SHIFT);
|
||||
dv->Consumer->press(HIDConsumer::VOLUME_UP);
|
||||
} else {
|
||||
dv->Consumer->press(HIDConsumer::VOLUME_DOWN);
|
||||
}
|
||||
} else {
|
||||
keyboard_release(dv, addr, k);
|
||||
}
|
||||
@ -319,7 +321,6 @@ void keypad_release_core(DEVTERM*dv, uint16_t k) {
|
||||
|
||||
switch (k) {
|
||||
case _FN_SHIFT:
|
||||
dv->Keyboard_state.sf_on = 0;
|
||||
break;
|
||||
case _LEFT_SHIFT_KEY:
|
||||
case KEY_RIGHT_SHIFT:
|
||||
@ -327,6 +328,7 @@ void keypad_release_core(DEVTERM*dv, uint16_t k) {
|
||||
dv->Keyboard->release(k);
|
||||
dv->Keyboard_state.shift.begin = 0;
|
||||
dv->Keyboard_state.shift.time = 0;
|
||||
dv->Keyboard_state.sf_on = 0;
|
||||
}
|
||||
break;
|
||||
|
||||
@ -474,11 +476,7 @@ void keypad_action(DEVTERM*dv, uint8_t col, uint8_t mode) {
|
||||
|
||||
switch (k) {
|
||||
case _FN_SHIFT:
|
||||
if (mode == KEY_PRESSED) {
|
||||
dv->Keyboard_state.sf_on = k;
|
||||
} else {
|
||||
keypad_release(dv, col, k);
|
||||
}
|
||||
break;
|
||||
case _LEFT_SHIFT_KEY:
|
||||
case KEY_RIGHT_SHIFT:
|
||||
@ -486,6 +484,7 @@ void keypad_action(DEVTERM*dv, uint8_t col, uint8_t mode) {
|
||||
if (dv->Keyboard_state.shift.lock == 0) {
|
||||
dv->Keyboard->press(k);
|
||||
dv->Keyboard_state.shift.begin = k;
|
||||
dv->Keyboard_state.sf_on = k;
|
||||
}
|
||||
} else if (mode == KEY_RELEASED) {
|
||||
keypad_release(dv, col, k);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user