Persist the current soft touch keyboard variant

This commit is contained in:
Aaron Culliney 2016-05-06 21:14:53 -07:00
parent 44b2e564d4
commit dadf5e02a1
2 changed files with 33 additions and 1 deletions

View File

@ -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"

View File

@ -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;