Overview
The Imager API allows the device to capture images using a 2D imager or camera on the device that appears as an imager. This API is not supported on Micro Kiosk devices.
In order to use this API you must include reference to the following JavaScript file that is included with the Enterprise Browser installation:
- elements.js
Note - this file either needs to be on the device in a relative folder from where your HTML page is, or it must be copied to your web server appropriately.
<script type="text/javascript" charset="utf-8" src="elements.js"></script>;
API Usage
This API does not use the EB namespace. It is simply referenced using the API name:
imager.capture();
Events
To handle events, you assign a string value to the event name that represents a function name or javascript statement to execute.
imagerEvent
The imagerEvent is called when the captured image has been successfully transfered to the specified destination. This should be used in conjunction with the Capture method.
Callback Parameters
- transferResult - In response to an upload to an HTTP site, the reply from the web server will be returned. There will be no response to an upload to an FTP site.
Usage
imager.imagerEvent = "url('JavaScript:imageSaveHandler(%json);')";
  imager.capture();
function imageSaveHandler(params){
    alert('Status' + params['transferResult']);
}
imagerCaptureEvent
Specifying an ImagerCaptureEvent will cause the captured image to be returned as a Data URI object when the capture() method is invoked. A Data URI is a base 64 encoding of the image and can be used to easily embed the image on the page, store the image in a database or transfer the image to a server.
Callback Parameters
- imageData - A DataURI representation of the captured Image.
Usage
imager.imagerCaptureEvent = "url('JavaScript:imageUriHandler(%json);')";
  imager.capture();
function imageUriHandler(params){
    //imagerImage may be an IMG tag object 
    //We can use this to display the image
    imagerImage.src = params.imageData;
}
imagerEnumEvent
The imagerEnumEvent is called after the enumerate method is invoked to provide the available imagers on the device.
Callback Parameters
- imagerArray (deviceName, friendlyName) - Two dimensional array of imagers present on the device.
The imagerArray attribute returned from imagerEnumEvent will enumerate each imager present on the device in a 2D array, associating each Imager’s device name with a user friendly name. The deviceName can be assigned imager.enabled property. The friendly name is a user readable description of the Imager, e.g: ["IMG1", "Imager"],["IMG2", "Color Camera"].
[
   [            //  Array for Imager 1
      deviceName,    //  The internal name given to the Imager, use this when enabling a specific imager.
      friendlyName,  //  A human readable description of the Imager.
   ]
   [            //  Array for Imager 2
      deviceName,
      friendlyName,
   ]
]
Usage
imager.imagerEnumEvent = "url('JavaScript:imageEnumHandler(%json);')";
  imager.enumerate();
