Difference between revisions of "On Screen Keyboard"

From WebOS Internals
Jump to navigation Jump to search
(upgrade procedure)
 
(8 intermediate revisions by 6 users not shown)
Line 1: Line 1:
[[Image: On_Screen_Keyboard.png|thumb|right]]
+
{{template:patch}}
'''Warning. This software is in intense development. It is changing nearly daily. '''
+
[[Image: VirtualKeyboard_1.png|thumb|right]]
 +
[[Image: VirtualKeyboard_2.png|thumb|right]]
  
'''While a number of people are having success with it, it makes DEEP changes in your Pre. You choose to use this entirely at your own risk. It may cause your pre to melt into a puddle and dissolve while turning blue.  Use at your own risk!'''
 
[[Image: On_screen_keyboard_2.png|thumb|right]]
 
 
=Introduction=
 
=Introduction=
[[Image: On_screen_keyboard_3.png|thumb|right]]
+
[[Image: VirtualKeyboard_3.png|thumb|right]]
[[Image: Messaging_2009-22-08_000708.png|thumb|right]]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 provided a basis for programmers to develop a fully functional on screen keyboard for the Pre.
+
The Palm Pre lacks a stock Virtual Keyboard, which can come in handy in many situations.  Having a virtual keyboard is good for quick text responses/notes without having to stress the slider too muchAlthough the biggest use for a virtual keyboard on the Palm Pre is landscape mode.  The goal of this Patch/Application is to have a fully integrated Virtual Keyboard for the many tasks where it is an inconvenience to use the hardware keyboard.
  
 
=Operation=  
 
=Operation=  
Unlike the Palm Symbol keyboard, you do not have to open the Pre's hardware keyboard to get the on-screen keyboard.  Double-tapping the gesture area (near the round silver button) will bring up the on-screen keyboard if you are in a text input field. Tap with two fingers separated or Double-tap quickly.  
+
Unlike the Palm Symbol keyboard, you do not have to open the Pre's hardware keyboard to get the on-screen keyboard.  Double-tapping the gesture area (near the round silver button that lights up) will bring up the on-screen keyboard if you are in a text input field. Tap with two fingers separated or Double-tap quickly.  Currently the rendering takes a few seconds, and a 3rd tap will hide/stop the rendering.  After you double-tap the blinking cursor should freeze for a few seconds while the keyboard renders.  Be patient, future versions will work to minimize the load lag.  When the Virtual Keyboard is displayed, a single tap on the gesture area will hide it.
  
=Installation Procedure=
+
=== Theme Selector key ===
==Install Via PreWare==
+
[[Image: VirtualKeyboard_4.png|160px|bottom]]<br><br>
If you have installed WebOS Internals over the air installer [[Application:Preware|Preware]] you can simply select the software keyboard from the list of available applications and install itNothing more is required.   
+
The Theme Selector key is the lower left gears key on the default themeOn the remix themes the theme selector key is the lower right blank keyTapping this brings up a list of installed themes to switch between.<br><br>
  
==Install Via WebOS Quick Install==
+
=== Drag Mode Key ===
Using WebOS Quick Install press the third button on the right select ''WebOS Internals Feed (all)'' from the drop down list at the top, choose virtual keyboard, press DOWNLOAD and then install.  
+
[[Image: VirtualKeyboard_5.png|160px|bottom]]<br><br>
 +
The Keyboard Drag-mode key is the finger key on the lower right side of the keyboard.  On the remix themes the drag-mode key is the lower left blank key.  Tapping this puts the keyboard into drag-mode, simply drag and drop the keyboard up and down the screen while this key is active.
  
==Command Line Installation==  
+
=Installation Procedure=
If you have completed the standard WebOS Internals "[[Next_steps|next steps]]" procedure, installing the keyboard from the command line is very simple: 
+
Use the WebOS Internals over the air installer [[Application:Preware|Preware]] and simply select the software keyboard from the list of available patches and install it.  From Preware go to Available Packages -> Patch -> Mojo to find the Virtual Keyboard.
<pre>
 
/usr/bin/ipkg -o /var install org.webosinternals.virtual-keyboard
 
sh /var/usr/lib/ipkg/info/org.webosinternals.virtual-keyboard.postinst
 
</pre>
 
 
 
