- Zoom in and out of app page(s)
- Show/hide custom buttons or keyboard layouts
- Show/hide the address bar
- Quit the EB app and return to the OS
- Quit the app and return to a login page
- Reboot the device
- Enter special character(s) not available on the selected keyboard
- Enter foreign-language characters not available on the selected keyboard
- Activate DataWedge and/or the scanner beam
- Clear cookies and/or the application cache
- Enable voice input
NOTE: Key mapping failures sometimes occur on Android devices that include a hardware keyboard. In some cases it might be necessary to disable the standard Android keyboard as the default SIP and install (and/or activate, if already installed) the Zebra Enterprise Keyboard as the default. See the Enterprise Keyboard user guide for more information.
Predefined Commands
The remapping feature for hardware keys supports only the predefined actions and mapping commands shown below.
Action Commands
- back - Navigates to the previous page in the EB app's history.
- forward - Navigates forward one page in the EB app's history.
- quit - Exits the EB app, executing any exit commands or actions defined in the
Config.xml
file. - refresh - Reloads the current page.
Mapping Commands
- key-[KeyEvent] - Sends the Android KeyEvent corresponding to the constant that follows (-) to the field in focus in the underlying app. For example, "key-11" sends a KeyEvent value of "11" (KEYCODE_4). See the full list of Android KeyEvents, constants and keycode values.
- runscript-[ScriptIdentifier] - Executes the specified JavaScript code block as defined in the
CustomScript.xml
file. For example: "runscript-clearcookiescript" executes the user-defined JavaScript code block in the “cleaarcookiescript” section of theCustomScript.xml
file. Learn more about the CustomScript file. - uc-[UnicodeValue] - Sends the unicode character corresponding to the code that follows (-) to the field in focus in the underlying app. This is useful for injecting foreign-language or scientific characters or other special symbols. For example, "uc-03C0" sends the Greek character Pi. See all Unicode characters.
All commands are case-sensitive.
Remapping Hardware Keys
Hardware keys are remapped in the KeyActions section of the KeyCodeMapping
.xml
file (EB 2.0 and higher only). Use the instructions in the Mapping Android Keycodes section above to modify the file and push it to the device.
Example
<KeyCodeConfiguration>
<KeyCodes>
...
</KeyCodes>
<KeyActions>
<KEYACTION keyvalue="133" action="runscript-clearcookiescript"/>
<KEYACTION keyvalue="132" action="quit" />
<KEYACTION keyvalue="9" action="key-11" />
<KEYACTION keyvalue="135" action="uc-03C0"/>
<KEYACTION keyvalue="136" action="back"/>
<KEYACTION keyvalue="137" action="forward"/>
<KEYACTION keyvalue="139" action="refresh" />
</KeyActions>
</KeyCodeConfiguration>
Handling Incorrect Keycodes
If it is determined that correct keypresses are generating incorrect keycodes, the incorrect keycode value must be determined before the correct one can be substituted. This process uses JavaScript to expose the keycodes that appear when pressing one or more keys.
The first step is to confirm that Windows keycodes are not being forced as a result of the <isWindowsKey> tag:
1. In the app's Config.xml file, confirm that the <isWindowsKey> tag has a value of 0.
2. Using one of the KeyCapture APIs, reveal the keycodes generated by keypresses to identify incorrect keycode value(s). The test code might look something like this:
// KeyCapture API 4.x:
EB.KeyCapture.captureKey(false,'all',function(obj){alert(obj.keyValue)
});
// KeyCapture API 2.x:
<META HTTP-Equiv="KeyCapture" Content="KeyValue:All; Dispatch:False; KeyEvent:url('JavaScript:alert('Key Pressed: %s');')">
3. Map the incorrect keycode values to the correct ones using the same syntax described in the earlier section:
<KEYCODE name="[KEYCODE_X]" from="[incorrect_keycode]" to="[correct_keycode]" />
For example, if Step 2 determined that the keycode value being generated is 0x05 and the desired value is 0x06, then the correct mapping statement would be:
<KEYCODE name="KEYCODE_X" from="0x05" to="0x06" />
where "KEYCODE_X" = the name of the keycode. Standard Android key names are recommended.
4. Relaunch Enterprise Browser and repeat Step 2 to confirm that correct code(s) are generated.
Mapping Proprietary Function Keycodes
The function keys of certain Zebra devices running Windows Mobile, including the WorkAbout Pro 4 and Omnii XT15 (with Windows Embedded Handheld 6.5), return a proprietary set of Unicode values via Windows character messages rather than the values expected from Windows keydown/keyup
messages. For example, pressing the F1 key returns the hexadecimal value E001 (57345 decimal) rather than the hex value 0x70 (112 decimal) as generally expected. This can lead to compatibility issues for Enterprise Browser apps when running on such devices with Windows Mobile.
For such scenarios, Zebra developed and recommends a means of mapping the proprietary Unicode values of function keys used by an Enterprise Browser application to Microsoft virtual keycode values.
Note: This method should be used only for function keys.
Enable and specify mapping
Mapping the function keys on a qualifying device requires adding a few lines to the app's Config.xml
file, creating a file to specify the mapping assignments and copying the file to the device.
To map proprietary function keys:
1. Add the three code lines shown below to the app's Config.xml
file as a child of the <Configuration> parent node:
<Configuration>
...
// Copy the three lines below:
<FunctionKeyMapping>
<FunctionKeyMappingToStandardMSValue value="1"/>
</FunctionKeyMapping>
// and paste them into the "Configuration" node
// of the app's Config.xml file
</Configuration>
Note: The maximum number of child tags is 65.
2. Create a file called EBFunctionKeyMapping.xml
, and using one of the templates below, specify the function key(s) to be mapped to Microsoft virtual keycode values.
Template 1- Map a Single Function Key
Use this template to map a single function key to a specific Microsoft keycode value. For example, to map the F1 key to a Microsoft virtual keycode, specify the proprietary Unicode value in hexadecimal (0xE001) first, followed by the Microsoft virtual keycode value in hexadecimal (0x70) as shown below:
<FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE001" SEND_KEYDOWN_VALUE="0x70"/>
</FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE>
Template 2- Map Multiple Function Keys
To map multiple function key to Microsoft keycode values, simply repeat the SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE
(child tag) statements above within the FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE
root tag. The example below maps the F1 through F5 function keys:
<FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE001" SEND_KEYDOWN_VALUE="0x70"/>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE002" SEND_KEYDOWN_VALUE="0x71"/>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE003" SEND_KEYDOWN_VALUE="0x72"/>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE004" SEND_KEYDOWN_VALUE="0x73"/>
<SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE IF_CHAR_VALUE="0xE005" SEND_KEYDOWN_VALUE="0x74"/>
</FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE>
3. Once the EBFunctionKeyMapping.xml
mapping file is complete, copy the file to the \Program Files\EnterpriseBrowser\
directory on the device.
The function key(s) will be mapped as specified in the mapping file the next time Enterprise Browser is launched and whenever an EB app is in the foreground.
Contents of the Function Key Mapping File
- FUNCTION_KEY_MAPPING_TO_STANDARD_MS_VALUE – the root tag
- SET_FUNCTION_KEY_TO_STANDARD_MS_VALUE - the child tag associated with the root tag
- IF_CHAR_VALUE - sets the proprietary Unicode value
- SEND_KEYDOWN_VALUE - sets the Microsoft virtual keyCode value
Rules
- Proprietary function key mapping is supported on Enterprise Browser 1.5 and later.
- Maximum number of child tags is 65.
- Mapped values are used internally by Enterprise Browser apps only.
- Whenver a function key is pressed, if the value of a Windows character message matches any of the IF_CHAR_VALUE attributes mapped in the
EBFunctionKeyMapping.xml
file, the set value of the associated SEND_KEYDOWN_VALUE attribute is sent to the Windows keydown message as the Microsoft virtual keycode value. - This function key mapping applies only to certain Zebra devices running Windows Mobile only. These include the WorkAbout Pro 4 and Omnii XT15 (with Windows Embedded Handheld 6.5).
- The format of
EBFunctionKeyMapping.xml
file should not be altered in any way. - Use the table below for Proprietary and Microsoft keycode values for function keys F1 to F24.
Function Keys | Proprietary Unicode Value | Microsoft Virtual Keycode Value |
---|---|---|
F1 | 0xE001 | 0x70 |
F2 | 0xE002 | 0x71 |
F3 | 0xE003 | 0x72 |
F4 | 0xE004 | 0x73 |
F5 | 0xE005 | 0x74 |
F6 | 0xE006 | 0x75 |
F7 | 0xE007 | 0x76 |
F8 | 0xE008 | 0x77 |
F9 | 0xE009 | 0x78 |
F10 | 0xE00A | 0x79 |
F11 | 0xE00B | 0x7A |
F12 | 0xE00C | 0x7B |
F13 | 0xE00D | 0x7C |
F14 | 0xE00E | 0x7D |
F15 | 0xE00F | 0x7E |
F16 | 0xE010 | 0x7F |
F17 | 0xE011 | 0x80 |
F18 | 0xE012 | 0x81 |
F19 | 0xE013 | 0x82 |
F20 | 0xE014 | 0x83 |
F21 | 0xE015 | 0x84 |
F22 | 0xE016 | 0x85 |
F23 | 0xE017 | 0x86 |
F24 | 0xE018 | 0x87 |
Also See
- KeyCapture API - how to include the API and use its methods
- Keys that cannot be captured - including the SHIFT and ALT keys
- Android KeyEvents documentation - the official list of Android key names