Difference between revisions of "On Screen Keyboard"

From WebOS Internals
Jump to navigation Jump to search
(gesture tap)
Line 57: Line 57:
 
* Made keyboard draggable after tapping blank key
 
* Made keyboard draggable after tapping blank key
 
* Added haptic feedback
 
* Added haptic feedback
 +
 +
===8/21/09 - Fixes/Enhancements===
 +
* Added support for Emulator (pageup will mimic gesture tap, double-tap for keyboard)
 +
* Separated themes from palm framework
 +
* Added customizable options and themes via .json files
 +
* Shrink keys when "active", i.e. shift, orange, sym...
 +
* Changed keyboard to come up with double-tap of gesture area (within 600ms)
 +
* Enabled usage within search fields (messaging/email apps etc...)
 +
* Changed position calculations to render keyboard as low as possible without covering cursor on initialization
  
 
=Issues=
 
=Issues=
as of 17 August 2009 the following issues are known:  
+
as of 21 August 2009 the following issues are known:  
  
* Do not bring up keyboard when using hard keyboard clipboard events (might have to disable the keyboard when slider is open exposing hard keyboard)  
+
* The top-most and left-most buttons do not show correctly when pressed (they get cut off)
* Enable usage to search contacts/universal search -- for example Name, email address, etc are ''search'' fields not text fields.  
+
* Sym key re-draws and re-positions the keyboard, should at least not re-position.
* Verify auto-correct when space added.
+
* Auto-Correct is not functional (SmartTextEngine is handled in libWebKitLuna.so, so might need plugin to add this support)
* Add clipboard capabilities
+
* Clipboard, orange-scroll and shift-highlight do not operate with virtual keyboard
 +
* There is no way to bring up Global Search without pressing a key on the hard keyboard.  One idea is to add a top-bar item in between the app menu and device menu that will launch Global Search with the virtual keyboard displayed.  The virtual keyboard already works properly once the Global Search is in the foreground (i.e. after a hard keypress)
 
* Explore T9-type, limited-width keyboard options
 
* Explore T9-type, limited-width keyboard options
 +
* Hide kb when focus changes from text box (e.g. landscape in web browser, text box goes away)
 +
* Make kb work with textfields in web pages on webview if possible
 +
 +
 +
=User configurable options=
 +
There is a config file located at /media/internal/virtual-keyboard/kb_config.json, with the following options:
 +
* haptic    : <number>  - How long to vibrate upon touch (0 - 100 ms)
 +
* clickFile : <string>  - Sound file to play upon button click (e.g. click1.wav)
 +
* theme    : <string>  - Name of keyboard theme to use (remix_classic, remix_glossy, remix_ice)
 +
 +
=Keyboard Themes=
 +
The virtual keyboard layout is a "list" of rows containing 10 "elements" each.  The design allows for the keys to span multiple elements.
 +
 +
The virtual keyboard will look for themes located at /media/internal/virtual-keyboard/themes/
 +
In this directory there shall exist theme-named directories with the following structure and options:
 +
 +
theme_config.json is the file that will control what images in this directory should be used and how.  The following keys are accepted:
 +
 +
* index      : <number> - (required) Key index on keyboard layout {e.g. for default layout, index of q is 0, index of a is 10, index of space is 24}
 +
* character  : <string> - Character to display when user hits associated key
 +