function imageEnumHandler(params)
{
    var imagerArray = params["imagerArray"];
    var imagerInfo = "Imagers On Device: " + imagerArray.length + "<BR>ID  --  Name<BR>" 
    for (i=0; i < imagerArray.length; i++)
    {
        imagerInfo = imagerInfo + imagerArray[i][0] + ' -- ' + imagerArray[i][1] + '<BR>';
    }
    message.innerHTML = imagerInfo;
}
Methods
enable()
Enables the imager device and shows the viewer window
Returns
- Void
Platforms
- Android
- Windows Mobile
- Windows CE
disable()
Disables the imager device and hides the viewer window
Returns
- Void
Platforms
- Android
- Windows Mobile
- Windows CE
capture()
Captures the current image and sends the file to the specified destination address. If an imagerCaptureEvent is specified the image will also be returned as a Data URI object.
Returns
- Void
Platforms
- Android
- Windows Mobile
- Windows CE
enumerate()
Return a list of imagers available on the device using ImagerEnumEvent. This event will be triggered immediately.
Returns
- Void
Platforms
- Android
- Windows Mobile
- Windows CE
Properties
enabled
Type
STRING
Description
Enables the referenced imager device and shows the viewer window.
Possible Value
- Imager ID -  Imager devicenameIDs can be obtained via ImagerEnumEvent. Do not use the friendlyName. ex:imager.enabled ='IMG1';
Platforms
- Android
- Windows Mobile
- Windows CE
desiredWidth
Type
STRING
Description
Sets the desired width of the output image, in pixels. Depending on the camera hardware in use the closest matching image size will be chosen; the width of the chosen image will equal or exceed the value specified up to the capabilities of the hardware.
Possible Value
- Numeric Value
Platforms
- Android
- Windows Mobile
- Windows CE
desiredHeight
Type
STRING
Description
Sets the desired height of the output image, in pixels. Depending on the camera hardware in use the closest matching image size will be chosen; the width of the chosen image will equal or exceed the value specified up to the capabilities of the hardware.
Possible Value
- Numeric Value
Platforms
- Android
- Windows Mobile
- Windows CE
username
Type
STRING
Description
The username for the HTTP or FTP server if required.
Platforms
- Android
- Windows Mobile
- Windows CE
password
Type
STRING
Description
The password for the HTTP or FTP server if required.
Platforms
- Android
- Windows Mobile
- Windows CE
left
Type
INTEGER - Positive number, representing pixels
Description
Sets the top left horizontal position of the viewer window in pixels.
Possible Value
- Numeric Value (0 - ScreenWidth)
Platforms
- Android
- Windows Mobile
- Windows CE
top
Type
INTEGER - Positive number, representing pixels
Description
Sets the top left vertical position of the viewer window in pixels.
Possible Value
- Numeric values (0 - ScreenHeight)
Platforms
- Android
- Windows Mobile
- Windows CE
width
Type
INTEGER - Positive number, representing pixels
Description
Sets the width of the viewer window in pixels.
Possible Value
- Numeric values (0 - ScreenWidth)
Platforms
- Android
- Windows Mobile
- Windows CE
height
Type
INTEGER - Positive number, representing pixels
Description
Sets the height of the viewer window in pixels.
Possible Value
- Numeric values (0 - ScreenHeight)
Note: On Android the height of the viewfinder cannot be set to any value less than 200.
Platforms
- Android
- Windows Mobile
- Windows CE
destination
Type
STRING
Description
Sets the destination path and name for the captured video file.
Possible Value
- Fully qualified URL or file name. Supports HTTP, FTP and File protocols.
Note: The protocol, port number, username (optional) and password (optional) are all derived from the URL string and should be specified in the following manner: [protocol]://[username]:[password@]Server[:Port]FileNameAndPath. FTP Example: ftp://admin:root@192.168.1.1:2500/Folder/Cap.mov. HTTP Example: http://admin:root@192.168.1.1:8080/Folder/Upload.aspx. File Example: file://\path\Cap.mov.
Platforms
- Android
- Windows Mobile
- Windows CE
lamp
Type
STRING
Description
Switches the illumination lamp ON or OFF.
Possible Value
- ON/OFF
Platforms
- Android
- Windows Mobile
- Windows CE
aim
Type
STRING
Description
Switches the imager laser aimer ON or OFF.
Possible Value
- ON/OFF
Platforms
- Android
- Windows Mobile
- Windows CE
sound
Type
STRING
Description
Specifies the wave file to play when capturing an image.
Possible Value
- wav file name - ex: '\windows\alarm2.wav'
Platforms
- Android
- Windows Mobile
- Windows CE
Remarks
Scanning and Image Capture Interaction
In some device configurations the scanner and imager share the same hardware, e.g. the blockbuster scanner and top mounted imager on the MC75a. Where two modules share the same physical hardware they cannot be enabled simultaneously, once the scanner is enabled it must be disabled before the imager can be used, and vice versa.
Setting up a Transfer to a remote HTTP or FTP location
The Imager API is designed to be configured before any transfer is made to a remote location. If the 'Destination' parameter is specified as either HTTP or an FTP location the 'destination' / 'username' / 'password' parameters can not be guaranteed to stay the same after the capture has completed, therefore configure your destination for each capture.
Image Size
The image can only be stretched as far as the screen dimensions will allow, do not expect to be able to create an image larger than the dimensions of your device's screen.
Multi Instance
When multiple Enterprise Browser applications are running the following considerations should be made: Only the foreground application is given access to the imaging hardware, when an application is sent to the background its state will be saved and it will automatically relinquish control of the imager. When brought back to the foreground, an application previously using the imager will have its previous configuration (eg. whether it was enabled or not) reapplied to the imager automatically. Please note that any file transfer that is in progress continues even if the application is sent to the background and capture will not have any effect on an application that is in the background