mirror of
https://github.com/jjsullivan5196/wvkbd.git
synced 2025-04-06 00:46:51 +02:00
Compare commits
9 Commits
acb1b4eeff
...
c17c1d3da5
Author | SHA1 | Date | |
---|---|---|---|
|
c17c1d3da5 | ||
|
621079c221 | ||
|
231623a9c6 | ||
|
fe3257450a | ||
|
1852b3ab06 | ||
|
9d130e7fd2 | ||
|
2f72b176cb | ||
|
f1a1865f6b | ||
|
100764a10c |
43
config.h
Normal file
43
config.h
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#ifndef config_def_h_INCLUDED
|
||||||
|
#define config_def_h_INCLUDED
|
||||||
|
|
||||||
|
#define DEFAULT_FONT "Sans 14"
|
||||||
|
#define DEFAULT_ROUNDING 5
|
||||||
|
static const int transparency = 255;
|
||||||
|
|
||||||
|
struct clr_scheme schemes[] = {
|
||||||
|
{
|
||||||
|
/* colors */
|
||||||
|
.bg = {.bgra = {54, 42, 40, transparency}},
|
||||||
|
.fg = {.bgra = {164, 114, 98, transparency}},
|
||||||
|
.high = {.bgra = {100, 100, 100, transparency}},
|
||||||
|
.swipe = {.bgra = {100, 255, 100, 64}},
|
||||||
|
.text = {.color = UINT32_MAX},
|
||||||
|
.font = DEFAULT_FONT,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
/* colors */
|
||||||
|
.bg = {.bgra = {54, 42, 40, transparency}},
|
||||||
|
.fg = {.bgra = {90, 71, 68, transparency}},
|
||||||
|
.high = {.bgra = {100, 100, 100, transparency}},
|
||||||
|
.swipe = {.bgra = {100, 255, 100, 64}},
|
||||||
|
.text = {.color = UINT32_MAX},
|
||||||
|
.font = DEFAULT_FONT,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* layers is an ordered list of layouts, used to cycle through */
|
||||||
|
static enum layout_id layers[] = {
|
||||||
|
Full, // First layout is the default layout on startup
|
||||||
|
Special,
|
||||||
|
NumLayouts // signals the last item, may not be omitted
|
||||||
|
};
|
||||||
|
|
||||||
|
/* layers is an ordered list of layouts, used to cycle through */
|
||||||
|
static enum layout_id landscape_layers[] = {
|
||||||
|
Landscape, // First layout is the default layout on startup
|
||||||
|
LandscapeSpecial,
|
||||||
|
NumLayouts // signals the last item, may not be omitted
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // config_def_h_INCLUDED
|
@ -1,4 +1,4 @@
|
|||||||
VERSION = 0.14.3
|
VERSION = 0.16
|
||||||
CFLAGS = -DVERSION=\"$(VERSION)\" -D_XOPEN_SOURCE=700
|
CFLAGS = -DVERSION=\"$(VERSION)\" -D_XOPEN_SOURCE=700
|
||||||
PREFIX = /usr/local
|
PREFIX = /usr/local
|
||||||
MANPREFIX = ${PREFIX}/share/man
|
MANPREFIX = ${PREFIX}/share/man
|
||||||
|
22
keyboard.c
22
keyboard.c
@ -276,13 +276,23 @@ kbd_get_layer_index(struct kbd *kb, struct layout *l)
|
|||||||
void
|
void
|
||||||
kbd_unpress_key(struct kbd *kb, uint32_t time)
|
kbd_unpress_key(struct kbd *kb, uint32_t time)
|
||||||
{
|
{
|
||||||
bool unlatch_shift = false;
|
bool unlatch_shift, unlatch_ctrl, unlatch_alt, unlatch_super, unlatch_altgr;
|
||||||
|
unlatch_shift = unlatch_ctrl = unlatch_alt = unlatch_super = unlatch_altgr = false;
|
||||||
|
|
||||||
if (kb->last_press) {
|
if (kb->last_press) {
|
||||||
unlatch_shift = (kb->mods & Shift) == Shift;
|
unlatch_shift = (kb->mods & Shift) == Shift;
|
||||||
|
unlatch_ctrl = (kb->mods & Ctrl) == Ctrl;
|
||||||
|
unlatch_alt = (kb->mods & Alt) == Alt;
|
||||||
|
unlatch_super = (kb->mods & Super) == Super;
|
||||||
|
unlatch_altgr = (kb->mods & AltGr) == AltGr;
|
||||||
|
|
||||||
if (unlatch_shift) {
|
if (unlatch_shift) kb->mods ^= Shift;
|
||||||
kb->mods ^= Shift;
|
if (unlatch_ctrl) kb->mods ^= Ctrl;
|
||||||
|
if (unlatch_alt) kb->mods ^= Alt;
|
||||||
|
if (unlatch_super) kb->mods ^= Super;
|
||||||
|
if (unlatch_altgr) kb->mods ^= AltGr;
|
||||||
|
|
||||||
|
if (unlatch_shift||unlatch_ctrl||unlatch_alt||unlatch_super||unlatch_altgr) {
|
||||||
zwp_virtual_keyboard_v1_modifiers(kb->vkbd, kb->mods, 0, 0, 0);
|
zwp_virtual_keyboard_v1_modifiers(kb->vkbd, kb->mods, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -304,7 +314,7 @@ kbd_unpress_key(struct kbd *kb, uint32_t time)
|
|||||||
if (kb->compose >= 2) {
|
if (kb->compose >= 2) {
|
||||||
kb->compose = 0;
|
kb->compose = 0;
|
||||||
kbd_switch_layout(kb, kb->last_abc_layout, kb->last_abc_index);
|
kbd_switch_layout(kb, kb->last_abc_layout, kb->last_abc_index);
|
||||||
} else if (unlatch_shift) {
|
} else if (unlatch_shift||unlatch_ctrl||unlatch_alt||unlatch_super||unlatch_altgr) {
|
||||||
kbd_draw_layout(kb);
|
kbd_draw_layout(kb);
|
||||||
} else {
|
} else {
|
||||||
kbd_draw_key(kb, kb->last_press, Unpress);
|
kbd_draw_key(kb, kb->last_press, Unpress);
|
||||||
@ -418,7 +428,7 @@ kbd_press_key(struct kbd *kb, struct key *k, uint32_t time)
|
|||||||
break;
|
break;
|
||||||
case Mod:
|
case Mod:
|
||||||
kb->mods ^= k->code;
|
kb->mods ^= k->code;
|
||||||
if (k->code == Shift) {
|
if ((k->code == Shift) || (k->code == CapsLock)) {
|
||||||
kbd_draw_layout(kb);
|
kbd_draw_layout(kb);
|
||||||
} else {
|
} else {
|
||||||
if (kb->mods & k->code) {
|
if (kb->mods & k->code) {
|
||||||
@ -551,7 +561,7 @@ kbd_clear_last_popup(struct kbd *kb)
|
|||||||
void
|
void
|
||||||
kbd_draw_key(struct kbd *kb, struct key *k, enum key_draw_type type)
|
kbd_draw_key(struct kbd *kb, struct key *k, enum key_draw_type type)
|
||||||
{
|
{
|
||||||
const char *label = (kb->mods & Shift) ? k->shift_label : k->label;
|
const char *label = ((kb->mods & Shift)||(kb->mods & CapsLock)) ? k->shift_label : k->label;
|
||||||
if (kb->debug)
|
if (kb->debug)
|
||||||
fprintf(stderr, "Draw key +%d+%d %dx%d -> %s\n", k->x, k->y, k->w, k->h,
|
fprintf(stderr, "Draw key +%d+%d %dx%d -> %s\n", k->x, k->y, k->w, k->h,
|
||||||
label);
|
label);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user