* image      : <string> - Name of image (located in this theme's directory) to display on keyboard for specified index'd key
 +
* span      : <number> - How many elements the key shall take up (e.g. default is 3 for space bar)

Revision as of 04:37, 22 August 2009

On Screen Keyboard.png

Warning. This is PRE ALPHA testing grade only software. It may cause your pre to melt into a puddle and dissolve while turning blue. Use at your own risk!

On screen keyboard 2.png

Introduction

The Palm Pre ships with a very limited on-screen keyboard for inserting symbols. It works in portrait and landscape, in all apps, in any text field. (It doesn't work in Search fields like email address or url, which has led to difficulties with enhancing it.) This on screen keyboard has provided a basis for programmers to develop a fully functional on screen keyboard for the Pre.

Background and Explanation

On an unmodified Pre if you press the "sym" key and a scrollable 5x5 keyboard pops up full of alternate characters.

On screen keyboard 3.png

This is controlled by code incorporated into the framework.js. The specific functions there can be seeen in /usr/palm/frameworks/mojo/submissions/191.15/javascripts/widget_charselector.js

with the layout controlled by 3 files in /usr/palm/frameworks/mojo/submissions/191.15/templates/charselector

the actual list of characters that appear on the screen is controlled by /usr/palm/frameworks/mojo/submissions/191.15/resources/en_us/alternatechars_table.json

At the simplest level then, creating an on-screen keyboard requires editing the alternate characters table json, to add the "regular" charcters to it, and then when you want a keyboard, press SYM and poof, a keyboard. The problem with that is, the alternatechars_table.json is "fragile" the slightests mis-edit results in the pre entering a continuous book cycle.

At the next level, the framework's copy of widget_charselector.js needs to be modified to not close the keyboard after each keypress.

As of 12 August 2009 Webos-internals contributor Eric Gaudet (irc egaudet) announced success at patching the framework.js to accept a new function derived from the charselector widget. This pre-alpha proof of concept on-screen keyboard is available as a patch.

Operation

Unlike the Palm Symbol keyboard, you do not have to open the Pre's hardware kb to get the on-screen keyboard. Tapping the gesture area (near the round silver button) will bring up the on-screen keyboard if you are in a text field. Note: as of 19 August 2009, the on-screen keyboard does NOT YET WORK in search boxes (email, name, etc)

Procedure

The patch is on Gitorious, please read the following to install the patch: Applying Patches

The patch should be stored (on Pre) in: /opt/src/modifications/frameworks/add-onscreen-keyboard.patch

There are also theme images needed in the current release. Folow these instructions to install the patch AND the theme images (NOTE: must be root)

sh /opt/src/modifications/install add-onscreen-keyboard.patch
sh /opt/src/modifications/frameworks/install_theme

Change Log

8/13/09 - Fixes

  • Functional backspace, space and enter keys added.

8/16/09 - Fixes

  • Added functional shift and sym capabilities.
  • Added landscape mode resize.


8/18/09 - Fixes/Enhancements

  • Added theme capabilities
  • Changed default theme to use remix2000's images (big thanks!)
  • Added missing symbols
  • Fixed landscape mode to correctly render in landscape if launched from that state.

Thanks again to remix2000 for the nice keyboard images. Specs will be posted eventually for the images/theme framework once a user-app callable way to switch themes is implemented.

8/18/09 (evening) - Fixes/Enhancements

  • Increased width of keyboard to span entire screen
  • Added orange-key functionality
  • Made keyboard draggable after tapping blank key
  • Added haptic feedback

8/21/09 - Fixes/Enhancements

  • Added support for Emulator (pageup will mimic gesture tap, double-tap for keyboard)
  • Separated themes from palm framework
  • Added customizable options and themes via .json files
  • Shrink keys when "active", i.e. shift, orange, sym...
  • Changed keyboard to come up with double-tap of gesture area (within 600ms)
  • Enabled usage within search fields (messaging/email apps etc...)
  • Changed position calculations to render keyboard as low as possible without covering cursor on initialization

Issues

as of 21 August 2009 the following issues are known:

  • The top-most and left-most buttons do not show correctly when pressed (they get cut off)
  • Sym key re-draws and re-positions the keyboard, should at least not re-position.
  • Auto-Correct is not functional (SmartTextEngine is handled in libWebKitLuna.so, so might need plugin to add this support)
  • Clipboard, orange-scroll and shift-highlight do not operate with virtual keyboard
  • There is no way to bring up Global Search without pressing a key on the hard keyboard. One idea is to add a top-bar item in between the app menu and device menu that will launch Global Search with the virtual keyboard displayed. The virtual keyboard already works properly once the Global Search is in the foreground (i.e. after a hard keypress)
  • Explore T9-type, limited-width keyboard options
  • Hide kb when focus changes from text box (e.g. landscape in web browser, text box goes away)
  • Make kb work with textfields in web pages on webview if possible


User configurable options

There is a config file located at /media/internal/virtual-keyboard/kb_config.json, with the following options:

  • haptic : <number> - How long to vibrate upon touch (0 - 100 ms)
  • clickFile : <string> - Sound file to play upon button click (e.g. click1.wav)
  • theme : <string> - Name of keyboard theme to use (remix_classic, remix_glossy, remix_ice)

Keyboard Themes

The virtual keyboard layout is a "list" of rows containing 10 "elements" each. The design allows for the keys to span multiple elements.

The virtual keyboard will look for themes located at /media/internal/virtual-keyboard/themes/ In this directory there shall exist theme-named directories with the following structure and options:

theme_config.json is the file that will control what images in this directory should be used and how. The following keys are accepted:

  • index : <number> - (required) Key index on keyboard layout {e.g. for default layout, index of q is 0, index of a is 10, index of space is 24}
  • character : <string> - Character to display when user hits associated key
  • image : <string> - Name of image (located in this theme's directory) to display on keyboard for specified index'd key
  • span : <number> - How many elements the key shall take up (e.g. default is 3 for space bar)