mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-11 14:30:08 +00:00
Persist the current soft touch keyboard variant
This commit is contained in:
parent
44b2e564d4
commit
dadf5e02a1
@ -68,6 +68,7 @@
|
|||||||
#define PREF_GLYPH_MULTIPLIER "glyphMultiplier"
|
#define PREF_GLYPH_MULTIPLIER "glyphMultiplier"
|
||||||
#define PREF_KEYBOARD_CAPS "caps"
|
#define PREF_KEYBOARD_CAPS "caps"
|
||||||
#define PREF_KEYBOARD_ALT_PATH "altPath"
|
#define PREF_KEYBOARD_ALT_PATH "altPath"
|
||||||
|
#define PREF_KEYBOARD_VARIANT "variant"
|
||||||
#define PREF_LOWERCASE_ENABLED "lowercaseEnabled"
|
#define PREF_LOWERCASE_ENABLED "lowercaseEnabled"
|
||||||
#define PREF_PORTRAIT_HEIGHT_SCALE "portraitHeightScale"
|
#define PREF_PORTRAIT_HEIGHT_SCALE "portraitHeightScale"
|
||||||
#define PREF_PORTRAIT_POSITION_SCALE "portraitPositionScale"
|
#define PREF_PORTRAIT_POSITION_SCALE "portraitPositionScale"
|
||||||
|
@ -41,6 +41,14 @@
|
|||||||
#define KBD_OBJ_W GL_MODEL_MAX // model width fits screen
|
#define KBD_OBJ_W GL_MODEL_MAX // model width fits screen
|
||||||
#define KBD_OBJ_H_LANDSCAPE GL_MODEL_MAX
|
#define KBD_OBJ_H_LANDSCAPE GL_MODEL_MAX
|
||||||
|
|
||||||
|
typedef enum keyboard_variant_t {
|
||||||
|
KBD_VARIANT_DEFAULT=0,
|
||||||
|
KBD_VARIANT_LOWERCASE,
|
||||||
|
KBD_VARIANT_SYMBOLS,
|
||||||
|
KBD_VARIANT_USERALT,
|
||||||
|
} keyboard_variant_t;
|
||||||
|
#define KBD_VARIANT_UPPERCASE KBD_VARIANT_DEFAULT
|
||||||
|
|
||||||
static bool isAvailable = false; // Were there any OpenGL/memory errors on gltouchkbd initialization?
|
static bool isAvailable = false; // Were there any OpenGL/memory errors on gltouchkbd initialization?
|
||||||
static bool ownsScreen = false; // Does the touchkbd currently own the screen to the exclusion?
|
static bool ownsScreen = false; // Does the touchkbd currently own the screen to the exclusion?
|
||||||
static bool isCalibrating = false; // Are we in calibration mode?
|
static bool isCalibrating = false; // Are we in calibration mode?
|
||||||
@ -317,11 +325,13 @@ static inline int64_t _tap_key_at_point(float x, float y) {
|
|||||||
switch (key) {
|
switch (key) {
|
||||||
case ICONTEXT_LOWERCASE:
|
case ICONTEXT_LOWERCASE:
|
||||||
key = 0;
|
key = 0;
|
||||||
|
prefs_setLongValue(PREF_DOMAIN_KEYBOARD, PREF_KEYBOARD_VARIANT, KBD_VARIANT_LOWERCASE);
|
||||||
_switch_keyboard(kbd.model, kbdTemplateLCase[0]);
|
_switch_keyboard(kbd.model, kbdTemplateLCase[0]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ICONTEXT_UPPERCASE:
|
case ICONTEXT_UPPERCASE:
|
||||||
key = 0;
|
key = 0;
|
||||||
|
prefs_setLongValue(PREF_DOMAIN_KEYBOARD, PREF_KEYBOARD_VARIANT, KBD_VARIANT_UPPERCASE);
|
||||||
_switch_keyboard(kbd.model, kbdTemplateUCase[0]);
|
_switch_keyboard(kbd.model, kbdTemplateUCase[0]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -332,6 +342,7 @@ static inline int64_t _tap_key_at_point(float x, float y) {
|
|||||||
} else {
|
} else {
|
||||||
kbdTemplateAlt[CTRLROW][SWITCHCOL] = ICONTEXT_UPPERCASE;
|
kbdTemplateAlt[CTRLROW][SWITCHCOL] = ICONTEXT_UPPERCASE;
|
||||||
}
|
}
|
||||||
|
prefs_setLongValue(PREF_DOMAIN_KEYBOARD, PREF_KEYBOARD_VARIANT, KBD_VARIANT_SYMBOLS);
|
||||||
_switch_keyboard(kbd.model, kbdTemplateAlt[0]);
|
_switch_keyboard(kbd.model, kbdTemplateAlt[0]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -390,6 +401,7 @@ static inline int64_t _tap_key_at_point(float x, float y) {
|
|||||||
|
|
||||||
case ICONTEXT_MENU_SPROUT:
|
case ICONTEXT_MENU_SPROUT:
|
||||||
key = 0;
|
key = 0;
|
||||||
|
prefs_setLongValue(PREF_DOMAIN_KEYBOARD, PREF_KEYBOARD_VARIANT, KBD_VARIANT_USERALT);
|
||||||
_switch_keyboard(kbd.model, kbdTemplateUserAlt[0]);
|
_switch_keyboard(kbd.model, kbdTemplateUserAlt[0]);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -476,7 +488,26 @@ static void *_create_touchkbd_hud(GLModel *parent) {
|
|||||||
hudKeyboard->tpl = MALLOC(size);
|
hudKeyboard->tpl = MALLOC(size);
|
||||||
hudKeyboard->pixels = MALLOC(KBD_FB_WIDTH * KBD_FB_HEIGHT);
|
hudKeyboard->pixels = MALLOC(KBD_FB_WIDTH * KBD_FB_HEIGHT);
|
||||||
|
|
||||||
memcpy(hudKeyboard->tpl, kbdTemplateUCase[0], sizeof(kbdTemplateUCase/* assuming all the same dimensions */));
|
uint8_t *template = NULL;
|
||||||
|
long lVal = 0;
|
||||||
|
keyboard_variant_t variant = prefs_parseLongValue(PREF_DOMAIN_KEYBOARD, PREF_KEYBOARD_VARIANT, &lVal, /*base:*/10) ? lVal : KBD_VARIANT_DEFAULT;
|
||||||
|
switch (variant) {
|
||||||
|
case KBD_VARIANT_DEFAULT:
|
||||||
|
default:
|
||||||
|
template = kbdTemplateUCase[0];
|
||||||
|
break;
|
||||||
|
case KBD_VARIANT_SYMBOLS:
|
||||||
|
template = kbdTemplateAlt[0];
|
||||||
|
break;
|
||||||
|
case KBD_VARIANT_USERALT:
|
||||||
|
template = kbdTemplateUserAlt[0];
|
||||||
|
break;
|
||||||
|
case KBD_VARIANT_LOWERCASE:
|
||||||
|
template = allowLowercase ? kbdTemplateLCase[0] : kbdTemplateUCase[0];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(hudKeyboard->tpl, template, sizeof(kbdTemplateUCase/* assuming all the same dimensions */));
|
||||||
|
|
||||||
// setup normal color pixels
|
// setup normal color pixels
|
||||||
hudKeyboard->colorScheme = RED_ON_BLACK;
|
hudKeyboard->colorScheme = RED_ON_BLACK;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user