=Upgrade Procedure=
 
 
 
Remove the old version of the virtual keyboard using Preware 0.9.0 or later.
 
 
 
Install the new version of the virtual keyboard using Preware 0.9.0 or later.
 
 
 
=Options and Themes=
 
 
 
The keyboard has several user configurable options.  As of 28 August 2009 there is no keyboard configuration appHowever, '''you do not have to have root access''' to configure the keyboard.  Simply attach your Pre to your computer in USB Drive Mode.  Then, navigate to the Pre's USB drive.  On your desktop, there will be a directory (folder) called virtual-keyboard. (From within the Pre this is /media/internal/virtual-keyboard ''which is the same place''.) 
 
 
 
Inside that folder, you will find a file named virtual-keyboard/kb_config.json.  Use your editor of choice (such as Wordpad - ''do not use MS Word'') to edit that file.  You may change any of the following options:
 
* haptic    : <number>  - How long to vibrate upon touch (0 - 100 ms) (50 seems good.  100 makes the keyboard lag a little.
 
* clickFile : <string>  - Sound file if any to play upon button click (e.g. click1.wav)
 
* installed_themes : [{label:<string>,value:<string>},...] - Installed themes, label is the display name and value is the themes folder name
 
* theme    : <string>  - Name of keyboard theme to use. Three themes ship with the keyboard:
 
** remix_classic
 
** remix_glossy
 
** remix_ice
 
*: You may choose any of the three or add your own theme in an appropriate folder and name it as you please.  See below on creating theme files.
 
 
 
<TABLE><TR><TD>Remix Classic [[Image:remixClassic.png|70px]]</TD><TD>Remix Glossy [[Image:remixGlossy.png|70px]]</TD><TD>Remix Ice [[Image:remixIce.png|70px]]</TD></TR></TABLE>
 
 
 
== Additional Available Themes - Not working ==
 
 
 
<TABLE><TR><TD>
 
'''Eazys Theme''' [[image:28731d1251393689-screen-keyboard-bugs-functionality-enhancements-messaging_2009-27-08_121219.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/28732d1251393700-screen-keyboard-bugs-functionality-enhancements-eazys_theme.zip]
 
 
 
</TD><TD>'''Eazys Theme 2''' [[image:eazystheme2.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/28963d1251487552-screen-keyboard-bugs-functionality-enhancements-eazys_theme2.zip]
 
 
 
</TD></TR><TR><TD>'''Eazys Theme Gloss''' [[image:eazysthemegloss.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/28953d1251482182-screen-keyboard-bugs-functionality-enhancements-eazys_themegloss.zip]
 
 
 
</TD><TD>'''Eazys Trans''' [[image:eazystrans.png|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/28924d1251474261-screen-keyboard-bugs-functionality-enhancements-eazys_trans.zip]
 
 
 
</TD></TR><TR><TD>'''dianehelen Glossy Blue''' [[image:glossyblue.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/29123d1251633769-screen-keyboard-bugs-functionality-enhancements-glossy_blue.zip]
 
 
 
</TD><TD>'''2sslow Blue''' [[Image:messaging_2009-27-08_213107.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/28850d1251436402-screen-keyboard-bugs-functionality-enhancements-2sslow_blue.zip]
 
 
 
</TD></TR><tr><td>'''pychozoundz sleek light'''  [[Image:SleekLight.jpg|thumb|80px]]</td><td>'''and dark'''[[Image:sleekDark.jpg|thumb|80px]][http://www.2shared.com/file/7441193/71eb02de/sleek_light_dark.html]
 
 
 
</TD></TR><TR><TD>Un-Designer LucasPapaya [[Image:LucasPapaya.jpg|thumb|80px]] [http://dl.getdropbox.com/u/15257/LucasPapaya.zip]</td>
 
 
 
 
 
 
 
 
 
<TD> '''dianehelen Autumn''' [[image:autumnkb.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/29125d1251633839-screen-keyboard-bugs-functionality-enhancements-autumn.zip]
 
</td>
 
 
 
 
 
 
 
 
 
</tr>
 
 
 
 
 
 
 
<TR> <TD>'''dianehelen Denali''' [[image:denalikb.jpg|thumb|80px]] Download [http://discussion.treocentral.com/attachments/web-os-development/29127d1251633870-screen-keyboard-bugs-functionality-enhancements-denali.zip]
 
</TD>
 
 
 
<TD>
 
 
 
 
 
'''dianehelen RBW(RedBlackWhite)''' [[image:rbwkb.jpg|thumb|80px]] Download [http://forums.precentral.net/attachments/web-os-development/29218d1251678400-onscreen-keyboard-theme-instructions-rwb.zip]
 
 
 
 
 
 
 
 
 
 
 
 
 
</TD></TR>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
</table>
 
 
 
=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
 
 
 
===8/26/09 - Fixes/Enhancements===
 
* Fixed duplication problem in messaging apps
 
* Fixed symbols appearing in tasks app.
 
* Fixed dragger not to interact with scene
 
* Modified keyboard to allow scene interactions when touching outside of the keyboard. As long as a tap is inside the keyboard, it should not effect the scene. A tap outside of the keyboard should be passed to the scene controller, and not dismiss the keyboard. Tap the gesture area, enter (submit+dismiss), or anything on the hard keyboard to dismiss virtual keyboard.
 
 
 
===8/26/09 (PM) - Fixes/Enhancements===
 
* Allow dragger to drag to bottom of screen regardless of cursor position (user control)
 
* Send newline to text fields along with enter key event when enter is pressed
 
* Close the keyboard only when gesture area is tapped
 
 
 
=== 0.1.3 - Added packaging metadata ===
 
* Added Icon, Homepage, Screenshots metadata to the ipkg for use in Preware 0.8.0 (not yet released)
 
 
 
=== 0.2.2 - Fixes/Enhancements ===
 
* Increased theme capabilities
 
* Added dynamic theme changing capbilities
 
* Updated all localizations with default .json so at the least the layout works for all.
 
* Optimized code to reduce lag
 
* New default theme made by un_designer
 
 
 
=== 0.2.3 - Fixes/Enhancements ===
 
* Fix default theme installation in postinst (LPC_Dark_Rounded_2e)
 
 
 
=Issues=
 
as of 26 August 2009 the following issues are known:
 
* Auto-Correct is not functional (SmartTextEngine is handled in libWebKitLuna.so, so might need plugin to add this support)
 
* Backspace/enter do not work in webview text fields (The text fields in webview seem to be handled by the browser adapter plugin).
 
* Sym key re-draws and re-positions the keyboard, should at least not re-position.
 
* 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 key press)
 
* Hide kb when focus changes from text box (e.g. landscape in web browser, text box goes away)
 
* Notifications and probably other scene re-sizes do not move the keyboard, however the text fields move and this may put them beneath the virtual keyboard. Keyboard should be able to adjust with the scene.
 
==User requested options which are not currently under development==
 
* Explore T9-type, limited-width keyboard options
 
 
 
 
 
Issue tracker: [http://preyourmind.org/project/issues/oskb]
 
 
 
=Creating 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 first layer of the JSON for each key element will have 3 parts:
 
index:<Integer>,portrait:{},landscape:{}
 
 
 
index - index of key
 
portrait - orientation JSON describing theme layout for portrait mode
 
landscape - orientation JSON describing theme layout for landscape mode
 
 
 
 
 
Inside of the orientation JSON's we have another 3 parts:
 
normal:{},function:{},shift:{}
 
 
 
normal - key description JSON when in normal keyboard
 
function - key description JSON when function (orange) key is active
 
shift - key description JSON when shift key is active
 
  
 +
=Known Issues=
 +
* 3-second Load Lag
 +
* Must highlight the text box that was highlighted when the VKB was drawn in order to single-tap hide
 +
* Backspace/Enter does not work in web pages
 +
* Lacks Autocorrect
 +
* Need configuration/customization application support
  
The key description JSON has the following 4 parts:
+
=Themes and Options=
keyCode:<Integer>,display:{},output:<String>,span:<Integer>
+
You may wish to add haptic feedback, click sound feedback and/or custom themes.  Currently this consists of editing json file(s).  For detailed information on themes and options: [[Virtual Keyboard Configuration]]
  
keyCode - currently only used for special action keys (shift, function, etc..)
+
=Technical Background, Explanation and History=
display - key display JSON
 
output - output string when key is pressed
 
span - number of element-widths to span (1 element-width=10%)
 
 
 
 
 
The key display JSON has 2 parts:
 
html:<String>,img:<String>
 
 
 
html - HTML to display as element if no img supplied
 
img - Image (including relative path in this theme's directory) to display as element
 
 
 
 
 
=Technical Background and Explanation=
 
 
On an unmodified Pre if you press the "sym" key a scrollable 5x5 keyboard pops up full of alternate characters.  
 
On an unmodified Pre if you press the "sym" key a scrollable 5x5 keyboard pops up full of alternate characters.  
  
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'''
+
This is controlled by code incorporated into the framework.js.  The specific functions there can be seeen in '''/usr/palm/frameworks/mojo/submissions/<framework_version>/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.
+
with the layout controlled by 3 files in '''/usr/palm/frameworks/mojo/submissions/<framework_version>/templates/charselector'''
  
At the next level, the framework's copy of widget_charselector.js needs to be modified to not close the keyboard after each keypress. 
+
the actual list of characters that appear on the screen is controlled by '''/usr/palm/frameworks/mojo/submissions/<framework_version>/resources/en_us/alternatechars_table.json'''
  
 
On 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 was made available as a patch.  Since that time, the keyboard has been extended to work in search fields, to be installable as an IPKG, and to be themeable.   
 
On 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 was made available as a patch.  Since that time, the keyboard has been extended to work in search fields, to be installable as an IPKG, and to be themeable.   
  
''Note that this requires patching the primary framework of WebOS.'' This is not an application running on top of WebOS but rather a modification of the operation of the OS itself.
+
''Note that this requires patching the primary framework of WebOS.'' This is not an application running on top of WebOS but rather a modification of the operation of the OS itself to render a custom widget.

Latest revision as of 06:49, 8 July 2010


VirtualKeyboard 1.png
VirtualKeyboard 2.png

Introduction

VirtualKeyboard 3.png

The Palm Pre lacks a stock Virtual Keyboard, which can come in handy in many situations. Having a virtual keyboard is good for quick text responses/notes without having to stress the slider too much. Although the biggest use for a virtual keyboard on the Palm Pre is landscape mode. The goal of this Patch/Application is to have a fully integrated Virtual Keyboard for the many tasks where it is an inconvenience to use the hardware keyboard.

Operation

Unlike the Palm Symbol keyboard, you do not have to open the Pre's hardware keyboard to get the on-screen keyboard. Double-tapping the gesture area (near the round silver button that lights up) will bring up the on-screen keyboard if you are in a text input field. Tap with two fingers separated or Double-tap quickly. Currently the rendering takes a few seconds, and a 3rd tap will hide/stop the rendering. After you double-tap the blinking cursor should freeze for a few seconds while the keyboard renders. Be patient, future versions will work to minimize the load lag. When the Virtual Keyboard is displayed, a single tap on the gesture area will hide it.

Theme Selector key

VirtualKeyboard 4.png

The Theme Selector key is the lower left gears key on the default theme. On the remix themes the theme selector key is the lower right blank key. Tapping this brings up a list of installed themes to switch between.

Drag Mode Key

VirtualKeyboard 5.png

The Keyboard Drag-mode key is the finger key on the lower right side of the keyboard. On the remix themes the drag-mode key is the lower left blank key. Tapping this puts the keyboard into drag-mode, simply drag and drop the keyboard up and down the screen while this key is active.

Installation Procedure

Use the WebOS Internals over the air installer Preware and simply select the software keyboard from the list of available patches and install it. From Preware go to Available Packages -> Patch -> Mojo to find the Virtual Keyboard.

Known Issues

  • 3-second Load Lag
  • Must highlight the text box that was highlighted when the VKB was drawn in order to single-tap hide
  • Backspace/Enter does not work in web pages
  • Lacks Autocorrect
  • Need configuration/customization application support

Themes and Options

You may wish to add haptic feedback, click sound feedback and/or custom themes. Currently this consists of editing json file(s). For detailed information on themes and options: Virtual Keyboard Configuration

Technical Background, Explanation and History

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

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

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

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

On 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 was made available as a patch. Since that time, the keyboard has been extended to work in search fields, to be installable as an IPKG, and to be themeable.

Note that this requires patching the primary framework of WebOS. This is not an application running on top of WebOS but rather a modification of the operation of the OS itself to render a custom widget.