Dynamsoft Dynamic Web TWAIN Developer's Guide
User Manual:
Open the PDF directly: View PDF
.
Page Count: 307
| Download | |
| Open PDF In Browser | View PDF |
Table of Contents
Developers Guide
Overview
1.1
Create the "Hello World" Page
1.1.1
Customize the Web TWAIN Object
1.1.2
Properties/Methods/Events
1.1.3
Explore the Features
1.1.4
Customize your scan settings
1.1.4.1
Manipulate the images
1.1.4.2
Use the ImageEditor
1.1.4.3
Create a thumbnails view
1.1.4.4
Scan large amounts of documents
1.1.4.5
Load local images
1.1.4.6
Save images locally
1.1.4.7
Upload images to the web server
1.1.4.8
Download images from the web
1.1.4.9
Use Capability Negotiation
1.1.4.10
Add/Remove the object individually
1.1.4.11
License Verification
1.1.5
Use Optional Addons
1.1.6
PDF Rasterizer
1.1.6.1
Barcode Reader
1.1.6.2
Desktop Browser Capture
1.1.6.3
Mobile Browser Capture
1.1.6.4
OCR
1.1.6.5
Contact Us
1.1.7
API Documentation
API List
2.1
Basic Scan
2.1.1
Basic Edit
2.1.2
Display & UI
2.1.3
Load & Save
2.1.4
Upload & Download
2.1.5
1
Advanced Scan
2.1.6
Capability Negotiation
2.1.6.1
Encode & Decode
2.1.7
Runtime Info
2.1.8
General Utilities
2.1.9
Addons
2.1.10
PDF Rasterizer
2.1.10.1
Webcam Capture
2.1.10.2
File Uploader
2.1.10.3
Barcode Reader
2.1.10.4
OCR Basic
2.1.10.5
OCR Pro
2.1.10.6
Appendix
2.1.11
Enumerations
2.1.11.1
Knowledge Base
Install & Upgrade
3.1
Update From a Trial or Old Version
3.1.1
Install on the Client Machines
3.1.2
Install/Uninstall Silently
3.1.3
Uninstall on the Client Machines
3.1.4
Deploy & Distribute
3.2
Environmental Requirements
3.2.1
About the Running Services
3.2.2
About the Distribution Files
3.2.3
License & Price
3.3
Update the Product Key
3.3.1
Decide On Required Licenses
3.3.2
TroubleShooting
3.4
Confirm Hardware Compatibility
3.4.1
Get Detailed Info of Issues
3.4.2
Develop & Customize
3.5
Insert Images To a Specified Index
3.5.1
Reuse TWAIN Configurations
3.5.2
TWAIN Capability Negotiation
3.5.3
Details on the Upload Feature
3.5.4
Details on the Download Feature
3.5.5
Hide or Change the Progress Bar
3.5.6
2
Customize Prompts
3.5.7
Customize Display Language
3.5.8
Customize Built-in Image Editor
3.5.9
Make Saved Images Small
3.5.10
3
Preface
Description
This guide provides instructions on how to use Dynamsoft’s Dynamic Web TWAIN SDK. It provides an overview
of most of the things you can achieve with the SDK.
Audience
This guide is meant for all developers interested in the Dynamic Web TWAIN SDK.
For new developers, there is a step-by-step guide to help you develop a scanning page in your web application
from scratch.
For those who have used the SDK before, you can find information on advanced or new APIs that you can use to
polish your scanning page.
Get Started
What is TWAIN | ICA | SANE
TWAIN is a standard software protocol and application programming interface (API) that regulates
communication between software applications and imaging devices such as scanners and digital cameras.
The TWAIN standard, including the specification, data source manager and sample code, is maintained by the
not-for-profit organization TWAIN Working Group.
Dynamsoft Corporation is a member of the TWAIN Working Group.
The TWAIN protocol works very well on Windows but not as good on macOS. Thus, a substitute is also used by
Dynamsoft’s SDK on macOS which is called Image Capture Architecture or ICA for short.
On Linux, TWAIN isn’t available; therefore SANE is used. As described on the official introduction page, SANE
stands for "Scanner Access Now Easy" and is an application programming interface (API) that provides
standardized access to any raster image scanner hardware such as flatbed scanners, hand-held scanners, video
and still cameras, frame-grabbers.
What is Dynamic Web TWAIN
4
Dynamic Web TWAIN is a scanning SDK specifically optimized for web applications. It was initially designed for
Windows at the beginning, and only TWAIN protocol was supported at the time which is why TWAIN is in the
name of the SDK. However, it has been dramatically improved and extended over the years, and now it supports
TWAIN on Windows & macOS, ICA on macOS and SANE on Linux. The SDK enables you to write code, in just a
few lines, to scan documents from a
TWAIN|ICA|SANE
compliant device which typically is a scanner. Users can
then edit the images, save them locally, or upload them to a remote server in a variety of formats.
With the SDK, you can also import files in the formats
BMP|JPG|PNG|TIF|PDF
from a local disk or the web via
HTTP(s) or FTP.
Basic Requirements
Server Side
Operating System: Windows, macOS, Linux, etc.
Web Server: IIS, Apache, Tomcat, NGINX, WebSphere, ColdFusion, etc.
Programming Languages:
Front-end: HTML, JavaScript, TypeScript, CSS, etc.
Back-end: ASP.NET (C# and VB), PHP, JSP (JAVA), ASP, Python, NodeJS, etc.
Client Side
Browser/OS Support
Windows XP/7/8/2008/2012/2016 and 10; 32-bit and 64-bit
IE 6-9: ActiveX
IE 10-11: HTML5/ActiveX
Edge: HTML5
Chrome/Firefox 27+: HTML5
Mac OS X 10.6.8 and later
Chrome/Firefox 27+, Safari 7+: HTML5
Ubuntu 12.0.4+, Debian 8+, Fedora 24+, mint 18.3; 64-bit
Chrome/Firefox 27+: HTML5
IOS
Safari v11+: MBC
Android
Chrome v58+: MBC
Choose which Dynamic Web TWAIN Edition to use
Dynamic Web TWAIN has five editions: ActiveX, HTML5 for Windows, HTML5 for Mac, HTML5 for Linux and
Mobile Browser Capture for IOS & Android. Based on the browser(s) your end users use, you can decide which
edition(s) you need.
ActiveX
: supports IE 6-9 by default, it can be configured to support IE 10, 11 as well
HTML5 for Windows
HTML5 for Mac
: supports Firefox/Chrome 27+, IE 10/11 and Edge
: supports Chrome/Firefox 27+, Safari 7+
5
HTML5 for Linux
: supports Chrome/Firefox 27+
MBC for IOS & Android
: supports Safari v11+ on IOS and Chrome v58+ on Android
6
Build the "Hello World" Scan Page
NOTE: Before you start, please make sure you’ve downloaded and installed the latest version of Dynamic
Web TWAIN. If you haven’t done so, you can get the 30-day free trial here.
The following 3 steps show you how to create your first web-based scanning application in just 5 minutes!
Step 1: Start a Web Application
Copy the Dynamsoft Resources folder to your project
You can typically find the Resources folder in
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {Version Number}
{Trial}\
Create an empty HTML page
Put an empty HTML page together with the Resources folder, as shown below
Step 2: Add Dynamic Web TWAIN to the HTML Page
Include the two Dynamsoft JS files in the tag
Add Dynamic Web TWAIN container to the tag
Note: "
dwtcontrolContainer
" is the default id for the div. You can change it in the file
necessary.
Step 3: Use Dynamic Web TWAIN
7
dynamsoft.webtwain.config.js
if
Add a Scan button and the minimum code to scan
Review the completed code
Hello World
See the scan page in action
If you open the Hello World page in your browser, it should look like this:
8
Now, you can click on the Scan button to select a device, as shown below:
NOTE:
Only
TWAIN|ICA|SANE
-compliant devices are listed in the Select Source dialog. If your connected
scanner doesn't show up in the list, please make sure the proper driver is installed.
If you are using Windows and don’t have a real scanner at hand, you can install the Virtual Scanner –
a scanner simulator which is developed by the TWAIN Working Group for testing purposes.
Once the scanning is done, image(s) will show up in the built-in Dynamic Web TWAIN viewer:
9
If you have installed the 30-day trial version of Dynamic Web TWAIN, you can normally find the complete Hello
World application at
Started\
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {Version Number} {Trial}\Samples\Getting
.
As you can see, there are lots of samples there (source code provided) for you to try out the many features of
Dynamic Web TWAIN. You can also find advanced samples on the online sample gallery.
10
11
Customize the Dynamic Web TWAIN Object
Change the name of the object
By default, the (first) Dynamic Web TWAIN object is named
DWObject
. You should set it before using any
properties or methods of Dynamic Web TWAIN. A good place to do this is the built-in function
Dynamsoft_OnReady
For example, in our Hello World sample:
function Dynamsoft_OnReady() {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
}
The div with id
dwtcontrolContainer
defined in the file
is the placeholder for Dynamic Web TWAIN. Its initial name and size are
dynamsoft.webtwain.config.js
as shown below. You can change it if necessary.
Dynamsoft.WebTwainEnv.Containers=[{ContainerId:'dwtcontrolContainer',Width:270,Height:350}];
Change the Size of the Viewer
You can change the initial size of the container (the built-in viewer) in
dynamsoft.webtwain.config.js
. You can use
either a number or a percentage here. For example
Dynamsoft.WebTwainEnv.Containers = [{ ContainerId: 'dwtcontrolContainer', Width: '50%', Height: '513px' }];
NOTE
You can also change the size of the container at runtime using the properties Width and Height.
12
.
Use Dynamic Web TWAIN
By default, Dynamic Web TWAIN automatically initializes after the page finishes loading. Once the Dynamic Web
TWAIN object finishes initializing, you can start to call its methods, set its properties, etc. You can refer to our API
Documentation to check all properties, methods and events of Dynamic Web TWAIN.
Properties
Properties are used to get or set a certain value of the Dynamic Web TWAIN object at runtime such as
Resolution
,
Duplex
,
IfShowUI
, etc.
DWObject.Resolution = 200; // Scan pages in 200 DPI
Methods
Methods are used to call the built-in functions of the Dynamic Web TWAIN object such as
SaveAsJPEG()
,
Rotate()
AcquireImage()
,
, etc. The syntax is like this:
DWObject.Rotate(0, 45, false); // Rotate the 1st image in the buffer by 45 degrees
Events
Events are triggered when the program reaches certain trigger points. For example,
when you click the mouse,
OnPostTransfer
OnMouseClick
is triggered
is triggered when one image is transferred, etc. Compared with
Properties and Methods, Events are a bit tricky to use. We’ll talk about it a little more here.
Handling Events
Add an event listener
To add an event listener, you can use the built-in method
RegisterEvent()
. Please refer to the sample code
below:
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', Dynamsoft_OnReady);
var DWObject;
/* OnWebTwainReady event fires as soon as Dynamic Web TWAIN is initialized. It is the best place to add event listene
rs */
function Dynamsoft_OnReady() {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
DWObject.RegisterEvent("OnPostTransfer", Dynamsoft_OnPostTransfer);
}
function Dynamsoft_OnPostTransfer() {
/* This event handler will be called after a transfer ends. */
/* Your code goes here*/
}
13
In the code above, we added the JavaScript function
OnPostTransfer
Dynamsoft_OnPostTransfer()
as an event listener for the event
. Alternatively, you can also write code as shown below:
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', Dynamsoft_OnReady);
var DWObject;
function Dynamsoft_OnReady() {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
DWObject.RegisterEvent("OnPostTransfer", function () {
/* Your code goes here*/
};
}
Event with argument(s)
Some of the events have argument(s). Take the
OnMouseClick
event for an example:
OnMouseClick(Number nImageIndex) /* nImageIndex refers to the image you clicked on*/
When you create the corresponding JavaScript function (the event listener), you can include the argument(s) and
retrieve the value at runtime.
function DynamicWebTwain_OnMouseClick(index) {
console.log(index);
}
or
DWObject.RegisterEvent("OnMouseClick", function (index) {
console.log(index);
};
Special Event - OnWebTwainReady
To check all the events, please refer to the API Documentation. Of all these events, there is one called
OnWebTwainReady
that is special. This event fires as soon as the Dynamic Web TWAIN object finishes initializing.
As you may have seen earlier in the document, the recommended way to use it is:
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', Dynamsoft_OnReady);
var DWObject;
function Dynamsoft_OnReady() {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
}
or
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', function () {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
};
14
15
Explore the Features
Customize your scan settings
Manipulate the images
Use the ImageEditor
Create a thumbnails view
Scan large amounts of documents
Load local images
Save images locally
Upload images to the web server
Download images from the web
Use Capability Negotiation
Add/Remove the object individually
16
Customize scan settings
Before you start an actual scan, you can choose how you want to scan your documents. Typically, you can
change all the settings in the scanner’s built-in User Interface. Take the Virtual scanner for example:
All these settings might be overwhelming for end users, especially for those without a technical background. With
Dynamic Web TWAIN, you can customize all these settings in your JavaScript code. For example:
DWObject.SelectSource();
DWObject.OpenSource();// You should customize the settings after opening a source
DWObject.IfShowUI = false;// Hide the User Interface of the scanner
17
DWObject.IfFeederEnabled = true;// Use the document feeder to scan in batches
DWObject.IfDuplexEnabled = false;// Scan in Simplex mode (only 1 side of the page)
DWObject.PixelType = EnumDWT_PixelType.TWPT_GRAY; // Scan pages in GRAY
DWObject.Resolution = 200; // Scan pages in 200 DPI
DWObject.AcquireImage();// Start scanning
18
Manipulate the image(s)
When you have scanned or loaded images in Dynamic Web TWAIN, you can start manipulating the images. You
can:
1. Go through each image by changing the property
CurrentImageIndexInBuffer
/* Show the 3rd image in the buffer */
DWObject.CurrentImageIndexInBuffer = 2;
2. Show multiple images by changing the view mode (other than 1 by 1 or -1 by -1) using
/* Show 4 images in the viewer 2 by 2*/
DWObject.SetViewMode(2, 2);
3. Rotate, flip, mirror or crop an image, etc.
DWObject.Mirror(0);
DWObject.Flip(1);
DWObject.RotateRight(2);
DWObject.Crop(3,101,243,680,831);
DWObject.RotateLeft(3);
19
SetViewMode()
Also, you can remove an image by its index or remove selected or all images at once. The methods are
RemoveImage()
,
RemoveAllSelectedImages()
,
RemoveAllImages()
20
.
21
Create A Thumbnails View
In the HTML5 edition of version 14.0+, you can use the built-in editor of Dynamic Web TWAIN together with the
main image viewer to create a thumbnails view. The following code shows how to do it.
Note:
For the ActiveX, you will still need to use two controls to simulate the thumbnails.
Thumbnails View
The following shows what it looks like
22
As shown above, the built-in editor comes with many features itself. By clicking the buttons, you can scan, load,
remove images and then edit them or zoom in/out to view them better.
Note:
If the DIV holding the editor isn't wide enough, the buttons are hidden group by group automatically.
All buttons are displayed by default. If you like, you can choose to hide/show one or more buttons in the file
dynamsoft.webtwain.config.js
.
In the dynamsoft.webtwain.config.js
The following are the default configurations, and you can edit the visibility to show/hide some buttons.
bShowAllButtons: true,
visibility: {
//only valid when bShowAllButtons is true, otherwise changing visibility does nothing
'scan': true, 'load': true, 'print': true,
'removeall': true, 'removeselected': true,
'rotateleft': true, 'rotate': true, 'rotateright': true, 'deskew': true,
'crop': true, 'erase': true, 'changeimagesize': true, 'flip': true, 'mirror': true,
'zoomin': true, 'originalsize': true, 'zoomout': true, 'stretch': true,
'fit': true, 'fitw': true, 'fith': true,
'hand': true, 'rectselect': true, 'zoom': true
}
23
Scan Lots of Documents at a Time - Disk Caching
Sometimes, you may need to scan hundreds or even thousands of documents at a time. In this case, the disk
caching feature may come in handy. The related properties are
IfAllowLocalCache
and
BufferMemoryLimit
.
Although Dynamic Web TWAIN can run both in 32bit and 64bit, it’s 32bit by default which means it can utilize no
more than 2 GB of physical memory. However, the data the SDK deals with are images which take up much
space. For example, one A4 paper scanned in 300 DPI takes around 24MB in memory (DIB) and even if you can
use 2GB to store images, you can store no more than 85 of them. Therefore Dynamsoft added the disk-caching
feature to the SDK which, when enabled, caches most images temporarily on the disk while keeping a few active
ones in the memory to maintain high performance.
The disk caching feature is enabled by default and can be disabled by setting
IfAllowLocalCache
to
false
.
We can also set how much memory we want the SDK to use before images start to be cached. By default,
is used. You can change it using the property
BufferMemoryLimit
800MB
.
NOTE:
All cached data is encrypted and can only be accessed by Dynamic Web TWAIN
For ActiveX Edition: the cached data is stored in
C:\Users\{User
Name}\AppData\LocalLow\Dynamsoft\cache
For HTML5 Edition: it is stored in
C:\Windows\SysWOW64 {or system32}\Dynamsoft\DynamsoftService\cache
When the SDK is unloaded (like when the browser tab is closed), the cached data is destroyed and
removed from the disk automatically.
Although you can scan and load as many images as you like, you need to handle them in a smaller
volume instead of processing them all at once. For example, you should not upload too many images
as one file because it may exceed the memory limit.
24
Load local image(s) into Dynamic Web TWAIN
NOTE
Before you try to load any images, bear in mind that as a lightweight component running in web browsers,
Dynamic Web TWAIN is only designed to deal with the most basic images in the following formats: BMP,
JPEG, PNG, TIFF and PDF. We only guarantee that images generated by Dynamic Web TWAIN can load
successfully. If you are trying to load an image that was not generated by Dynamic Web TWAIN, it may or
may not work.
Methods
With Dynamic Web TWAIN, you can load local images with the methods
LoadImage()
or
LoadImageEx()
. Below is
a simple code snippet:
DWObject.LoadImage("C:\\WebTWAIN\\Images\\ImageData.jpg", optionalAsyncSuccessFunc, optionalAsyncFailureFunc);
DWObject.LoadImageEx("C:\\WebTWAIN\\Images\\ImageData.jpg", EnumDWT_ImageType.IT_JPG, optionalAsyncSuccessFunc, optio
nalAsyncFailureFunc); // ImageType: JPG
//Callback functions for async APIs
function optionalAsyncSuccessFunc() {
console.log(‘successful’);
}
function optionalAsyncFailureFunc(errorCode, errorString) {
alert(errorString);
}
As you can see, you need to provide the complete file path to load an image. It is somewhat clumsy especially
when you need to load more than one image. But no worries, Dynamic Web TWAIN can open a "Select File…"
dialog for you to locate the image(s) you want to load. Moreover, like other properties and methods, it’s effortless
to use. Below is a code snippet:
DWObject.IfShowFileDialog = true;
DWObject.LoadImageEx("", EnumDWT_ImageType.IT_ALL); //ALL (BMP, JPG, PNG, PDF, TIFF)
Please note that the second parameter
ImageType
in the method
the "Select File…" dialog.
25
LoadImageEx()
would determine the file filter in
Starting from v14.0, you can also drag and drop images onto the Dynamic Web TWAIN viewer to load them.
26
27
Save image(s) locally
NOTE
Dynamic Web TWAIN can save all scanned or loaded images locally in the following formats:
PNG
,
(single-page or multi-page) and
TIFF
PDF
BMP
,
JPEG
,
(single-page or multi-page).
Methods
With Dynamic Web TWAIN, you can choose one of the following methods to save an image or images:
Format
Method
Single-Page
SaveAsBMP()
SaveAsJPEG()
SaveAsPDF()
SaveAsPNG()
SaveAsTIFF()
Multi-Page PDF
SaveSelectedImagesAsMultiPagePDF()
SaveAllAsPDF()
Multi-Page TIFF
SaveAllAsMultiPageTIFF()
SaveSelectedImagesAsMultiPageTIFF()
Code snippet:
//Use it synchronously
DWObject.SaveAsJPEG("C:\\WebTWAIN\\Images\\ImageData.jpg", 0);
//Use it asynchronously
DWObject.SaveAllAsPDF("C:\\WebTWAIN\\Images\\ImageData.pdf", optionalAsyncSuccessFunc, optionalAsyncFailureFunc);
//Callback functions for Async APIs
function optionalAsyncSuccessFunc() {
console.log(‘successful’);
}
function optionalAsyncFailureFunc(errorCode, errorString) {
alert(errorString);
}
From the above code, you can see that you need to provide the complete file path to save an image locally,
which is sometimes inconvenient. But no worries, just like loading an image, Dynamic Web TWAIN can also open
a "Save As…" dialog for you to locate the path that you want to save the image(s) to. Below is a code snippet:
DWObject.IfShowFileDialog = true;
DWObject.SaveAsJPEG("",0);
It brings up this dialog box with the "Save as type" specified by the method you use:
28
NOTE
On Windows 7 and above, Microsoft has strengthened security which means you can only save images to
certain places where you have the write permission. If you try to save to other places, you will get the
below error message. You can then save to a different directory or first obtain permission for that directory.
29
Upload image(s) to the web server
NOTE
Before we upload the image(s), we need to set the server IP/name, set the port number, as well as define
the path for the action page. The action page refers to the target script that receives the HTTP Post
request containing the image data and handles all the server-side operation like saving the data on the
hard disk or database, etc. Here is an example:
Upload and Save on the Server Disk
var strHTTPServer = location.hostname;
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0, CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "actionPage.aspx";
var uploadfilename = "TestImage.pdf";
In the code snippet
strHTTPServer
is used to store the server name which specifies which server the image(s) will be uploaded to.
You can also use the server’s IP for the same purpose. If you want to upload image(s) to the same server as the
current page, we suggest you use
The property
443
is for
HTTPPort
HTTPS
location.hostname
to get the
hostname
at runtime.
specifies the HTTP port to be used for the upload. Normally, port
. If you are not sure about the port number, you can use
80
is for
HTTP
, port
location.port == "" ? 80 : location.port
to get the current port number at runtime.
CurrentPathName
strActionPage
uploadfilename
and
CurrentPath
are used to build the relative path of the action page.
stores the relative path of the action page.
stores the file name for the uploaded image(s). You should change the extension of the name
accordingly.
NOTE
In version 10.0 and above, we are using the browser as the upload agent. Due to browser security
restrictions, client-side scripts (e.g., JavaScript) are not allowed to make requests to another domain.
Therefore, when you try to upload an image to a server with a different domain, subdomain, port, or
protocol, you need to configure your server to allow such requests by adding an HTTP Response Header,
namely
Access-Control-Allow-Origin: *
Take IIS 7 for example. What you need to do is merge the following lines into the web.config file at the root
of your application / site:
30
If you don't have a web.config file already, just create a new file called "web.config" and add the snippet
above.
Methods
Now, we can call one of the HTTP upload methods to upload the image(s). We have 8 methods:
Format
Method
Any Type
HTTPUploadThroughPostDirectly()
Supported Images
HTTPUpload()
HTTPUploadThroughPost()
HTTPUploadThroughPostEx()
Multi-Page PDF
HTTPUploadAllThroughPostAsPDF()
HTTPUploadThroughPostAsMultiPagePDF()
Multi-Page TIFF
HTTPUploadAllThroughPostAsMultiPageTIFF()
HTTPUploadThroughPostAsMultiPageTIFF()
Let’s take the method
HTTPUploadAllThroughPostAsPDF()
for example:
DWObject.HTTPUploadAllThroughPostAsPDF(
strHTTPServer,
strActionPage,
uploadfilename,
OnHttpUploadSuccess,
OnHttpUploadFailure
);
With this method, all the images in the Dynamic Web TWAIN control will be sent to the web server as one multipage PDF file.
In the above code, the parameters
OnHttpUploadSuccess
and
OnHttpUploadFailure
are optional callback functions. If
they are present, the method is asynchronous; otherwise, the method is synchronous. You can use the methods
asynchronously to avoid possible browser hanging.
The following is a simple implementation of these two functions:
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
31
If you want to upload one image as a single-page file, you can use
HTTPUploadThroughPostEx()
HTTPUploadThroughPost()
or
.
If you want to upload selected images as a multi-page file, you can use
HTTPUploadThroughPostAsMultiPageTIFF()
HTTPUploadThroughPostAsMultiPagePDF()
or
.
Action Page
The HTTP upload method(s) makes a standard HTTP post request to the action page on the server. The request
contains the image data, image name, etc. In the action page, you can process the image data according to your
requirements. Technically you can write the action page in any server-side language (such as
Java
C#
,
VB
,
PHP
,
).
Here is an example in
C#
:
This action page retrieves the image data from the current HTTP request object and saves it as a local file on the
server.
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
uploadfile.SaveAs(System.Web.HttpContext.Current.Request.MapPath(".") + "/" + uploadfile.FileName);
Note
Please note that
RemoteFile
is the default name/key for the uploaded image data. If necessary, you can
change it using the property
HttpFieldNameOfUploadedImage
.
To do the same thing in PHP:
$fileTempName = $_FILES['RemoteFile']['tmp_name'];
$fileSize = $_FILES['RemoteFile']['size'];
$fileName = $_FILES['RemoteFile']['name'];
move_uploaded_file($fileTempName, $fileName) ;
Upload to FTP
Besides the HTTP upload methods, you can also use the FTP Upload methods to update the image(s) to your
FTP web server. The available APIs are:
Format
Method
Any Type
FTPUploadDirectly()
Supported Images
FTPUpload()
FTPUploadEx()
Multi-Page PDF
FTPUploadAllAsPDF()
FTPUploadAsMultiPagePDF()
Multi-Page TIFF
FTPUploadAllAsMultiPageTIFF()
FTPUploadAsMultiPageTIFF()
Code Snippet
DWObject.FTPUserName = 'test';
32
DWObject.FTPPort = 21;
DWObject.FTPPassword = 'test';
DWObject.FTPUploadAllAsPDF(
'192.168.8.222',
'test.pdf',
OnFtpUploadSuccess,
OnFtpUploadFailure
);
Upload image(s) to a Database
Dynamic Web TWAIN doesn’t save/upload the image(s) to your database directly. Instead, the image data hits
the action page first, and then the code in the action page decides where to store it.
If you are not sure how to upload the image data to the server, please refer to the previous section Upload and
Save on the Server Disk.
Different database systems may have different data types for image data. We generally use
in
MSSQL
Server,
Long raw
Here is an example in
C#
or
BLOB
with
in
MSSQL
Oracle
,
BLOB
in
MySQL
BLOB
or
varbinary
.
Server:
int iFileLength;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
String strImageName = uploadfile.FileName;
iFileLength = uploadfile.ContentLength;
Byte[] inputBuffer = new Byte[iFileLength];
System.IO.Stream inputStream;
inputStream = uploadfile.InputStream;
inputStream.Read(inputBuffer,0,iFileLength);
// add code to connect to database
String SqlCmdText = "INSERT INTO tblImage (strImageName,imgImageData) VALUES (@ImageName,@Image)";
System.Data.SqlClient.SqlCommand sqlCmdObj = new System.Data.SqlClient.SqlCommand(SqlCmdText, sqlConnection);
sqlCmdObj.Parameters.Add("@Image",System.Data.SqlDbType.Binary,iFileLength).Value = inputBuffer;
sqlCmdObj.Parameters.Add("@ImageName",System.Data.SqlDbType.VarChar,255).Value = strImageName;
sqlConnection.Open();
sqlCmdObj.ExecuteNonQuery();
sqlConnection.Close();
In the code snippet, we get the file object from the current HTTP request and write the image data to a byte array.
In the SQL statement, we pass the byte array to the database as
in a BL field called
imgImageData
System.Data.SqlDbType.Binary
and store the data
.
Upload image(s) with extra data
If you are not sure how to upload the image data to the server, please refer to the previous section Upload and
Save on the Server Disk.
Sometimes we need to pass more information to the server. For example,
description
document type
,
employee ID
,
document
, etc. Since we don’t have any options to pass extra data in the HTTP upload method, we need to use
a method called
SetHTTPFormField
.
33
SetHTTPFormField(String sFieldName, String sFieldValue)
: specifies the name of a text field in the web form
String
sFieldName
String
sFieldValue
: specifies the value of a text field in the web form
We need to use this method before the Upload. Here is an example:
DWObject.ClearAllHTTPFormField(); // Clear all fields first
DWObject.SetHTTPFormField("EmployeeID", "2012000054");
DWObject.SetHTTPFormField("DocumentType", "Invoice");
DWObject.SetHTTPFormField("DocumentDesc", "This is an invoice from ...");
In the action page, you can retrieve the data from the request object by the field names. For example:
String EmployeeID = HttpContext.Current.Request.Form["EmployeeID"];
34
Download image(s) from the web
You can use the method
HTTPDownload()
or
HTTPDownloadEx()
to download an image from the web server into
Dynamic Web TWAIN. It is especially useful when you want to review an image created and uploaded by
Dynamic Web TWAIN.
DWObject.HTTPDownload("www.dynamsoft.com", "/images/dwt-logo.png",
optionalAsyncSuccessFunc, optionalAsyncFailureFunc);
//Callback functions for async APIs
function optionalAsyncSuccessFunc() {
console.log('successful');
}
function optionalAsyncFailureFunc(errorCode, errorString) {
alert(errorString);
}
Even when the image data is stored in the database, you can write an action page to pull the data from the
database and get it downloaded (in this case, you need to use the method
HTTPDownloadEx()
because the image
format needs to be specified explicitly). Besides the HTTP download methods, you can also use the FTP
download methods to download image(s) from an FTP server. Available methods are
FTPDownloadEx()
FTPDownload()
,
, etc.
NOTE
When you try to download an image from a server with a different domain, subdomain, port, or protocol,
you need to configure your server to allow such requests by adding one HTTP Response Header, namely:
Access-Control-Allow-Origin: *
Take IIS 7 for example, what you need to do is merge the following lines into the
web.config
file at the root
of your application/site:
If you don't have a
web.config
file already, just create a new file called
above.
35
web.config
and add the snippet
36
Use Capability Negotiation
Introduction
Capabilities represent the features that a specified TWAIN source (e.g., a scanner) provides. To make full use of
such a source/device, TWAIN applications need to perform the operation called capability negotiation. With the
negotiation, TWAIN applications can understand the source and then guide it to provide the images they would
like to receive from it.
Capability Containers
Container Data
Structure
Type of Contents
TW_ONEVALUE
A single value whose current and default values are coincident. The range of
available values for this type of capability is simply this single value. For example,
a capability that indicates the presence of a document feeder could be of this
type.
TW_ARRAY
An array of values that describes the current logical item. The available values
may be a larger array of values. For example, a list of the supported capabilities
list returned by the CAP_SUPPORTEDCAPS capability, would use this type of
container.
TW_RANGE
Many capabilities allow users to select their current value from a range of
regularly spaced values. The capability can specify the minimum and maximum
acceptable values and the incremental step size between values. For example,
the resolution might be supported from 100 to 600 in steps of 50 (100, 150, 200,
..., 550, 600).
TW_ENUMERATION
This is the most general type because it defines a list of values from which the
Current Value can be chosen. The values do not progress uniformly through a
range and there is not a consistent step size between the values. For example, if
a Source’s resolution options did not occur in even step sizes, then an
enumeration would be used (for example, 150, 400, and 600).
What is involved
To perform capability negotiation, you do two things
Get a Capability. It is used to ask the source about a specified capability and get its type, value, etc.
Set a Capability. It is generally used to request the source to set/change the value of a capability.
Now we’ll talk about how to perform capability negotiation
Before doing any capability negotiation, please keep in mind that it can only take place when the source is open
(
DataSourceStatus
is 1). You need to use the methods
SelectSource()
and get it ready for the negotiation. The related APIs are
Capability
37
and
OpenSource()
to select a TWAIN source
CapGet
CapSet
CapReset
CapType
CapValue
CapValueType
CapValueString
CapGetCurrent
CapGetDefault
CapCurrentIndex
CapCurrentValue
CapDefaultIndex
CapDefaultValue
CapMaxValue
CapMinValue
CapNumItems
CapStepSize
GetCapItemsString
GetCapItems
Get
To get information about a capability, you can use the following code snippet by specifying the capability.
DWObject.OpenSource();
DWObject.Capability = EnumDWT_Cap.***;
DWObject.CapGet();
var tempValue = '';
DWObject.CapValueType > 8 ?
/*STR*/tempValue = DWObject.CapValueString
:
/*NUM*/tempValue = DWObject.CapValue;
/*
* Special for BOOL
*/
if (DWObject.CapValueType == EnumDWT_CapValueType.TWTY_BOOL) {
tempValue == 0 ? tempValue = 'FALSE' : tempValue = 'TRUE';
}
alert('The type of the capability is ' + DWObject.CapType); /*More info*/
alert('The value of the capability is ' + tempValue);
Set
Please NOTE that the TWAIN source vendor generally dictates the container type and available values for a
capability. When you try to set a capability, you are just trying to change it so that it uses a different but available
value. Therefore, you should try to get the capability before you set it.
The code to set capabilities is different if they have different container types.
TW_ONEVALUE
38
DWObject.OpenSource();
DWObject.Capability = EnumDWT_Cap.***; /*Make sure this Capability is TW_ONEVALUE*/
DWObject.CapGet(); /*Recommended*/
DWObject.CapType = EnumDWT_TWAINCONTAINERTYPE.TWON_ONEVALUE;
DWObject.CapValueType > 8 ?
/*STR*/DWObject.CapValue = someStringValue;
:
/*NUM*/DWObject.CapValue = someNonStringValue;
DWObject.CapSet();
TW_ARRAY
DWObject.OpenSource();
DWObject.Capability = EnumDWT_Cap.***; /*Make sure this Capability is TWON_ARRAY*/
DWObject.CapGet(); /*Recommended*/
DWObject.CapType = EnumDWT_TWAINCONTAINERTYPE.TWON_ARRAY;
DWObject.CapNumItems = *;
if (DWObject.CapValueType > 8) {
/*STR*/
DWObject.SetCapItemsString(0, someStringValue);
DWObject.SetCapItemsString(1, someStringValue);
…
} else {
/*NUM*/
DWObject.SetCapItems(0, someNonStringValue);
DWObject.SetCapItems(1, someNonStringValue);
…
}
DWObject.CapSet();
TW_RANGE
DWObject.OpenSource();
DWObject.Capability = EnumDWT_Cap.***; /*Make sure this Capability is TWON_RANGE*/
DWObject.CapGet(); /*Recommended*/
DWObject.CapType = EnumDWT_TWAINCONTAINERTYPE.TWON_RANGE;
DWObject.CapMinValue = 80;
DWObject.CapMaxValue = 200;
DWObject.CapStepSize = 20;
DWObject.CapCurrentValue = 100;
DWObject.CapSet();
TW_ENUMERATION
DWObject.OpenSource();
DWObject.Capability = EnumDWT_Cap.***; /*Make sure this Capability is
TWON_ENUMERATION*/
DWObject.CapGet(); /*Recommended*/
DWObject.CapType = EnumDWT_TWAINCONTAINERTYPE.TWON_ENUMERATION;
DWObject.CapNumItems = *;
if(DWObject.CapValueType > 8 ){
/*STR*/
DWObject. SetCapItemsString (0, someStringValue);
DWObject. SetCapItemsString (1, someStringValue);
…
} else {
/*NUM*/
DWObject. SetCapItems(0, someNonStringValue);
39
DWObject. SetCapItems(1, someNonStringValue);
…
}
DWObject.CapCurrentIndex = 1;
DWObject.CapSet();
40
Add/Remove Additional Dynamic Web TWAIN
object(s)
NOTE: What is discussed here works only for the HTML5 editions of Dynamic Web TWAIN.
To add/remove an additional Dynamic Web TWAIN object, you can use the following methods.
Dynamsoft.WebTwainEnv.CreateDWTObject(id, OnSuccessCallback, OnFailureCallback)
Dynamsoft.WebTwainEnv.DeleteDWTObject(id).
Add a Dynamic Web TWAIN object at runtime
1. Create a new DIV element as the placeholder for this object.
2. Use the method
Dynamsoft.WebTwainEnv.CreateDWTObject(id, OnSuccessCallback, OnFailureCallback)
initialize the Dynamic Web TWAIN object that will be embedded in the div with id
to create and
dwtcontrolContainer2
.
var DWObject2;
Dynamsoft.WebTwainEnv.CreateDWTObject(
"dwtcontrolContainer2",
function (newDWObject) { DWObject2 = newDWObject; },
function (errorString) { alert(errorString); }
);
NOTE: If the div element with id
Dynamsoft.WebTwainEnv.Containers
dwtcontrolContainer2
already exists in
, you will get the following error
Duplicate ID detected for creating Dynamic Web TWAIN objects, please check and modify.
When this happens, please check if you’ve set
in
dwtcontrolContainer2
in
Dynamsoft.WebTwainEnv.Containers
dynamsoft.webtwain.config.js
3. You can now use the new Dynamic Web TWAIN object.
DWObject2.Width = 580;
DWObject2.Height = 600;
DWObject2.SelectSource();
DWObject2.AcquireImage();
Remove a Dynamic Web TWAIN object at runtime
To remove a Dynamic Web TWAIN object from the web page. Just call the method
Dynamsoft.WebTwainEnv.DeleteDWTObject(id)
with
id
specifying the container id. For example
Dynamsoft.WebTwainEnv.DeleteDWTObject("dwtcontrolContainer2");
41
NOTE:
Dynamsoft.WebTwainEnv.Unload()
can’t release the Dynamic Web TWAIN objects generated by the method
Dynamsoft.WebTwainEnv.CreateDWTObject()
. You can only use the method
Dynamsoft.WebTwainEnv.DeleteDWTObject(id)
to release that object.
42
License Verification
Basic Information
Since version 9.0, Dynamic Web TWAIN has been using the property ProductKey for license verification at
runtime. The property accepts a series of alphanumeric code as the product key which is generated based on the
license(s) you own. All editions share the same authentication mechanism.
Note
1. One product key can be generated from one or many licenses, this is done by Dynamsoft
2. The product key represents the encrypted license(s); every product key is unique
3. The product key can also be bound to a specific domain (since version 11)
Use the Product Key
Set it during initialization (recommended)
Set ProductKey in the file Dynamsoft.webtwain.config.js
Dynamsoft.WebTwainEnv.ProductKey = 't0068MgAA…';
Set it when necessary (not recommended)
Set ProductKey in your code before you call the method
AcquireImage()
function AcquireImage() {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.ProductKey = 't0068Mg…';
DWObject.AcquireImage();
}
Use Multiple ProductKeys
If you have multiple product keys generated from multiple serial numbers, you can combine all of them using the
semi-colon
;
and assign them to the
ProductKey
property.
Dynamsoft.WebTwainEnv.ProductKey = 't0068MgAA…;t006…;t00…';
43
Use Add-ons
In summary, the functionality of the Dynamic Web TWAIN SDK itself is mainly
Get images from a scanner or other source (such as local images, server-side images)
Display the captured image in the image viewer
Edit images in ways like rotating, cropping, deleting, etc.
Encode the image data into various image formats (PDF, TIFF, JPEG, PNG, BMP)
Save encoded images on the local disk or onto a remote server/database.
In many document management systems, in addition to the above functions, you may also need features like
barcode recognition, text extraction, etc. In the light of this, Dynamsoft also offers the following extensions so that
you can design more efficient and automated business processes:
PDF Rasterizer
Convert an existing text-based PDF file (that is, the text in the file is searchable) into an image. Because only
then can this PDF file be displayed in the image viewer of the SDK.
Barcode Reader
Identify the barcode data directly from the image acquired from the scanner or local disk. The use of barcodes on
documents can significantly improve the efficiency of document categorization or content extraction.
Dynamsoft Camera Capture
Display the video stream of a Webcam attached to the machine directly on the web page and capture still images
from the stream.
Mobile Browser Capture
Perform document capture using the cameras from mobile devices.
OCR
Extract the text information from acquired images or convert the images to text or searchable PDF files.
44
Quickly convert PDF to images with the PDF
Rasterizer
Introduction
PDF is one of the most popular formats on the market. In most cases, PDF files are readable, meaning that
they contain text content internally. One way to convert this to an image is to take a screenshot of the
page. However, this is very inefficient. By using the PDF Rasterizer, you can get it done quickly.
Environment
node
NOTE:
The PDF Rasterizer itself doesn't rely on
Node.js
, and it's needed in this article just because it's faster for
us to use its package manager (npm) to get required files.
Steps
Step 1 Create a new directory, open the command line tool inside
(shortcut is Ctrl+Shift+right click ). Download the core control used
in this article through npm
npm install dwt@14.2.0
Then you can see the following in this directory
Step 2 Open to the following directory
node_modules\dwt\sample
where you can see
45
Step 3 In this article, we are going to check PDFRasterizer.html .
Double click it to open. If the related controls are not yet available, follow
the prompts to install them
Under normal circumstances, the installed files can be found in the
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService
directory. The core files here are mainly
DynamsoftService.exe
dwt_trial_14.1.0.0828.dll
DynamicPdf_10.3.0.0712.dll
Step 4 After the installation is complete, refresh the page, click the second
button and open a local PDF file. Soon this PDF file will show up as an
image(s) in the image viewer on the page
46
At this point, you can open the browser's developer interface (F12) and try to execute the following code which
allows you to view multiple images at a time.
DWObject.SetViewMode(3,3);
47
You can also save these images to your local disk (in formats like
JPEG
,
BMP
,
PNG
,
TIF
, etc.)
DWObject.IfShowFileDialog = true;
DWObject.SaveAsJPEG('');
How it is done
Open
PDFRasterizer.html
in a text editor
References to the Core JavaScript files
Here the files referenced are
JS library for the core SDK
Dynamic Web TWAIN
node_modules\dwt\dist\dynamsoft.webtwain.initiate.js
JS library for the
node_modules\dwt\dist\dynamsoft.webtwain.config.js
PDF Rasterizer addon
node_modules\dwt\dist\addon\dynamsoft.webtwain.addon.pdf.js
If you have previously installed the Dynamic Web TWAIN locally, the same files are located in the following
directory.
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {version number} {Trial}\Resources
Runtime installation of the necessary files
When you open the page, the JavaScript files execute trying to set up the runtime environment. If the local
Dynamsoft Service and the library files including the Dynamic Web TWAIN and PDF Rasterizer are missing, the
code will show the prompt (Step 3) so that you can download and install the files.
Use the addon
if (DWObject.Addon && DWObject.Addon.PDF) {
DWObject.Addon.PDF.SetResolution(300);
DWObject.Addon.PDF.SetConvertMode(EnumDWT_ConvertMode.CM_RENDERALL);
}
DWObject.LoadImageEx('', 5,
function () {
},
function (errorCode, errorString) {
alert('Load Image:' + errorString);
}
);
The core code is
DWObject.Addon.PDF.SetResolution(300); //Set the resolution for the conversion
48
DWObject.Addon.PDF.SetConvertMode(EnumDWT_ConvertMode.CM_RENDERALL);//Set the conversion mode, generally just set it
to CM_RENDERALL
After the above settings, when you import a
HTTPDownload
, etc.,
PDF Rasterizer
PDF
file by calling one of the methods
LoadImage
is called automatically to raster the file into an image.
49
,
LoadImageEx
,
Automatic classification in document digitalization
by using Barcode recognition
Introduction
Nowadays, the idea of a paperless office is becoming more and more popular, and the digitalization of
paper documents has become a trend. At the same time, many industries, such as hospitals, banks, etc.,
still need to print documents and then digitalize them after that. As a result, due to the time difference
between different operations, it is very likely that a large number of paper documents will pile up and wait
for scanning. Then it'll require a one-time scanning of multiple documents during which the documents
need to be classified. It is true that these tasks can be done manually, but automation can save a lot of
time and effort. In this article, we share how to implement the automation through barcode in a web
application.
Environment
Windows
Local web server
Steps
Step 1 Create a new directory DocumentsSeparation create a new page
in it index.html
Documents Separation
Step 2 Reference core JavaScript library
Documents Separation
Note
50
The online
JavaScript
file is referenced here. In your project, you should instead reference the
corresponding file in your project. If you have previously installed the
Dynamic Web TWAIN
product locally, the
same files can also be found in the following directory.
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {version number} {Trial}\Resource
Step 3 Add a DIV and a few buttons
They'll look like this
Step 4 Add initialization code
51
Step 5 Open index.html in the browser. If it has not been installed
before, follow the prompts on the page to install the corresponding scan
and Barcode recognition controls. This installation process only needs to
be done once on each computer
Typically they are installed to
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService
The following are the major files used in the article.
DynamsoftService.exe
dwt_trial_14.1.0.0828.dll
DynamsoftBarcodeReaderx86_6.3.dll
dbr_6.3.0.0723.dll
Step 6 Add code for the buttons
function AcquireImage() {
if (DWObject) {
DWObject.SelectSource(function () {
var OnAcquireImageSuccess, OnAcquireImageFailure;
OnAcquireImageSuccess = OnAcquireImageFailure = function () {
DWObject.CloseSource();
};
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage(OnAcquireImageSuccess, OnAcquireImageFailure);
}, function () {
52
console.log('Failed to select a source');
});
}
}
function LoadImages() {
if (DWObject) {
DWObject.LoadImageEx('', 5,
function () {
},
function (errorCode, errorString) {
console.log('ailed to load a file with the error code:' + errorString);
}
);
}
}
function RemoveImages() {
if (DWObject)
DWObject.RemoveAllSelectedImages();
}
Step 7 Refresh the page. At this point, you can call the local scanner or
load the local image, or delete the selected image. You can even drag a
local image directly to load it directly
53
Step 8 Add the Barcode recognition code, because there are many types
of Barcode, we first add a selection box, the corresponding code is as
follows
HTML
54
JavaScript
var BarcodeInfo =
[
{ desc: "All", val: 503317503 },
{ desc: "1D Barcodes", val: 1023 },
{ desc: "QR Code", val: 67108864 },
{ desc: "PDF417", val: 33554432 },
{ desc: "DATAMATRIX", val: 134217728 },
{ desc: "AZTEC", val: 268435456 },
{ desc: "CODE_39", val: 1 },
{ desc: "CODE_128", val: 2 },
{ desc: "CODE_93", val: 4 },
{ desc: "CODABAR", val: 8 },
{ desc: "ITF", val: 16 },
{ desc: "EAN_13", val: 32 },
{ desc: "EAN_8", val: 64 },
{ desc: "UPC_A", val: 128 },
{ desc: "UPC_E", val: 256 },
{ desc: "INDUSTRIAL_25", val: 512 }
];
// Add the following code to the function `Dynamsoft_OnReady` mentioned above
for (var index = 0; index < BarcodeInfo.length; index++)
document.getElementById("barcodeformat").options.add(new Option(BarcodeInfo[index].desc, index));
document.getElementById("barcodeformat").options.selectedIndex = 0;
Step 9 There are three ways to do the classification of documents
Start each document with an image with barcode
Use the images with barcode as the separator only without including them in any document
Each page has a Barode and the image with the same Barcode belongs to the same file
We'll implement all three ways in our code
-
-
-
55
-
-
-
Now the page looks like this
Step 10 Add JavaScript code for the classification
function UploadFiles() {
DWObject.IfShowProgressBar = false;
ProcssedImagesCount = 0;
imageArrays = [];
aryIndicesMode1 = [];
aryIndicesMode2 = [];
aryIndicesMode3 = {
'noBarcode': []
};
Dynamsoft.Lib.showMask();
ReadBarcode(0);
}
56
function ReadBarcode(i) {
var j, sImageIndex = i,
bBarcodeFound = false,
strSelectedMode = document.getElementsByName('UploadModes');
for (j = 0; j < strSelectedMode.length; j++) {
if (strSelectedMode.item(j).checked == true) {
strSelectedMode = strSelectedMode.item(j).value;
break;
}
}
if (sImageIndex == DWObject.HowManyImagesInBuffer)
return;
if (dbrObject) {
var settings = dbrObject.getRuntimeSettings();
settings.mBarcodeFormatIds = BarcodeInfo[document.getElementById("barcodeformat").selectedIndex].val;
dbrObject.updateRuntimeSettings(settings);
DWObject.CurrentImageIndexInBuffer = sImageIndex;
var barcodeImage = DWObject.GetImageURL(sImageIndex, -1, -1);
dbrObject.decode(barcodeImage).then(function (results) {
ProcssedImagesCount++;
if (results.length == 0) {
console.log("No barcode found on image " + (sImageIndex + 1));
if (bBarcodeFound == true) {
bBarcodeFound = false;
aryIndicesMode1[aryIndicesMode1.length - 1].push(sImageIndex);
if (aryIndicesMode2.length == 0)
aryIndicesMode2.push([sImageIndex]);
else
aryIndicesMode2[aryIndicesMode2.length - 1].push(sImageIndex);
} else {
if (aryIndicesMode1.length == 0)
aryIndicesMode1.push([sImageIndex]);
else
aryIndicesMode1[aryIndicesMode1.length - 1].push(sImageIndex);
if (aryIndicesMode2.length == 0)
aryIndicesMode2.push([sImageIndex]);
else
aryIndicesMode2[aryIndicesMode2.length - 1].push(sImageIndex);
}
aryIndicesMode3.noBarcode.push(sImageIndex);
} else {
bBarcodeFound = true;
console.log("Barcode found on image " + (sImageIndex + 1));
aryIndicesMode1.push([sImageIndex]);
if (aryIndicesMode2.length == 0)
aryIndicesMode2.push([]);
else if (aryIndicesMode2[aryIndicesMode2.length - 1].length != 0)
aryIndicesMode2.push([]);
var barcodeOnThisImage = [],
allKeys = [];
for (j = 0; j < results.length; j++) {
var result = results[j];
var barcodeText = result.BarcodeText;
if (barcodeOnThisImage.indexOf(barcodeText) == -1)
barcodeOnThisImage.push(barcodeText);
console.log("The content for barcode number " + (j + 1) + "is: " + barcodeText);
var imageArray = {
index: sImageIndex,
text: barcodeText
};
imageArrays.push(imageArray);
}
Dynamsoft.Lib.each(aryIndicesMode3, function (value, key) {
57
allKeys.push(key);
});
for (j = 0; j < allKeys.length; j++) {
var oKey = allKeys[j];
if (barcodeOnThisImage.indexOf(oKey) != -1) {
barcodeOnThisImage.splice(barcodeOnThisImage.indexOf(oKey), 1);
var _value = aryIndicesMode3[oKey];
if (_value.indexOf(sImageIndex) == -1) {
_value.push(sImageIndex);
aryIndicesMode3[oKey] = _value;
}
}
}
for (j = 0; j < barcodeOnThisImage.length; j++) {
aryIndicesMode3[barcodeOnThisImage[j]] = [sImageIndex];
}
}
if (ProcssedImagesCount == DWObject.HowManyImagesInBuffer) {
ProcssedImagesCount = 0;
var aryTemp = [];
Dynamsoft.Lib.each(aryIndicesMode3, function (value, key) {
aryTemp.push(value);
});
aryIndicesMode3 = aryTemp;
Dynamsoft.Lib.hideMask();
switch (strSelectedMode) {
case 'mode1':
console.log(aryIndicesMode1);
break;
case 'mode2':
console.log(aryIndicesMode2);
break;
case 'mode3':
console.log(aryIndicesMode3);
break;
}
}
/*
* Read the next image
*/
ReadBarcode(sImageIndex + 1);
}, function (ex) {
console.log("Error reading barcode: " + ex.message);
Dynamsoft.Lib.hideMask();
});
}
}
Load a few images and click "
Separate
", then check the browser console (F12)
58
Step 11 Add upload code and back-end code (in C# ) to receive the
separated files
function UploadImagesSeparatedByBarcode(ary) {
var i, Digital, uploadfilename, CurrentPathName = unescape(location.pathname),
CurrentPath = CurrentPathName.substring(0, CurrentPathName.lastIndexOf("/") + 1),
strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = Dynamsoft.Lib.detect.ssl;
var _strPort = location.port == "" ? 80 : location.port;
if (Dynamsoft.Lib.detect.ssl == true)
_strPort = location.port == "" ? 443 : location.port;
DWObject.HTTPPort = _strPort;
strFullActionPagePath = location.protocol + "//" + location.hostname + ":" + DWObject.HTTPPort + strActionPage;
for (i = 0; i < ary.length; i++) {
if (ary[i].length == 0) {
ary.splice(i, 1);
i--;
continue;
}
Digital = new Date();
uploadfilename = 'Doc_' + i + '_' + Digital.getMilliseconds() + '_' + (Math.floor(Math.random() * 1000 + 1)).
toString() + '.pdf';
DWObject.HTTPUpload(strFullActionPagePath, ary[i], EnumDWT_ImageType.IT_PDF, EnumDWT_UploadDataFormat.Binary,
uploadfilename, function () { }, function () { });
59
}
}
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
String Path = System.Web.HttpContext.Current.Request.MapPath(".") + "/ImageScanned/";
if (!Directory.Exists(Path))
{
Directory.CreateDirectory(Path);
}
uploadfile.SaveAs(Path + uploadfile.FileName);
Step 12 Change code to upload files
Update the following
switch (strSelectedMode) {
case 'mode1': console.log(aryIndicesMode1); break;
case 'mode2': console.log(aryIndicesMode2); break;
case 'mode3': console.log(aryIndicesMode3); break;
}
to
switch (strSelectedMode) {
case 'mode1': UploadImagesSeparatedByBarcode(aryIndicesMode1); break;
case 'mode2': UploadImagesSeparatedByBarcode(aryIndicesMode2); break;
case 'mode3': UploadImagesSeparatedByBarcode(aryIndicesMode3); break;
}
Step 13 Refresh the page, load the images again and click " Separate ".
Then you can check the uploaded images on the server
For mode 2, 3
That's it. You can also test the code online.
60
61
62
Quickly integrate mobile device camera into web
applications
Introduction
In recent years, with the popularity of smart mobile devices, websites must be designed with a balance of
traditional desktop browsers (including the three most common systems
mobile device browsers (generally including
iOS
and
Android
Windows
,
macOS
and
Linux
) and
). This article shares how to design a web
application that takes into account desktop and mobile browsers.
Preparation
Download the following files.
Dynamic Web TWAIN v14.2
(.exe)
Mobile Browser Capture v2.0
(.zip)
Environment
Dynamic Web TWAIN
can be used across desktop platforms.
Mobile Browser Capture
JDK
:
currently supports only
.NET
&
Java
. We'll use
Java
in this article.
1.8.0_172
Eclipse
:
64位Tomcat
Oxygen.3a Release (4.7.3a)
:
Tomcat v9.0
Steps
Step 1 Create a Dynamic Web Application , name it
AcquireFromPCsAndMobileDevices and select Apache Tomcat v9.0
as the runtime environment
63
Step 2 Start from a sample
Unzip
Mobile Browser Capture
, copy
src
and
WebContent
from
MobileBrowserCaptureSDK2.0\MobileBrowserCaptureSDK2.0\samples\javaDemo
to application
AcquireFromPCsAndMobileDevices
and replace any conflicts.
Install
Dynamic Web TWAIN
Samples\Scan
In
Eclipse
to
and navigate to
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK 14.1 Trial
AcquireFromPCsAndMobileDevices\WebContent
.
, refresh to see the file changes.
64
. Copy
Step 3 Add a 'server' in Eclipse and add
AcquireFromPCsAndMobileDevices to it. Then start Tomcat
65
Check the application in the browser.
For mobile browser
http://localhost:8080/AcquireFromPCsAndMobileDevices/MobileBrowserCapture.html
For desktop browser
http://localhost:8080/AcquireFromPCsAndMobileDevices/Scan/CustomScan.html
Step 4 Try the page for mobile browser first
This page works both on desktop browsers and mobile browsers, and in desktop Chrome, it's like this
66
Here you can click
Show Video
to use the webcam on the PC or click
Grab Image
to load a local file. We'll load a
file.
Once the file is loaded, extra features will show up as buttons to delete, upload, edit, download, etc.
67
Open it in a mobile browser (assume the
IP
of the dev machine is
192.168.1.100
)
http://192.168.1.100:8080/AcquireFromPCsAndMobileDevices/MobileBrowserCapture.html
The interface is like the following where you can click 'Grab Image' to take a picture or load a local file
68
Once an image is loaded/captured
69
70
Upload and press
Redirect
to see a list of the uploaded files.
71
72
The uploaded files are saved in a path specified by
System.getProperty("user.dir")
plus a runtime user id. For
example
C:\Program Files\eclipse-jee-oxygen-3a-win32-x86_64\eclipse\Dynamsoft_Upload\391008ba-aa9f-4564-a285-b44a42ec7864
The path can be changed in the following file.
AcquireFromPCsAndMobileDevices\WebContent\WEB-INF\web.xml
dynamsoft_upload
D:\\uploadedimages\\
This will then save the files in
D:\uploadedimages\391008ba-aa9f-4564-a285-b44a42ec7864
Step 5 Test the page meant for desktop
Open
http://localhost:8080/AcquireFromPCsAndMobileDevices/Scan/CustomScan.html
73
>. Acquire an image
Step 6 Add a button to upload
HTML
JavaScript
function Upload() {
if (DWObject) {
var strFullActionPagePath = location.href.substr(0, location.href.lastIndexOf('/') + 1) + 'upload.jsp';
DWObject.HTTPUpload(strFullActionPagePath, [DWObject.CurrentImageIndexInBuffer], EnumDWT_ImageType.IT_JPG, En
umDWT_UploadDataFormat.Binary, "test.jpg", function(){}, function(errCode, errString){ console.log(errString);});
}
}
JSP
<%@
page language="java" import="java.io.*,java.util.*,org.apache.commons.fileupload.*,org.apache.commons.fileupload
.disk.*,org.apache.commons.fileupload.servlet.*"%><%!
%><%
// Create a factory for disk-based file items
DiskFileItemFactory factory = new DiskFileItemFactory();
// Configure a repository (to ensure a secure temp location is used)
ServletContext servletContext = this.getServletConfig().getServletContext();
File repository = (File) servletContext.getAttribute("javax.servlet.context.tempdir");
factory.setRepository(repository);
74
// Set factory constraints
factory.setSizeThreshold(1000000000);// Sets the size threshold beyond which files are written directly to disk.
// Create a new file upload handler
ServletFileUpload upload = new ServletFileUpload(factory);
// Set overall request size constraint
upload.setSizeMax(-1);
// Parse the request
List items = upload.parseRequest(request);
// Process the uploaded items
Iterator iter = items.iterator();
String _fields = "";
String fileName = "";
long sizeInBytes = 0;
String path = application.getRealPath(request.getRequestURI());
String dir = request.getServletContext().getInitParameter("dynamsoft_upload");
dir = dir.replace("\\\\","/");
String _temp_Name = dir + "files-uploaded-in-pc-browsers";
File _fieldsTXT = new File(_temp_Name);
if(!_fieldsTXT.exists())
{
boolean result = _fieldsTXT.mkdirs();
System.out.println("File create result:"+result);
}
while (iter.hasNext()) {
FileItem item = iter.next();
// Process a regular form field
if (item.isFormField()) {
}
// Process a file upload
else {
String fieldName = item.getFieldName();
fileName = item.getName();
String contentType = item.getContentType();
boolean isInMemory = item.isInMemory();
sizeInBytes = item.getSize();
if(fileName!=null && sizeInBytes!=0){
File uploadedFile = new File(_temp_Name + "/" + fileName);
if(!uploadedFile.exists())
{
boolean result = uploadedFile.createNewFile();
System.out.println("File create result:"+result);
}
try {
item.write(uploadedFile);
}
catch (Exception e) {
e.printStackTrace();
}
}
}
}
%>
Step 7 Add code to detect the environment and redirect accordingly.
Name the file common.js and place it under WebContent/js/
var dynamsoft = dynamsoft || {};
(function () {
75
var ua = navigator.userAgent.toLowerCase(),
_platform = navigator.platform.toLowerCase(),
_bWin = (_platform == 'win32') || (_platform == 'win64') || (_platform == 'windows'),
_nMSIE = ua.indexOf('msie'),
_nTrident = ua.indexOf('trident'),
_nRV = ua.indexOf('rv:'),
_nEdge = ua.indexOf('edge'),
_tmp = ua.match(/version\/([\d.]+).*safari/),
_bSafari = _tmp ? !0 : !1,
_nSafari = _tmp ? _tmp[1] : 0,
_nFirefox = ua.indexOf('firefox'),
_bFirefox = (_nFirefox != -1),
_bEdge = _bWin && !_bFirefox && (_nEdge != -1),
_indexOfChrome = ua.indexOf('chrome'),
_bChrome = !_bEdge && (_indexOfChrome != -1),
_bIE = _bWin && !_bFirefox && !_bEdge && !_bChrome && (_nMSIE != -1 || _nTrident != -1 || _nRV != -1),
_strBrowserVersion = '',
_mainVer = 0;
var _deviceType,
bIsIpad = ua.match(/ipad/i) == "ipad",
bIsIphoneOs = ua.match(/iphone os/i) == "iphone os",
bIsMidp = ua.match(/midp/i) == "midp",
bIsUc7 = ua.match(/rv:1.2.3.4/i) == "rv:1.2.3.4",
bIsUc = ua.match(/ucweb/i) == "ucweb",
bIsAndroid = ua.match(/android/i) == "android",
bIsCE = ua.match(/windows ce/i) == "windows ce",
bIsWM = ua.match(/windows mobile/i) == "windows mobile";
if (bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) {
_deviceType = 'phone';
} else {
_deviceType = 'pc';
}
if (_bEdge) {
_tmp = ua.slice(_nEdge + 5);
_tmp = _tmp.slice(0, _tmp.indexOf(' '));
_strBrowserVersion = _tmp;
} else if (_bChrome) {
_tmp = ua.slice(_indexOfChrome + 7);
_tmp = _tmp.slice(0, _tmp.indexOf(' '));
_strBrowserVersion = _tmp;
} else if (_bFirefox) {// FF
_tmp = ua.slice(_nFirefox + 8);
_tmp = _tmp.slice(0, _tmp.indexOf(' '));
_strBrowserVersion = _tmp;
} else if (_bIE) {
if (_nMSIE != -1) {
// 'msie'
_tmp = ua.slice(_nMSIE + 4);
_tmp = _tmp.slice(0, _tmp.indexOf(';'));
_strBrowserVersion = _tmp;
} else if (_nRV != -1) {
// 'rv:'
_tmp = ua.slice(_nRV + 3);
_tmp = _tmp.slice(0, _tmp.indexOf(';'));
_tmp = _tmp.slice(0, _tmp.indexOf(')'));
_strBrowserVersion = _tmp;
} else if (_nTrident != -1) {
// 'trident'
_tmp = ua.slice(_nTrident + 7);
_tmp = _tmp.slice(0, _tmp.indexOf(';'));
_strBrowserVersion = _tmp;
}
} else if (_bSafari) {
if (_tmp) {
_strBrowserVersion = _tmp[1];
}
76
}
if (_strBrowserVersion.indexOf('.') > -1)
_mainVer = _strBrowserVersion.slice(0, _strBrowserVersion.indexOf('.')) * 1.0;
dynamsoft.onlineNavInfo = {
bWin: _bWin,
bIE: _bIE,
bEdge: _bEdge,
bFirefox: _bFirefox,
bChrome: _bChrome,
bSafari: _bSafari,
strVersion: _strBrowserVersion,
mainVer: _mainVer,
deviceType: _deviceType
};
})();
var strHREF = window.location.href;
if (dynamsoft.onlineNavInfo.deviceType == 'pc') {
if (strHREF.indexOf('CustomScan') == -1)
window.location.replace(strHREF.substr(0, strHREF.lastIndexOf('AcquireFromPCsAndMobileDevices') + 30) + '/Sca
n/CustomScan.html');
} else {
if (strHREF.indexOf('MobileBrowserCapture') == -1)
window.location.replace(strHREF.substr(0, strHREF.lastIndexOf('AcquireFromPCsAndMobileDevices') + 30) + '/Mob
ileBrowserCapture.html');
}
Step 8 Create a file index.jsp under WebContent with the following
code
<%@ page session="false" pageEncoding="UTF-8" contentType="text/html; charset=UTF-8" %>
Capture Anywhere
Redirecting
Reference
common.js
in both
MobileBrowserCapture.html
and
CustomScan.html
Now when you navigate to
http://192.168.1.100:8080/AcquireFromPCsAndMobileDevices/
page meant for the browser being used.
77
, you will land on the correct
Quickly implement text recognition in web
applications
Introduction
In the process of document digitization, it is often necessary to extract the required information from the
acquired images.
Optical Character Recognition (OCR)
is the technology used for this purpose. In this article,
we explore how to quickly scan and recognize text in a browser with Dynamic Web TWAIN and its OCR
Add-on.
NOTE
We only discuss the basic OCR engine in this article and we are using it on the client-side. The engine can
also be used on the server side. Furthermore, Dynamsoft offers another engine called Professional OCR
which is faster and more accurate and can also be used on both client-side and server-side. For more info,
please contact us.
Environment
node
The OCR module itself doesn't rely on
Node.js
, it's needed in this article just because it's faster to get
required files with its package manager (npm).
Steps
Step 1 Create a new directory, open the command line tool inside
(shortcut is Ctrl+Shift+right click ). Download the core control used
in this article through npm
npm install dwt@14.2.0
Then you can see the following in this directory
Step 2 Open to the following directory
node_modules\dwt\sample
where you can see
78
Step 3 In this article, we are going to check OCRADocument.html . Double
click it to open. If the related controls are not yet available, follow the
prompts to install them
Under normal circumstances, the installed files can be found in the
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService
directory. The core files here are mainly
DynamsoftService.exe
dwt_trial_14.1.0.0828.dll
DynamicOCR.dll
/DynamicOCR/
Step 4 After the installation is complete, refresh the page, click Scan
Documents (local need scanner) or Load Images or PDFs to scan or
load local image files with English text. Then click on OCR An Image with
English . The recognition result of the image will then show up in the
result box on the right
79
How it is done
Open
OCRADocument.html
in a text editor
References to the Core JavaScript files
Here the files referenced are
JS library for the core SDK
Dynamic Web TWAIN
node_modules\dwt\dis\dynamsoft.webtwain.initiate.js
JS library for the
node_modules\dwt\dis\dynamsoft.webtwain.config.js
Dynamsoft OCR Basic
node_modules\dwt\dist\addon\dynamsoft.webtwain.addon.ocr.js
PDF Rasterizer
is not necessary, check out PDF Rasterizer
node_modules\dwt\dist\addon\dynamsoft.webtwain.addon.pdf.js
If you have previously installed the Dynamic Web TWAIN product locally, the same files (except
dynamsoft.webtwain.addon.pdf.js
) can also be found in the following directory.
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {version number} {Trial}\Resource
Dynamsoft OCR Basic runtime installation code
function downloadOCRBasic(bDownloadDLL) {
var strOCRPath = Dynamsoft.WebTwainEnv.ResourcesPath + "/OCRResources/OCR.zip",
strOCRLangPath = Dynamsoft.WebTwainEnv.ResourcesPath + '/OCRResources/OCRBasicLanguages/English.zip';
if (bDownloadDLL) {
80
DWObject.Addon.OCR.Download(
strOCRPath,
function () {/*console.log('OCR dll is installed');*/
downloadOCRBasic(false);
},
function (errorCode, errorString) {
console.log(errorString);
}
);
} else {
DWObject.Addon.OCR.DownloadLangData(
strOCRLangPath,
function () {
}, function (errorCode, errorString) {
console.log(errorString);
});
}
}
As shown in the above code, the
core
DLL
(
DynamicOCR.dll
from
second step is to install the
(
Dynamsoft OCR Basic
OCR
) with the
DWObject.Addon.OCR.Download
interface, The
language pack or the recognition dictionary
'/OCRResources/OCRBasicLanguages/English.zip'
English
installation takes two steps. The first step is to install the
"/OCRResources/OCR.zip"
) with the
DWObject.Addon.OCR.DownloadLangData
interface. Only the
dictionary is installed here, so the program can only recognize English. If you need to identify other
languages (27 main languages in total), you can download a complete example or refer to this online example
Scan Documents and Client-side OCR basic
List of supported languages
Arabic, Bengali, Chinese_Simplified, Chinese_Traditional, English, French, German, Hindi, Indonesian,
Italian, Japanese, Javanese, Korean, Malay, Marathi, Panjabi, Persian, Portuguese, Russian, Spanish,
Swahili, Tamil, Telugu, Thai, Turkish, Vietnamese, Urdu.
Use the addon
function DoOCR() {
if (DWObject) {
if (DWObject.HowManyImagesInBuffer == 0) {
alert("Please scan or load an image first.");
return;
}
DWObject.Addon.OCR.SetLanguage('eng');
DWObject.Addon.OCR.SetOutputFormat(EnumDWT_OCROutputFormat.OCROF_TEXT);
DWObject.Addon.OCR.Recognize(
DWObject.CurrentImageIndexInBuffer,
function (sImageIndex, result) {
if (result == null)
return null;
var _textResult = (Dynamsoft.Lib.base64.decode(result.Get())).split(/\r?\n/g), _resultToShow = [];
for (var i = 0; i < _textResult.length; i++) {
if (i == 0 && _textResult[i].trim() == "")
continue;
_resultToShow.push(_textResult[i] + '
');
}
_resultToShow.splice(0, 0, '');
_resultToShow.push('
');
document.getElementById('divNoteMessage').innerHTML = _resultToShow.join('');
},
function (errorcode, errorstring, result) {
alert(errorstring);
81
}
);
}
}
The core code is
DWObject.Addon.OCR.SetLanguage('eng'); //Set the language to be recognized
DWObject.Addon.OCR.SetOutputFormat(EnumDWT_OCROutputFormat.OCROF_TEXT); //Set the output format
DWObject.Addon.OCR.Recognize(... //Start Reconizing
Check out the supported output formats
EnumDWT_OCROutputFormat
.
Related methods are
SetLanguage()
Recognize()
,
,
SetOutputFormat()
RecognizeFile()
,
RecognizeRect()
,
RecognizeSelectedImages()
82
Contact Us
Email:
support@dynamsoft.com
Online Chat:
Telephone:
http://www.dynamsoft.com/Support/LiveHelp.aspx
+1 604.605.5491
|
+1 877.605.5491 (Toll-Free)
83
API Documentation
Basic Scan
Methods
AcquireImage()
CloseSource()
DisableSource()
EnableSource()
OpenSource()
SelectSource()
SelectSourceByIndex()
SetOpenSourceTimeout()
Properties
BitDepth
IfAppendImage
IfDisableSourceAfterAcquire
IfDuplexEnabled
IfFeederEnabled
IfShowUI
ImageCaptureDriverType
PageSize
PixelType
Resolution
SourceCount
Events
OnPostAllTransfers
OnPostTransfer
Basic Edit
Methods
AddText()
ChangeBitDepth()
ChangeImageSize()
ConvertToGrayScale()
CopyToClipboard()
CreateTextFont()
Crop()
CropToClipboard()
CutFrameToClipboard()
CutToClipboard()
Erase()
Flip()
Mirror()
MoveImage()
OverlayRectangle()
RemoveAllImages()
RemoveAllSelectedImages()
RemoveImage()
Rotate()
RotateEx()
RotateLeft()
RotateRight()
SetDPI()
SetImageWidth()
SetSelectedImageArea()
SetSelectedImageIndex()
ShowImageEditor()
SwitchImage()
Properties
SelectionRectAspectRatio
Events
84
OnImageAreaSelected
OnImageAreaDeSelected
UI & Display
Methods
SetViewMode()
Properties
BackgroundColor
BackgroundFillColor
FitWindowType
Height
IfAutoScroll
IfFitWindow
ImageMargin
MaxImagesInBuffer
MouseShape
SelectionImageBorderColor
Width
Zoom
ShowPageNumber
MouseX
MouseY
Events
OnTopImageInTheViewChanged
OnMouseClick
OnMouseDoubleClick
OnMouseMove
OnMouseRightClick
Load & Save
Methods
FileExists()
LoadDibFromClipboard()
LoadImage()
LoadImageEx()
LoadImageFromBase64Binary()
SaveAllAsMultiPageTIFF()
SaveAllAsPDF()
SaveAsBMP()
SaveAsJPEG()
SaveAsPDF()
SaveAsPNG()
SaveAsTIFF()
SaveSelectedImagesAsMultiPagePDF()
SaveSelectedImagesAsMultiPageTIFF()
SaveSelectedImagesToBase64Binary()
ShowFileDialog()
Properties
IfShowFileDialog
Events
OnGetFilePath
OnPostLoad
85
Upload & Download
Methods
ClearAllHTTPFormField()
FTPDownload()
FTPDownloadDirectly()
FTPDownloadEx()
FTPUpload()
FTPUploadAllAsMultiPageTIFF()
FTPUploadAllAsPDF()
FTPUploadAsMultiPagePDF()
FTPUploadAsMultiPageTIFF()
FTPUploadDirectly()
FTPUploadEx()
HTTPDownload()
HTTPDownloadDirectly()
HTTPDownloadEx()
HTTPUpload()
HTTPUploadAllThroughPostAsMultiPageTIFF()
HTTPUploadAllThroughPostAsPDF()
HTTPUploadThroughPost()
HTTPUploadThroughPostAsMultiPagePDF()
HTTPUploadThroughPostAsMultiPageTIFF()
HTTPUploadThroughPostDirectly()
HTTPUploadThroughPostEx()
SetHTTPFormField()
SetUploadSegment()
SetHTTPHeader()
Properties
FTPPassword
FTPPort
FTPUserName
HttpFieldNameOfUploadedImage
HTTPPort
HTTPPostResponseString
IfPASVMode
IfShowCancelDialogWhenImageTransfer
IfSSL
MaxUploadImageSize
Events
OnInternetTransferPercentage
Advanced Scan
Methods
CancelAllPendingTransfers()
CloseSourceManager()
CloseWorkingProcess()
FeedPage()
GetCustomDSData()
GetCustomDSDataEx()
GetDeviceType()
GetSourceNameItems()
OpenSourceManager()
ResetImageLayout()
RewindPage()
SetCustomDSData()
SetCustomDSDataEx()
SetFileXferInfo()
SetImageLayout()
Properties
86
Brightness
Contrast
CurrentSourceName
DataSourceStatus
DefaultSourceName
Duplex
IfAutoBright
IfAutoDiscardBlankpages
IfAutoFeed
IfAutomaticBorderDetection
IfAutomaticDeskew
IfAutoScan
IfFeederLoaded
IfPaperDetectable
IfShowIndicator
IfUIControllable
IfUseTwainDSM
PendingXfers
PixelFlavor
TransferMode
Unit
OnPreTransfer
OnSourceUIClose
XferCount
Events
OnPreAllTransfers
Capability Negotiation
Methods
CapGet()
CapGetCurrent()
CapGetDefault()
CapGetFrameBottom()
CapGetFrameLeft()
CapGetFrameRight()
CapGetFrameTop()
CapGetHelp()
CapGetLabel()
CapGetLabels()
CapIfSupported()
CapReset()
CapSet()
CapSetFrame()
GetCapItems()
GetCapItemsString()
SetCapItems()
SetCapItemsString()
Capability
CapCurrentIndex
CapCurrentValue
CapDefaultIndex
CapDefaultValue
CapMaxValue
CapMinValue
CapNumItems
CapStepSize
CapType
CapValue
CapValueString
ConvertToBase64()
ConvertToBlob()
IfTiffMultiPage
JPEGQuality/a>
Properties
CapValueType
Encode & Decode
Methods
ClearTiffCustomTag()
SetTiffCustomTag()
Properties
IfOpenImageWithGDIPlus
87
PDFAuthor
PDFCompressionType
PDFCreationDate
PDFCreator
PDFKeywords
PDFModifiedDate
PDFProducer
PDFSubject
PDFTitle
PDFVersion
TIFFCompressionType
Runtime Info
Methods
GetImageBitDepth()
GetImageHeight()
GetImageSize()
GetImageSizeWithSpecifiedType()
GetImageWidth()
GetImageXResolution()
GetImageYResolution()
GetSelectedImageIndex()
GetSelectedImagesSize()
GetSkewAngle()
GetSkewAngleEx()
IsBlankImageExpress()
Properties
BlankImageCurrentStdDev
BlankImageMaxStdDev
BlankImageThreshold
CurrentImageIndexInBuffer
HowManyImagesInBuffer
ImageLayoutDocumentNumber
ImageLayoutFrameBottom
ImageLayoutFrameLeft
ImageLayoutFrameNumber
ImageLayoutFrameRight
ImageLayoutFrameTop
ImageLayoutPageNumber
ImagePixelType
MagData
MagType
GetImagePartURL()
GetImageURL()
Print()
RegisterEvent()
UnregisterEvent()
SetLanguage()
BufferMemoryLimit
ErrorCode
ErrorString
IfAllowLocalCache
IfShowProgressBar
LogLevel
Manufacturer
ProductFamily
ProductKey
ProductName
VersionInfo
SelectedImagesCount
General Utilities
Methods
Properties
Events
OnBitmapChanged
PDF Rasterizer
88
Methods
Addon.PDF.Download()
Addon.PDF.SetResolution()
Addon.PDF.SetPassword()
Addon.PDF.SetConvertMode()
Webcam Capture
Methods
Addon.Webcam.CaptureImage()
Addon.Webcam.CloseSource()
Addon.Webcam.Download()
Addon.Webcam.GetCameraControlPropertyMoreSetting()
Addon.Webcam.GetCameraControlPropertySetting()
Addon.Webcam.GetFrameRate()
Addon.Webcam.GetImagePartUrl()
Addon.Webcam.GetImageUrl()
Addon.Webcam.GetMediaType()
Addon.Webcam.GetResolution()
Addon.Webcam.GetSourceList()
Addon.Webcam.GetVideoPropertyMoreSetting()
Addon.Webcam.GetVideoPropertySetting()
Addon.Webcam.PauseVideo()
Addon.Webcam.PlayVideo()
Addon.Webcam.SelectSource()
Addon.Webcam.SetCameraControlPropertySetting()
Addon.Webcam.SetFrameRate()
Addon.Webcam.SetMediaType()
Addon.Webcam.SetResolution()
Addon.Webcam.SetVideoPropertySetting()
Addon.Webcam.SetVideoRotateMode()
Addon.Webcam.StopVideo()
File Uploader
Methods
Init()
CreateJob()
Run()
Cancel()
CancelAllUpload()
GenerateURLForUploadData()
HttpHeader
SourceValue
OnRunSuccess
OnRunFailure
Properties
ServerUrl
Events
OnUploadTransferPercentage
Barcode Reader
Constructor
dynamsoft.BarcodeReader()
89
Methods
decode()
decodeBase64String()
updateRuntimeSettings()
resetRuntimeSettings()
getRuntimeSettings()
dynamsoft.BarcodeReader.initServiceConnection()
Properties
productKey
bAutoConnectService
resourcesPath
ifCheck64bitServiceFirst
Events
onAutoConnectServiceSuccess
onAutoConnectServiceError
Enumerations
Errors
OCR Basic
Client-Side
Methods
Download()
DownloadLangData()
GetIfUseDetectedFont()
GetMinFontSizeforMoreAccurateResult()
GetUnicodeFontName()
IsModuleInstalled()
Recognize()
RecognizeFile()
RecognizeRect()
RecognizeSelectedImages
SetIfUseDetectedFont()
SetLanguage()
SetMinFontSizeforMoreAccurateResult()
SetOutputFormat()
SetPageSetMode()
SetUnicodeFontName()
OCR Basic Result Object
Result
PageSetResult
LineResult
WordResult
PageResult
Server-Side (Java)
OCR Pro
Client-Side
Methods
Download()
IsModuleInstalled()
Recognize()
RecognizeFile()
RecognizeRect()
RecognizeSelectedImages
90
Properties
Settings
OCR Pro Result Object
OCRResult
PageResult
LetterResult
ErrorInfo
Server-Side
OCRPro.ServerSide.Request
OCRPro.ServerSide.Response
91
Basic Scan
Methods
AcquireImage()
CloseSource()
DisableSource()
EnableSource()
OpenSource()
SelectSource()
SelectSourceByIndex()
SetOpenSourceTimeout()
Properties
BitDepth
IfAppendImage
IfDisableSourceAfterAcquire
IfDuplexEnabled
IfFeederEnabled
IfShowUI
ImageCaptureDriverType
PageSize
PixelType
Resolution
SourceCount
Events
OnPostAllTransfers
OnPostTransfer
Code example
The following code example demonstrates how to use the APIs above to perform basic scanning.
function BasicScan() {
if (DWObject) {
if (Dynamsoft.Lib.env.bMac) {
DWObject.ImageCaptureDriverType = EnumDWT_Driver.TWAIN_AND_ICA;
}
DWObject.RegisterEvent('OnPostTransfer', function () {
console.log('One page scanned!');
});
DWObject.RegisterEvent('OnPostAllTransfers', function () {
DWObject.CloseSource();
});
DWObject.SelectSource(function () {
DWObject.SetOpenSourceTimeout(3000);
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.PixelType = EnumDWT_PixelType.TWPT_RGB;
DWObject.BitDepth = 24;
DWObject.PageSize = EnumDWT_CapSupportedSizes.TWSS_A4;
DWObject.Resolution = 300;
DWObject.IfFeederEnabled = true;
DWObject.IfDuplexEnabled = true;
DWObject.IfAppendImage = false;
DWObject.AcquireImage(function () {
/**
* Actually not necessary when you have
* IfDisableSourceAfterAcquire set to true.
*/
DWObject.DisableSource();
},
92
function () {
DWObject.DisableSource();
}
);
}, function () {
console.log('Failed to select a source, there are ' +
DWObject.SourceCount + ' sources in total.');
});
}
}
Methods
AcquireImage()
Starts image acquisition.
Syntax
.AcquireImage([optionalDeviceConfig], [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
optional
optionalDeviceConfig
Parameters
optional
: A JS object used to set up the device for image acquisition.
optionalAsyncSuccessFunc : callback function triggered when
acquiring succeeds.
optional
optionalAsyncFailureFunc
: callback function triggered when
acquiring fails.
Return
value
Availability
Usage
notes
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
The parameters are only available in the HTML5 Edition. As the parameters are all optional,
there are 4 ways to use this method as demonstrated below.
var DeviceConfig = {
IfShowUI: false,
PixelType: EnumDWT_PixelType.TWPT_RGB,
Resolution: 300,
IfFeederEnabled: true,
IfDuplexEnabled: false,
IfDisableSourceAfterAcquire: true
};
function AsyncSuccessFunc() {
console.log('successful');
}
function AsyncFailureFunc(errorCode, errorString) {
alert(errorString);
}
Example
function AcquireImage1() {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.PixelType = EnumDWT_PixelType.TWPT_RGB;
DWObject.Resolution = 300;
DWObject.IfFeederEnabled = true;
DWObject.IfDuplexEnabled = false;
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
function AcquireImage2() {
DWObject.SelectSource();
93
DWObject.OpenSource();
DWObject.AcquireImage(DeviceConfig);
}
function AcquireImage3() {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.PixelType = EnumDWT_PixelType.TWPT_RGB;
DWObject.Resolution = 300;
DWObject.IfFeederEnabled = true;
DWObject.IfDuplexEnabled = false;
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage(AsyncSuccessFunc, AsyncFailureFunc);
}
function AcquireImage4() {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.AcquireImage(DeviceConfig, AsyncSuccessFunc, AsyncFailureFunc);
}
CloseSource()
Closes the Data Source (a TWAIN/ICA/SANE device which in most cases is a scanner) to free it to be used by
other applications.
Syntax
.CloseSource();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
In version 10.0 ~ 11.2, CloseSource() is called automatically after all pages have been scanned.
This method can be called after SelectSource() and before OpenSource() in order to close any
existing connections.
DWObject.RegisterEvent('OnPostAllTransfers', function () {
DWObject.CloseSource();
});
Example
DisableSource()
Disables the Data Source (a TWAIN/ICA/SANE device which in most cases is a scanner) to stop the acquiring
process. If the source's user interface is displayed, it will be closed.
Syntax
.DisableSource();
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
94
Usage
notes
Example
After DisableSource() is called, the Source is still open and you can continue to acquire images
by calling AcquireImage() or EnableSource() .
DWObject.RegisterEvent('OnPostAllTransfers', function () {
DWObject.DisableSource();
});
EnableSource()
Enables the source to start the acquiring process.
Syntax
.EnableSource();
Parameters
None
Return
value
boolean
Availability
Usage
notes
Example
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
The method is equivalent to
AcquireImage()
without parameters.
function AcquireImage4() {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.EnableSource();
}
OpenSource()
Loads the currently selected Data Source into memory and initializes it for image acquisition. If no source is
specified (neither SelectSource() nor SelectSourceByIndex() has been called), the default source will be loaded.
Syntax
.OpenSource();
Parameters
None
Return
value
boolean
Availability
Usage
notes
Example
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Call OpenSource() before you negotiate any capabilities.
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.Resolution = 300;
DWObject.AcquireImage();
95
SelectSource()
Brings up the Source Selection User Interface (UI) for the user to choose a Data Source.
Syntax
.SelectSource([optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
optional
optionalAsyncSuccessFunc
: callback function triggered when
optional
optionalAsyncFailureFunc
: callback function triggered when
selecting succeeds.
selecting fails.
Return
value
Availability
Usage
notes
boolean
, only when used synchronously (without parameters).
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v14.0
The optional parameters which make the method asynchronous were added in v14.0 of the
HTML5 edition and in v14.1 of the ActiveX edition.
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.Resolution = 300;
DWObject.AcquireImage();
Example
DWObject.SelectSource(function () {
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.Resolution = 300;
DWObject.AcquireImage();
}, function () {
console.log('Failed to select a source, there are ' +
DWObject.SourceCount + ' sources in total.');
});
SelectSourceByIndex()
Selects a Data Source by its index in the Data Source Manager.
Syntax
.SelectSourceByIndex(Number index);
Parameters
number
Return
value
boolean
Availability
Usage
notes
Example
index
: The index of the targeted Data Source in the Data Source Manager.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Use this method when you don't want to show the Data Source Selecting UI.
DWObject.SelectSourceByIndex(0);
DWObject.IfShowUI = false;
DWObject.Resolution = 300;
DWObject.AcquireImage();
96
SetOpenSourceTimeout()
Sets a timer which stops the source opening process once it expires.
Syntax
.SetOpenSourceTimeout(nMilliseconds);
Parameters
number
Return
value
boolean
Availability
Usage
notes
nMilliseconds
: The time, in milliseconds (thousandths of a second).
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v11.0
✓ | v11.0
✓ | v11.0
✓ | v11.0
✗
SetOpenSourceTimeout()
should be called before
OpenSource()
.
DWObject.SelectSource(function () {
DWObject.SetOpenSourceTimeout(3000);
DWObject.OpenSource();
DWObject.AcquireImage();
Example
Properties
BitDepth
Returns or sets the pixel bit depth for the current value of
Type
number
Accessors
Get Set
Availability
Usage
notes
PixelType
.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✗
✗
Set this property after OpenSource() and before AcquireImage() .
Set BitDepth based on the current value of PixelType . By default, the bit depth is 1 for
'TWPT_BW'(0), 8 for 'TWPT_GRAY'(1) and 24 for 'TWPT_RGB'(2).
IfAppendImage
Returns or sets whether newly acquired images are inserted or appended.
Type
boolean
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.1
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
97
Usage
notes
If the value of the property is set to true , the newly acquired images will be appended after the
last image in buffer. If it's set to false , the images will be inserted before the current image.
IfDisableSourceAfterAcquire
Returns or sets whether to close the user interface after all images have been acquired.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Set this property after OpenSource() and before
when IfShowUI is set to true .
AcquireImage()
. This property only makes sense
IfDuplexEnabled
Returns or sets whether to enable duplex scanning (in other words, whether to scan both sides of the paper).
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Set this property after OpenSource() and before AcquireImage() .
Not all scanners support duplex scanning. To confirm, check the user manual of the device or
check the value of Duplex after OpenSource() .
IfFeederEnabled
Returns or sets whether a Data Source's Automatic Document Feeder (ADF) is enabled for scanning.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Set this property after OpenSource() and before AcquireImage() .
If the property is set to true , the Data Source will try acquiring images from the document
feeder first. If the Data Source doesn't have a document feeder, the flatbed will be used.
IfShowUI
Returns or sets whether the source displays the user interface when scanning.
Type
boolean
98
Accessors
Availability
Usage
notes
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
If the property is set to true , the Data Source will display its user interface when
AcquireImage() is called. Otherwise, the UI will not be displayed and scanning will begin
immediately.
ImageCaptureDriverType
Returns or sets whether to use TWAIN or ICA protocol on macOS.
Type
number
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✗
✓ | v11.0
✓ | v11.0
✗
Set this property right after the SDK is initialized or after calling
OpenSourceManager() .
and
CloseSourceManager()
This property only works on macOS. Allowed values are
EnumDWT_Driver.TWAIN: 0
EnumDWT_Driver.ICA: 3
EnumDWT_Driver.TWAIN_AND_ICA: 4
Usage
notes
(added in v14.0, this is the default value since v14.0)
When the property is set to EnumDWT_Driver.TWAIN or 0, only devices with TWAIN drivers can be
used. When set to EnumDWT_Driver.ICA or 3, only devices with ICA drivers can be used which are
typically listed here. When set to EnumDWT_Driver.TWAIN_AND_ICA or 4, both TWAIN and ICA
devices can be used.
Dynamsoft recommends the use of ICA drivers on macOS for the following reasons:
1. 1. Usually there is no need to install a driver for your scanner anymore, you can plug and
play
2. 2. Generally, ICA drivers - which come with the Mac OS - works better
PageSize
Returns or sets the page size the source uses to acquire images.
Type
EnumDWT_CapSupportedSizes
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
Set this property after
OpenSource()
and before
PixelType
99
AcquireImage()
.
Returns or sets the pixel type used when acquiring images.
Type
EnumDWT_PixelType
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Set this property after
OpenSource()
and before
AcquireImage()
.
Resolution
Returns or sets the pixel type used when acquiring images.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Set this property after
OpenSource()
and before
AcquireImage()
.
SourceCount
Returns how many Data Sources are available on the local system.
Type
number
Accessors
Get
Usage
notes
If
Availability
Usage
notes
If
SourceCount
returns 0, it means there is no source available to use on the system.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
SourceCount
returns 0, it means there is no source available to use on the system.
Events
OnPostAllTransfers
This event is triggered when all page(s) have been scanned and transferred.
Syntax
.RegisterEvent('OnPostAllTransfers',function(){...});
100
Arguments
Example
Availability
Usage
notes
None
DWObject.RegisterEvent('OnPostAllTransfers', function() {
console.log(DWObject.HowManyImagesInBuffer);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v2.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This event fires after all pages in the document feeder have been scanned. This is a good place
to upload the images, detect barcodes, discard blank pages, etc.
OnPostTransfer
This event is triggered after each page has been scanned and transferred.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnPostTransfer',function(nImageIndex){...});
number
nImageIndex
: The index of the transferred image.
DWObject.RegisterEvent('OnPostTransfer', function(nImageIndex) {
console.log(nImageIndex);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
101
Basic Edit
Methods
AddText()
ChangeBitDepth()
ChangeImageSize()
ConvertToGrayScale()
CopyToClipboard()
CreateTextFont()
Crop()
CropToClipboard()
CutFrameToClipboard()
CutToClipboard()
Erase()
Flip()
Mirror()
MoveImage()
OverlayRectangle()
RemoveAllImages()
RemoveAllSelectedImages()
RemoveImage()
Rotate()
RotateEx()
RotateLeft()
RotateRight()
SetDPI()
SetImageWidth()
SetSelectedImageArea()
SetSelectedImageIndex()
ShowImageEditor()
SwitchImage()
Properties
SelectionRectAspectRatio
Events
OnImageAreaSelected
OnImageAreaDeSelected
Methods
AddText()
Adds text on an image.
Syntax
.AddText(nImageIndex, x, y, text, textColor, backgroundColor, backgroundRoundRadius,
backgroundOpacity);
Parameters
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the text.
number y : Specifies the y-coordinate of the upper-left corner of the text.
string text : Specifies the content of the text.
number textColor : Specifies the color for the text.
number backgroundColor :Specifies the background color. It is a value Specifying the 24-bit RGB
value. Default is white (0xffffff). The byte-ordering of the 24-bit RGB value is RRGGBB. RR
represents red, GG represents green and BB represents blue.
number backgroundRoundRadius :Specifies the background round radius ranging from 0 to 0.5.
number backgroundOpacity :Specifies the opacity of the color. 1.0 is 100% opaque and 0.0 is
totally transparent.
Return
value
Example
number
nImageIndex
number
x
boolean
DWObject.CreateTextFont(50, 30, 0, 0, 10, 0, 0, 0, 0, 0, 0, 0, 0, "Arial");
DWObject.AddText(0, 250, 600, 'Dynamic Web TWAIN', 0x0000ff, 0xff0000, 0.5, 0.5);
102
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
ChangeBitDepth()
Changes the bitdepth of a specified image. By doing this, you can change the pixel type of the image.
Syntax
.ChangeBitDepth(nImageIndex, sBitDepth, bHighQuality);
Parameters
: Specifies the index of the image to be converted. The index is 0-based.
: Specifies the target bit depth.
boolean bHighQuality : Specifies whether or not to keep high quality while changing the bit
depth. When it's true, it takes more time.
Return
value
Availability
Usage
notes
number
nImageIndex
number
sBitDepth
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
The allowed bit depths are 1, 4, 8, 24.
ChangeImageSize()
Changes the size of an image specified by index.
Syntax
.ChangeImageSize(nImageIndex, iNewwidth, iNewheight, newInterpolationMethod);
: Specifies the index of the image to be converted. The index is 0-based.
: Specifies the new width (in pixels)
number iNewHeight : Specifies the new height (in pixels)
EnumDWT_InterpolationMethod newInterpolationMethod : Specifies the algorithm used to do
interpolation.
number
nImageIndex
number
iNewWidth
Allowed Values
Parameters
Return
value
Availability
Interpolation Method
1
EnumDWT_InterpolationMethod.IM_NEARESTNEIGHBOUR
2
EnumDWT_InterpolationMethod.IM_BILINEAR
3
EnumDWT_InterpolationMethod.IM_BICUBIC
5
EnumDWT_InterpolationMethod.IM_BESTQUALITY
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
ConvertToGrayScale()
103
Converts a specified image to gray scale.
Syntax
.ConvertToGrayScale(nImageIndex);
Parameters
number
Return
value
boolean
Availability
Usage
notes
nImageIndex
: Specifies the index of the image to be converted. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Typically, it only makes sense to convert a colored image to grey scale.
CopyToClipboard()
Specifies the index of image in buffer. The index is 0-based.
Syntax
Parameters
Return
value
.CopyToClipboard(nImageIndex);
number
: Specifies the index of image in buffer. The index is 0-based.
boolean
Availability
Usage
notes
nImageIndex
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method makes a copy of the image to the clipboard. The copied image is in DIB format.
CreateTextFont()
Creates the font for adding text on an image using the method AddText().
Syntax
Parameters
.CreateTextFont(height, width, escapement, orientation, weight, italic, underline, strikeOut,
charSet, outputPrecision, clipPrecision, quality, pitchAndFamily, faceName);
:Specifies the desired height of the font.
: Specifies the average width of characters in the font.
number escapement : Specifies the angle between the escapement vector and the x-axis of the
display surface. The escapement vector is the line through the origins of the first and last
characters on a line. The angle is measured counterclockwise from the x-axis.
number orientation : Specifies the angle between the baseline of a character and the x-axis.
The angle is measured counterclockwise from the x-axis for coordinate systems in which the ydirection is down and clockwise from the x-axis for coordinate systems in which the y-direction
is up.
number weight : Specifies the font weight.
number italic : Specifies an italic font if the value is not 0.
number underline : Specifies an underlined font if the value is not 0.
number strikeOut : Specifies an strikeout font if the value is not 0.
number charSet : Specifies the font's character set.
number outputPrecision : Specifies the desired output precision. The output precision defines
how closely the output must match the requested font's height, width, character orientation,
escapement, and pitch.
number clipPrecision : Specifies the desired clipping precision. The clipping precision defines
number
height
number
width
104
how to clip characters that are partially outside of the clipping region.
number quality : Specifies the font's output quality which defines how carefully the GDI should
attempt to match the logical-font attributes to those of an actual physical font.
number pitchAndFamily : Specifies the pitch and family of the font.
string faceName : Specifies the typeface name, the length of this string must not exceed 32
characters, including the terminating null character.
Return
value
Example
Availability
boolean
DWObject.CreateTextFont(50, 30, 0, 0, 10, 0, 0, 0, 0, 0, 0, 0, 0, "Arial");
DWObject.AddText(0, 250, 600, 'Dynamic Web TWAIN', 0x0000ff, 0xff0000, 0.5, 0.5);
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
Crop()
Crops an image of the specified index in buffer.
Syntax
.Crop(nImageIndex, left, top, right, bottom);
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle. The unit is
number
nImageIndex
number
left
pixel.
number
Parameters
top
: Specifies the y-coordinate of the upper-left corner of the rectangle. The unit is
pixel.
number
right
: Specifies the x-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
number
bottom
: Specifies the y-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
Return
value
Availability
Usage
notes
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method crops an image and replaces the original image with the cropped copy. If the
application still needs the original image, use CropToClipboard() instead.
CropToClipboard()
Crops the image of a specified index in buffer to clipboard in DIB format.
Syntax
.CropToClipboard(nImageIndex, left, top, right, bottom);
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle. The unit is
number
nImageIndex
number
left
pixel.
number
Parameters
top
: Specifies the y-coordinate of the upper-left corner of the rectangle. The unit is
pixel.
number
right
: Specifies the x-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
number
bottom
: Specifies the y-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
105
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method crops an image and makes a copy of the cropped image to the clipboard.
CutFrameToClipboard()
Cuts the image data in the specified area to the system clipboard in DIB format.
Syntax
.CutFrameToClipboard(nImageIndex, left, top, right, bottom);
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle. The unit is
number
nImageIndex
number
left
pixel.
number
Parameters
top
: Specifies the y-coordinate of the upper-left corner of the rectangle. The unit is
pixel.
number
right
: Specifies the x-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
number
bottom
: Specifies the y-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Use
BackgroundFillColor
to specify the fill color for the cut frame.
Currently this method is only valid in Windows & Mac.
CutToClipboard()
Copies the image of a specified index in buffer to clipboard in DIB format.
Syntax
Parameters
Return
value
Availability
.CopyToClipboard(nImageIndex);
number
nImageIndex
: Specifies the index of image in buffer. The index is 0-based.
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Erase()
Clears the specified area of a specified image and fill the area with the fill color.
106
Syntax
.Erase(nImageIndex, left, top, right, bottom);
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle. The unit is
number
nImageIndex
number
left
pixel.
number
Parameters
top
: Specifies the y-coordinate of the upper-left corner of the rectangle. The unit is
pixel.
number
right
: Specifies the x-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
number
bottom
: Specifies the y-coordinate of the lower-right corner of the rectangle. The unit is
pixel.
Return
value
Availability
Usage
notes
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
The fill color is set by
BackgroundFillColor
.
Flip()
Flips the image of a specified index in buffer.
Syntax
.Flip(nImageIndex);
Parameters
number
Return
value
boolean
Availability
nImageIndex
: Specifies the index of image in buffer. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Mirror()
Mirrors the image of a specified index in buffer.
Syntax
.Mirror(nImageIndex);
Parameters
number
Return
value
boolean
Availability
nImageIndex
: Specifies the index of image in buffer. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
MoveImage()
Moves a specified image.
Syntax
.MoveImage(nImageIndex, nTargetImageIndex);
107
Parameters
Return
value
Availability
: Specifies the index of the image to be converted. The index is 0-based.
: Specifies the new index.
number
nImageIndex
number
nTargetImageIndex
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
OverlayRectangle()
Decorates an image specified by index. The decoration is in the form of rectangles filled with transparent color.
Syntax
.OverlayRectangle(nImageIndex, left, top, right, bottom, color, nOpacity);
nImageIndex
number
left
number
number
number
Parameters
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle.
top : Specifies the y-coordinate of the upper-left corner of the rectangle.
right : Specifies the x-coordinate of the lower-right corner of the rectangle.
bottom : Specifies the y-coordinate of the lower-right corner of the rectangle.
color : Specifies the color. It is a value Specifying the 24-bit RGB value.
number
number
Default is white (0xffffff). The byte-ordering of the 24-bit RGB value is RRGGBB. RR represents
red, GG represents green and BB represents blue.
number
nOpacity
: Specifies the opacity of the color. 1.0 is 100% opaque and 0.0 is totally
transparent.
Return
value
Example
Availability
boolean
DWObject.OverlayRectangle(0, 50, 50, 300, 300, 0xff0000, 0.5);
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
RemoveAllImages()
Removes all images in buffer.
Syntax
.RemoveAllImages();
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
RemoveAllSelectedImages()
108
Removes all selected images.
Syntax
.RemoveAllSelectedImages();
Parameters
None
Return
value
boolean
//This will remove the 2nd and 3rd images
DWObject.SelectedImagesCount = 2;
for(var i = 0; i < 2; i++){
DWObject.SetSelectedImageIndex(i,i + 1);
}
DWObject.RemoveAllSelectedImages();
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
RemoveImage()
Removes the image of a specified index in buffer.
Syntax
.RemoveImage(nImageIndex)
Parameters
number
Return
value
boolean
Availability
nImageIndex
: Specifies the index of the image to be removed. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Rotate()
Rotates the image of a specified index in buffer by a specified angle.
Syntax
.Rotate(nImageIndex, fAngle, bKeepSize);
Parameters
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the angle to rotate the image. Positive angle means clockwise.
Negative value is counter-clockwise.
boolean bKeepSize : Specifies whether to keep the original size of the image.
Return
value
Availability
Usage
notes
number
nImageIndex
number
fAngle
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Rotate() rotates an image and replaces the original image with the rotated copy.
109
RotateEx()
Rotates the image of a specified index in buffer by a specified angle.
Syntax
.RotateEx(nImageIndex, fAngle, bKeepSize, newInterpolationMethod);
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the angle to rotate the image. Positive angle means clockwise.
Negative value is counter-clockwise.
boolean bKeepSize : Specifies whether to keep the original size of the image.
EnumDWT_InterpolationMethod
newInterpolationMethod : Specifies the algorithm to do interpolation.
Parameters
Return
value
Availability
Usage
notes
number
nImageIndex
number
fAngle
Allowed Values
Interpolation Method
1
EnumDWT_InterpolationMethod.IM_NEARESTNEIGHBOUR
2
EnumDWT_InterpolationMethod.IM_BILINEAR
3
EnumDWT_InterpolationMethod.IM_BICUBIC
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method rotates an image and replaces the original image with the rotated copy.
RotateLeft()
Rotates the image of a specified index in buffer by 90 degrees counter-clockwise.
Syntax
.RotateLeft(nImageIndex);
Parameters
number
Return
value
boolean
Availability
Usage
notes
nImageIndex
: Specifies the index of image in buffer. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
RotateLeft() rotates an image and replaces the original image with the rotated copy.
RotateRight()
Rotates the image of a specified index in buffer by 90 degrees clockwise.
Syntax
.RotateRight(nImageIndex);
Parameters
number
Return
value
boolean
nImageIndex
: Specifies the index of image in buffer. The index is 0-based.
110
Usage
notes
This method rotates an image and replaces the original image with the rotated copy.
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
SetDPI()
Changes the DPI (dots per inch) of an image specified by index.
Syntax
.SetDPI(nImageIndex, xResolution, yResolution, bResampleImage, newInterpolationMethod);
: Specifies the index of the image to be converted. The index is 0-based.
: Specifies horizontal resolution.
number yResolution : Specifies vertical resolution.
boolean bResampleImage : Specifies whether to resample the image. (The image size will change
if this is set to true).
EnumDWT_InterpolationMethod newInterpolationMethod : Specifies the algorithm to do interpolation.
number
nImageIndex
number
xResolution
Parameters
Return
value
Allowed Values
Interpolation Method
1
EnumDWT_InterpolationMethod.IM_NEARESTNEIGHBOUR
2
EnumDWT_InterpolationMethod.IM_BILINEAR
3
EnumDWT_InterpolationMethod.IM_BICUBIC
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
SetImageWidth()
Changes the width of an image specified by index by adding an extra margin or removing part of the image.
Syntax
Parameters
Return
value
Availability
.SetImageWidth(ImageIndex, iNewWidth);
: Specifies the index of the image to be converted. The index is 0-based.
: Specifies the new width.
number
nImageIndex
number
iNewWidth
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
SetSelectedImageArea()
Selects a rectangular area on an image specified by index.
111
Syntax
Parameters
.SetSelectedImageArea(nImageIndex, left, top, right, bottom);
nImageIndex
number
left
number
number
number
Return
value
Availability
Usage
notes
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle.
top : Specifies the y-coordinate of the upper-left corner of the rectangle.
right : Specifies the x-coordinate of the lower-right corner of the rectangle.
bottom : Specifies the y-coordinate of the lower-right corner of the rectangle.
number
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
You should set Unit before using this method.
SetSelectedImageIndex()
Selects images programatically (instead of seleting by clicking on the images).
Syntax
.SetSelectedImageIndex(selectionArrayindex, newIndextobeSelected);
Parameters
number selectionArrayindex : Specifies the index of the selected Array to be used for storing the
next image index to be selected.
number newIndextobeSelected : Specifies the index of the image to be selected.
Return
value
Example
Availability
boolean
//This will remove the 2nd and 3rd images
DWObject.SelectedImagesCount = 2;
for(var i = 0; i < 2; i++){
DWObject.SetSelectedImageIndex(i,i + 1);
}
DWObject.RemoveAllSelectedImages();
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
ShowImageEditor()
Shows or hides the built-in image editor of Dynamic Web TWAIN.
Syntax
.ShowImageEditor([strDIVID, nDIVWidth, nDIVHeight]);
Parameters
The parameters are optional, you should either provide None or all 3.
string
optionalDIVID : A DIV to hold the editor on the page and its size. If the parameters are
not provided, the editor will take the full window space.
number nDIVWidth : The width of the DIV holding the editor.
number nDIVHeight : The width of the DIV holding the editor.
Return
value
Example
boolean
DWObject.ShowImageEditor('divEditor', 500,700);
112
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Only one editor is allowed on one web page. The second time you try to call this method will
close the editor that is already opened.
SwitchImage()
Switches two images of specified indices in the buffer.
Syntax
.SwitchImage(nImageIndex1, nImageIndex2);
number
Parameters
nImageIndex1
: Specifies the 1st index of the images to be switched. The index is 0-
nImageIndex2
: Specifies the 2nd index of the images to be switched. The index is 0-
based.
number
based.
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Properties
SelectionRectAspectRatio
Specifies a fixed aspect ratio to be used when you use mouse to draw a rectanglar on an image to select an
area.
Type
float
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Events
OnImageAreaDeSelected
This event is triggered when user deselects an area (clicks outside of the drawn rectangle) on an image in
Dynamic Web TWAIN viewer.
Syntax
Arguments
.RegisterEvent('OnImageAreaDeSelected',function(nImageIndex){...});
number nImageIndex : the index of the image. It should be >=0. When it is -1, it means the
mouse is not on any image.
113
Example
Availability
DWObject.RegisterEvent('OnImageAreaDeSelected', function(nImageIndex){
alert('The selected area on the image with index '
+ nImageIndex + 'has been deselected');
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
OnImageAreaSelected
This event is triggered when user selects an area (draws a rectangle) or move a selected area on an image in
Dynamic Web TWAIN viewer.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnImageAreaSelected',function(nImageIndex, left, top, right, bottom,
sAreaIndex){...});
: Specifies the index of image in buffer. The index is 0-based.
: Specifies the x-coordinate of the upper-left corner of the rectangle.
number top : Specifies the y-coordinate of the upper-left corner of the rectangle.
number right : Specifies the x-coordinate of the lower-right corner of the rectangle.
number bottom : Specifies the y-coordinate of the lower-right corner of the rectangle.
number sAreaIndex : Specifies the index of the selected area. The index is 1-based. This is
useful when you have multiple selected areas on one image.
number
nImageIndex
number
left
DWObject.RegisterEvent('OnImageAreaSelected', function(nImageIndex, left, top,
right, bottom, sAreaIndex){
alert(nImageIndex + 'left: ' + left);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
114
Display & UI
Methods
SetViewMode()
CloseSource()
DisableSource()
EnableSource()
OpenSource()
SelectSource()
SelectSourceByIndex()
SetOpenSourceTimeout()
Properties
BackgroundColor
BackgroundFillColor
FitWindowType
Height
IfAutoScroll
IfFitWindow
ImageMargin
MaxImagesInBuffer
MouseShape
SelectionImageBorderColor
Width
Zoom
ShowPageNumber
MouseX
MouseY
Events
OnTopImageInTheViewChanged
OnMouseClick
OnMouseDoubleClick
OnMouseMove
OnMouseRightClick
Methods
SetViewMode()
Sets how the images are displayed in Dynamic Web TWAIN viewer.
Syntax
Parameters
Return
value
.SetViewMode(sHorizontalImageCount, sVerticalImageCount);
: specifies the number of columns.
: specifies the number of rows.
number
sHorizontalImageCount
number
sVerticalImageCount
Void
// Zoom is valid only when the view mode is set to -1 by -1.
Example
Availability
DWObject.SetViewMode(-1,-1);
DWObject.Zoom = DWObject.Zoom * 1.2;
DWObject.Zoom = DWObject.Zoom / 1.2;
// Zoom in
// Zoom out
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
The default view mode is 1 by 1.
115
When the view mode is set to -1 by -1, Dynamic Web TWAIN only shows the current image. No
scroll bar is provided to navigate to other images.
When the view mode is set to m (m>0) by n (n>0), a vertical scroll bar will be provided to
navigate to other images.
When the view mode is set to n (n>=1) by -1, a horizontal scroll bar will be provided to navigate
to other images.
Usage
notes
Properties
BackgroundColor
Returns or sets the background color of the built-in viewer.
Type
number
Accessors
Get Set
Usage
notes
Default is white (0xffffff). The byte-ordering of the 24-bit RGB value is RRGGBB. RR represents
red, GG represents green and BB represents blue.
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
BackgroundFillColor
Returns or sets the fill color of the selected area of an image when it is cut, erased or rotated. It is a value
specifying the 24-bit RGB value.
Type
number
Accessors
Get Set
Usage
notes
Default is white (0xffffff). The byte-ordering of the 24-bit RGB value is RRGGBB. RR represents
red, GG represents green and BB represents blue.
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
FitWindowType
Returns or sets how the image is/should be resized to fit to the width or height of the Dynamic Web TWAIN
viewer. To use the property, the view mode should be set to -1 by -1.
Type
number
Accessors
Get Set
Before change the value of FitWindowType, make sure you have set the view mode to -1 by -1
using SetViewMode.
Besides, if you want to change the value of FitWindowType after Zoom in/out, make sure set
the property IfFitWindow to true.
Allowed Values
Usage
notes
0 (default)
Fit Window Type
Fit the image to both the width and height of
the viewer
116
1
Fit the image to the height of the viewer
2
Fit the image to the width of the viewer
When an error occurs, check ErrorCode or ErrorString for error information.
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
Height
Returns or sets the viewer height (in px) of a Dynamic Web TWAIN instance on the page.
Type
number
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
IfAutoScroll
Returns or sets whether to display the newly added image or keep the current one after an image(s) is imported
into the Dynamic Web TWAIN viewer.
Type
boolean
Accessors
Get Set
Usage
notes
Availability
This property is valid only in the ActiveX Edition and the HTML5 Edition from v12.0.
This property doesn't work when the view mode is set to -1 by -1.
The default value of the IfAutoScroll property is true.
If set to true, it will display the newly added image. If set to false, it will display the current one.
When an error occurs, check ErrorCode or ErrorString for error information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v12.0
✓ | v12.0
✓ | v12.0
✓ | v12.0
✓ | v12.1
IfFitWindow
Returns or sets whether to resize the image to fit both the width and height of the Dynamic Web TWAIN viewer.
To use the property, the view mode should be set to -1 by -1.
Type
boolean
Accessors
Get Set
Usage
notes
Before change the value of IfFitWindow, make sure you have set the view mode to -1 by -1
using SetViewMode.
The default value of the IfFitWindow property is true.
When the value is 'false', the image will be displayed in its full size and scroll bars will appear if
necessary (the width or height of the image is bigger than the viewer size).
When an error occurs, check ErrorCode or ErrorString for error information.
117
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
ImageMargin
Returns or sets the margin between images when multiple images are displayed in Dynamic Web TWAIN
viewer.
Type
number
Accessors
Get Set
Usage
notes
Availability
The default value will auto judge.
When an error occurs, check ErrorCode or ErrorString for error information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
MaxImagesInBuffer
Returns or sets how many images are allowed to be acquired.
Type
number
Accessors
Get Set
Usage
notes
Availability
The default value of this property is 32767.
If you set MaxImagesInBuffer to be smaller than HowManyImagesInBuffer, the extra images in
buffer will be removed.
When image buffer is full, that is HowManyImagesInBuffer equals MaxImagesInBuffer, the
newly acquired or loaded image will replace the existing ones from the first one on.
When an error occurs, check ErrorCode or ErrorString for error information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
MouseShape
Returns or sets the shape of the mouse (cursor).
Type
boolean
Accessors
Get Set
Usage
notes
When the property is true, the cursor is set as 'hand'.
If the width or height of the image is bigger than the Dynamic Web TWAIN viewer, scroll bars
will appear and you can drag the image to adjust the position.
When the property is false, the cursor is set as 'crosshair'.
You can then select a rectangular area on Dynamic Web TWAIN viewer directly. After that, the
event OnImageAreaSelected will fire and you can do things like 'crop the selected area'.
When an error occurs, check ErrorCode or ErrorString for error information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
118
H5(macOS/ICA)
H5(Linux)
Availability
✓|
v5.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
MouseX
Returns the X co-ordinate of the mouse. This is a read-only property.
Type
number
Accessors
Get
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
MouseY
Returns the Y co-ordinate of the mouse. This is a read-only property.
Type
number
Accessors
Get
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
SelectionImageBorderColor
Returns or sets the border color of the selected image. It is a value specifying the 24-bit RGB value.
Type
number
Accessors
Get Set
Usage
notes
Availability
The default value is light blue 0x7DA2CE. Please NOTE that the byte-ordering of the 24-bit
RGB value is RRGGBB. RR represents red, GG represents green and BB represents blue.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
ShowPageNumber
Returns or sets whether to show the page number at the top left corner of the viewer.
Type
boolean
Accessors
Get Set
Usage
notes
This property only works in the HTML5 Edition from v10.2.
If the property is true, the page number will be displayed at the top left corner of the viewer.
If it is false, the page number will not be displayed.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
119
H5(macOS/ICA)
H5(Linux)
Availability
✗
✓ | v10.2
✓ | v11.0
✓ | v11.0
✓ | v12.1
Width
Returns or sets the viewer width (in px) of a Dynamic Web TWAIN instance on the page.
Type
number
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
Zoom
Returns or sets zoom factor for the image, only valid when the view mode is set to -1 by -1.
Type
number
Accessors
Get Set
Usage
notes
Availability
The viewer will refresh to reflect the change of Zoom.
Before change the value of Zoom, make sure you have set the view mode to -1 by -1 using
SetViewMode.
Also make sure you have set IfFitWindow to false.
The zoom value is expressed as a percentage. The valid range is from 2 to 6500 percent
(Value: 0.02 ~ 65.0); the default value is 100 percent (Value: 1.0). A zoom value can be
specified before or after an image is displayed. When the zoom value is changed, the displayed
image will refresh automatically.
When an error occurs, check ErrorCode or ErrorString for error information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
Events
OnMouseClick
This event is triggered when the mouse clicks on an image in Dynamic Web TWAIN viewer.
Syntax
Arguments
Example
.RegisterEvent('OnMouseClick',function(sImageIndex){...});
number
: The index of the image.
DWObject.RegisterEvent('OnMouseClick', function(sImageIndex){
alert(sImageIndex);
});
ActiveX
Availability
sImageIndex
H5(Windows)
H5(macOS/TWAIN)
✓|
120
H5(macOS/ICA)
H5(Linux)
v5.0
OnMouseDoubleClick
This event is triggered when the mouse double clicks on an image in Dynamic Web TWAIN viewer.
Syntax
.RegisterEvent('OnMouseDoubleClick',function(sImageIndex){...});
number
Arguments
sImageIndex
: The index of the image.
DWObject.RegisterEvent('OnMouseDoubleClick', function(sImageIndex){
alert(sImageIndex);
});
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
OnMouseMove
This event is triggered when the mouse hovers over an image in Dynamic Web TWAIN viewer.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnMouseMove',function(sImageIndex){...});
number
sImageIndex
: The index of the image.
DWObject.RegisterEvent('OnMouseMove', function(sImageIndex){
alert(sImageIndex);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
OnMouseRightClick
This event is triggered when the mouse right clicks on an image in Dynamic Web TWAIN viewer.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnMouseRightClick',function(sImageIndex){...});
number
sImageIndex
: The index of the image which was clicked upon.
DWObject.RegisterEvent('OnMouseRightClick', function(sImageIndex){
alert(sImageIndex);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
121
v5.1
OnTopImageInTheViewChanged
This event is triggered when the top image currently displayed in Dynamic Web TWAIN viewer changes.
Syntax
Arguments
Example
Availability
Usage
notes
.RegisterEvent('OnTopImageInTheViewChanged',function(sImageIndex){...});
number
sImageIndex
: The index of the image.
DWObject.RegisterEvent('OnTopImageInTheViewChanged', function(sImageIndex){
alert(sImageIndex);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.1
✓ | v10.1
✓ | v11.0
✓ | v11.0
✓ | v12.1
The returned value sImageIndex means the index of the top image. When sImageIndex equals
-1, it indicates that there is no image in buffer.
122
Load & Save
Methods
FileExists()
LoadDibFromClipboard()
LoadImage()
LoadImageEx()
LoadImageFromBase64Binary()
SaveAllAsMultiPageTIFF()
SaveAllAsPDF()
SaveAsBMP()
SaveAsJPEG()
SaveAsPDF()
SaveAsPNG()
SaveAsTIFF()
SaveSelectedImagesAsMultiPagePDF()
SaveSelectedImagesAsMultiPageTIFF()
SaveSelectedImagesToBase64Binary()
ShowFileDialog()
Properties
IfShowFileDialog
Events
OnGetFilePath
OnPostLoad
Code example
The following code example demonstrates how to use the APIs above to perform basic scanning.
var imagedata;
DWObject.SelectedImagesCount = 1;
DWObject.SetSelectedImageIndex(0,0);
DWObject.GetSelectedImagesSize(EnumDWT_ImageType.IT_JPG);
imagedata = DWObject.SaveSelectedImagesToBase64Binary();
DWObject.LoadImageFromBase64Binary(imagedata, EnumDWT_ImageType.IT_JPG, function(){
console.log('success');
},function(){
console.log('failure');
});
Methods
FileExists()
Checks whether a certain file exists on the local disk.
Syntax
.FileExists(fileName);
Parameters
string
Return
value
boolean
fileName
: the absolute path of the file to be checked.
123
Example
Availability
DWObject.FileExists("C:\\DWT\\WebTWAIN.jpg");
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v9.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
LoadDibFromClipboard()
Loads a DIB image from the system clipboard into Dynamic Web TWAIN.
Syntax
.LoadDibFromClipboard([optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is loaded successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be loaded.
Return
value
Availability
boolean
Only valid when used synchronously.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.1
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
LoadImage()
Loads local image(s) into the Dynamic Web TWAIN buffer.
Syntax
.LoadImage(fileName, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string fileName : the absolute path to the file to be opened.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is loaded successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be loaded.
Return
value
Example
Availability
Usage
notes
boolean
Only valid when used synchronously.
DWObject.LoadImage("C:\\DWT.jpg");
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Dynamic Web TWAIN processes the image format according to the extension of
124
fileName
.
LoadImageEx()
Loads local image(s) into Dynamic Web TWAIN.
Syntax
.LoadImageEx(fileName, imageType, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
: the absolute path to open the file.
imageType : the image format.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is loaded successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be loaded.
Return
value
Only valid when used synchronously.
string
fileName
EnumDWT_ImageType (int)
Example
Availability
Usage
notes
boolean
DWObject.IfShowFileDialog = true;
DWObject.LoadImageEx("", EnumDWT_ImageType.IT_ALL);
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to load/open images by showing the 'Open File' dialog box, you can set
IfShowFileDialog to true.
LoadImageFromBase64Binary()
Load image(s) from a base64 string.
Syntax
.LoadImageFromBase64Binary(imageData, imageType, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
: the base64 string that represents the image.
imageType : the image format.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the
operation succeeds.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the
operation fails.
string
imageData
EnumDWT_ImageType (int)
Return
value
Example
boolean
var imagedata;
DWObject.SelectedImagesCount = 1;
DWObject.SetSelectedImageIndex(0,0);
DWObject.GetSelectedImagesSize(EnumDWT_ImageType.IT_JPG);
imagedata = DWObject.SaveSelectedImagesToBase64Binary();
DWObject.LoadImageFromBase64Binary(imagedata, EnumDWT_ImageType.IT_JPG, function(){
console.log('success');
},function(){
console.log('failure');
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
✓|
125
H5(macOS/ICA)
H5(Linux)
v6.2
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
SaveAllAsMultiPageTIFF()
Saves all the images in the buffer as a Multipage TIFF file.
Syntax
.SaveAllAsMultiPageTIFF(fileName, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string fileName : the absolute path to save the file.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
boolean
Only valid when used synchronously.
DWObject.SaveAllAsMultiPageTIFF("C:\\DWT.tiff");
Example
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Multi-Page TIFF encoding is a built-in feature of Dynamic Web TWAIN, no extra dlls are
required. If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveAllAsPDF()
Saves all the images in the buffer as a Multipage PDF file.
Syntax
.SaveAllAsPDF(fileName, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string fileName : the absolute path to save the file.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
Example
Availability
Usage
boolean
Only valid when used synchronously.
DWObject.SaveAllAsPDF("C:\\DWT.pdf");
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Multi-Page PDF encoding is a built-in feature of Dynamic Web TWAIN, no extra dlls are
required. If you would like to save images by showing the 'Save File' dialog box, you can set
126
IfShowFileDialog
to true.
SaveAsBMP()
Saves the image of a specified index in the buffer as a BMP file.
Syntax
.SaveAsBMP(fileName, sImageIndex, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
: the absolute path on the client machine to save the file.
: the index of the image in the buffer. The index is 0-based.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
Example
Availability
Usage
notes
string
fileName
number
sImageIndex
boolean
Only valid when used synchronously.
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
alert(errorString);
}
function btn_SaveOnClick() {
if (DWObject.HowManyImagesInBuffer == 0){
alert("No images in buffer.");
return;
}
DWObject.SaveAsBMP("D:\\test.bmp", 0, OnSuccess, OnFailure);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveAsJPEG()
Saves the image of a specified index in the buffer as a JPEG file.
Syntax
.SaveAsJPEG(fileName, sImageIndex, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
: the absolute path on the client machine to save the file.
: the index of the image in the buffer. The index is 0-based.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
string
fileName
number
sImageIndex
boolean
Only valid when used synchronously.
//Callback functions for async APIs
127
Example
Availability
Usage
notes
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
alert(errorString);
}
function btn_SaveOnClick() {
if (DWObject.HowManyImagesInBuffer == 0){
alert("No images in buffer.");
return;
}
DWObject.SaveAsJPEG("D:\\test.jpg", 0, OnSuccess, OnFailure);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveAsPDF()
Saves the image of a specified index in the buffer as a PDF file.
Syntax
.SaveAsPDF(fileName, sImageIndex, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
: the absolute path on the client machine to save the file.
: the index of the image in the buffer. The index is 0-based.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
Example
Availability
Usage
notes
string
fileName
number
sImageIndex
boolean
Only valid when used synchronously.
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
alert(errorString);
}
function btn_SaveOnClick() {
if (DWObject.HowManyImagesInBuffer == 0){
alert("No images in buffer.");
return;
}
DWObject.SaveAsPDF("D:\\test.pdf", 0, OnSuccess, OnFailure);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
128
SaveAsPNG()
Saves the image of a specified index in the buffer as a PNG file.
Syntax
.SaveAsPNG(fileName, sImageIndex, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
: the absolute path on the client machine to save the file.
: the index of the image in the buffer. The index is 0-based.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
Example
Availability
Usage
notes
string
fileName
number
sImageIndex
boolean
Only valid when used synchronously.
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
alert(errorString);
}
function btn_SaveOnClick() {
if (DWObject.HowManyImagesInBuffer == 0){
alert("No images in buffer.");
return;
}
DWObject.SaveAsPNG("D:\\test.png", 0, OnSuccess, OnFailure);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v4.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveAsTIFF()
Saves the image of a specified index in the buffer as a TIFF file.
Syntax
.SaveAsTIFF(fileName, sImageIndex, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
: the absolute path on the client machine to save the file.
: the index of the image in the buffer. The index is 0-based.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
string
fileName
number
sImageIndex
boolean
Only valid when used synchronously.
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
129
Example
Availability
Usage
notes
}
function btn_SaveOnClick() {
if (DWObject.HowManyImagesInBuffer == 0){
alert("No images in buffer.");
return;
}
DWObject.SaveAsTIFF("D:\\test.tif", 0, OnSuccess, OnFailure);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveSelectedImagesAsMultiPagePDF()
Saves the selected images in the buffer as a Multipage PDF file.
Syntax
.SaveSelectedImagesAsMultiPagePDF(fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
string fileName : the absolute path on the client machine for saving the file.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
OnFailure Function optional optionalAsyncFailureFunc : callback function triggered when the file
failed to be saved.
Return
value
Example
Availability
Usage
notes
boolean
Only valid when used synchronously.
DWObject.SelectedImagesCount = 1;
DWObject.SetSelectedImageIndex(0,0);
DWObject.SaveSelectedImagesAsMultiPagePDF("C:\\DWT.pdf");
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Multi-Page PDF encoding is a built-in feature of Dynamic Web TWAIN, no extra dlls are
required. If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveSelectedImagesAsMultiPageTIFF()
Saves the selected images in the buffer as a Multipage TIFF file.
Syntax
Parameters
.SaveSelectedImagesAsMultiPagePDF(fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
string fileName : the absolute path to save the file.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
OnSuccess Function optional optionalAsyncSuccessFunc : callback function triggered when the file
is saved successfully.
130
OnFailure Function
optional
optionalAsyncFailureFunc
: callback function triggered when the file
failed to be saved.
Return
value
boolean
Only valid when used synchronously.
DWObject.SelectedImagesCount = 1;
DWObject.SetSelectedImageIndex(0,0);
DWObject.SaveSelectedImagesAsMultiPageTIFF("C:\\DWT.tiff");
Example
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Multi-Page TIFF encoding is a built-in feature of Dynamic Web TWAIN, no extra dlls are
required. If you would like to save images by showing the 'Save File' dialog box, you can set
IfShowFileDialog to true.
SaveSelectedImagesToBase64Binary()
Saves the selected images in the buffer to a base64 string.
Syntax
Parameters
.SaveSelectedImagesToBase64Binary();
None
string
Return
value
The result string is the pure base64 string with no extra info. For example,
"/9j/4AAQSkZJRgABA..." .
To use the string in most circumstances, you need to add extra info like
data:image/png;base64,"/9j/4AAQSkZJRgABA..." .
var imagedata;
DWObject.SelectedImagesCount = 1;
DWObject.SetSelectedImageIndex(0, 0);
DWObject.GetSelectedImagesSize(EnumDWT_ImageType.IT_JPG);
imagedata = DWObject.SaveSelectedImagesToBase64Binary();
newImage.src = "data:image/png;base64," + imagedata;
Example
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Please invoke GetSelectedImagesSize before invoking this method to specify the target format.
The default value is IT_JPG and it doesn't support black and white images.
ShowFileDialog()
Show the system's save-file dialog or open-file dialog.
Syntax
.ShowFileDialog(bSave, filter, filterIndex, defaultExtension, initialDir, allowMultiSelect,
overwritePrompt, flags);
: true -- show save-file dialog, false -- show open-file dialog.
: the filter name specifies the filter pattern (for example, "JPG | *.jpg"). To
specify multiple filter patterns use a semicolon to separate the patterns (for example, "JPG,
PNG and TIF | *.jpg;*.png;*.tif" or "JPG, PNG , TIF" for macOS). A pattern string can be a
boolean
bsave
string
filter
131
Parameters
Return
value
combination of valid file extensions with asterisk (*). Do not include spaces in the pattern string.
To show all files, use the string "All Files | *.*".
int filterIndex : determines the index for the filter string we set, in other words, where the
filter string should appear in the dialog's filters drop-down box. By default, it's 0 and you don't
need to change it. This parameter doesn't work on macOS.
string defaultExtension : define the default extension which will be appended to the file name.
Only useful when you try to save an image or images. If this member is NULL and the user fails
to type an extension, no extension is appended.
string initialDir : the initial directory. The algorithm for selecting the initial directory varies on
different platforms.
boolean allowMultiSelect : true -- allow multiple selections, false -- only allow single file
selection.
boolean overwritePrompt : true -- if a file already exists with the same name, the user needs to
confirm before the existing file is overwritten, false -- if a file already exists with the same name,
it will be overwritten without further user confirmation.
int flags : if this parameter equals 0, the program will be initiated with the custom settings.
Otherwise it will be initiated with default flags, which means allowMultiSelect and
overwritePrompt will not work.
boolean
DWObject.RegisterEvent('OnGetFilePath', function(bSave, filesCount,
index, path, filename){
alert(" fileCount: " + filesCount + " index: " + index +
" path: " + path + "\\" + filename);
});
//On macOS
var result = DWObject.ShowFileDialog(false, "TIF,TIFF,JPG,JPEG,PNG,PDF", 0,
"", "", true, false, 0);
//On Windows
var result = DWObject.ShowFileDialog(false, "TIF,TIFF,JPG,JPEG,PNG,PDF", 0,
"", "", true, true, 0)
alert(result);
Example
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
For Mac Edition, the method performs differently.
This method will trigger OnGetFilePath event even when it fails. If multiple files are selected, the
event will be called multiple times.
Properties
IfShowFileDialog
Returns or sets whether to show open/save file dialog when saving scanned images or loading images from a
local directory.
Type
boolean
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
132
Usage
notes
When loading, the property only works for the method
LoadImageEx
.
Events
OnGetFilePath
This event is triggered when a file path is returned from the operating system this occurs when the
ShowFileDialog method is called or when the LoadImageEx method is called with IfShowFileDialog set to true.
Syntax
.RegisterEvent('OnGetFilePath',function(bSave, filesCount, index, path, filename){...});
: 'true' -- show save file dialog, 'false' -- show open file dialog.
: How many files were selected. 0 means no file was selected or the
user closed/cancelled.
number index : The index of the currently selected file. 0-based. -1 means no file was
selected.
string path : The parent path of currently selected file(s), "\\" is not included. If the
methed ShowFileDialog() failed, the initial directory path set in the ShowFileDialog method is
returned.
string filename : The current file name.
boolean
number
Arguments
Example
Availability
bSave
filesCount
DWObject.RegisterEvent('OnGetFilePath', function(bSave, filesCount,
index, path, filename)
{
alert("bSave:" + bSave + " fileCount: " + filesCount + " index: " +
" path: " + path + "\\" + filename);
});
index +
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
OnPostLoad
This event is triggered when an image file from a local directory has been loaded into the control.
Syntax
Arguments
Example
Availability
Usage
.RegisterEvent('OnPostLoad',function(path, name, type){...});
string path : the local path of the loaded image. For example, C:\Users\
[username]\Downloads\
string name : the name of the loaded image. For example, image1.jpg
EnumDWT_ImageType type : Image format.
DWObject.RegisterEvent('OnPostLoad', function(path, name, type) {
alert(path + '\\' + name);
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.3
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
If multiple image files are loaded, this event will be triggered once for each image.
133
notes
If multiple image files are loaded, this event will be triggered once for each image.
134
Upload & Download
Methods
ClearAllHTTPFormField()
FTPDownload()
FTPDownloadDirectly()
FTPDownloadEx()
FTPUpload()
FTPUploadAllAsMultiPageTIFF()
FTPUploadAllAsPDF()
FTPUploadAsMultiPagePDF()
FTPUploadAsMultiPageTIFF()
FTPUploadDirectly()
FTPUploadEx()
HTTPDownload()
HTTPDownloadDirectly()
HTTPDownloadEx()
HTTPUpload()
HTTPUploadAllThroughPostAsMultiPageTIFF()
HTTPUploadAllThroughPostAsPDF()
HTTPUploadThroughPost()
HTTPUploadThroughPostAsMultiPagePDF()
HTTPUploadThroughPostAsMultiPageTIFF()
HTTPUploadThroughPostDirectly()
HTTPUploadThroughPostEx()
SetHTTPFormField()
SetUploadSegment()
SetHTTPHeader()
Properties
FTPPassword
FTPPort
FTPUserName
HttpFieldNameOfUploadedImage
HTTPPort
HTTPPostResponseString
IfPASVMode
IfShowCancelDialogWhenImageTransfer
IfSSL
MaxUploadImageSize
Events
OnInternetTransferPercentage
OnInternetTransferPercentageEx
Code example
The following code example demonstrates how to use the APIs above to perform basic uploading.
DWObject.HTTPUpload ('www.dynamsoft.com/SaveToFile.aspx?filename=001.pdf', [0,1],
EnumDWT_ImageType.IT_PDF, EnumDWT_
UploadDataFormat.Binary, 'test.pdf', OnHttpUploadSuccess, OnHttpUploadFailure);
function OnHttpUploadSuccess (httpResponse) {
console.log("HTTPResponseString: " + httpResponse);
}
function OnHttpUploadFailure (errorCode, errorString, httpResponse) {
alert("ErrorCode: " + errorCode+ "ErrorString: " + errorString + "HTTPResponseString: " + httpResponse);
}
135
Methods
ClearAllHTTPFormField()
Clears all the web form fields which will be sent to the server with the images when uploading.
Syntax
.ClearAllHTTPFormField();
Parameters
None
Return value
boolean
Example
DWObject.ClearAllHTTPFormField();
Usage notes
Availability
v5.0+
FTPDownload()
Downloads an image from a specified FTP server.
Syntax
.FTPDownload(fTPServer, fTPRemoteFile, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
fTPRemoteFile: the path of the file on the FTP server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Dynamic Web TWAIN processes the image format according to the extension of
fTPRemoteFile.
Availability
v4.0+
FTPDownloadDirectly()
Downloads a file from a specified FTP server directly without opening it in Dynamic Web TWAIN.
Syntax
.FTPDownloadDirectly(fTPServer, fTPRemoteFile, localFile,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
fTPRemoteFile: the path of the file on the FTP server.
string localFile: the local path for the downloaded file.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
136
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Technically this method can download any file from the FTP server.
Availability
v7.0+
FTPDownloadEx()
Downloads an image from a specified FTP server.
Syntax
.FTPDownloadEx(fTPServer, fTPRemoteFile, imageType, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
fTPServer: the FTP server.
fTPRemoteFile: the path of the file on the FTP server.
EnumDWT_ImageType (int) imageType: the image format to be used.
string
string
Type
Parameters
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
IT_PDF
4
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v5.0+
FTPUpload()
Uploads the image of a specified index in the buffer to the FTP server in a specified image format.
Syntax
.FTPUpload(fTPServer, sImageIndex, fTPRemoteFile, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
sImageIndex: the index of the image in the buffer. The index is 0-based.
string fTPRemoteFile: the file name, path included.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
number
Return value
Boolean, only valid when used synchronously.
137
Example
Usage notes
Dynamic Web TWAIN processes the image format according to the extension of
fTPRemoteFile.
Availability
v4.0+
FTPUploadAllAsMultiPageTIFF()
Uploads all the images in the buffer to a specified FTP server as a TIFF file.
Syntax
.FTPUploadAllAsMultiPageTIFF(fTPServer, fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
fileName: the file name, including the path.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v4.0+
FTPUploadAllAsPDF()
Uploads all the images in the buffer to a specified FTP server as a PDF file.
Syntax
.FTPUploadAllAsPDF(fTPServer, fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
fileName: the file name, including the path to the file.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v4.0+
FTPUploadAsMultiPagePDF()
Uploads the selected images in buffer to a specified FTP server as a PDF file.
Syntax
.FTPUploadAsMultiPagePDF(fTPServer, fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
string
fTPServer: the FTP server.
138
Parameters
Return value
string fileName: the file name, path included.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v6.0+
FTPUploadAsMultiPageTIFF()
Uploads the selected images in the buffer to a specified FTP server as a TIFF file.
Syntax
.FTPUploadAsMultiPageTIFF(fTPServer, fileName, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
fileName: the file name, path included.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v6.0+
FTPUploadDirectly
Upload any type of file to the server via FTP.
Syntax
.FTPUploadDirectly(fTPServer, strLocalFile, fTPRemoteFile,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
fTPServer: the FTP server.
strLocalFile: the path of the local file.
string fTPRemoteFile: the file name, path included.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
139
Availability
v7.0+
FTPUploadEx()
Uploads the image of a specified index in buffer to the FTP server in a specified image format.
Syntax
.FTPUploadEx(fTPServer, sImageIndex, fTPRemoteFile, imageType,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
fTPServer: the FTP server.
sImageIndex: the index of image in buffer. The index is 0-based.
string fTPRemoteFile: the file name, path included.
EnumDWT_ImageType (int) imageType: the format.
string
number
Type
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
IT_PDF
4
Parameters
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be uploaded.
Please refer to the function prototype OnSuccess or OnFailure.
Return value
Boolean, only valid when used synchronously.
Example
Usage notes
Availability
v5.0+
HTTPDownload()
Downloads an image from a specified HTTP server.
Syntax
.HTTPDownload(strHTTPServer, strHTTPRemoteFile, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
strHTTPServer: the HTTP server.
strHTTPRemoteFile: the file name, the path of the file on the HTTP server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype onsuccess or OnFailure.
string
string
Return value
Example
Boolean, only valid when used synchronously.
/****Get image01.png from: http://www.dynamsoft.com/images/image01.png****/
DWObject.HTTPDownload('www.dynamsoft.com','/images/image01.png');
140
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v4.0+
HTTPDownloadDirectly()
Downloads a file from a specified HTTP server directly without opening it in Dynamic Web TWAIN.
Syntax
.HTTPDownloadDirectly(strHTTPServer, strHTTPRemoteFile, localFile,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
strHTTPServer: the HTTP server.
strHTTPRemoteFile: the path of the file on the HTTP server, or the path to an
action page (with necessary parameters) which gets and sends back the file stream to
the client.
string localFile: the local path for the downloaded file.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
string
string
Return value
Boolean, only valid when used synchronously.
/*Get ducument.txt from: http://www.dynamsoft.com/files/ducument.txt*/
/*Save as 01.txt to: D:/*/
DWObject.HTTPDownloadDirectly('www.dynamsoft.com','/files/ducument.txt','D:/01.txt');
/*Get image02.jpg
from: http://www.dynamsoft.com/images/GetImage.aspx?Index=2&Name=image02.jpg*/
/**Save as 02.jpg to: D:/temp/02.jpg**/
DWObject.HTTPDownloadDirectly('www.dynamsoft.com',
'/images/GetImage.aspx?Index=2&Name=image02.jpg','D:/temp/02.jpg');
Example
Usage notes
Technically this method can download any file from the HTTP server.
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v7.0+
HTTPDownloadEx()
Downloads an image from a specified HTTP server.
Syntax
.HTTPDownloadEx(strHTTPServer, strHTTPRemoteFile, imageType,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
string strHTTPServer: the address of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string strHTTPRemoteFile: the path of the file on the HTTP server, or the path to an
action page (with necessary parameters) which gets and sends back the image stream
to the client.
EnumDWT_ImageType (int) imageType: the image format.
Type
Parameters
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
141
IT_PDF
4
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered
when the file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered
when the file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
Return value
Boolean, only valid when used synchronously.
/*Get image01.png from: http://www.dynamsoft.com/images/image01.png*/
DWObject.HTTPDownloadEx('www.dynamsoft.com','/images/image01.png',3);
Example
/*Get image02.jpg from:
http://www.dynamsoft.com/images/GetImage.aspx?Index=2&Name=image02.jpg*/
DWObject.HTTPDownloadEx('www.dynamsoft.com',
'/images/GetImage.aspx?Index=2&Name=image02.jpg',1);
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v5.0+
HTTPUpload()
1. Uploads images of specified indices in the buffer to the HTTP server asynchronously.
1. Or uploads the form created by SetHTTPFormField.
Syntax
1. HTTPUpload(url, indices, enumImageType, dataFormat, fileName,
asyncSuccessFunc, asyncFailureFunc);
2. HTTPUpload(url, indices, enumImageType, dataFormat, asyncSuccessFunc,
asyncFailureFunc);
3. HTTPUpload(url, asyncSuccessFunc, asyncFailureFunc);
string url: specifies the name of http server and action page and filename. For
example "www.dynamsoft.com/ActionPageName?filename=FileName".
Array indices: specifies the indices of images in buffer. The index is 0-based. If
EnumDWT_ImageType is IT_BMP/IT_JPG/IT_PNG, since multi-page file is not
possible, you can only specify one index.
EnumDWT_ImageType imageType: specifies the format of the file you want to upload as.
Type
Parameters
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
IT_PDF
4
fileName: specifies the file name.
dataFormat: specifies the data format, either
EnumDWT_UploadDataFormat.Binary or EnumDWT_UploadDataFormat.base64.
string
EnumDWT_UploadDataFormat
Type
Numeric Value
BINARY
0
BASE64
1
142
asyncSuccessFunc
: callback function triggered when the
file is uploaded successfully.
asyncFailureFunc : callback function triggered when the
file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Example
Boolean. This method is used asynchronously only. Even though it returns true doesn't mean
that the upload is successful.
DWObject.HTTPUpload('www.dynamsoft.com/SaveToFile.aspx?filename=001.pdf',
[0,1], EnumDWT_ImageType.IT_PDF, EnumDWT_UploadDataFormat.Binary,
'test.pdf', OnHttpUploadSuccess, OnHttpUploadFailure);
function OnHttpUploadSuccess (httpResponse) {
console.log("HTTPResponseString: " + httpResponse);
}
function OnHttpUploadFailure (errorCode, errorString, httpResponse) {
alert("ErrorCode: " + errorCode+ "ErrorString: " +
errorString + "HTTPResponseString: " + httpResponse);
}
Usage notes
This method is valid only in the HTML5 Edition from v12.0.
Availability
v12.0+
HTTPUploadAllThroughPostAsMultiPageTIFF()
Uploads all the images in the buffer to a specified HTTP server as a single TIFF file.
Syntax
.HTTPUploadAllThroughPostAsMultiPageTIFF(strHTTPServer, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
143
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
Example
// Upload all the images in the buffer to the
// HTTP server as a TIFF file asynchronously
DWObject.HTTPUploadAllThroughPostAsMultiPageTIFF(
strstrHTTPServer,
strActionPage,
"imageData.tif",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v4.0+
HTTPUploadAllThroughPostAsPDF()
Uploads all of the images in the buffer to a specified HTTP server as a PDF file.
Syntax
.HTTPUploadAllThroughPostAsPDF(strHTTPServer, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name to be saved on the server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
144
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
Example
// Upload all of the images in Dynamic Web TWAIN viewer
// to the HTTP server as a PDF file asynchronously
DWObject.HTTPUploadAllThroughPostAsPDF(
strstrHTTPServer,
strActionPage,
"imageData.pdf",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v5.0+
HTTPUploadThroughPost()
Uploads the image of a specified index in the buffer to a specified HTTP server.
Syntax
.HTTPUploadThroughPost(strHTTPServer, sImageIndex, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
number sImageIndex: the index of the image in the buffer. The index is 0-based.
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name to be saved on the server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSource();
145
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
// Upload the image of a specified index in
// Dynamic Web TWAIN viewer to the HTTP server asynchronously
if (document.getElementById("JPEG").checked) {
DWObject.HTTPUploadThroughPost(
strstrHTTPServer,
DWObject.CurrentImageIndexInBuffer,
strActionPage,
"imageData.jpg",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
if (document.getElementById("PNG").checked) {
DWObject.HTTPUploadThroughPost(
strstrHTTPServer,
DWObject.CurrentImageIndexInBuffer,
strActionPage,
"imageData.png",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
if (document.getElementById("BMP").checked) {
DWObject.HTTPUploadThroughPost(
strstrHTTPServer,
DWObject.CurrentImageIndexInBuffer,
strActionPage,
"imageData.bmp",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
Example
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
Dynamic Web TWAIN processes the image format according to the extension of
fileName.
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
146
Availability
v4.0+
HTTPUploadThroughPostAsMultiPagePDF()
Uploads the selected images in the buffer to a specified HTTP server as a PDF file.
Syntax
.HTTPUploadThroughPostAsMultiPagePDF(strHTTPServer, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name to be saved on the server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSourceByIndex(document.getElementById("source").selectedIndex);
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
DWObject.SelectedImagesCount = 3;
DWObject.SetSelectedImageIndex(0, 0);
// Set the 1st image as the first selected image.
DWObject.SetSelectedImageIndex(1, 2);
// Set the 3rd image as the second selected image.
DWObject.SetSelectedImageIndex(2, 4);
// Set the 5th image as the third selected image.
DWObject.GetSelectedImagesSize(4);
// 4 - PDF format. Calculate the size of selected images in PDF format.
Example
// Upload the selected images to the server asynchronously
DWObject.HTTPUploadThroughPostAsMultiPagePDF(
strstrHTTPServer,
strActionPage,
"imageData.pdf",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
147
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v6.0+
HTTPUploadThroughPostAsMultiPageTIFF()
Uploads selected images in the buffer to the HTTP server as a TIFF file.
Syntax
.HTTPUploadThroughPostAsMultiPageTIFF(strHTTPServer, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name to be saved on the server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSourceByIndex(document.getElementById("source").selectedIndex);
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
DWObject.SelectedImagesCount = 3;
DWObject.SetSelectedImageIndex(0, 0);
// Set the 1st image as the first selected image.
148
DWObject.SetSelectedImageIndex(1, 2);
// Set the 3rd image as the second selected image.
DWObject.SetSelectedImageIndex(2, 4);
// Set the 5th image as the third selected image.
DWObject.GetSelectedImagesSize(2);
// 2 - TIFF format. Calculate the size of selected images in TIFF format.
Example
// Upload the selected images to the server asynchronously
DWObject.HTTPUploadThroughPostAsMultiPageTIFF(
strstrHTTPServer,
strActionPage,
"imageData.tiff",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v6.0+
HTTPUploadThroughPostDirectly()
Upload any type of file to the server.
Syntax
.HTTPUploadThroughPostDirectly(strHTTPServer, strLocalFile, actionPage, fileName,
[optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
Parameters
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
string strLocalFile: the path of the file to upload.
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded file stream.
string fileName: the file name to be used when saving the file on the server.
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
149
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false; // Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
// Uploads a specific image in the buffer to
// the HTTP server in a specified image format asynchronously
DWObject.HTTPUploadThroughPostDirectly(
strstrHTTPServer,
"D:\\DWT.jpg",
strActionPage,
"imageData.jpg",
OnHttpUploadSuccess,
OnHttpUploadFailure
);
Example
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v7.0+
HTTPUploadThroughPostEx()
Uploads the image of a specified index in the buffer to the HTTP server in a specified image format.
Syntax
.HTTPUploadThroughPostEx(strHTTPServer, sImageIndex, actionPage, fileName,
imageType, [optionalAsyncSuccessFunc, optionalAsyncFailureFunc]);
string strHTTPServer: the name of the HTTP server. For example:
"www.dynamsoft.com", "localhost", "127.0.0.1".
number sImageIndex: the index of the image in the buffer. The index is 0-based.
string actionPage: the relative path for the action page on the server. The action page
will receive and process the uploaded image stream.
string fileName: the file name to be saved on the server.
EnumDWT_ImageType imageType: the format of the image.
Type
Parameters
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
IT_PDF
4
The following two parameters are optional. If either one exists or both exist, the method
is asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function
triggered when the file is uploaded successfully.
150
optional optionalAsyncFailureFunc : callback function
triggered when the file failed to be uploaded.
Please refer to the function prototype onHttpUploadSuccess or onHttpUploadFailure.
Return value
Boolean, only valid when used synchronously.
function btnScan_onclick()
{
if (DWObject) {
DWObject.SelectSourceByIndex(document.getElementById("source").selectedIndex);
DWObject.OpenSource();
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
}
// OnHttpUploadSuccess and OnHttpUploadFailure are callback functions.
function OnHttpUploadSuccess() {
console.log('successful');
}
function OnHttpUploadFailure(errorCode, errorString, sHttpResponse) {
alert(errorString + sHttpResponse);
}
function btnUpload_onclick()
{
var strstrHTTPServer = location.hostname; //The name of the HTTP server.
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0,
CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.IfSSL = false;
// Set whether SSL is used
DWObject.HTTPPort = location.port == "" ? 80 : location.port;
Example
// Uploads a specific image in the buffer to the HTTP
// server in a specified image format asynchronously
DWObject.HTTPUploadThroughPostEx(
strstrHTTPServer,
DWObject.CurrentImageIndexInBuffer,
strActionPage, "imageData.jpg",
EnumDWT_ImageType.IT_JPG,
OnHttpUploadSuccess,
OnHttpUploadFailure
);
}
//SaveToFile.aspx:
<%@ Page Language="C#" %>
<%
try{
String strImageName;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName);
}
catch{
}
%>
Usage notes
If you want to use this method to upload / download files through HTTPS, please don't
forget to set IfSSL to true and set the correct HTTPPort.
Availability
v5.0+
SetHTTPFormField()
Sets up a field in the web form which will be sent to the server once an upload is initiated. You can set
multiple fields by calling this method mutliple times.
.SetHTTPFormField(fieldName, fieldValue);
151
.SetHTTPFormField(fieldName, blobValue, optional fileName);
Parameters
Return value
string fieldName: the name of the field which can later be used on the server to
retrieve the field value.
string fieldValue: the field value.
string fieldName: the name of the field which can later be used on the server to
retrieve the blob.
Blob blobValue: the binary data to be uploaded.
string fileName: the name to be used when saving the binary on the server.
boolean
DWObject.ClearAllHTTPFormField();
DWObject.SetHTTPFormField("PDFFileName", "test.pdf");
//Get action page path
var CurrentPathName = unescape(location.pathname);
var CurrentPath = CurrentPathName.substring(0, CurrentPathName.lastIndexOf("/") + 1);
var strActionPage = CurrentPath + "SaveToFile.aspx";
DWObject.HTTPUploadAllThroughPostAsMultiPageTIFF(
"www.dynamsoft.com",
strActionPage,
"test.tiff"
);
Example
//C# Action Page Part:
System.Web.HttpContext.Current.Request.Form["PDFFileName"];
Usage notes
It was improved to be able to set Blobs in HTTP Forms aside from strings from v13.1.
Availability
v5.0+
SetUploadSegment()
Specifies when an upload should be segmented and the size of the segments.
Syntax
.SetUploadSegment(segementUploadThreshold, moduleSize);
Parameters
number segementUploadThreshold: the threshold (in MB) over which segmented
upload will be invoked.
number moduleSize: the size of each segment (in KB).
Return value
Availability
boolean
v12.1+
SetHTTPHeader()
Adds a header to an http(s) post request. This header will be cleared every time a
HTTPUpload/HTTPDownload request is done.
Syntax
.SetHTTPHeader(HeaderName, HeaderValue);
Parameters
string HeaderName: the name of the header which can later be used on the server to
retrieve the header value.
string HeaderValue: the header value.
Return value
Example
boolean
DWObject.SetHTTPHeader('dwt_CustomHeader','dynamsoft');
DWObject.HTTPUpload ('www.dynamsoft.com/SaveToFile.aspx?filename=001.pdf',
[0,1], EnumImageType.PDF,
EnumDWT_UploadDataFormat.BINARY, true, OnHttpUploadSuccess, OnHttpUploadFailure);
function OnHttpUploadSuccess (httpResponse) {
console.log("HTTPResponseString: " + httpResponse);
}
152
Example
}
function OnHttpUploadFailure (errorCode, errorString, httpResponse) {
alert("ErrorCode: " + errorCode+ "ErrorString: " +
errorString + "HTTPResponseString: " + httpResponse);
}
Usage notes
This method is valid only in the HTML5 Edition.
Availability
v12.0+
Properties
FTPPassword
Returns or sets the password used to log into the FTP server.
Type
string
Accessors
Get Set
Usage notes
If you are logging into a FTP server as "anonymous", then you don't need to set
FTPUserName or FTPUserPassword.
Availability
v5.2+
FTPPort
Returns or sets the port number of the FTP server to be used for uploading/downloading.
Type
number
Accessors
Get Set
Usage notes
The default FTP port number is 21.
Availability
v5.2+
FTPUserName
Returns or sets the username used to log into a FTP server.
Type
string
Accessors
Get Set
Usage notes
If you are logging into a FTP server as "anonymous", then you don't need to set
FTPUserName or FTPUserPassword.
Availability
v5.2+
HttpFieldNameOfUploadedImage
Returns or sets the field name of the uploaded image when uploading through POST.
Type
string
Accessors
Get Set
Usage notes
The default value is "RemoteFile".
Availability
v6.0+
153
HTTPPort
Returns or sets the port number to be used for uploading via HTTP.
Type
number
Accessors
Get Set
Usage notes
The default HTTP port number is 80. This property is typically used with (IfSSL)
[#IfSSL].
Availability
v4.2.1+
HTTPPostResponseString
Returns the response string from the HTTP server if an error occurred after calling one of the
HTTPUploadThroughPost*** methods.
Type
string
Accessors
Get
Usage notes
This is a read-only property.
Availability
v3.0.3+
IfPASVMode
Returns or sets whether FTP passive mode is enabled.
Type
boolean
Accessors
Get Set
Usage notes
The default value is true.
When the value of the property is true, FTP passive mode is enabled.
When the value of the property is set to false, FTP active mode is enabled.
Availability
v6.0+
IfShowCancelDialogWhenImageTransfer
Returns or sets whether to show the cancel dialog when uploading images to server. The default value is true.
Type
boolean
Accessors
Get Set
In the HTML5 Edition, this property only works with asynchronous uploading.
The IfShowProgressBar property works for any image encoding/decoding related methods. For example:
LoadImage,LoadImageEx, etc.
Property
HTML5 Edition
Non-HTML5
Editions (ActiveX /
Plugin)
true
Upload/Download:
The progress bar
will appear.
Upload/Download:
The progress bar will
appear.
false
Upload/Download:
The progress bar
will not appear.
Upload/Download:
The progress bar will
not appear.
Value
IfShowCancelDialogWhenImageTransfer
Usage
Save/Load:
154
Usage
notes
true
Save/Load:
The progress bar
will appear.
IfShowProgressBar
false
Availability
Save/Load:
The progress bar
will not appear.
Save/Load:
The progress bar will
appear.
Upload/Download
(Encoding/Decoding):
The progress bar will
appear.
Save/Load:
The progress bar will
not appear.
Upload/Download
(Encoding/Decoding):
The progress bar will
not appear.
v5.2+
IfSSL
Returns or sets whether SSL is used when uploading or downloading images.
Type
number
Accessors
Get Set
Usage notes
The default value is false.
This property is typically used with HTTPPort. If IfSSL is set to true, make sure
HTTPPort is set to a secure port like 443.
Availability
v5.2+
MaxUploadImageSize
Returns or sets the size limit for uploading images.
Type
number
Accessors
Get Set
Usage notes
The default value is -1 which indicates there is no limit over the upload size. The unit is
'Byte'.
Availability
v5.2+
Events
OnInternetTransferPercentage
This event is triggered during image uploading or downloading.
Syntax
Arguments
Example
.RegisterEvent('OnInternetTransferPercentage',function(sPercentage){...});
number
sPercentage
: the percentage that has been uploaded or downloaded.
DWObject.RegisterEvent('OnInternetTransferPercentage', function(sPercentage) {
console.log(sPercentage);
});
155
Usage notes
Availability
v5.0+
156
Advanced Scan
Methods
CancelAllPendingTransfers()
CloseSourceManager()
CloseWorkingProcess()
FeedPage()
GetCustomDSData()
GetCustomDSDataEx()
GetDeviceType()
GetSourceNameItems()
OpenSourceManager()
ResetImageLayout()
RewindPage()
SetCustomDSData()
SetCustomDSDataEx()
SetFileXferInfo()
SetImageLayout()
Brightness
Contrast
CurrentSourceName
DataSourceStatus
DefaultSourceName
Duplex
IfAutoBright
IfAutoDiscardBlankpages
IfAutoFeed
IfAutomaticBorderDetection
IfAutomaticDeskew
IfAutoScan
IfFeederLoaded
IfPaperDetectable
IfShowIndicator
IfUIControllable
IfUseTwainDSM
PendingXfers
PixelFlavor
TransferMode
Unit
OnPreTransfer
OnSourceUIClose
Properties
XferCount
Events
OnPreAllTransfers
Methods
CancelAllPendingTransfers()
Cancels all pending transfers.
Syntax
.CancelAllPendingTransfers();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method is only valid in the events
157
OnPreAllTransfers
,
OnPreTransfer
and
OnPostTransfer
.
CloseSourceManager()
Closes and unloads Data Source Manager.
Syntax
.CloseSourceManager();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
If this method is not called explicitly by the application, it'll be called automatically when the
browser or tab closes.
CloseWorkingProcess()
Closes the scanning process to release resources on the machine.
Syntax
.CloseWorkingProcess();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v11.2
✓ | v11.2
✓ | v11.2
✓ | v11.2
✓ | v12.1
In the HTML5 edition, Dynamic Web TWAIN uses a separate process to communicate with the
scanners. When it's not scanning, you can choose to close this process to release the
resources (CPU, memory, etc.) used on the machine.
FeedPage()
Ejects the current page and begins scanning the next page in the document feeder.
Syntax
.FeedPage();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Use this method after
OpenSource()
is called and make sure IfFeederEnabled is
GetCustomDSData()
158
true
.
Gets custom DS data and saves the data in a specified file.
Syntax
.GetCustomDSData(fileName);
Parameters
string
Return
value
boolean
Availability
Usage
notes
filename
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✗
✗
The path of the file used for storing custom DS data. For example
DWObject.GetCustomDSData("C:\\customDSData");
GetCustomDSDataEx()
Gets custom DS data and returns it in a base64 encoded string.
Syntax
.GetCustomDSDataEx();
Availability
Return
value
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✗
✗
A base64 encoded string which represents the custom DS data.
GetDeviceType()
Retrieve the device type of the currently selected Data Source, it might be a scanner, a web camera, etc.
Syntax
.GetDeviceType();
Parameters
None
Return
value
number
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✗
✗
Please find below all available numbers and the descriptions:
0: Failed, please check ErrorString for details.
1: Digital Camera
2: Flatbed-only scanner
3: Flatbed, feeder, auto feed
4: Feeder-only scanner, auto feed
5: Flatbed, feeder, without auto feed
6: Feeder-only scanner, without auto feed
7: Webcam
GetSourceNameItems()
Gets the name of a Data Source by its index in Data Source Manager Source list.
159
Syntax
.GetSourceNameItems(short index);
Parameters
The index of a Data Source in Data Source Manager Source list. For example
short index
DWObject.GetSourceNameItems(0);
Return
value
Availability
Usage
notes
string
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This method replaces
SourceNameItems
in old versions of Dynamic Web TWAIN.
OpenSourceManager()
Loads and opens Data Source Manager.
Syntax
.OpenSourceManager();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
If application identification information needs to be set, it should be set before
OpenSourceManager().
Dynamic Web TWAIN has built-in Wizard Mode. With Wizard Mode, OpenSourceManager() is
called automatically when needed by methods like EnableSource() or SelectSource().
ResetImageLayout()
Reset the image layout in the Data Source back to default.
Syntax
.ResetImageLayout();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
To set the image layout manually, you can use SetImageLayout().
RewindPage()
If IfFeederEnabled property is
true
, the Source will return the current page to the input area and return the last
160
page from the output area into the acquisition area.
Syntax
.RewindPage();
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Use this method after
OpenSource()
method and make sure IfFeederEnabled property is
true
.
SetCustomDSData()
Sets custom DS data to be used for scanning, the data is stored in a file. Custom DS data means a specific
scanning profile.
Syntax
.SetCustomDSData(string fileName);
Parameters
string
Return
value
boolean
Availability
Usage
notes
filename
: The absolute path of the file where the custom Data Source data is stored.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✗
✗
If you want to get custom DS data and save the data in a local file, you can check
GetCustomDSData() method or GetCustomDSDataEx() method.
SetCustomDSDataEx()
Sets custom DS data to be used for scanning, the input string is base64 encoded. Custom DS data means a
specific scanning profile.
Syntax
.SetCustomDSDataEx(string strBase64);
Parameters
string
Return
value
boolean
Availability
Usage
notes
strBase64
: The input string which is base64 encoded.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✗
✗
If you want to get custom DS data and save the data in a local file, you can check
GetCustomDSData() method or GetCustomDSDataEx() method.
SetFileXferInfo()
Sets the absolute file name (including its path) and file format to be used in File Transfer Mode. Note that this
161
method is valid only in File Transfer Mode. In File Transfer Mode, the image is transferred to the designated
location on the disk directly instead of Dynamic Web TWAIN.
Syntax
.SetFileXferInfo(string fileName, EnumDWT_FileFormat fileFormat);
string
Parameters
Return
value
boolean
DWObject.OpenSource();
DWObject.TransferMode = EnumDWT_TransferMode.TWSX_FILE;
if(DWObject.TransferMode == EnumDWT_TransferMode.TWSX_FILE){
if(DWObject.SetFileXferInfo("C:\\Temp\\WebTWAIN<>.bmp",
EnumDWT_FileFormat.TWFF_BMP)){
DWObject.IfShowUI = true;
DWObject.AcquireImage();
}
}
Example
Availability
Usage
notes
fileName
The name of the file to be used in the transfer. For example: "C:\\webtwain.jpg". When you write
the name like this string + %d + string, then when you scan multiple files, the name will
automatically change. For example: "C:\\webtwain" + <> + ".jpg" will result in
"C:\\webtwain0.jpg","C:\\webtwain1.jpg", "C:\\webtwain2.jpg", etc. By doing this, you are now
able to scan multiple files to the disk.
EnumDWT_FileFormat fileFormat : for all available values, please check this page
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Make sure the format you set is supported by the Data Source (your scanner).
SetImageLayout()
Sets the left, top, right, and bottom sides of the image layout rectangle for the current Data Source. In other
words, sets which area should be scanned. The image layout rectangle defines what portion of the Data
Source's scanning area is acquired. Note that you should set Unit property before using this method.
Syntax
Parameters
.SetImageLayout(left, top, right, bottom);
left
number
top
number
number
Return
value
Example
Availability
: specifies the left side of the image layout rectangle .
: specifies the top side of the image layout rectangle .
right : specifies the right side of the image layout rectangle .
bottom : specifies the bottom side of the image layout rectangle .
number
boolean
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.IfShowUI = false;
DWObject.Unit=EnumDWT_UnitType.TWUN_PIXELS;
DWObject.SetImageLayout(50, 50, 100, 100);
DWObject.AcquireImage();
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
162
Usage
notes
This method uses Capability Negotiation underneath, thus is device-dependent. If a device
doesn't support the customization of the scan area, this method might not work correctly.
Properties
Brightness
Returns or sets Brightness to be used for scanning by the Data Source.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✓ | 12.1
Set this property after OpenSource() and before
Typically the value to be set is -1000 ~ 1000.
AcquireImage()
.
Contrast
Returns or sets Contrast to be used for scanning by the Data Source.
Type
number
Accessors
Get Set
Usage
notes
Availability
Usage
notes
Set this property after OpenSource() and before
Typically the value to be set is -1000 ~ 1000.
AcquireImage()
.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✓ | 12.1
Set this property after OpenSource() and before
Typically the value to be set is -1000 ~ 1000.
AcquireImage()
.
CurrentSourceName
Returns the device name of current source. This is a read-only property.
Type
string
Accessors
Get
Usage
notes
Availability
If no source is currently selected, CurrentSourceName property returns "".
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
163
Usage
notes
If no source is currently selected, CurrentSourceName property returns "".
DataSourceStatus
Returns a value which indicates the Data Source status. This is a read-only property.
Type
number
Accessors
Get
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Allowed values :
0: The Data Source is closed
1: The Data Source is opened
2: The Data Source is enabled
3: The Data Source is acquiring images.
DefaultSourceName
Returns the name of the default source. This is a read-only property.
Type
string
Accessors
Get
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Duplex
Returns whether the source supports duplex. If yes, it further returns the level of duplex the Source supports
(one pass or two pass duplex). This is a read-only property.
Type
EnumDWT_DUPLEX (int)
Accessors
Get
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Available values.
TWDX_NONE (0): duplex is not supported TWDX_1PASSDUPLEX (1): 1-pass duplex
TWDX_2PASSDUPLEX (2): 2-pass duplex
IfAutoBright
Returns or sets whether to enable the Source's Auto-brightness feature.
Type
boolean
Accessors
Get Set
164
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
The default value is
false
.
IfAutoDiscardBlankpages
Returns or sets whether the Data Source (the scanner) discards blank images during scanning.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✗
✗
The property works only if the device and its driver supports discarding blank pages. You can
find whether your device supports this capbility from its user manual. Or, you can use the builtin methods of Dynamic Web TWAIN to detect blank images: IsBlankImageExpress.
IfAutoFeed
Returns or sets whether to enable the Data Source's automatic document feeding process.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✗
✗
If the value of this property is true , the Data Source will automatically feed the next page from
the document feeder after the previous page is acquired.
IfAutomaticBorderDetection
Returns or sets whether to enable the Data Source's automatic border detection feature.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✗
✗
The property works only if the device and its driver support detecting the border automatically.
You can find whether your device supports this capbility from its user manual.
If the value of this property is true , the Data Source (scanner) will automatically detect the
border of the document on the flatbed and will only scan the area within the border.
165
IfAutomaticDeskew
Returns or sets whether to enable the Data Source's automatic skew correction feature.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v7.0
✓ | v10.0
✓ | v11.0
✗
✗
The property works only if the device and its driver supports deskewing automatically. You can
find whether your device supports this capbility from its user manual.
If this property is set to true , the Data Source (scanner) will automatically correct the skew of
the scanned images.
IfAutoScan
Returns or sets whether to enable the Data Source's automatic document scanning process.
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Please Make sure IfFeederEnabled property is
true
before use this property.
IfFeederLoaded
Returns whether or not there are documents loaded in the Data Source's feeder when IfFeederEnabled and
IfPaperDetectable are true . This is a read-only property.
Type
boolean
Accessors
Get
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Make sure
IfPaperDetectable
is
true
before use this property.
IfPaperDetectable
Returns whether the Source has a paper sensor that can detect documents on the ADF or Flatbed. This is a
read-only property.
Type
boolean
Accessors
Get
166
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
IfShowIndicator
Returns or sets whether the Source displays a progress indicator during acquisition and transfer. This property
works only when IfShowUI is set to false .
Type
boolean
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
If you set both IfShowUI and IfShowIndicator to false , The progress indicator will not appear;
If you set IfShowUI to false but IfShowIndicator to true , The progress indicator will appear;
If you set IfShowUI to true , this property will no longer work. The progress indicator always
appears.
IfUIControllable
Returns whether the Data Source supports acquisitions with the UI (User Interface) disabled. ' false ' indicates
that the Data Source only supports acquisitions with the UI enabled. This is a read-only property.
Type
boolean
Accessors
Get
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Set this property after OpenSource() and before
Typically the value to be set is -1000 ~ 1000.
AcquireImage()
.
IfUseTwainDSM
Returns or sets whether the new TWAIN DSM (Data Source Manager) is used for acquisitions. The new TWAIN
DSM is a .dll file called 'TWAINDSM.dll'. By default, the old DSM is used ('twain_32.dll' under 'C:\Windows').
Type
boolean
Accessors
Get Set
Usage
notes
Availability
Set this property before any TWAIN related methods or properties are used.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.2
✓ | v10.0
✓ | v11.0
✗
✗
167
PendingXfers
Returns the number of transfers the Data Source is ready to supply upon demand. This is a read-only property.
Type
Short
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
This property is only valid in the event OnPostTransfer.
The Data Source returns -1 if it is not sure how many transfers are pending. Scanners with ADF
(Automatic Document Feeder) typically return -1 if the current image is not the last one.
PixelFlavor
Returns or sets the pixel flavor to be used for acquiring images.
Type
Short
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
Available values:
0: Chocolate. Zero pixel represents darkest shade
1: Vanilla. Zero pixel represents lightest shade.
TransferMode
Returns or sets the Data Source's transfer mode.
enumTW_TRANSFERMODE
Type
Accessors
Availability
Usage
notes
TWSX_NATIVE: NATIVE mode is the default mode. In this mode, the whole image is transfered
in a single memory block.
TWSX_FILE: DISK FILE mode is not required by TWAIN specification. In this mode, the image
is transfered to a specified file directly. The disk file mode is ideal when transferring large
images that might encounter memory limitations with Native mode.
TWSX_MEMORY: MEMORY mode is also required by TWAIN, like NATIVE mode. Although
this mode is the most complex, Dynamic TWAIN handles the tranfer details, making it as simple
as NATIVE mode.
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✗
The default value for TransferMode is TWSX_NATIVE (0).
For DISK FILE mode - TWSX_FILE (1), since it is not required by TWAIN, the application needs
to make sure it is supported by the current Source. One way to do this is to check the
TransferMode property after OpenSource() and see if it is still TWSX_FILE (1).
168
Unit
Returns or sets the unit of measure for all quantities.
Type
EnumDWT_UnitType (short)
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✗
Available values:
EnumDWT_UnitType.TWUN_INCHES: inches(Default)
EnumDWT_UnitType.TWUN_CENTIMETERS: centimeters
EnumDWT_UnitType.TWUN_PICAS: picas
EnumDWT_UnitType.TWUN_POINTS: points
EnumDWT_UnitType.TWUN_TWIPS: twips
EnumDWT_UnitType.TWUN_PIXELS: pixels
EnumDWT_UnitType.TWUN_MILLIMETERS: millimeters
XferCount
Returns and sets the number of images your application is willing to accept.
Type
Short
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✗
✓ | v12.1
Allowed values are between -1 and 215. '-1' indicate multiple images.
Events
OnPreAllTransfers
This event is triggered when all images are scanned and ready to be transferred.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnPreAllTransfers',function(){...});
None
DWObject.RegisterEvent('OnPreAllTransfers', function() {
DWObject.CancelAllPendingTransfers();
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
169
Usage
notes
Multiple transfers may occur when ADF(Auto Document Feeder) is enabled or there are more
than one frames in a page. In those cases, OnPreTransfer is triggered multiple times but
OnPreAllTransfers is triggerred just once. This is the place to call CancelAllPendingTransfers() .
OnPreTransfer
This event is triggered when a page has been scanned and ready to be transferred.
Syntax
Arguments
Example
Usage
notes
Availability
Usage
notes
.RegisterEvent('OnPreTransfer',function(){...});
None
DWObject.RegisterEvent('OnPreTransfer', function() {
DWObject.CancelAllPendingTransfers();
});
This is where to check PendingXFERs, ImageLayoutDocumentNumber ImageLayoutFrameLeft,
ImageLayoutFrameTop, ImageLayoutFrameRight, ImageLayoutFrameBottom,
ImageLayoutPageNumber, ImageLayoutFrameNumber.
This is also the place to call CancelAllPendingTransfers().
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.2
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
This is where to check PendingXFERs, ImageLayoutDocumentNumber ImageLayoutFrameLeft,
ImageLayoutFrameTop, ImageLayoutFrameRight, ImageLayoutFrameBottom,
ImageLayoutPageNumber, ImageLayoutFrameNumber.
This is also the place to call CancelAllPendingTransfers().
OnSourceUIClose
This event is triggered when the User Interface of the scanner source is closed manually by the user.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnSourceUIClose',function(){...});
None
DWObject.RegisterEvent('OnSourceUIClose', function() {
...;
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0.1
✓ | v10.0
✓ | v11.0
✗
✗
170
Capability Negotiation
Methods
CapGet()
CapGetCurrent()
CapGetDefault()
CapGetFrameBottom()
CapGetFrameLeft()
CapGetFrameRight()
CapGetFrameTop()
CapGetHelp()
CapGetLabel()
CapGetLabels()
CapIfSupported()
CapReset()
CapSet()
CapSetFrame()
GetCapItems()
GetCapItemsString()
SetCapItems()
SetCapItemsString()
Capability
CapCurrentIndex
CapCurrentValue
CapDefaultIndex
CapDefaultValue
CapMaxValue
CapMinValue
CapNumItems
CapMinValue
CapStepSize
CapType
CapValue
CapValueString
CapValueType
Properties
Code example
function getACapability(capability){// Specify a Capability with capability
STR_CapValueType = [
'TWTY_INT8', 'TWTY_INT16', 'TWTY_INT32', 'TWTY_UINT8', 'TWTY_UINT16', 'TWTY_int', 'TWTY_BOOL',
'TWTY_FIX32', 'TWTY_FRAME', 'TWTY_STR32', 'TWTY_STR64', 'TWTY_STR128', 'TWTY_STR255'];
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.Capability = capability; // Specify a Capability
DWObject.CapGet();
var i, nCapType = DWObject.CapType;
switch (nCapType) {
case EnumDWT_CapType.TWON_ARRAY/*3*/:
console.log('Available Values:');
for (i = 0; i < DWObject.CapNumItems; i++) {
if (DWObject.CapValueType > 8) /* >8 is string*/
/*STR*/console.log( DWObject.GetCapItemsString(i));
else
/*NUM*/console.log(DWObject.GetCapItems(i));
}
break;
case EnumDWT_CapType.TWON_ENUMERATION/*4*/:
console.log('Available Values:');
for (i = 0; i < DWObject.CapNumItems; i++) {
if (DWObject.CapValueType > 8)
/*STR*/console.log(DWObject.GetCapItemsString(i));
else
/*NUM*/console.log(DWObject.GetCapItems(i));
}
if (DWObject.CapValueType > 8) {
171
console.log('Current Index = ' + DWObject.CapCurrentIndex + ' (Value: ' + DWObject.GetCapItemsString(
DWObject.CapCurrentIndex) + ')');
console.log('Default Index = ' + DWObject.CapDefaultIndex + ' (Value: ' + DWObject.GetCapItemsString(
DWObject.CapDefaultIndex) + ')');
}
else {
console.log('Current Index = ' + DWObject.CapCurrentIndex + ' (Value: ' + DWObject.GetCapItems(DWObje
ct.CapCurrentIndex) + ')');
console.log('Default Index = ' + DWObject.CapDefaultIndex + ' (Value: ' + DWObject.GetCapItems(DWObje
ct.CapDefaultIndex) + ')');
}
break;
case EnumDWT_CapType.TWON_ONEVALUE/*5*/:
var tempValue = '';
if (DWObject.CapValueType > 8)
/*STR*/tempValue = DWObject.CapValueString;
else
/*NUM*/tempValue = DWObject.CapValue;
/*
* Special for BOOL
*/
if (DWObject.CapValueType == EnumDWT_CapValueType.TWTY_BOOL) {
if (tempValue == 0) tempValue = 'FALSE'; else tempValue = 'TRUE';
}
console.log('ItemType = ' + STR_CapValueType[DWObject.CapValueType]);
console.log('Value = ' + tempValue);
break;
case EnumDWT_CapType.TWON_RANGE/*6*/:
console.log('ItemType = ' + STR_CapValueType[DWObject.CapValueType]);
console.log('Min = ' + DWObject.CapMinValue);
console.log('Max = ' + DWObject.CapMaxValue);
console.log('StepSize = ' + DWObject.CapStepSize);
console.log('Default = ' + DWObject.CapDefaultValue);
console.log('Current = ' + DWObject.CapCurrentValue);
break;
default: console.log('This Capability is not supported');
}
var supportLevel = [];
if (DWObject.CapIfSupported(EnumDWT_MessageType.TWQC_GET)) supportLevel.push('GET');/*TWQC_GET*/
if (DWObject.CapIfSupported(EnumDWT_MessageType.TWQC_SET)) supportLevel.push('SET');/*TWQC_SET*/
if (DWObject.CapIfSupported(EnumDWT_MessageType.TWQC_RESET)) supportLevel.push('RESET');/*TWQC_RESET*/
if (supportLevel.length > 0) {
console.log('Supported operations: ');
console.log(supportLevel.join(' / '));
}
}
// Set A Capability
function setACapability(capability, valueToSet, indexToSet) {
var tempValue = '', i, valueToShow;
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.Capability = capability;
DWObject.CapGet();
nCapType = DWObject.CapType;
switch (nCapType) {
case EnumDWT_CapType.TWON_ARRAY/*3*/:
console.log('Setting an Array is not implemented');
break;
case EnumDWT_CapType.TWON_ENUMERATION/*4*/:
DWObject.CapValue = valueToSet;
DWObject.CapCurrentIndex = indexToSet;
DWObject.CapSet();
console.log('CapSet: ' + DWObject.ErrorString);
DWObject.CapGet();
console.log('After Setting:');
172
if (DWObject.CapValueType > 8) {
console.log('Current Index = ' + DWObject.CapCurrentIndex + ' (Value: ' + DWObject.GetCapItemsString(
DWObject.CapCurrentIndex) + ')');
console.log('Default Index = ' + DWObject.CapDefaultIndex + ' (Value: ' + DWObject.GetCapItemsString(
DWObject.CapDefaultIndex) + ')');
}
else {
console.log('Current Index = ' + DWObject.CapCurrentIndex + ' (Value: ' + DWObject.GetCapItems(DWObje
ct.CapCurrentIndex) + ')');
console.log('Default Index = ' + DWObject.CapDefaultIndex + ' (Value: ' + DWObject.GetCapItems(DWObje
ct.CapDefaultIndex) + ')');
}
break;
case EnumDWT_CapType.TWON_ONEVALUE/*5*/:
DWObject.CapValue = valueToSet;
DWObject.CapSet();
console.log('CapSet: ' + DWObject.ErrorString);
DWObject.CapGet();
console.log('Value after setting: ' + DWObject.CapValue);
break;
case EnumDWT_CapType.TWON_RANGE/*6*/:
DWObject.CapCurrentValue = valueToSet;
DWObject.CapSet();
console.log('CapSet: ' + DWObject.ErrorString);
DWObject.CapGet();
console.log('Value after setting: ' + DWObject.CapCurrentValue);
break;
default: console.log('This Capability is not supported');
}
}
Methods
CapGet()
Gets the detailed information of the capability specified by (Capability)[#Capability].
Syntax
.
CapGet()
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
H5(macOS/ICA)
H5(Linux)
CapGetCurrent()
Gets the current value of the capability specified by (Capability)[#Capability].
Syntax
.CapGetCurrent()
Parameters
None
Return
value
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
173
Availability
Usage
notes
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Currently this method is only valid in Windows & Mac.
CapGetDefault()
Gets the default value of the capability specified by (Capability)[#Capability].
Syntax
.CapGetDefault()
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
CapGetFrameBottom()
Returns the value of the bottom edge of the specified frame.
Syntax
.CapGetFrameBottom(index)
Parameters
number
Return
value
number
Availability
Usage
notes
optionalAsyncFailureFunc
: specifies which frame to check. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The default Unit is assumed to be "inches" unless it has been otherwise negotiated between the
application and Data Source.
CapGetFrameLeft()
Returns the value of the Left edge of the specified frame.
Syntax
.CapGetFrameLeft(index)
Parameters
number
Return
value
number
Availability
Usage
notes
optionalAsyncFailureFunc
: specifies which frame to check. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The default Unit is assumed to be "inches" unless it has been otherwise negotiated between the
application and Data Source.
174
CapGetFrameLeft()
Returns the value of the Left edge of the specified frame.
Syntax
.CapGetFrameLeft(index)
Parameters
number
Return
value
number
Availability
Usage
notes
optionalAsyncFailureFunc
: specifies which frame to check. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The default Unit is assumed to be "inches" unless it has been otherwise negotiated between the
application and Data Source.
CapGetFrameRight()
Returns the value of the Right edge of the specified frame.
Syntax
.CapGetFrameRight(index)
Parameters
number
Return
value
number
Availability
Usage
notes
optionalAsyncFailureFunc
: specifies which frame to check. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The default Unit is assumed to be "inches" unless it has been otherwise negotiated between the
application and Data Source.
CapGetFrameTop()
Returns the value of the Top edge of the specified frame.
Syntax
.CapGetFrameTop(index)
Parameters
number
Return
value
number
Availability
Usage
notes
optionalAsyncFailureFunc
: specifies which frame to check. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The default Unit is assumed to be "inches" unless it has been otherwise negotiated between the
application and Data Source.
CapGetHelp()
175
Get help information of the capability specified by Capability.
Syntax
.CapGetHelp(index)
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Call this method after calling
CapGet()
method.
CapGetLabel()
Get Label information of the capability specified by Capability.
Syntax
.CapGetLabel()
Parameters
None
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Call this method after calling
CapGet()
method.
CapGetLabels()
Get Labels information of the capability specified by Capability.
Syntax
.CapGetLabels()
Parameters
None
Return
value
boolean
Example
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Call this method after calling
CapGet()
method.
CapIfSupported()
Returns the Data Source's support level of the capability specified by Capability.
176
Syntax
.CapIfSupported(messageType)
Parameters
Return
value
boolean
Availability
messageType
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
CapReset()
Resets the the capability specified by Capability.
Syntax
.CapReset()
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
CapSet()
Sets the the capability specified by Capability.
Syntax
.
CapSet()
Parameters
None
Return
value
boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
CapSetFrame()
Sets the values of the specified frame.
Syntax
.CapSetFrame(index, left, top, right, bottom);
number
number
Parameters
number
number
number
Return
value
index: specifies which frame to set. The index is 0-based.
left: specifies the value of the left edge of the specified frame.
top: specifies the value of the top edge of the specified frame.
right: specifies the value of the right edge of the specified frame.
bottom: specifies the value of the bottom edge of the specified frame.
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
177
H5(macOS/ICA)
H5(Linux)
Availability
Usage
notes
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
The frame is specified by values in a specific unit. The default unit is "inches" and can be
configured by the property Unit
GetCapItems()
Gets the cap item value of the capability specified by Capability.
Syntax
.GetCapItems(index)
Parameters
number
Return
value
string
Availability
Usage
notes
index
:specifies the index of a cap item. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Valid only when CapType is
TWON_ARRAY (3)
or
TWON_ENUMERATION (4)
.
GetCapItemsString()
Gets the cap item value of the capability specified by Capability.
Syntax
.GetCapItemsString(index)
Parameters
number
Return
value
string
Availability
Usage
notes
index
:specifies the index of a cap item. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Valid only when CapType is
TWON_ARRAY (3)
or
TWON_ENUMERATION (4)
.
SetCapItems()
Sets the cap item value of the capability specified by Capability.
Syntax
Parameters
Return
value
Availability
.SetCapItems(index, newVal)
number
index
:specifies the index of a cap item. The index is 0-based.
number
newVal
:specifies
the value.
string
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
178
Usage
notes
Valid only when CapType is
TWON_ARRAY (3)
or
TWON_ENUMERATION (4)
.
SetCapItemsString()
Sets the cap item value of the capability specified by Capability.
Syntax
Parameters
Return
value
.SetCapItemsString(index, newVal)
number
:specifies the index of a cap item. The index is 0-based.
number
newVal
:specifies
None
Availability
Usage
notes
index
the value.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Valid only when CapType is
TWON_ARRAY (3)
or
TWON_ENUMERATION (4)
.
Properties
Capability
Specifies the capabiltiy to be negotiated with the Data Source.
Type
EnumDWT_Cap (int)
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
CapCurrentIndex
Returns the index (0-based) of the current value of a capability.
Then you can find the current value by this index in GetCapItemsString() or
Type
number
Accessors
Get Set
Availability
Usage
notes
GetCapItemsCapValueType()
.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of
179
TWON_ENUMERATION (4)
.
CapCurrentValue
Returns the current value of a capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of
TWON_RANGE (6)
.
CapDefaultIndex
Returns the index (0-based, read-only) of the default value of a capability. Then you can find the default value
by this index in GetCapItemsString or GetCapItems .
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of TWON_ENUMERATION (4) .
Default value reflects the Data Source's power-on value. It can NOT be set.
CapDefaultValue
Returns the default value of a capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of TWON_RANGE (6) .
Default value reflects the Data Source's power-on value. It can NOT be set.
CapMaxValue
Returns the maximum value of a capability.
Type
number
Accessors
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
180
H5(macOS/ICA)
H5(Linux)
Availability
Usage
notes
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of TWON_RANGE (6) .
Default value reflects the Data Source's power-on value. It can NOT be set.
CapMinValue
Returns the Minimum value of a capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Valid only when the capability has the CapType of TWON_RANGE (6) .
Default value reflects the Data Source's power-on value. It can NOT be set.
CapNumItems
Returns or sets the number of values of capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() .
Set this property before calling CapSet() .
Valid only when the capability has the CapType of
TWON_ARRAY (3)
or
TWON_ENUMERATION (4)
.
CapStepSize
Returns or sets the step size of the values of a capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Check this property after calling CapGet() . Set this property before calling
Valid only when the capability has the CapType of TWON_RANGE (6) .
CapType
181
CapSet()
.
Returns or sets the type of capability container used to exchange capability information between application
and source.
Type
EnumDWT_CapType (number)
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Set CapType when you try to set a capability with
capability by CapGet() .
CapSet()
. Check CapType after you read a
CapValue
Returns or sets the value of the capability specified by Capability.
Type
number
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
Set CapType when you try to set a capability with CapSet() . Check CapType after you read a
capability by CapGet() .
To check a capability, read this property after calling CapGet() method. When setting a
capability, set this property before calling CapSet() to actually set the value.
Valid only when the capability has the CapType of TWON_ONEVALUE (5) .
Use this property to get/set a capability that has a value type of number or even Boolean (1
means 'true', 0 means 'false'). For string type, use CapValueString instead.
CapValueString
Returns or sets the string value of a capability specified by Capability.
Type
string
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
To check a capability, read this property after calling CapGet() method. When setting a
capability, set this property before calling CapSet() to actually set the value.
Valid only when the capability has the CapType of TWON_ONEVALUE (5) .
Use this property to get/set a capability that has a value type of string , otherwise, use
CapValue instead.
CapValueType
Returns or sets the value type for reading the value of a capability.
182
Type
Accessors
Availability
Usage
notes
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v11.0
✗
✗
When you try to read a capability value, check CapValueType after you call CapGet() .
Valid only when the capability has the CapType of TWON_ONEVALUE (5) .
When you try to write a capability value, set CapValueType before you call CapSet() .
183
Encode & Decode
Methods
ClearTiffCustomTag()
ConvertToBase64()
ConvertToBlob()
IfOpenImageWithGDIPlus
IfTiffMultiPage
JPEGQuality
PDFAuthor
PDFCompressionType
PDFCreationDate
PDFCreator
PDFKeywords
PDFModifiedDate
PDFProducer
PDFSubject
PDFTitle
PDFVersion
TIFFCompressionType
SetTiffCustomTag()
Properties
Methods
ClearTiffCustomTag()
Clears the content of all custom tiff tags.
Syntax
.ClearTiffCustomTag()
Parameters
None
Return
value
None
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
ConvertToBase64()
Converts the images of specified indices in buffer to a base64 string.
Syntax
.ConvertToBase64(indices, enumImageType, asyncSuccessFunc, asyncFailureFunc);
number
indices
: specifies the indices of images in buffer. The index is 0-based.
enumImageType : specifies the format.
EnumDWT_ImageType
Numeric
Value
Type
Parameters
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
184
IT_PDF
4
OnSuccess function
asyncSuccessFunc
: callback function triggered when the file is converted
asyncFailureFunc
: callback function triggered when the file fails to be
successfully.
OnFailure function
converted.
Base64Result is returned in the callback asyncSuccessFunc()
Methods available in Base64Result object
Data
Type
Return
value
Method Name
Description
number
getLength()
Returns the length of the Base64 String
string
getData(offset,
length)
Returns the string containing the extracted part of the
Base64 string. The parameter offset means the
position where to start the extraction. The parameter
length means the number of characters to extract.
string
getMD5()
Returns the MD5 of the Base64 String.
The result string returned from getData is the pure base64 string with no extra info. For
example, "/9j/4AAQSkZJRgABA..."
To use the string in most circumstances, you need to add extra info like
data:image/png;base64,"/9j/4AAQSkZJRgABA..."
Because this method is async only, the returned value doesn't mean if the convert succeeds or
not. When conversion fails, check ErrorCode or ErrorString for error information.
DWObject.ConvertToBase64 ([1,3], EnumDWT_ImageType.IT_PDF, asyncSuccessFunc,
asyncFailureFunc);
function asyncSuccessFunc (result) {
var length=result.getLength();
console.log(result.getData(0,length));
console.log(result);
}
function asyncFailureFunc (errorCode, errorString) {
alert("ErrorCode: "+errorCode +"\r"+"ErrorString:"+ errorString);
}
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v12.0
✓ | v12.0
✓ | v12.0
✓ | v12.1
ConvertToBlob()
Converts the images of specified indices in buffer to a blob.
Syntax
.ConvertToBlob(indices, enumImageType, asyncSuccessFunc, asyncFailureFunc);
Number[]
indices
EnumDWT_ImageType
: specifies the indices of images in buffer. The index is 0-based.
enumImageType : specifies the format.
Type
Parameters
Numeric Value
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
185
IT_PDF
4
OnSuccess function
asyncSuccessFunc
: callback function triggered when the file is converted
asyncFailureFunc
: callback function triggered when the file fails to be
successfully.
OnFailure function
converted.
Return
value
Blob is returned in the callback asyncSuccessFunc()
Because this method is asynchronous, whether there is a returned value doesn't mean the
success/failure of the operation. When the conversion fails, check ErrorCode or ErrorString for
error information.
DWObject.ConvertToBlob ([1,3], EnumDWT_ImageType.IT_PDF, asyncSuccessFunc,
asyncFailureFunc);
function asyncSuccessFunc (result) {
console.log(result.size);
}
function asyncFailureFunc (errorCode, errorString) {
alert("ErrorCode: "+errorCode +"\r"+"ErrorString:"+ errorString);
}
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v13.0
✓ | v13.0
✓ | v13.0
✓ | v13.0
SetTiffCustomTag()
Sets a custom tiff tag (up to 32 tags). The string to be set in a tag can be base64 encoded.
Syntax
.SetTiffCustomTag(tagIdentifier, content, UseBase64Encoding);
Parameters
: specifies the identify number of custom tag in the tiff image.
: the string to be set for this tag. The string will be written to the .tiff file when
you save/upload it. If the string is base64 encoded, it'll be decoded when creating the TIFF file.
Boolean
UseBase64Encoding : specifies whether the content is base64 encoded.
Return
value
number
tagIdentifier
string
content
boolean
DWObject.ClearTiffCustomTag();
DWObject.SetTiffCustomTag(700, "Custom Tiff Tag Value", true);
DWObject.SaveAsTIFF("C:\\DWT.tiff", 0);
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
10.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Properties
IfOpenImageWithGDIPlus
Returns or sets whether to use GDI+ library to decode images when loading them.
Type
boolean
Accessors
Get Set
186
Usage
notes
Availability
Windows GDI+ is a class-based API for C/C++ programmers. It enables applications to use
graphics and formatted text on both the video display and the printer. Applications based on the
Microsoft Win32 API do not access graphics hardware directly. Instead, GDI+ interacts with
device drivers on behalf of applications. GDI+ is also supported by Microsoft Win64.
With GDI+, you can load some images which are not supported otherwise. However, please
note that GDI+ library might be different on different OS. So an image might load on Win 7 but
not Win XP.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✗
✗
✗
IfTiffMultiPage
Return or sets whether it's allowed to save many images as one TIFF file.
Type
boolean
Accessors
Get Set
Usage
notes
Availability
When you save a new image in the same name of an existing TIFF file
If this property is true, the new image will be added to the existing file
If this property is false, the new image will replace the existing file
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v3.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
JPEGQuality
Returns or sets the quality of JPEG files or JPEG-encoded PDF files.
Type
number
Accessors
Get Set
The default value of JPEGQuality property is 80.
Usage
notes
Availability
The valid range is 0-100. The higher the JPEGQuality property, the better the quality and the
bigger the size of the file.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
H5(macOS/ICA)
H5(Linux)
TIFFCompressionType
Returns or sets the compression type for TIFF files.
Type
number
Accessors
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
187
Availability
✓|
v4.0
✓ | v10.0
Allowed
Values
✓ | v11.0
EnumDWT_TIFFCompressionType
✓ | v12.1
Description
Supported
image
format
0
TIFF_AUTO
Auto mode
1, 4, 8, 24
bit
1
TIFF_NONE
Dump mode
1, 4, 8, 24
bit
2
TIFF_RLE
CCITT
modified
Huffman RLE
1 bit
TIFF_FAX3
CCITT Group
3 fax
encoding
1 bit
TIFF_T4
CCITT T.4
(TIFF 6 name)
1 bit
TIFF_FAX4
CCITT Group
4 fax
encoding
1 bit
TIFF_T6
CCITT T.6
(TIFF 6 name)
1 bit
5
TIFF_LZW
Lempel-Ziv &
Welch
1, 4, 8, 24
bit
7
TIFF_JPEG
JPEG
encoding
24 bit
32773
TIFF_PACKBITS
Macintosh
RLE
1, 4, 8, 24
bit
3
4
Usage
notes
✓ | v11.0
When set to TIFF_AUTO (0) , 1-bit images will be compressed in
other bit depth will be compressed in TIFF_LZW (5) .
TIFF_T6 (4)
while images with
When set to TIFF_JPEG (7) , 1-bit images will be compressed in TIFF_T6 (4) , color images or
grey images (8-bit or higher) in TIFF_JPEG (7) standard, and other images by TIFF_LZW (5) .
TIFF_T4 (3)
(4)
and
When
file.
and
TIFF_FAX3 (3)
are two names for the same compression type. So are
TIFF_T6
TIFF_FAX4 (4)
TIFF_JPEG (7)
As of version v14.2,
is used, you can use JPEGQuality to further reduce the size of the TIFF
TIFF_JPEG (7)
and
TIFF_PACKBITS (32773)
are only supported on Windows.
PDFAuthor
Returns or sets the name of the author that creates the PDF document.
Type
string
Accessors
Get Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
188
H5(macOS/ICA)
H5(Linux)
Availability
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFCompressionType
Returns or sets the compression type for PDF files.
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
Allowed
Values
Usage
notes
EnumDWT_PDFCompressionType
Description
Supported
image
format
0
PDF_AUTO
Auto mode
1, 4, 8, 24
bit
1
PDF_FAX3
CCITT Group
3 fax encoding
1 bit
2
PDF_FAX4
CCITT Group
4 fax encoding
1 bit
3
PDF_LZW
Lempel-Ziv &
Welch
1, 4, 8, 24
bit
4
PDF_RLE
CCITT
modified
Huffman RLE
1 bit
5
PDF_JPEG
JPEG
encoding
8, 24 bit
PDFCreationDate
Returns or sets the date when the PDF document is created.
Type
string
Accessors
Get Set
Usage
notes
Availability
The default value is current date.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFCreator
Returns or sets the name of the application that created the original document (used when the PDF document
is converted from another form);
189
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFKeywords
Returns or sets the keywords associated with the PDF document.
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFModifiedDate
Returns or sets the date when the PDF document is last modified.
Type
string
Accessors
Get Set
Usage
notes
Availability
The default value is current date.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFProducer
Returns or sets the name of the application that generated the PDF document.
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFSubject
Returns or sets the subject of the PDF document.
Type
string
Accessors
190
Accessors
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFTitle
Returns or sets the title of the PDF document.
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
PDFVersion
Returns or sets the version number for PDF files.
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v5.0
✓ | v10.0
✓ | v11.0
✓ | v11.0
✓ | v12.1
191
Runtime Information
Methods
GetImageBitDepth()
GetImageHeight()
GetImageSize()
GetImageSizeWithSpecifiedType()
GetImageWidth()
GetImageXResolution()
GetImageYResolution()
GetSelectedImageIndex()
GetSelectedImagesSize()
GetSkewAngle()
GetSkewAngleEx()
IsBlankImageExpress()
Properties
BlankImageCurrentStdDev
BlankImageMaxStdDev
BlankImageThreshold
CurrentImageIndexInBuffer
HowManyImagesInBuffer
ImageLayoutDocumentNumber
ImageLayoutFrameBottom
ImageLayoutFrameLeft
ImageLayoutFrameNumber
ImageLayoutFrameRight
ImageLayoutFrameTop
ImageLayoutPageNumber
ImagePixelType
MagData
MagType
SelectedImagesCount
Methods
GetImageBitDepth()
Returns the pixel bit depth of the selected image.
Syntax
Parameters
.GetImageBitDepth(sImageIndex);
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
number
Return value
If Dynamic Web TWAIN fails to get the pixel bit depth of the image, -1 is returned.
Availability
v6.2+
GetImageHeight()
Returns the height (in pixels) of the selected image.
Syntax
Parameters
.GetImageHeight(sImageIndex);
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
number
Return value
If Dynamic Web TWAIN fails to get the height of the image, -1 is returned.
Availability
v6.2+
GetImageSize()
Calculates the file size of a new image resized from an image of a specified index in buffer.
Syntax
.GetImageSize(sImageIndex, iWidth, iHeight);
192
Parameters
: the index of the image in the buffer. The index is 0-based.
: the width for the new image.
iHeight : the height for the new image.
number
sImageIndex
number
iWidth
number
Return value
number : returns the size in bytes.
If Dynamic Web TWAIN fails to get the size of the image, -1 is returned.
Availability
All versions.
GetImageSizeWithSpecifiedType()
Calculates the file size of a specified image based on its format.
Syntax
Parameters
.GetImageSizeWithSpecifiedType(sImageIndex, sImageType);
number
sImageIndex
EnumDWT_ImageType
: the index of the image in the buffer. The index is 0-based.
: the image format to be used.
sImageType
Return value
number : returns the size in bytes.
If Dynamic Web TWAIN fails to calculate the size, -1 is returned.
Availability
All versions.
GetImageWidth()
Returns the width (in pixels) of the selected image.
Syntax
Parameters
.GetImageWidth(sImageIndex);
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
number
Return value
If Dynamic Web TWAIN fails to get the width of the image, -1 is returned.
Availability
v6.2+
GetImageXResolution()
Returns the horizontal resolution of the specified image.
Syntax
Parameters
.GetImageXResolution(sImageIndex);
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
number
Return value
If Dynamic Web TWAIN fails to get the resolution of the image, -1 is returned.
Availability
v8.0+
GetImageYResolution()
Returns the vertical resolution of the specified image.
Syntax
.GetImageYResolution(sImageIndex);
Parameters
number
Return value
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
Availability
v8.0+
Usage notes
If Dynamic Web TWAIN fails to get the resolution of the image, -1 is returned.
GetSelectedImageIndex()
193
Returns the index of a selected image in the index array of selected images.
Syntax
Parameters
Return value
.GetSelectedImageIndex(selectedIndex);
number
selectedIndex
: the index of the array which holds all the indices of selected
images.
number
Availability
v7.0+
Usage notes
If three images are selected in a 10 image buffer (indexes 0,5,9)
GetSelectedImageIndex(1) = 5; as it is the second image selected.
GetSelectedImagesSize()
Calculates the file size in the specified format for the selected images.
Syntax
Parameters
.GetSelectedImagesSize(imageType);
EnumDWT_ImageType
sImageType
: the image format.
number
Return value
If Dynamic Web TWAIN fails to calculate the size, -1 is returned.
Availability
v6.0+
Usage notes
If the sImageType is IT_TIF or IT_PDF, GetSelectedImagesSize() returns the total size of
the selected images. Otherwise, the method returns the size of the first selected image.
GetSkewAngle()
Returns the skew angle of an image specified by index.
Syntax
.GetSkewAngle(sImageIndex);
Parameters
number
Return value
number
sImageIndex
: the index of the image in the buffer. The index is 0-based.
Availability
v9.0+
Usage notes
This method can be combined with a rotation API to correct a skewed document.
GetSkewAngleEx()
Returns the skew angle of a rectangular portion of an image specified by index.
Syntax
Parameters
.GetSkewAngleEx(sImageIndex, left, top, right, bottom);
sImageIndex
number
left
number
number
number
Return value
Availability
: the index of the image in the buffer. The index is 0-based.
: the x-coordinate of the upper-left corner of the rectangle.
top : the y-coordinate of the upper-left corner of the rectangle.
right : the x-coordinate of the lower-right corner of the rectangle.
bottom : the y-coordinate of the lower-right corner of the rectangle.
number
number
v9.0+
IsBlankImageExpress()
Detects whether the image of a specified index is blank.
Syntax
.IsBlankImageExpress(sImageIndex);
194
Parameters
number
sImageIndex
Return value
boolean
: 'true' means the image is blank.
Availability
: the index of the image in the buffer. The index is 0-based.
v10.0+
Properties
BlankImageCurrentStdDev
Returns the deviation of the pixels in the current image. This is a read-only property.
Type
number
Accessors
Get
Availability
v7.0+
Usage notes
This property is only valid after
IsBlankImageExpress
is called.
BlankImageMaxStdDev
Returns or sets the deviation of the pixels in an image.
Type
number
Accessors
Get Set
Availability
All versions.
Usage notes
[0, 100] is the interval of allowed values, inclusive. 0 gives a single-color image. The
default value is 1.
This property is only valid after IsBlankImageExpress is called.
BlankImageThreshold
Returns or sets the dividing line between black and white.
Type
number
Accessors
Get Set
Availability
All versions.
Usage notes
[0, 255] is the interval of allowed values, inclusive. The default value is 128.
This property is only valid after IsBlankImageExpress is called.
CurrentImageIndexInBuffer
Returns the index (0-based) of the current image selected by Dynamic Web TWAIN or sets the image with
the specified index as the current image.
Type
number
Accessors
Get Set
Availability
All versions.
By changing CurrentImageIndexInBuffer , you can enumerate all the images in buffer.
When CurrentImageIndexInBuffer changes, the control will be redrawn to reflect the
change.
When image buffer is full, that is HowManyImagesInBuffer = MaxImagesInBuffer , any
195
Usage notes
acquired or loaded image will replace the existing one positioned by
CurrentImageIndexInBuffer . For example, if
1. MaxImagesInBuffer is set to 4
2. HowManyImagesInBuffer returns 4
3. CurrentImageIndexInBuffer is 3
When a new image is acquired, the CurrentImageIndexInBuffer is set back to 0, and the
first image is replaced by the newly acquired one . If another image is acquired,
CurrentImageIndexInBuffer is set to 1 and the second image is replaced by the new one.
HowManyImagesInBuffer
Returns how many images are currently loaded in Dynamic Web TWAIN. This is a read-only property.
Type
number
Accessors
Get
Availability
All versions.
ImageLayoutDocumentNumber
Returns the document number of the current image. This is a read-only property.
Type
number
Accessors
Get
Availability
All versions.
Usage notes
The document number is assigned by the source and is useful for grouping pages
together. Usually a physical representation, this could just as well be a logical
construct. Initial value is 1. Increment when a new document is placed into the
document feeder (usually tell this has happened when the feeder empties). Resets
when no longer acquiring from the feeder.
ImageLayoutDocumentNumber property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
ImageLayoutFrameBottom
Returns the value of the bottom edge of the current image frame (in
Type
number
Accessors
Get
Unit
). This is a read-only property.
Availability
All versions.
Usage notes
The unit of ImageLayoutFrameBottom property is determined by Unit property.
The default unit is assumed to be "inches" unless it has been otherwise negotiated
between the application and Data Source.
ImageLayoutFrameBottom property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
The frame information here is only about the current frame. To get the information
about all the frames to be transferred in an acquire session, please use capability
negotiation. The capability to be negotiated is ICAP_FRAMES (4372).
ImageLayoutFrameLeft
Returns the value of the left-most edge of the current image frame (in
Type
number
Accessors
Get
196
Unit
). This is a read-only property.
Availability
All versions.
Usage notes
The unit of ImageLayoutFrameLeft property is determined by Unit property.
The default unit is assumed to be "inches" unless it has been otherwise negotiated
between the application and Data Source.
ImageLayoutFrameLeft property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
The frame information here is only about the current frame. To get the information
about all the frames to be transferred in an acquire session, please use capability
negotiation. The capability to be negotiated is ICAP_FRAMES (4372).
ImageLayoutFrameNumber
Returns the frame number of the current image. This is a read-only property.
Type
number
Accessors
Get
Availability
All versions.
Usage notes
Usually a chronological index of the acquired frames, these frames are related to one
another in some way. Usually, they were acquired from the same page. The source
assigns these values. Initial value is 1. Reset when a new page is acquired.
ImageLayoutFrameNumber property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
The frame information here is only about the current frame. To get the information
about all the frames to be transferred in an acquire session, please use capability
negotiation. The capability to be negotiated is ICAP_FRAMES (4372).
ImageLayoutFrameRight
Returns the value of the right-most edge of the current image frame (in
Type
number
Accessors
Get
Unit
). This is a read-only property.
Availability
All versions.
Usage notes
The unit of ImageLayoutFrameRight property is determined by Unit property.
The default unit is assumed to be "inches" unless it has been otherwise negotiated
between the application and Data Source.
ImageLayoutFrameRight property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
The frame information here is only about the current frame. To get the information
about all the frames to be transferred in an acquire session, please use capability
negotiation. The capability to be negotiated is ICAP_FRAMES (4372).
ImageLayoutFrameTop
Returns the value of the top-most edge of the current image frame (in
Type
number
Accessors
Get
Availability
Usage notes
Unit
). This is a read-only property.
All versions.
The unit of ImageLayoutFrameTop property is determined by Unit property.
The default unit is assumed to be "inches" unless it has been otherwise negotiated
between the application and Data Source.
ImageLayoutFrameTop property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
The frame information here is only about the current frame. To get the information
197
about all the frames to be transferred in an acquire session, please use capability
negotiation. The capability to be negotiated is ICAP_FRAMES (4372).
ImageLayoutPageNumber
Returns the page number of the current image. This is a read-only property.
Type
number
Accessors
Get
Availability
All versions.
Usage notes
Increment for each page fed from the feeder.
ImageLayoutPageNumber property, along with other properties about the current image
information, is valid only in OnPreTransfer and OnPostTransfer event.
ImagePixelType
Returns the pixel type of the current image. This is a read-only property.
Type
EnumDWT_PixelType
Accessors
Get
Availability
All versions.
Usage notes
Please note the property is only valid in
OnPreTransfer
and
OnPostTransfer
event.
MagData
Returns the magnetic data if the data source supports magnetic data recognition. This is a read-only
property.
Type
number
Accessors
Get
Availability
v8.0+
Usage notes
Whether it works depends on the scanner's capability. Binary information is not
supported.
MagType
Returns the magnetic type if the data source supports magnetic data recognition. This is a read-only
property.
Type
EnumDWT_MagType
Accessors
Get
Availability
v8.0+
SelectedImagesCount
Returns or sets how many scanned images are, or will be, selected.
Type
number
Accessors
Get Set
Availability
v6.0+
198
199
General Utilities
Methods
GetImagePartURL()
GetImageURL()
Print()
RegisterEvent()
UnregisterEvent()
SetLanguage()
BufferMemoryLimit
ErrorCode
ErrorString
IfAllowLocalCache
IfShowProgressBar
LogLevel
Manufacturer
ProductFamily
ProductKey
ProductName
VersionInfo
Properties
Events
OnBitmapChanged
Methods
GetImagePartURL()
Gets the internal url of an image in buffer specified by index.
Syntax
.GetImagePartURL(index);
Parameters
number
Return
value
string
Availability
Usage
notes
index
: specifies the index of image in buffer. The index is 0-based.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v13.0
✓ | v13.0
✓ | v13.0
✓ | v13.0
The returned URL will be like "dwt://dwt_trial_13000404/img?
id=306159652&index=0&t=1502184632022".
GetImageURL()
Gets the url of the new image resized from the image of a specified index in buffer.
Syntax
.GetImageURL(index, [optional nWidth, optional nHeight]);
number
Parameters
optional
optional
Return
value
: specifies the index of image in buffer. The index is 0-based.
nWidth: specifies the new width which should be no smaller than 150.
number nHeight: specifies the new height which should be no smaller than 150.
index
number
string
ActiveX
H5(Windows)
H5(macOS/TWAIN)
200
H5(macOS/ICA)
H5(Linux)
Availability
Usage
notes
✗
✓ | v12.0
✓ | v12.0
✓ | v12.0
✓ | v12.1
The returned URL will be like "http://127.0.0.1:18622/dwt/dwt_trial_14100828/img?
id=780003506&index=0&t=1539674113432". If nWidth and nHeight are not specified, the
original image will be returned.
Print()
Opens the print dialog of the browser to print images.
Syntax
.Print()
Parameters
boolean PrintOption : By default, it uses the browser print UI. If set it to true, it will open a
separate process for the print operation.
Return
value
Availability
Usage
notes
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Currently this method is only valid in Windows & Mac.
This method opens the browser print dialog to print documents. This dialog will appear in a new
browser window. Typically it is blocked by the browser at the first time, you can choose to
'always allow' the dialog.
RegisterEvent()
Adds an event listener to a built-in Dynamic Web TWAIN event.
Syntax
.RegisterEvent()
Parameters
string
Return
value
boolean
Availability
Usage
notes
eventName
: the name of a built-in event.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v9.2
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
For the same event, the 2nd listener will override the 1st one. So there is always just one event
listener for one event.
UnRegisterEvent()
Adds an event listener to a built-in Dynamic Web TWAIN event.
Syntax
Parameters
Return
value
.UnRegisterEvent(eventName,evt)
string
Function
: the name of a built-in event.
: a function as the event listener.
eventName
evt
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
201
H5(macOS/ICA)
H5(Linux)
Availability
✓|
v9.2
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
SetLanguage()
Sets the language for the authorization dialogs.
Syntax
.SetLanguage()
Parameters
boolean PrintOption : By default, it uses the browser print UI. If set it to true, it will open a
separate process for the print operation.
Return
value
boolean
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v13.0
✓ | v13.0
✓ | v13.0
✓ | v13.0
Available values are English: 0, French: 1, Arabic: 2, Spanish: 3, Portuguese: 4, German: 5,
Italian: 6, Russian: 7, Chinese: 8
Properties
BufferMemoryLimit
Returns or sets how much physical memory (caching threshold) is allowed for storing images currently loaded
in Dynamic Web TWAIN. Once the limit is reached, images will be cached on the hard disk.
Type
number
Accessors
Gets Set
Usage
notes
Availability
Set this property only when you have a very small physical memory (< 2GB) or a very big one
(>4GB). The more memory is allowed, the better the performance will be.
The default value is set to 800 (MB), anything beyond 800MB gets compressed, encrypted and
cached on the local disk.
All cached data is encrypted and can only be read by Dynamic Web TWAIN and it will be
destroyed when it is no longer used.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.1
✓ | v10.1
✓ | v10.1
✓ | v11.0
✓ | v12.1
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
ErrorCode
Returns the error code.
Type
number
Accessors
Get
Usage
notes
Check out the Complete Error List
ActiveX
H5(Windows)
202
Availability
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
ErrorString
Returns the error string.
Type
number
Accessors
Get
Usage
notes
Availability
Check out the Complete Error List
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
IfAllowLocalCache
Returns or sets whether the feature of disk caching is enabled.
Type
boolean
Accessors
Get Set
Usage
notes
Availability
The default value of IfAllowLocalCache is true. When the property is true, you can scan as
many images as you want as long as you have a big enough disk.
The default threshold is set to 800 (MB), anything beyond 800MB gets compressed, encrypted
and cached on the local disk.
If neccessary, you can set the threshold using BufferMemoryLimit for better performance.
All cached data is encrypted and can only be read by Dynamic Web TWAIN and it will be
destroyed when it is no longer used.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v10.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
IfShowProgressBar
Returns or sets whether the progress bar is/should be displayed during encoding or decoding.
It works for any image encoding/decoding related methods. For example: LoadImage, LoadImageEx,
ConvertToBlob, etc.
Type
boolean
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
LogLevel
Returns or sets the log level for debugging.
203
Type
Accessors
Availability
Usage
notes
Number
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v6.3
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
The default value for LogLevel is 0 which means the extra information for debugging won't be
logged. To log the information for debugging, you can set it to 1.
Manufacturer
Returns or sets the Manufacturer string for the application identity.
Type
Accessors
Availability
Usage
notes
string
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
The Manufacturer property is a part of the application identity. The application identity consists
of the Manufacturer, ProductFamily, ProductName and VersionInfo.
All the application identity information should be set prior to invoking OpenSourceManager().
Since with built-in Wizard Mode, Dynamic TWAIN manages the transition of TWAIN state
intelligently, OpensourceManager() may be called automatically by other TWAIN related
functions, such as OpenSource() or AcquireImage(). It is recommended that application identity
information be set prior to any other TWAIN functions.
ProductFamily
Returns or sets the ProductFamily string for the application identity.
Type
Accessors
Availability
Usage
notes
string
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
The ProductFamily property is a part of the application identity. The application identity consists
of the Manufacturer, ProductFamily, ProductName and VersionInfo.
All the application identity information should be set prior to invoking OpenSourceManager().
Since with built-in Wizard Mode, Dynamic TWAIN manages the transition of TWAIN state
intelligently, OpensourceManager() may be called automatically by other TWAIN related
functions, such as OpenSource() or AcquireImage(). It is recommended that application identity
information be set prior to any other TWAIN functions.
ProductKey
Returns or sets the ProductKey string for the application identity.
Type
string
204
Accessors
Availability
Usage
notes
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v9.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
Each product key is generated with one or a set of licenses. It's not allowed to run your
application which based on Dynamic Web TWAIN without a product key (the licenses).
ProductName
Returns or sets the ProductName string for the application identity.
Type
Accessors
Availability
Usage
notes
string
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
The ProductName property is a part of the application identity. The application identity consists
of the Manufacturer, ProductFamily, ProductName and VersionInfo.
All the application identity information should be set prior to invoking OpenSourceManager().
Since with built-in Wizard Mode, Dynamic TWAIN manages the transition of TWAIN state
intelligently, OpensourceManager() may be called automatically by other TWAIN related
functions, such as OpenSource() or AcquireImage(). It is recommended that application identity
information be set prior to any other TWAIN functions.
VersionInfo
Returns or sets the VersionInfo string for the application identity.
Type
Accessors
Availability
Usage
notes
string
Get, Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v1.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
The VersionInfo property is a part of the application identity. The application identity consists of
the Manufacturer, ProductFamily, ProductName and VersionInfo.
All the application identity information should be set prior to invoking OpenSourceManager().
Since with built-in Wizard Mode, Dynamic TWAIN manages the transition of TWAIN state
intelligently, OpensourceManager() may be called automatically by other TWAIN related
functions, such as OpenSource() or AcquireImage(). It is recommended that application identity
information be set prior to any other TWAIN functions.
Events
OnWebTwainReady
This event is triggered as soon as Dynamic Web TWAIN is successfully loaded and initialized on the page.
205
Syntax
Arguments
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', Dynamsoft_OnReady); function
Dynamsoft_OnReady() {...}
or
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', function() {...});
None
Dynamsoft.WebTwainEnv.RegisterEvent('OnWebTwainReady', Dynamsoft_OnReady);
Example
Availability
Usage
notes
function Dynamsoft_OnReady() {
var DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
DWObject.Width = 270;
DWObject.Height = 350;
//Add event listeners to DWObject
DWObject.RegisterEvent("OnPostTransfer", function(){...});
DWObject.RegisterEvent("OnPostLoad", function(){...});
DWObject.RegisterEvent("OnMouseClick", function(){...});
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
This is the best place to set up Dynamic Web TWAIN (change the size of it, add event listeners,
etc.) as shown below in the example.
OnBitmapChanged
This event is triggered when the current image in buffer is changed like flipped, cropped, rotated, etc. or a new
image has been acquired.
Syntax
Arguments
Example
Availability
.RegisterEvent('OnBitmapChanged',function(){...});
None
DWObject.RegisterEvent('OnBitmapChanged', function() {
alert('image is changed');
});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v8.0
✓ | v10.0
✓ | v10.0
✓ | v11.0
✓ | v12.1
206
Addons
1. PDF Raterizer
2. Webcam Capture
3. File Uploader
4. Barcode Reader
5. OCR Basic
6. OCR Pro
207
PDF Rasterizer
Methods
Addon.PDF.Download()
Addon.PDF.SetResolution()
Addon.PDF.SetPassword()
Addon.PDF.SetConvertMode()
Code example
The following code example demonstrates how to use the APIs above to perform basic scanning.
//Callback functions for async APIs
function OnSuccess() {
console.log('successful');
}
function OnFailure(errorCode, errorString) {
alert(errorString);
}
function LoadImage() {
if (DWObject) {
//Please NOTE that the PDF Rasterizer doesn't work for Chrome/Firefox 26// Call DWObject.Addon.PDF.Download(url) to download PDF Rasterizer module to local.
DWObject.Addon.PDF.SetResolution(200);
DWObject.Addon.PDF.SetConvertMode(EnumDWT_ConvertMode.CM_RENDERALL);
DWObject.IfShowFileDialog = true; // Open the system's file dialog to load image
DWObject.LoadImageEx("", EnumDWT_ImageType.IT_PDF, OnSuccess, OnFailure);
// Load images in all supported formats (.bmp, .jpg, .tif, .png, .pdf). OnSuccess or OnFailure will be ca
lled after the operation
}
}
Methods
Addon.PDF.Download()
Downloads and installs the PDF add-on (it's typically a zipped dll file) on the local system.
Syntax
.Addon.PDF.Download(remoteFile, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
string remoteFile : specifies the url path of the add-on. E.g.
"http://www.dynamsoft.com/DWT/Resources/PDF.zip".
OnSuccess function optional optionalAsyncSuccessFunc : callback function triggered when
the file is downloaded successfully.
OnFailure function optional optionalAsyncFailureFunc : callback function triggered when
the file failed to be downloaded.
Return value
Usage notes
boolean
Only valid when used synchronously.
The server version number info is defined in the addon JS file. As long as the defined
version number is not the same as the local addon dll, the download method will auto
208
get the dll from server deployed to local.
Availability
v11.2+
Addon.PDF.SetResolution()
Sets the output image resolution of the PDF Rasterizer.
Syntax
.Addon.PDF.SetResolution(resolution)
Parameters
number
Return value
boolean
resolution
: specifies the resolution of the output images.
Usage notes
The default value is 200. We recommend that you set a value smaller than 300,
otherwise it might slow down the program or cause the process to fail.
Availability
v11.2+
Addon.PDF.SetPassword()
Specifies the password needed for rasterizing a password-protected PDF file.
Syntax
.Addon.PDF.SetPassword(password)
Parameters
string
Return value
boolean
password
: Specifies the PDF password.
Usage notes
This API is only available in the HTML5 edition for Windows.
Availability
v11.2+
Addon.PDF.SetConvertMode()
Sets the image convert mode for the PDF Rasterizer.
Syntax
.Addon.PDF.SetConvertMode(EnumDWT_ConvertMode.CM_RENDERALL);
EnumDWT_ConvertMode
EnumDWT_ConvertMode.CM_DEFAULT
Parameters
Return value
: It's the default mode. In this mode, the PDF Rasterizer
is turned off.
EnumDWT_ConvertMode.CM_RENDERALL : All the content in the target PDF file will converted in
a set resolution in this mode. The value of the resolution is 200 by default but can be
set via the method Addon.PDF.SetResolution.
boolean
Usage notes
Use this method before you import a PDF into the control with methods such as
LoadImage() and FTPDownload().
Availability
v11.2+
209
Webcam Capture
Methods
Addon.Webcam.CaptureImage()
Addon.Webcam.CloseSource()
Addon.Webcam.Download()
Addon.Webcam.GetCameraControlPropertyMoreSetting()
Addon.Webcam.GetCameraControlPropertySetting()
Addon.Webcam.GetFrameRate()
Addon.Webcam.GetFramePartUrl()
Addon.Webcam.GetFrameUrl()
Addon.Webcam.GetMediaType()
Addon.Webcam.GetResolution()
Addon.Webcam.GetSourceList()
Addon.Webcam.GetVideoPropertyMoreSetting()
Addon.Webcam.GetVideoPropertySetting()
Addon.Webcam.PauseVideo()
Addon.Webcam.PlayVideo()
Addon.Webcam.SelectSource()
Addon.Webcam.SetCameraControlPropertySetting()
Addon.Webcam.SetFrameRate()
Addon.Webcam.SetMediaType()
Addon.Webcam.SetResolution()
Addon.Webcam.SetVideoPropertySetting()
Addon.Webcam.SetVideoRotateMode()
Addon.Webcam.StopVideo()
Methods
Addon.Webcam.CaptureImage()
Captures an image from the current Webcam.
Syntax
Parameters
Return
value
Availability
.Addon.Webcam.CaptureImage(OnCaptureSuccess, OnCaptureError);
: callback function fired when capturing suceeds.
: callback function fired when capturing fails.
Function
OnCaptureSuccess
Function
OnCaptureError
Void
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.CloseSource()
Closes the current Webcam Source.
Syntax
.Addon.Webcam.CloseSource();
Parameters
None
Return
value
Boolean
210
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
When you close the camera, the video stream will also stop at the last frame.
Addon.Webcam.Download()
Downloads and installs Webcam add-on (it's typically a zipped dll file) on the local system.
Syntax
.Addon.Webcam.Download(strFilePath, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
Parameters
string strFilePath: the path of the .zip file that contains the Webcam add-on.
The following two parameters are optional. If either one exists or both exist, the method is
asynchronous, otherwise it's synchronous.
optional optionalAsyncSuccessFunc : callback function triggered when the
file is downloaded successfully.
optional optionalAsyncFailureFunc : callback function triggered when the
file failed to be downloaded.
Please refer to the function prototype OnSuccess or OnFailure.
Return
value
Usage
notes
Availability
boolean
, only valid when used synchronnously.
The download will occur when the Webcam add-on doesn't exist on the local machine or the
local add-on is of a different version.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.GetCameraControlPropertyMoreSetting()
Returns the range and default values of a specified Webcam property.
Syntax
.Addon.Webcam.GetCameraControlPropertyMoreSetting(nProperty);
number
nProperty
Values
0
1
: specifies the property to query. Allowed values are
EnumDWT_CameraControlProperty
Description
CCP_PAN
Specifies the camera's pan
setting, in degrees. Values range
from –180 to +180, with the
default set to zero. Positive values
are clockwise from the origin (the
camera rotates clockwise when
viewed from above), and negative
values are counterclockwise from
the origin.
CCP_TILT
Specifies the camera's tilt setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values point the
imaging plane up, and negative
values point the imaging plane
down.
211
Specifies the camera's roll setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values cause a
clockwise rotation of the camera
along the image-viewing axis, and
negative values cause a
counterclockwise rotation of the
camera.
2
CCP_ROLL
3
CCP_ZOOM
Specifies the camera's zoom
setting, in millimeters. Values
range from 10 to 600, and the
default is specific to the device.
CCP_EXPOSURE
Specifies the exposure setting, in
log base 2 seconds. In other
words, for values less than zero,
the exposure time is 1/2^n
seconds, and for values zero or
above, the exposure time is 2^n
seconds. For example:
Value Seconds
-3 1/8
-2 1/4
-1 1/2
0
1
1
2
2
4
Parameters
4
5
6
CCP_IRIS
Specifies the camera's iris setting,
in units of fstop* 10.
CCP_FOCUS
Specifies the camera's focus
setting, as the distance to the
optimally focused target, in
millimeters. The range and default
value are specific to the device.
An object of the type
Data
Type
Return
value
Availability
CameraControlMoreSetting
is returned. Methods available in the object are
Method Name
Description
GetMinValue()
Returns the minimum value of the property.
GetMaxValue()
Returns the maximum value of the property.
GetSteppingDelta()
Returns the step size for the property. The step
size is the smallest increment by which the
property can change.
GetDefaultValue()
Returns the default value of the property.
GetIfAuto()
Returns a value that indicates whether the setting
is controlled manually or automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
212
Addon.Webcam.GetCameraControlPropertySetting()
Returns the basic settings of a camera property.
Syntax
.Addon.Webcam.GetCameraControlPropertySetting(nProperty);
number
nProperty
Values
: specifies the property to query. Allowed values are
EnumDWT_CameraControlProperty
Description
CCP_PAN
Specifies the camera's pan
setting, in degrees. Values range
from –180 to +180, with the
default set to zero. Positive values
are clockwise from the origin (the
camera rotates clockwise when
viewed from above), and negative
values are counterclockwise from
the origin.
CCP_TILT
Specifies the camera's tilt setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values point the
imaging plane up, and negative
values point the imaging plane
down.
2
CCP_ROLL
Specifies the camera's roll setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values cause a
clockwise rotation of the camera
along the image-viewing axis, and
negative values cause a
counterclockwise rotation of the
camera.
3
CCP_ZOOM
Specifies the camera's zoom
setting, in millimeters. Values
range from 10 to 600, and the
default is specific to the device.
CCP_EXPOSURE
Specifies the exposure setting, in
log base 2 seconds. In other
words, for values less than zero,
the exposure time is 1/2^n
seconds, and for values zero or
above, the exposure time is 2^n
seconds. For example:
Value Seconds
-3 1/8
-2 1/4
-1 1/2
0
1
1
2
2
4
0
1
Parameters
4
5
6
CCP_IRIS
Specifies the camera's iris setting,
in units of fstop* 10.
CCP_FOCUS
Specifies the camera's focus
setting, as the distance to the
optimally focused target, in
millimeters. The range and default
value are specific to the device.
213
An object of the type
Data
Type
Return
value
Availability
CameraControlSetting
is returned. Methods available in the object are
Method
Name
Description
GetValue()
Returns the value of the property.
GetIfAuto()
Returns a value that indicates whether the setting is
controlled manually or automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.GetFrameRate()
Retrieves the frame rates supported by the current Webcam.
Syntax
Parameters
.Addon.Webcam.GetFrameRate();
None
An object of the type WebcamFrameRate is returned which contains a list of all available frame
rates. Methods available in the object are
Data Type
Return
value
Usage
notes
Availability
Method Name
Description
GetCount()
Returns the count of available frame rates.
Get(Number index)
Returns a frame rate from the list.
GetCurrent()
Returns the current frame rate.
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.3.1
✗
✗
✗
Addon.Webcam.GetFramePartUrl()
Gets the internal URL (dwt://) of the latest frame of the video stream.
Syntax
.Addon.Webcam.GetFramePartUrl();
Parameters
None
Return
value
String
Usage
notes
Availability
The returned URL will be like "dwt://dwt_trial_13000404/img?
id=306159652&index=0&t=1502184632022".
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3.1
✗
✗
✗
214
Addon.Webcam.GetFrameUrl()
Gets the URL (http(s)://) of the latest frame of the video stream.
Syntax
.Addon.Webcam.GetFrameUrl();
Parameters
None
Return
value
String
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.3.1
✗
✗
✗
Addon.Webcam.GetMediaType()
Retrieves the media types supported by the current Webcam.
Syntax
Parameters
.Addon.Webcam.GetMediaType();
None
An object of the type WebcamMediaType is returned which contains a list of all available media
types. Methods available in the object are
Data
Type
Return
value
Usage
notes
Availability
Method Name
Description
GetCount()
Returns the count of available media types.
Get(Number index)
Returns a media type from the list.
GetCurrent()
Returns the current media type.
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.GetResolution();
Retrieves the resolutions supported by the current Webcam.
Syntax
Parameters
.Addon.Webcam.GetResolution()
None
An object of the type WebcamResolution is returned which contains a list of all available
resolutions. Methods available in the object are
Data Type
Return
value
Method Name
Description
GetCount()
Returns the count of available resolutions.
Get(Number index)
Returns a resolution from the list.
GetCurrent()
Returns the current resolution.
215
Usage
notes
Availability
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.GetSourceList()
Gets a list of all available Webcams.
Syntax
Parameters
Return
value
Availability
Usage
notes
.Addon.Webcam.GetSourceList();
None
String[] An array of strings containing all Webcam names e.g. ["HD Webcam", "HP Webcam
123", "USB video driver"].
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
When you call this method, the camera addon will be restored. In other words, the video stream
will be cut off and the selected camera will be deselected and previous settings will be lost.
Addon.Webcam.GetVideoPropertyMoreSetting()
Returns the range and default values of a specified video property.
Syntax
.Addon.Webcam.GetVideoPropertyMoreSetting(nProperty);
number
nProperty
Values
Parameters
: Specifies the property to query, allowed values are:
EnumDWT_VideoProperty
Description
0
VP_BRIGHTNESS
Specifies the brightness, also called
the black level. For NTSC, the value
is expressed in IRE units * 100. For
non-NTSC sources, the units are
arbitrary, with zero representing
blanking and 10,000 representing
pure white. Values range from –
10,000 to 10,000.
1
VP_CONTRAST
Specifies the contrast, expressed as
gain factor * 100. Values range from
zero to 10,000.
2
VP_HUE
Specifies the hue, in degrees * 100.
Values range from -180,000 to
180,000 (-180 to +180 degrees).
3
VP_SATURATION
Specifies the saturation. Values
range from 0 to 10,000.
4
VP_SHARPNESS
Specifies the sharpness. Values
range from 0 to 100.
5
VP_GAMMA
Specifies the gamma, as gamma *
100. Values range from 1 to 500.
216
VP_COLORENABLE
Specifies the color enable setting.
The possible values are 0 (off) and 1
(on).
7
VP_WHITEBALANCE
Specifies the white balance, as a
color temperature in degrees Kelvin.
The range of values depends on the
device.
8
VP_BACKLIGHTCOMPENSATION
Specifies the backlight compensation
setting. Possible values are 0 (off)
and 1 (on).
VP_GAIN
Specifies the gain adjustment. Zero is
normal. Positive values are brighter
and negative values are darker. The
range of values depends on the
device.
6
9
An object of the type
Data
Type
Return
value
Availability
VideoPropertyMoreSetting
is returned. Methods available in the object are
Method Name
Description
GetMinValue()
Returns the minimum value of the property.
GetMaxValue()
Returns the maximum value of the property.
GetSteppingDelta()
Returns the step size for the property. The step
size is the smallest increment by which the
property can change.
GetDefaultValue()
Returns the default value of the property.
GetIfAuto()
Returns a value that indicates whether the setting
is controlled manually or automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.GetVideoPropertySetting()
Returns the basic settings of a video property.
Syntax
.Addon.Webcam.GetVideoPropertySetting(nProperty);
number
nProperty
Values
: Specifies the property to query, allowed values are:
EnumDWT_VideoProperty
0
VP_BRIGHTNESS
1
VP_CONTRAST
Description
Specifies the brightness, also called
the black level. For NTSC, the value
is expressed in IRE units * 100. For
non-NTSC sources, the units are
arbitrary, with zero representing
blanking and 10,000 representing
pure white. Values range from –
10,000 to 10,000.
Specifies the contrast, expressed as
gain factor * 100. Values range from
217
zero to 10,000.
Parameters
2
VP_HUE
Specifies the hue, in degrees * 100.
Values range from -180,000 to
180,000 (-180 to +180 degrees).
3
VP_SATURATION
Specifies the saturation. Values
range from 0 to 10,000.
4
VP_SHARPNESS
Specifies the sharpness. Values
range from 0 to 100.
5
VP_GAMMA
Specifies the gamma, as gamma *
100. Values range from 1 to 500.
6
VP_COLORENABLE
Specifies the color enable setting.
The possible values are 0 (off) and 1
(on).
7
VP_WHITEBALANCE
Specifies the white balance, as a
color temperature in degrees Kelvin.
The range of values depends on the
device.
8
VP_BACKLIGHTCOMPENSATION
Specifies the backlight compensation
setting. Possible values are 0 (off)
and 1 (on).
VP_GAIN
Specifies the gain adjustment. Zero is
normal. Positive values are brighter
and negative values are darker. The
range of values depends on the
device.
9
An object of the type
Data
Type
Return
value
Availability
VideoPropertySetting
is returned. Methods available in the object are
Method
Name
Description
GetValue()
Returns the current value of the property.
GetIfAuto()
Returns a value that indicates whether the setting is
controlled manually or automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
Addon.Webcam.PauseVideo()
Pauses the video stream.
Syntax
.Addon.Webcam.PauseVideo();
Parameters
None
Return
value
Boolean
ActiveX
Availability
H5(Windows)
✓|
218
✓ | v14.3
v14.3.1
Usage
notes
✗
✗
✗
This method only pauses the video for the HTML5 edition. Also, when you capture an image, it'll
be based on the actual frame at that point from the camera, not the paused frame.
Addon.Webcam.PlayVideo()
Starts to play the video stream in a specified container.
Syntax
Parameters
.Addon.Webcam.PlayVideo(DWObject, nQuality ,onFrameCaptured);
Object
DWObject
number
nQuality
: Specifies the object to hold the video stream.
: Specifies the quality of each frame in the video stream. Only valid for the
HTML5 edition.
optional
Function
onFrameCaptured
: Specifies the callback function for each showing frame in
the video stream.
Return
value
Availability
None
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SelectSource()
Selects an available Webcam.
Syntax
.Addon.Webcam.SelectSource(strWebcamName);
Parameters
string
Return
value
Boolean
Availability
strWebcamName
: specifies the Webcam to select.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetCameraControlPropertySetting()
Sets a property for the current camera.
Syntax
.Addon.Webcam.SetCameraControlPropertySetting(nProperty, nValue, bAuto);
number
nProperty
Values
0
: specifies the property to change. Allowed values are
EnumDWT_CameraControlProperty
Description
Specifies the camera's pan
setting, in degrees. Values range
from –180 to +180, with the
default set to zero. Positive values
are clockwise from the origin (the
camera rotates clockwise when
viewed from above), and negative
values are counterclockwise from
the origin.
CCP_PAN
219
1
2
Specifies the camera's tilt setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values point the
imaging plane up, and negative
values point the imaging plane
down.
CCP_TILT
CCP_ROLL
Specifies the camera's roll setting,
in degrees. Values range from –
180 to +180, with the default set to
zero. Positive values cause a
clockwise rotation of the camera
along the image-viewing axis, and
negative values cause a
counterclockwise rotation of the
camera.
CCP_ZOOM
Specifies the camera's zoom
setting, in millimeters. Values
range from 10 to 600, and the
default is specific to the device.
CCP_EXPOSURE
Specifies the exposure setting, in
log base 2 seconds. In other
words, for values less than zero,
the exposure time is 1/2^n
seconds, and for values zero or
above, the exposure time is 2^n
seconds. For example:
Value Seconds
-3 1/8
-2 1/4
-1 1/2
0
1
1
2
2
4
Parameters
3
4
5
6
CCP_IRIS
Specifies the camera's iris setting,
in units of fstop* 10.
CCP_FOCUS
Specifies the camera's focus
setting, as the distance to the
optimally focused target, in
millimeters. The range and default
value are specific to the device.
number nValue : Specifies the value to set to the property.
the setting is controlled manually or automatically.
Return
value
Usage
notes
Availability
boolean
bAuto
: Specifies whether
Boolean
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetFrameRate()
Sets the frame rate of the current Webcam.
220
Sets the frame rate of the current Webcam.
Syntax
.Addon.Webcam.SetFrameRate(nValue);
Parameters
number
Return
value
Boolean
Usage
notes
Availability
nValue
: Specifies the frame rate.
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetMediaType()
Sets the media type of the current Webcam.
Syntax
.Addon.Webcam.SetMediaType(strMediaType);
Parameters
string
Return
value
Boolean
Usage
notes
Availability
strMediaType
: Specifies the media type.
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically. Make sure you only set a supported media type
which you can get using the method Addon.Webcam.GetMediaType() .
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetResolution()
Sets the resolution of the current Webcam.
Syntax
.Addon.Webcam.SetResolution(strResolution)
Parameters
string
Return
value
Boolean
Usage
notes
Availability
strResolution
: Specifies the resolution.
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically. Make sure you only set a supported resolution which
you can get using the method Addon.Webcam.GetResolution() .
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetVideoPropertySetting()
Sets a property for the video stream.
221
number
nProperty
Values
: Specifies the property to change, allowed values are:
EnumDWT_VideoProperty
Description
0
VP_BRIGHTNESS
Specifies the brightness, also called
the black level. For NTSC, the value
is expressed in IRE units * 100. For
non-NTSC sources, the units are
arbitrary, with zero representing
blanking and 10,000 representing
pure white. Values range from –
10,000 to 10,000.
1
VP_CONTRAST
Specifies the contrast, expressed as
gain factor * 100. Values range from
zero to 10,000.
2
VP_HUE
Specifies the hue, in degrees * 100.
Values range from -180,000 to
180,000 (-180 to +180 degrees).
3
VP_SATURATION
Specifies the saturation. Values
range from 0 to 10,000.
4
VP_SHARPNESS
Specifies the sharpness. Values
range from 0 to 100.
5
VP_GAMMA
Specifies the gamma, as gamma *
100. Values range from 1 to 500.
6
VP_COLORENABLE
Specifies the color enable setting.
The possible values are 0 (off) and 1
(on).
7
VP_WHITEBALANCE
Specifies the white balance, as a
color temperature in degrees Kelvin.
The range of values depends on the
device.
8
VP_BACKLIGHTCOMPENSATION
Specifies the backlight compensation
setting. Possible values are 0 (off)
and 1 (on).
VP_GAIN
Specifies the gain adjustment. Zero is
normal. Positive values are brighter
and negative values are darker. The
range of values depends on the
device.
Parameters
9
number nValue : Specifies the value to set to the property.
the setting is controlled manually or automatically.
Return
value
Usage
notes
Availability
boolean
bAuto
: Specifies whether
Boolean
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.SetVideoRotateMode()
222
Sets video rotate mode of the current Webcam.
Syntax
.Addon.Webcam.SetVideoRotateMode(nVideoRotateMode);
number
nVideoRotateMode
: Specifies the video rotate mode on a video capture device, allowed
values are:
Values
Parameters
Return
value
Usage
notes
Availability
EnumDWT_VideoRotateMode enumeration
Description
0
VRM_NONE
Don't rotate
1
VRM_90_DEGREES_CLOCKWISE
90 deg Clockwise
2
VRM_180_DEGREES_CLOCKWISE
180 deg Clockwise
3
VRM_270_DEGREES_CLOCKWISE
270 deg Clockwise
4
VRM_FLIP_VERTICAL
Flip
5
VRM_FLIP_HORIZONTAL
Mirror
Boolean
This method should be called after Addon.Webcam.SelectSource() . If there is only one data source
available, it will be selected automatically.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
Addon.Webcam.StopVideo()
Stops the video stream.
Syntax
.Addon.Webcam.StopVideo();
Parameters
None
Return
value
Boolean
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.3.1
✓ | v14.3
✗
✗
✗
223
File Uploader
The
FileUploader
is an independent module that handles the uploading of files. It's released with Dynamic
Web TWAIN version 14.0. Once an upload job starts, it no longer relies on Dynamic Web TWAIN which
means the upload carries on even after you have closed the browser. The files/data to upload is stored
temporarily on the local disk (typically in the path
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\upload
)
before they're uploaded and will be purged as soon as they're uploaded or when the Dynamsoft Service
restarts.
Methods
Init()
CreateJob()
Run()
Cancel()
CancelAllUpload()
GenerateURLForUploadData()
HttpHeader
SourceValue
OnRunSuccess
OnRunFailure
Properties
ServerUrl
FormField
Events
OnUploadTransferPercentage
Code example
The following code example demonstrates how to use the APIs above to perform uploading.
var fileUploaderManager;
function onInitSuccess(objFileUploader) {
fileUploaderManager = objFileUploader;
}
function onInitFailure(errorCode, errorString) {
alert('Init failed: ' + errorString);
};
Dynamsoft.FileUploader.Init("", onInitSuccess, onInitFailure);
function UploadFile() {
var job = fileUploaderManager.CreateJob();
job.ServerUrl ='http://yourserver/youractionpage.aspx';
job.FileName = "sample.jpg";
job.ImageType = EnumDWT_ImageType.IT_JPG;
DWObject.GenerateURLForUploadData([0],EnumDWT_ImageType.IT_JPG, function(result) {
job.SourceValue.Add(result, "sample.jpg");
job.FormField.Add('customField', 'FormFieldValue');
job.OnUploadTransferPercentage = FileUpload_OnUploadTransferPercentage;
job.OnRunSuccess = FileUpload_OnRunSuccess;
job.OnRunFailure = FileUpload_OnRunFailure;
fileUploaderManager.Run(job);
}, function(errorCode, errorString) {
console.log(errorString);
});
224
}
function FileUpload_OnUploadTransferPercentage(job, sPercentage) {
console.log(sPercentage);
}
function FileUpload_OnRunFailure(job, errorCode, errorString) {
alert(errorString);
}
function FileUpload_OnRunSuccess(job) {
alert(' upload completed! ');
}
Methods
Init()
This is a global API that initiates the FileUploader module.
Syntax
Dynamsoft.FileUploader.Init(remoteFile, asyncSuccessFunc, asyncFailureFunc);
Parameters
string remoteFile: an URL that specifies the path of the FileUploader library on the server. In
v14.0, the library is installed together with the core|scan module of Dynamic Web TWAIN, so
you can set this parameter to be an empty string.
OnSuccess function asyncSuccessFunc : callback function triggered when initiation succeeds, this
function has a primitive parameter which refers to an UploadManager object that has just been
initiated.
OnFailure function asyncFailureFunc : callback function triggered when initiation fails. When the
FileUploader library (.dll) is not installed or the installed file is a different version, Init will try to
download and install the library from the path specified by remoteFile. If that fails, this callback
function is triggered.
Please refer to the function prototype OnSuccess or OnFailure.
Example
Availability
var dsUploadManager;
Dynamsoft.FileUploader.Init('', function(obj) {
dsUploadManager = obj;
}, function(){});
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
CreateJob()
Create a upload job.
Syntax
.CreateJob();
Parameters
None
Return
value
Object A job object. For instance:
{HttpHeader: {}, documents: Array(0), Version: "1.0", HttpVersion: "1.1", ServerUrl: "", …}
Example
var job = dsUploadManager.CreateJob();
ActiveX
H5(Windows)
H5(macOS/TWAIN)
225
H5(macOS/ICA)
H5(Linux)
Availability
✗
✓ | v14.0
✗
✗
✗
Run()
Starts to execute an upload job.
Syntax
.Run(obj);
Parameters
Object
Return
value
boolean
Example
Availability
obj: A job object.
var job = dsUploadManager.CreateJob();
dsUploadManager.Run(job);
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
Cancel()
Cancels a upload job after it has started and before it completes. Normally this is done in the event
OnUploadTransferPercentage.
Syntax
.Cancel(obj);
Parameters
Object
Return
value
boolean
Example
Availability
obj: A job object.
var job = dsUploadManager.CreateJob();
job.OnUploadTransferPercentage= FileUpload_OnUploadTransferPercentage;
dsUploadManager.Run(job);
function FileUpload_OnUploadTransferPercentage(job, iPercentage)
{
console.log('job cancelled!')
dsUploadManager.Cancel(job);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
CancelAllUpload()
Cancels all upload jobs.
Syntax
.CancelAllUpload();
Parameters
None
Return
value
boolean
Example
dsUploadManager.CancelAllUpload();
226
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
GenerateURLForUploadData()
Generates a URL that will be used by the upload module to fetch the file/data to upload.
Syntax
DWObject.GenerateURLForUploadData(indices, enumImageType, asyncSuccessFunc,
asyncFailureFunc);
Parameters
indices: the indices of the images in the buffer. The index is 0-based.
enumImageType: the format in which you'd like the images to be uploaded.
OnSuccess function asyncSuccessFunc :callback function triggered when the operation succeeds.
This function will return the result URL.
OnFailure function asyncFailureFunc : callback function triggered when the operation fails.
Please refer to the function prototype OnSuccess or OnFailure.
Number[]
EnumDWT_ImageType
Dynamsoft.FileUploader.Init('', function(obj){dsUploadManager=obj}, function(){});
DWObject.GenerateURLForUploadData([0,1], EnumDWT_ImageType.IT_PDF,
function(result){
var serverurl= "https://yoursite/yourserverurl.aspx";
var jobtemp = dsUploadManager.CreateJob();
jobtemp.ServerUrl = serverUrl;
jobtemp.SourceValue.Add(result, "uploadedFile.pdf");
dsUploadManager.Run(jobtemp);
}, function(){});
Example
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
Properties
ServerUrl
Specifies the target of the HTTP Post Request of the upload job. This typically is a file on the server. For
example: job.ServerUrl = 'http://www.dynamsoft.com/ScanAndUpload/Actions/SaveToFile.aspx';
Type
string
Accessors
Get Set
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
HttpHeader
Specifies headers in the the HTTP Post Request of the upload job. For example: job.HttpHeader["ContentType"] = "text/plain";
Type
Object
227
Accessors
Availability
Usage
notes
Set
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
By default, HttpHeader is an empty object. If left as it is, default headers are used. Otherwise,
the headers set by this property will be added to the HTTP Post Request or replace existing
ones with the same names.
SourceValue
Specifies the files to be uploaded and the name for it. The files are specified by URLs which can be created
with the method GenerateURLForUploadData. This object has a method Add to add file to the job.
Type
Object
Accessors
Set
Usage
notes
Availability
Use the Add(string urltoFetchFileData, string fileName) method of the Object to add data for
uploading, check out the sample code for more information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
FormField
Specifies extra fields to be uploaded in the same HTTP post.
Type
Object
Accessors
Set
Usage
notes
Availability
Use the Add(string fieldName, string fieldValue) method of the Object to add fields for
uploading, check out the sample code for more information.
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
Events
OnUploadTransferPercentage
The event is triggered during the execution of an upload job. It has a parameter which specifies the percentage
of the completion of the job.
Syntax
Arguments
Example
.OnUploadTransferPercentage = function(){...};
: A job object.
: The percentage of the completion of the job.
Object
obj
number
sPercentage
job.OnUploadTransferPercentage = FileUpload_OnUploadTransferPercentage;
function FileUpload_ OnUploadTransferPercentage (obj, sPercentage){
console.log(sPercentage);
}
228
Availability
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
OnRunSuccess
The event is triggered when an upload job completes successfully.
Syntax
.OnRunSuccess = function(){...};
Object
Arguments
Example
Availability
obj
: A job object.
job.OnRunSuccess = FileUpload_OnRunSuccess;
function FileUpload_OnRunSuccess(obj) {
alert(' upload completed ');
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
OnRunFailure
The event is triggered when an upload job fails.
Syntax
.OnRunFailure = function(){...};
Arguments
Example
Availability
: A job object.
: The error code.
errorString : The error string.
Object
obj
number
errorCode
string
job.OnRunFailure = FileUpload_OnRunFailure;
function FileUpload_OnRunFailure(obj, errorCode, errorString) {
alert(errorString);
}
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v14.0
✗
✗
✗
229
Barcode Reader
Constructor
dynamsoft.BarcodeReader()
Methods
decode()
decodeBase64String()
updateRuntimeSettings()
resetRuntimeSettings()
getRuntimeSettings()
dynamsoft.BarcodeReader.initServiceConnection()
Properties
productKey
bAutoConnectService
resourcesPath
ifCheck64bitServiceFirst
Events
onAutoConnectServiceSuccess
onAutoConnectServiceError
Others
Enumerations
Errors
Code example
The following code example demonstrates how to use the APIs above to perform barcode reading.
var reader = new dynamsoft.BarcodeReader("");
var runtimeSettings = reader.getRuntimeSettings();
runtimeSettings.mBarcodeFormatIds = 1023; // 1D Barcodes
reader.updateRuntimeSettings(runtimeSettings);
var idx = DWObject.GetSelectedImageIndex(0);
var url = DWObject.GetImagePartURL(idx);
reader.decode(url).then(function(results){
for(var i = 0; i < results.length; ++i){
console.log(results[i].BarcodeText);
console.log(results[i].LocalizationResult.ExtendedResultArray[0].Confidence);
}
});
Constructor
dynamsoft.BarcodeReader()
Creates an instance of BarcodeReader.
Syntax
dynamsoft.BarcodeReader();
or
dynamsoft.BarcodeReader(licenceKeys);
230
Parameters
string
Return value
dynamsoft.BarcodeReader
: The license key for the Barcode Reader add-on.
var reader = new dynamsoft.BarcodeReader();
Example
Usage notes
licenceKeys (optional)
If the parameter licenceKeys is not set, the SDK will get the license key from
dynamsoft.dbrEnv.productKey
lo
Availability
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
Methods
decode()
Decodes barcodes from an image.
Syntax
Parameters
.decode(source);
The image to be decoded. It supports png, jpeg, bmp and tiff files.
The parameter source supports the following types:
string
source (dcsUrl)
string
source (dwtUrl)
Promise(resolve(array TextResult), reject(ex))
Methods available in the
TextResult
object:
Members
Return value
Example
Description
ResultType emResultType
The barcode format.
pszBarcodeFormatString
Barcode type in string.
pszBarcodeText
The barcode text, ends by '\0'.
pBarcodeBytes
The barcode content in a byte array.
nBarcodeBytesLength
The length of the byte array.
SLocalizationResult pLocalizationResult
The corresponding localization result.
// dwtUrl: HTML5 Edition only
reader.decode('dwt://dwt_trial_13000404/img?id=306159652&index=0&t=1502184632022').then(
results=>{
for(var i = 0; i < results.length; ++i){
console.log(results[i].BarcodeText);
// Confidence >= 30 is reliable
console.log(results[i].LocalizationResult.ExtendedResultArray[0].Confidence);
}
});
// dcsUrl
reader.decode('dcs://dcs_trial_6110531/img?id=306159652&index=0&t=1502184632022').then(
function(results){
// ie6-7 does not support console.log
var messageArr = [];
for(var i = 0; i < results.length; ++i){
messageArr.push(results[i].BarcodeText);
// Confidence >= 30 is reliable
231
messageArr.push(results[i].LocalizationResult.ExtendedResultArray[0].Confidence);
}
alert(messageArr.join(''));
})['catch'](function(ex){
// ie6-9 does not support '.catch(function(ex){...})'
if(ex){alert(ex.message||ex);}
});
Availability
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓|
v14.1
✗
✗
✗
decodeBase64String()
Decodes barcodes from a base64 image.
Syntax
Parameters
.decodeBase64String(base64Str);
string
base64Str
: The barcode image to be decoded.
Promise(resolve(array TextResult), reject(ex))
Methods available in the
TextResult
object:
Members
Return value
Example
Availability
Description
ResultType emResultType
The barcode format.
pszBarcodeFormatString
Barcode type in string.
pszBarcodeText
The barcode text, ends by '\0'.
pBarcodeBytes
The barcode content in a byte array.
nBarcodeBytesLength
The length of the byte array.
SLocalizationResult pLocalizationResult
The corresponding localization result.
var base64str = '';
//with mime
reader.decodeBase64String(base64str).then(results=>{
for(var i = 0; i < results.length; ++i){
console.log(results[i].BarcodeText);
}
});
//without mime
reader.decodeBase64String(base64str.substring(base64str.indexOf(',') + 1)).then(results=>{
for(var i = 0; i < results.length; ++i){
console.log(results[i].BarcodeText);
}
});
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
getRuntimeSettings()
Gets the current barcode reading settings.
Syntax
.getRuntimeSettings();
232
Parameters
Return value
Example
Availability
None.
PlainObject
var mysettings = reader.getRuntimeSettings();
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
updateRuntimeSettings()
Updates the current barcode reading settings.
Syntax
.updateRuntimeSettings(settings);
PublicRuntimeSettings Object
Parameters
settings
: A struct that represents barcode reader settings.
typedef struct PublicRuntimeSettings
{
number mTimeout;
number mBarcodeFormatIds;
number mTextureDetectionSensitivity;
number mDeblurLevel;
number mAntiDamageLevel;
number mMaxBarcodesCount;
number mScaleDownThreshold;
number mGrayEqualizationSensitivity;
number mExpectedBarcodesCount;
};
For more info, please refer to PublicParameterSettings.
Return value
Example
Availability
undefined
//get the barcode reading settings
var settings = reader.getRuntimeSettings();
//change the settings
settings.mBarcodeFormatIds = 1023; // 1D barcodes
settings.mExpectedBarcodesCount = 10;
settings.mDeblurLevel = 9;
settings.mAntiDamageLevel = 9;
settings.mScaleDownThreshold = 3000;
//update the settings
reader.updateRuntimeSettings(settings);
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
resetRuntimeSettings()
Resets all barcode reading settings to default values.
Syntax
.resetRuntimeSettings();
Parameters
None.
Return value
undefined
233
Example
Availability
reader.resetRuntimeSettings();
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
dynamsoft.BarcodeReader.initServiceConnection()
Initializes the connection to the Dynamsoft Service.
Syntax
dynamsoft.BarcodeReader.initServiceConnection();
Parameters
None.
Return value
Availability
Promise(resolve(null), reject(ex))
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
Properties
productKey
Returns or sets the license key for Barcode Reader add-on.
Type
string
Accessors
Get Set
Usage notes
Availability
The default value of bAutoConnectService is true.
If you want to connect to the service manually, please set it to false before loading
"dynamsoft.barcodereader.min.js" and call
dynamsoft.BarcodeReader.initServiceConnection when needed.
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
bAutoConnectService
Returns or sets whether to connect to the Dynamsoft Service automatically.
Type
boolean
Accessors
Get Set
Usage notes
If you don’t pass a license or the license has expired, the barcode reader add-on will
continue to function normally but the last three characters of the barcode result will be
masked with “***”.
ActiveX
H5(Win)
H5(macOS/TWAIN)
234
H5(macOS/ICA)
H5(Linux)
Availability
✓|
v14.1
✓|
v14.1
✗
✗
✗
resourcesPath
Returns or sets where the barcode reader related dependencies are placed. This is a relative path to the
current web page.
Type
string
Accessors
Get Set
Usage notes
Availability
The path is very important as it points to all the JavaScript files, MSI file, images, etc.
necessary for the barcode reader add-on to work correctly.
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
ifCheck64bitServiceFirst
Returns or sets whether to use Dynamsoft Service 64-bit first.
Type
string
Accessors
Get Set
Usage notes
Availability
The default value of ifCheck64bitServiceFirst is false.
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
Events
onAutoConnectServiceSuccess
The success callback function of the service connection.
Syntax
dynamsoft.dbrEnv.onAutoConnectServiceSuccess = function(){ ... };);
Arguments
None.
Example
Availability
dynamsoft.dbrEnv.onAutoConnectServiceSuccess = function(){
console.log("success");
};
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
235
onAutoConnectServiceError
The failure callback function of the service connection.
Syntax
dynamsoft.dbrEnv.onAutoConnectServiceError = function(status){ ... };
status
Arguments
Example
Availability
: The status of the service.
dynamsoft.dbrEnv.onAutoConnectServiceError = function(status){
console.log("error");
};
ActiveX
H5(Win)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✓|
v14.1
✓|
v14.1
✗
✗
✗
Error
Error dynamsoft.BarcodeReader.BarcodeReaderException
Member
Type
code
number
message
String
dynamsoft.BarcodeReader.EnumErrorCode
Description
The error code.
The error string.
Environment APIs (Optional)
The following code example demonstrates how to set the Barcode Reader environment.
// All settings are optional, including dynamsoft and dynamsoft.dbrEnv.
dynamsoft = self.dynamsoft || {};
dynamsoft.dbrEnv = dynamsoft.dbrEnv || {};
dynamsoft.dbrEnv.productKey = "",
dynamsoft.dbrEnv.bAutoConnectService = true;
dynamsoft.dbrEnv.resourcesPath = 'DBRResources';
dynamsoft.dbrEnv.ifCheck64bitServiceFirst = true;
dynamsoft.dbrEnv.onAutoConnectServiceSuccess = function(){
console.log("success");
};
dynamsoft.dbrEnv.onAutoConnectServiceError = function(status){
console.log("error");
};
Enumerations
enum dynamsoft.BarcodeReader.EnumBarcodeFormat
dynamsoft.BarcodeReader.EnumBarcodeFormat.All = 503317503;
dynamsoft.BarcodeReader.EnumBarcodeFormat.OneD = 0x3FF;
236
dynamsoft.BarcodeReader.EnumBarcodeFormat.CODE_39 = 0x1;
dynamsoft.BarcodeReader.EnumBarcodeFormat.CODE_128 = 0x2;
dynamsoft.BarcodeReader.EnumBarcodeFormat.CODE_93 = 0x4;
dynamsoft.BarcodeReader.EnumBarcodeFormat.CODABAR = 0x8;
dynamsoft.BarcodeReader.EnumBarcodeFormat.ITF = 0x10;
dynamsoft.BarcodeReader.EnumBarcodeFormat.EAN_13 = 0x20;
dynamsoft.BarcodeReader.EnumBarcodeFormat.EAN_8 = 0x40;
dynamsoft.BarcodeReader.EnumBarcodeFormat.UPC_A = 0x80;
dynamsoft.BarcodeReader.EnumBarcodeFormat.UPC_E = 0x100;
dynamsoft.BarcodeReader.EnumBarcodeFormat.INDUSTRIAL_25 = 0x200;
dynamsoft.BarcodeReader.EnumBarcodeFormat.PDF417 = 0x2000000;
dynamsoft.BarcodeReader.EnumBarcodeFormat.QR_CODE = 0x4000000;
dynamsoft.BarcodeReader.EnumBarcodeFormat.DATAMATRIX = 0x8000000;
dynamsoft.BarcodeReader.EnumBarcodeFormat.AZTEC = 0x10000000;
enum dynamsoft.BarcodeReader.EnumErrorCode
dynamsoft.BarcodeReader.EnumErrorCode.DBR_SYSTEM_EXCEPTION = 1;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_SUCCESS = 0;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_UNKNOWN = -10000;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_NO_MEMORY = -10001;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_NULL_REFERENCE = -10002;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_LICENSE_INVALID = -10003;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_LICENSE_EXPIRED = -10004;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_FILE_NOT_FOUND = -10005;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_FILETYPE_NOT_SUPPORTED = -10006;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_BPP_NOT_SUPPORTED = -10007;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_INDEX_INVALID = -10008;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_BARCODE_FORMAT_INVALID = -10009;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_CUSTOM_REGION_INVALID = -10010;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_MAX_BARCODE_NUMBER_INVALID = -10011;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_IMAGE_READ_FAILED = -10012;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_TIFF_READ_FAILED = -10013;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_QR_LICENSE_INVALID = -10016;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_1D_LICENSE_INVALID = -10017;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_DIB_BUFFER_INVALID = -10018;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_PDF417_LICENSE_INVALID = 10019;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_DATAMATRIX_LICENSE_INVALID = -10020;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_PDF_READ_FAILED = -10021;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_PDF_DLL_MISSING = -10022;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_PAGE_NUMBER_INVALID = -10023;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_CUSTOM_SIZE_INVALID = -10024;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_CUSTOM_MODULESIZE_INVALID = -10025;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_RECOGNITION_TIMEOUT = -10026;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_PARSE_FAILED = -10030;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_TYPE_INVALID = -10031;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_KEY_INVALID = -10032;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_VALUE_INVALID = -10033;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_NAME_KEY_MISSING = -10034;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_NAME_VALUE_DUPLICATED = -10035;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_TEMPLATE_NAME_INVALID = -10036;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_JSON_NAME_REFERENCE_INVALID = -10037;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_PARAMETER_VALUE_INVALID = 10038;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_DOMAIN_NOT_MATCHED = -10039;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_RESERVEDINFO_NOT_MATCHED = -10040;
dynamsoft.BarcodeReader.EnumErrorCode.DBR_DBRERR_AZTEC_LICENSE_INVALID = -10041;
237
238
239
OCR Pro
For Server Side OCR, check out Server-Side OCR
Client-Side
Methods
Download()
IsModuleInstalled()
Recognize()
RecognizeFile()
RecognizeRect()
RecognizeSelectedImages()
Properties
Settings
OCR Pro Result Object
OCRResult
PageResult
LetterResult
ErrorInfo
Code example
The following code example demonstrates how to use the APIs above to perform basic scanning.
function DoOCR() {
if (DWObject) {
if (DWObject.HowManyImagesInBuffer == 0) {
alert("Please scan or load an image first.");
return;
}
var settings = Dynamsoft.WebTwain.Addon.OCRPro.NewSettings();
var bMultipage = false;
settings.RecognitionModule = EnumDWT_OCRProRecognitionModule.OCRPM_AUTO;
settings.Languages = "eng";
settings.OutputFormat = EnumDWT_OCRProOutputFormat.OCRPFT_TXTS;
settings.LicenseChecker = "LicenseChecker.aspx";
DWObject.Addon.OCRPro.Settings = settings;
//Get ocr result.
var i, nCount = DWObject.HowManyImagesInBuffer;
DWObject.SelectedImagesCount = nCount;
for (i = 0; i < nCount; i++) {
DWObject.SetSelectedImageIndex(i, i);
}
DWObject.Addon.OCRPro.RecognizeSelectedImages(function(result) {
if (result == null)
return null;
var bRet = "", pageCount = result.GetPageCount();
if (pageCount == 0) {
alert("OCR result is Null.");
return;
} else {
for (i = 0; i < pageCount; i++) {
var page = result.GetPageContent(i);
var letterCount = page.GetLettersCount();
240
for (var n = 0; n < letterCount; n++) {
var letter = page.GetLetterContent(n);
bRet += letter.GetText();
}
}
console.log(bRet);
}
}, function(errorcode, errorstring, result) {
if (errorcode != -2600 && errorcode != -2601) //-2600:LicenseChecker cannot be empty.
-2601:Cannot c
onnect to the LicenseChecker, please check and make sure it's set correctly.
alert(errorstring);
var strErrorDetail = "";
var aryErrorDetailList = result.GetErrorDetailList();
for (var i = 0; i < aryErrorDetailList.length; i++) {
if (i > 0)
strErrorDetail += ";";
strErrorDetail += aryErrorDetailList[i].GetMessage();
}
if (strErrorDetail.length > 0 && errorstring != strErrorDetail)
alert(strErrorDetail);
}
);
}
}
Methods
Download()
Downloads and installs the OCRPro add-on (it's typically a zipped dll file) on the local system.
Syntax
.Addon.OCRPro.Download(sDLLPath, [optionalAsyncSuccessFunc,
optionalAsyncFailureFunc]);
: specifies the url path of the add-on. E.g.
.
optional optionalAsyncSuccessFunc : callback function triggered when
the download succeeds.
optional optionalAsyncFailureFunc : callback function triggered when
the download fails.
string
sDLLPath
"http://www.dynamsoft.com/DWT/Resources/OCR.zip"
Parameters
Return
value
Availability
Usage
notes
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
This method will attempt to download and install the dll from the server if the dll doesn't exist
already or the exising one is of a different version. The method IsModuleInstalled() can be used
to determine whether it's necessary to call Download() .
IsModuleInstalled()
Returns whether the OCRPro module is already installed on the local system.
Syntax
Parameters
.Addon.OCRPro.IsModuleInstalled();
None
241
Return value
boolean
Availability
Versions:
Usage notes
If the method returns false , you can use the method
install the dll from the server.
v14.1+
Download()
to download and
Recognize()
Performs OCR on a given image.
Syntax
.Addon.OCRPro.Recognize(nImageIndex, asyncSuccessFunc, asyncFailureFunc);
: Specifies the index of the image in buffer. The index is 0-based.
asyncSuccessFunc : Callback function triggered when the OCR
executed successfully. The arguments are
number
nImageIndex
number
OCRResult
Parameters
The index of the image.
nImageIndex
The OCR result.
Result
asyncFailureFunc
: Callback function triggered when the OCR
operation fails. The arguments are
number
nErrorCode
The error code.
string
strErrorString
The error string.
OCRResult
Return
value
Availability
Usage
notes
The OCR result for the image.
Result
None
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
Check out the sample code and the details for
OCRResult
.
RecognizeFile()
Performs OCR on local files directly without loading them in the viewer.
Syntax
.Addon.OCRPro.RecognizeFile(strFileNames, asyncSuccessFunc, asyncFailureFunc);
string strFileNames : Specifies the local paths of the target files. If multiple files are given,
they should be separated by the '|' character.
asyncSuccessFunc : Callback function triggered when the OCR
executed successfully. The arguments are
string
OCRResult
Parameters
The file paths.
strFileNames
The OCR result for the image.
Result
asyncFailureFunc
: Callback function triggered when the OCR
operation fails. The arguments are
number
nErrorCode
The error code.
string
strErrorString
The error string.
242
OCRResult
Return
value
boolean
Availability
Usage
notes
The OCR result for the image.
Result
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
Check out the sample code and the details for
OCRResult
.
RecognizeRect()
Peforms OCR on the given rectangle on a specified image.
Syntax
.Addon.OCRPro.RecognizeRect(nImageIndex, aryZones, asyncSuccessFunc,
asyncFailureFunc);
: Specifies the index of the image in buffer. The index is 0-based.
: An array of OCRZone's created by the method
Dynamsoft.WebTwain.Addon.OCRPro.NewOCRZone to specify the coordinates of the rectangle(s) for
OCR.
asyncSuccessFunc : Callback function triggered when the OCR
executed successfully. The arguments are
number
Array
nImageIndex
aryZones
number
OCRResult
Parameters
The index of the image.
nImageIndex
The OCR result.
Result
asyncFailureFunc
: Callback function triggered when the OCR
operation fails. The arguments are
number
nErrorCode
The error code.
string
strErrorString
The error string.
OCRResult
Return
value
Availability
Usage
notes
The OCR result for the image.
Result
boolean
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
Check out the sample code and the details for
OCRResult
.
RecognizeSelectedImages()
Performs OCR on the currently selected images in buffer.
Syntax
Return
value
.Addon.OCRPro.RecognizeSelectedImages(asyncSuccessFunc, asyncFailureFunc);
boolean
243
asyncSuccessFunc : Callback function triggered when
the OCR executed successfully. The only argument is
OCRResult
asyncFailureFunc
: Callback function triggered when the OCR
operation fails. The arguments are
Parameters
number
nErrorCode
The error code.
string
strErrorString
The error string.
OCRResult
Availability
Usage
notes
The OCR result for the image.
Result
The OCR result for the image.
Result
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
Check out the sample code and the details for
OCRResult
.
Properties
Settings
Returns or sets the parameters for OCR.
Type
Dynamsoft.WebTwain.Addon.OCRPro.NewSettings
Accessors
Get Set
Availability
Usage
notes
ActiveX
H5(Windows)
H5(macOS/TWAIN)
H5(macOS/ICA)
H5(Linux)
✗
✓ | v11.3.2
✗
✗
✗
Check out Settings
New Settings
Name
Type
Description
The language to OCR. E.g., "eng" or
Languages
EnumDWT_OCRLanguage
LicenseChecker
string
A string that specify the url for the license
checker
OutputFormat
EnumDWT_OCROutputFormat
Specify the output format.
E.g., EnumDWT_OCROutputFormat.OCROF_PDFIMAGEOVERTEXT
PDFAVersion
EnumDWT_OCRProPDFAVersion
Specify the PDFA version. E.g.,
PDFVersion
EnumDWT_OCRProPDFVersion
Specify the PDF version. E.g.,
EnumDWT_OCRLanguage.OCRL_ENG
EnumDWT_OCRProPDFAVersion.OCRPPDFAV_1A
EnumDWT_OCRProPDFVersion.OCRPPDFV_0
244
RecognitionModule
Specify the recognition module. E.g.,
EnumDWT_OCRProRecognitionModule
EnumDWT_OCRProRecognitionModule.OCRPM_AUTO
Redaction
Redaction
An object that specifies the redaction
Redaction
Name
Type
Description
FindText
string
The text to find. E.g., "twain".
FindTextFlags
EnumDWT_OCRFindTextFlags
Specify how the finding works.
FindTextAction
EnumDWT_OCRFindTextAction
Specify the action for redaction.
OCRResult
An object of the type
OCRResult
is returned which contains the OCR result. Methods of the object are
Name
Description
Get()
Returns a base64 encoded string that contains the result of the OCR
operation.
GetErrorCode()
Returns the OCR error code.
GetErrorString()
Returns the OCR error string.
GetErrorDetailList()
Returns an array which contains detailed error information for each page that
was OCR'd. Check out ErrorInfo.
GetInput()
Returns the input information of the OCR processing methods. The input
could be the indices of the images in buffer or the local file paths.
Save()
Saves the OCR result as a file (.txt, .pdf, etc.) on the local disk.
GetOCRTotalCount()
Returns how many pages are allowed to be OCR'd by the current license.
E.g. 300000.
GetAlreadyOCRCount()
Returns how many pages have been OCR'd.
GetPageCount()
Returns how many pages there are in the OCR result.
GetPageContent(nPageIndex)
Returns the content (
PageResult
) of the page specified by
nPageIndex
.
PageResult
An object of the type
PageResult
is returned by
Name
GetPageContent(nPageIndex)
. Methods of the object are
Description
GetLetterCount()
Returns how many letters are recognized on the specified page.
GetLetterContent(nLetterIndex)
Returns the content (
LetterResult
) of the specified letter.
LetterResult
An object of the type
Name
LetterResult
is returned by
GetLetterContent(nLetterIndex)
Description
245
. Methods of the object are
GetText()
Returns the text of the specified word in the OCR result.
GetLetterRect()
Returns the coordinates for the rectangle that contains a specified letter. The
coordinates string is in the format of "left,top,right,bottom".
ErrorInfo
The following are the methods in each
Name
ErrorInfo
object.
Description
GetInput()
Returns the file path or the index of the Input.
GetMessage()
Returns the error message.
GetPage()
Returns the number of the page on which the error was thrown. If GetInput() returns a
file path, then this returns the index of the page in that file. If GetInput() returns an index,
then GetPage() is always "0".
Server-Side
The OCR Pro engine runs as a service. The process of server-side OCR is
1. The image(s) is uploaded to the server and saved
2. The path(s) of the saved image(s) is sent to the OCR pro service as part of the OCRPro.ServerSide.Request
3. The service returns the OCR result in a HTTP Response
The following demonstrates the structures of the Request and the Response
OCRPro.ServerSide.Request
{
productKey: "***",
inputFile: ["d:\\input\\1.tif"],
outputFile: " d:\\temp\\ocrresult.pdf",
zones: [[100, 100, 200, 300]],
settings:
{
recognitionModule: "auto", /*optional*/
languages: "eng,arabic",
recognitionMethod: "File",
threadCount: "2", /*optional*/
outputFormat: "IOTPDF",
pdfVersion: "1.7", /*optional*/
pdfAVersion: "pdf/a-2a", /*optional*/
redaction:
{
"findText": "AAA",
"findTextFlags": 1,
"findTextAction": 0
}
}
}
API
Description
246
productKey
The product key which is generated from an OCR license.
inputFile
Specifies the files to be OCR'd. This is an array of strings which are absolute paths
of the files. The supported formats are BMP, JPG, TIF, PDF, PNG, JBIG2,
JPEG2000, PCX, etc. Please note the use of '\\' instead of just '\'.
outputFile
Specifies where the output file is saved. If the input includes more than one file, all
of them will be merged into one file. Otherwise, the result will only be returned in the
OCRPro.ServerSide.Response.
zones
Specifies which zones are to be OCR'd on an image. There can be multiple zones
but it works only when the recognitionMethod is Page . The coordinates are in the
sequence of [[left, top, right, bottom]].
settings
Specifies which Module is to be used for this OCR. Allowed values are:
Most accurate but time consuming
mostaccurate
fastest
Takes the least time but not very accurate
balanced
Maintains a balance between accuracy and performance
auto
Automatically use one of the aboove 3 modules, this is the
default value
.recognitionModule
.languages
Specifies the language for this OCR. For example, English: "eng", Arabic :"arabic".
You can also set multiple languages like this "eng,arabic". The supported languages
are "ara / arabic; ces / czech; dan / danish; deu / german; ell / greek; eng / english;
fra / french; fin / finnish; hun / hungar; ita / italian; nld / duntch; nor / norsk; por / port;
pol / polish; rus / russian; swe / swedish; spa / spanish; tur / turkish";
.recognitionMethod
Specifies how the OCR is performed. There are two methods: Page is the default
value and it means the OCR is performed on one page at a time, the other method
is File which means the OCR is performed on one file at a time. The method File
is faster and it supports multiple threads. But only the method Page supports zonal
OCR and returning detailed results like the coordinates for each recognized letter.
.threadCount
Specifies the maximum number of threads to be used for this OCR. The default
value is -1 which means all possible threads will be used. This setting is only valid
when recognitionMethod is set to File .
Specifies the file type for outputting the OCR result. Allowed values are
Format
.outputFormat
.pdfVersion
.pdfAVersion
Description
TXTS
Standard text file.
TXTCSV
CSV text file.
TXTF
Formatted Text file.
XML
Simple XML file.
IOTPDF
Image over text PDF file.
IOTPDF_MRC
Image over text PDF with MRC technology.
Specifies the version of the PDF file if the outputFormat is set to either IOTPDF or
IOTPDF_MRC . The version number allowed are 1.0 to 1.7 and by default it is 1.5.
Specifies the version of the PDF file if the outputFormat is set to either IOTPDF or
IOTPDF_MRC . The version number allowed are "pdf/a-1a","pdf/a-1b","pdf/a-2a ","
247
pdf/a-2b "," pdf/a-2u ", " pdf/a-3a ","pdf/a-3b","pdf/a-3u".
Specifies how the redaction is done.
Option
.redaction
Description
findText
A string to specify what to find.
findTextFlags
Specifies how the text is found. The allowed values are 1
(WHOLEWORD), 2 (MATCHCASE), 4 (FUZZYMATCH).
findTextAction
Specifies the action once the text is found. The allowed
values are 0 (HIGHLIGHT), 1 (STRIKEOUT) or 2
(MARKFORREDACT).
OCRPro.ServerSide.Response
{
"Request": {
inputFile: ["d:\\input\\1.tif"],
settings: {...},
outputFile: ...
}
ocrTotalCount: 300000,
alreadyOCRCount: 80,
code: 0,
message: "Recognize succeeded.",
errorList:
[
{
"input": "d:\\input\\1.tif",
"message": "Image file format error.",
"page": "1"
}
]
resultFile: "***", //base64-encoded file content
resultDetail:
[
[//page 0
{//letter 0
"letter": "Aa",
"boundary": [0,0,18,18]
},
{//letter 1
...
},
...
],
[//page 1
...
],
...
]
}
API
Description
inputFile
Check out OCRPro.ServerSide.Request for more info.
settings
Check out OCRPro.ServerSide.Request for more info.
outputFile
248
outputFile
Check out OCRPro.ServerSide.Request for more info.
ocrTotalCount
Returns how many pages are allowed to be OCR'd by the current license.
alreadyOCRCount
Returns how many pages have already been OCR'd.
code
Returns the error code for the OCR. If it's not
message
Returns the overall error message.
errorList
Returns the detailed error messages for each of the OCR'd files.
resultFile
Returns the result file encoded as a base64 string. It only works when
OCRPro.ServerSide.Request doesn't specify an output file path.
resultDetail
Returns detailed OCR result down to each found letter in JSON format. This is only
valid when the recognitionMethod is set to Page .
249
0
, check
errorList
for more details.
Appendix
Editions
Dynamic Web TWAIN
Name
Description
HTML5 for
Windows
This edition supports Chrome 27+, Firefox 27+, IE 10+ and Edge on Windows
HTML5 for Mac
This edition supports Chrome 27+, Firefox 27+ and Safari 7+ on macOS
HTML5 for Linux
This edition supports Chrome 27+, Firefox 27+ on Linux
HTML5
This refers to all three editions above
ActiveX for
Windows
This edition supports IE 6 ~ 9 and can be configured to work in IE 10/11 as well on
Windows
Mobile Browser Capture
Name
Description
Mobile Browser Capture
This edition supports Safari 11+ on
iOS
and Chrome 58+ on
Operating Systems
Windows
Windows XP/7/8/2008/2012/2016 and 10; 32-bit and 64-bit
macOS
OS X 10.6.8 and later
Linux
Ubuntu 12.0.4+, Debian 8+, Fedora 24+, mint 18.3; 64-bit
Function Prototypes
Description The following are all the function prototypes used in Dynamic Web TWAIN.
OnSuccess()
Parameters
Type
Description
None
N/A
N/A
250
Android
OnFailure(errorCode, errorString)
Parameters
Type
Description
errorCode
Number
The error code
errorString
String
The error string
OnHttpUploadSuccess(sHttpResponse)
Parameters
Type
Description
sHttpResponse
String
The information returned from the server after the upload
OnHttpUploadFailure(errorCode, errorString, sHttpResponse)
Parameters
Type
Description
errorCode
Number
The error code
errorString
String
The error string
sHttpResponse
String
The detailed error information returned from the server
251
Enumerations
EnumDWT_PixelType
TWPT_BW
0
TWPT_GRAY
1
TWPT_RGB
2
TWPT_PALLETE
3
TWPT_CMY
4
TWPT_CMYK
5
TWPT_YUV
6
TWPT_YUVK
7
TWPT_CIEXYZ
8
TWPT_LAB
9
TWPT_SRGB
10
TWPT_SCRGB
11
TWPT_INFRARED
16
EnumDWT_BorderStyle
TWBS_NONE
0
TWBS_SINGLEFLAT
1
TWBS_SINGLE3D
2
EnumDWT_MessageType
TWQC_GET
1
TWQC_SET
2
TWQC_GETDEFAULT
4
TWQC_GETCURRENT
8
TWQC_RESET
16
EnumDWT_Cap
CAP_NONE
0
CAP_XFERCOUNT
1
ICAP_COMPRESSION
256
ICAP_PIXELTYPE
257
ICAP_UNITS
258
252
ICAP_XFERMECH
259
CAP_AUTHOR
4096
CAP_CAPTION
4097
CAP_FEEDERENABLED
4098
CAP_FEEDERLOADED
4099
CAP_TIMEDATE
4100
CAP_SUPPORTEDCAPS
4101
CAP_EXTENDEDCAPS
4102
CAP_AUTOFEED
4103
CAP_CLEARPAGE
4104
CAP_FEEDPAGE
4105
CAP_REWINDPAGE
4106
CAP_INDICATORS
4107
CAP_SUPPORTEDCAPSEXT
4108
CAP_PAPERDETECTABLE
4109
CAP_UICONTROLLABLE
4110
CAP_DEVICEONLINE
4111
CAP_AUTOSCAN
4112
CAP_THUMBNAILSENABLED
4113
CAP_DUPLEX
4114
CAP_DUPLEXENABLED
4115
CAP_ENABLEDSUIONLY
4116
CAP_CUSTOMDSDATA
4117
CAP_ENDORSER
4118
CAP_ALARMS
4120
CAP_ALARMVOLUME
4121
CAP_AUTOMATICCAPTURE
4122
CAP_TIMEBEFOREFIRSTCAPTURE
4123
CAP_TIMEBETWEENCAPTURES
4124
CAP_CLEARBUFFERS
4125
CAP_MAXBATCHBUFFERS
4126
CAP_DEVICETIMEDATE
4127
CAP_POWERSUPPLY
4128
CAP_CAMERAPREVIEWUI
4129
253
CAP_SERIALNUMBER
4132
CAP_PRINTER
4134
CAP_PRINTERENABLED
4135
CAP_PRINTERINDEX
4136
CAP_PRINTERMODE
4137
CAP_PRINTERSTRING
4138
CAP_PRINTERSUFFIX
4139
CAP_LANGUAGE
4140
CAP_FEEDERALIGNMENT
4141
CAP_FEEDERORDER
4142
CAP_REACQUIREALLOWED
4144
CAP_BATTERYMINUTES
4146
CAP_BATTERYPERCENTAGE
4147
CAP_CAMERASIDE
4148
CAP_SEGMENTED
4149
CAP_CAMERAENABLED
4150
CAP_CAMERAORDER
4151
CAP_MICRENABLED
4152
CAP_FEEDERPREP
4153
CAP_FEEDERPOCKET
4154
CAP_AUTOMATICSENSEMEDIUM
4155
CAP_CUSTOMINTERFACEGUID
4156
ICAP_AUTOBRIGHT
4352
ICAP_BRIGHTNESS
4353
ICAP_CONTRAST
4355
ICAP_CUSTHALFTONE
4356
ICAP_EXPOSURETIME
4357
ICAP_FILTER
4358
ICAP_FLASHUSED
4359
ICAP_GAMMA
4360
ICAP_HALFTONES
4361
ICAP_HIGHLIGHT
4362
ICAP_IMAGEFILEFORMAT
4364
ICAP_LAMPSTATE
4365
254
ICAP_LIGHTSOURCE
4366
ICAP_ORIENTATION
4368
ICAP_PHYSICALWIDTH
4369
ICAP_PHYSICALHEIGHT
4370
ICAP_SHADOW
4371
ICAP_FRAMES
4372
ICAP_XNATIVERESOLUTION
4374
ICAP_YNATIVERESOLUTION
4375
ICAP_XRESOLUTION
4376
ICAP_YRESOLUTION
4377
ICAP_MAXFRAMES
4378
ICAP_TILES
4379
ICAP_BITORDER
4380
ICAP_CCITTKFACTOR
4381
ICAP_LIGHTPATH
4382
ICAP_PIXELFLAVOR
4383
ICAP_PLANARCHUNKY
4384
ICAP_ROTATION
4385
ICAP_SUPPORTEDSIZES
4386
ICAP_THRESHOLD
4387
ICAP_XSCALING
4388
ICAP_YSCALING
4389
ICAP_BITORDERCODES
4390
ICAP_PIXELFLAVORCODES
4391
ICAP_JPEGPIXELTYPE
4392
ICAP_TIMEFILL
4394
ICAP_BITDEPTH
4395
ICAP_BITDEPTHREDUCTION
4396
ICAP_UNDEFINEDIMAGESIZE
4397
ICAP_EXTIMAGEINFO
4399
ICAP_MINIMUMHEIGHT
4400
ICAP_MINIMUMWIDTH
4401
ICAP_AUTODISCARDBLANKPAGES
4404
ICAP_FLIPROTATION
4406
255
ICAP_BARCODEDETECTIONENABLED
4407
ICAP_SUPPORTEDBARCODETYPES
4408
ICAP_BARCODEMAXSEARCHPRIORITIES
4409
ICAP_BARCODESEARCHPRIORITIES
4410
ICAP_BARCODESEARCHMODE
4411
ICAP_BARCODEMAXRETRIES
4412
ICAP_BARCODETIMEOUT
4413
ICAP_ZOOMFACTOR
4414
ICAP_PATCHCODEDETECTIONENABLED
4415
ICAP_SUPPORTEDPATCHCODETYPES
4416
ICAP_PATCHCODEMAXSEARCHPRIORITIES
4417
ICAP_PATCHCODESEARCHPRIORITIES
4418
ICAP_PATCHCODESEARCHMODE
4419
ICAP_PATCHCODEMAXRETRIES
4420
ICAP_PATCHCODETIMEOUT
4421
ICAP_FLASHUSED2
4422
ICAP_IMAGEFILTER
4423
ICAP_NOISEFILTER
4424
ICAP_OVERSCAN
4425
ICAP_AUTOMATICBORDERDETECTION
4432
ICAP_AUTOMATICDESKEW
4433
ICAP_AUTOMATICROTATE
4434
ICAP_JPEGQUALITY
4435
ICAP_FEEDERTYPE
4436
ICAP_ICCPROFILE
4437
ICAP_AUTOSIZE
4438
ICAP_AUTOMATICCROPUSESFRAME
4439
ICAP_AUTOMATICLENGTHDETECTION
4440
ICAP_AUTOMATICCOLORENABLED
4441
ICAP_AUTOMATICCOLORNONCOLORPIXELTYPE
4442
ICAP_COLORMANAGEMENTENABLED
4443
ICAP_IMAGEMERGE
4444
ICAP_IMAGEMERGEHEIGHTTHRESHOLD
4445
ICAP_SUPPORTEDEXTIMAGEINFO
4446
256
EnumDWT_CapType
TWON_NONE
0
TWON_ARRAY
3
TWON_ENUMERATION
4
TWON_ONEVALUE
5
TWON_RANGE
6
EnumDWT_TransferMode
TWSX_NATIVE
0
TWSX_FILE
1
TWSX_MEMORY
2
EnumDWT_FileFormat
TWFF_TIFF
0
TWFF_PICT
1
TWFF_BMP
2
TWFF_XBM
3
TWFF_JFIF
4
TWFF_FPX
5
TWFF_TIFFMULTI
6
TWFF_PNG
7
TWFF_SPIFF
8
TWFF_EXIF
9
TWFF_PDF
10
TWFF_JP2
11
TWFF_JPN
12
TWFF_JPX
13
TWFF_DEJAVU
14
TWFF_PDFA
15
TWFF_PDFA2
16
EnumDWT_TIFFCompressionType
TIFF_AUTO
0
TIFF_NONE
1
TIFF_RLE
2
TIFF_FAX3
3
257
TIFF_T4
3
TIFF_FAX4
4
TIFF_T6
4
TIFF_LZW
5
TIFF_JPEG
7
TIFF_PACKBITS
32773
EnumDWT_InterpolationMethod
IM_NEARESTNEIGHBOUR
1
IM_BILINEAR
2
IM_BICUBIC
3
IM_BESTQUALITY
5
EnumDWT_ImageType
IT_BMP
0
IT_JPG
1
IT_TIF
2
IT_PNG
3
IT_PDF
4
IT_ALL
5
IT_GIF
6
EnumDWT_PDFCompressionType
PDF_AUTO
0
PDF_FAX3
1
PDF_FAX4
2
PDF_LZW
3
PDF_RLE
4
PDF_JPEG
5
EnumDWT_ShowMode
SW_ACTIVE
0
SW_MAX
1
SW_MIN
2
SW_CLOSE
3
SW_IFLIVE
4
258
EnumDWT_CapValueType
TWTY_INT8
0
TWTY_INT16
1
TWTY_INT32
2
TWTY_UINT8
3
TWTY_UINT16
4
TWTY_int
5
TWTY_BOOL
6
TWTY_FIX32
7
TWTY_FRAME
8
TWTY_STR32
9
TWTY_STR64
10
TWTY_STR128
11
TWTY_STR255
12
EnumDWT_UnitType
TWUN_INCHES
0
TWUN_CENTIMETERS
1
TWUN_PICAS
2
TWUN_POINTS
3
TWUN_TWIPS
4
TWUN_PIXELS
5
TWUN_MILLIMETERS
6
EnumDWT_DUPLEX
TWDX_NONE
0
TWDX_1PASSDUPLEX
1
TWDX_2PASSDUPLEX
2
EnumDWT_CapLanguage
TWLG_DAN
0
TWLG_DUT
1
TWLG_ENG
2
TWLG_FCF
3
TWLG_FIN
4
TWLG_FRN
5
259
TWLG_GER
6
TWLG_ICE
7
TWLG_ITN
8
TWLG_NOR
9
TWLG_POR
10
TWLG_SPA
11
TWLG_SWE
12
TWLG_USA
13
TWLG_USERLOCALE
-1
TWLG_AFRIKAANS
14
TWLG_ALBANIA
15
TWLG_ARABIC
16
TWLG_ARABIC_ALGERIA
17
TWLG_ARABIC_BAHRAIN
18
TWLG_ARABIC_EGYPT
19
TWLG_ARABIC_IRAQ
20
TWLG_ARABIC_JORDAN
21
TWLG_ARABIC_KUWAIT
22
TWLG_ARABIC_LEBANON
23
TWLG_ARABIC_LIBYA
24
TWLG_ARABIC_MOROCCO
25
TWLG_ARABIC_OMAN
26
TWLG_ARABIC_QATAR
27
TWLG_ARABIC_SAUDIARABIA
28
TWLG_ARABIC_SYRIA
29
TWLG_ARABIC_TUNISIA
30
TWLG_ARABIC_UAE
31
TWLG_ARABIC_YEMEN
32
TWLG_BASQUE
33
TWLG_BYELORUSSIAN
34
TWLG_BULGARIAN
35
TWLG_CATALAN
36
TWLG_CHINESE
37
TWLG_CHINESE_HONGKONG
38
260
TWLG_CHINESE_PRC
39
TWLG_CHINESE_SINGAPORE
40
TWLG_CHINESE_SIMPLIFIED
41
TWLG_CHINESE_TAIWAN
42
TWLG_CHINESE_TRADITIONAL
43
TWLG_CROATIA
44
TWLG_CZECH
45
TWLG_DANISH
0
TWLG_DUTCH
1
TWLG_DUTCH_BELGIAN
46
TWLG_ENGLISH
2
TWLG_ENGLISH_AUSTRALIAN
47
TWLG_ENGLISH_CANADIAN
48
TWLG_ENGLISH_IRELAND
49
TWLG_ENGLISH_NEWZEALAND
50
TWLG_ENGLISH_SOUTHAFRICA
51
TWLG_ENGLISH_UK
52
TWLG_ENGLISH_USA
13
TWLG_ESTONIAN
53
TWLG_FAEROESE
54
TWLG_FARSI
55
TWLG_FINNISH
4
TWLG_FRENCH
5
TWLG_FRENCH_BELGIAN
56
TWLG_FRENCH_CANADIAN
3
TWLG_FRENCH_LUXEMBOURG
57
TWLG_FRENCH_SWISS
58
TWLG_GERMAN
6
TWLG_GERMAN_AUSTRIAN
59
TWLG_GERMAN_LUXEMBOURG
60
TWLG_GERMAN_LIECHTENSTEIN
61
TWLG_GERMAN_SWISS
62
TWLG_GREEK
63
TWLG_HEBREW
64
261
TWLG_HUNGARIAN
65
TWLG_ICELANDIC
7
TWLG_INDONESIAN
66
TWLG_ITALIAN
8
TWLG_ITALIAN_SWISS
67
TWLG_JAPANESE
68
TWLG_KOREAN
69
TWLG_KOREAN_JOHAB
70
TWLG_LATVIAN
71
TWLG_LITHUANIAN
72
TWLG_NORWEGIAN
9
TWLG_NORWEGIAN_BOKMAL
73
TWLG_NORWEGIAN_NYNORSK
74
TWLG_POLISH
75
TWLG_PORTUGUESE
10
TWLG_PORTUGUESE_BRAZIL
76
TWLG_ROMANIAN
77
TWLG_RUSSIAN
78
TWLG_SERBIAN_LATIN
79
TWLG_SLOVAK
80
TWLG_SLOVENIAN
81
TWLG_SPANISH
11
TWLG_SPANISH_MEXICAN
82
TWLG_SPANISH_MODERN
83
TWLG_SWEDISH
12
TWLG_THAI
84
TWLG_TURKISH
85
TWLG_UKRANIAN
86
TWLG_ASSAMESE
87
TWLG_BENGALI
88
TWLG_BIHARI
89
TWLG_BODO
90
TWLG_DOGRI
91
TWLG_GUJARATI
92
262
TWLG_HARYANVI
93
TWLG_HINDI
94
TWLG_KANNADA
95
TWLG_KASHMIRI
96
TWLG_MALAYALAM
97
TWLG_MARATHI
98
TWLG_MARWARI
99
TWLG_MEGHALAYAN
100
TWLG_MIZO
101
TWLG_NAGA
102
TWLG_ORISSI
103
TWLG_PUNJABI
104
TWLG_PUSHTU
105
TWLG_SERBIAN_CYRILLIC
106
TWLG_SIKKIMI
107
TWLG_SWEDISH_FINLAND
108
TWLG_TAMIL
109
TWLG_TELUGU
110
TWLG_TRIPURI
111
TWLG_URDU
112
TWLG_VIETNAMESE
113
EnumDWT_CapSupportedSizes
TWSS_NONE
0
TWSS_A4LETTER
1
TWSS_B5LETTER
2
TWSS_USLETTER
3
TWSS_USLEGAL
4
TWSS_A5
5
TWSS_B4
6
TWSS_B6
7
TWSS_USLEDGER
9
TWSS_USEXECUTIVE
10
TWSS_A3
11
TWSS_B3
12
263
TWSS_A6
13
TWSS_C4
14
TWSS_C5
15
TWSS_C6
16
TWSS_4A0
17
TWSS_2A0
18
TWSS_A0
19
TWSS_A1
20
TWSS_A2
21
TWSS_A4
1
TWSS_A7
22
TWSS_A8
23
TWSS_A9
24
TWSS_A10
25
TWSS_ISOB0
26
TWSS_ISOB1
27
TWSS_ISOB2
28
TWSS_ISOB3
12
TWSS_ISOB4
6
TWSS_ISOB5
29
TWSS_ISOB6
7
TWSS_ISOB7
30
TWSS_ISOB8
31
TWSS_ISOB9
32
TWSS_ISOB10
33
TWSS_JISB0
34
TWSS_JISB1
35
TWSS_JISB2
36
TWSS_JISB3
37
TWSS_JISB4
38
TWSS_JISB5
2
TWSS_JISB6
39
TWSS_JISB7
40
TWSS_JISB8
41
264
TWSS_JISB9
42
TWSS_JISB10
43
TWSS_C0
44
TWSS_C1
45
TWSS_C2
46
TWSS_C3
47
TWSS_C7
48
TWSS_C8
49
TWSS_C9
50
TWSS_C10
51
TWSS_USSTATEMENT
52
TWSS_BUSINESSCARD
53
TWSS_MAXSIZE
54
EnumDWT_CapFeederAlignment
TWFA_NONE
0
TWFA_LEFT
1
TWFA_CENTER
2
TWFA_RIGHT
3
EnumDWT_CapFeederOrder
TWFO_FIRSTPAGEFIRST
0
TWFO_LASTPAGEFIRST
1
EnumDWT_CapPrinter
TWPR_IMPRINTERTOPBEFORE
0
TWPR_IMPRINTERTOPAFTER
1
TWPR_IMPRINTERBOTTOMBEFORE
2
TWPR_IMPRINTERBOTTOMAFTER
3
TWPR_ENDORSERTOPBEFORE
4
TWPR_ENDORSERTOPAFTER
5
TWPR_ENDORSERBOTTOMBEFORE
6
TWPR_ENDORSERBOTTOMAFTER
7
EnumDWT_CapPrinterMode
TWPM_SINGLESTRING
0
TWPM_MULTISTRING
1
265
TWPM_COMPOUNDSTRING
2
EnumDWT_CapBitdepthReduction
TWBR_THRESHOLD
0
TWBR_HALFTONE
1
TWBR_CUSTHALFTONE
2
TWBR_DIFFUSION
3
EnumDWT_CapBitOrder
TWBO_LSBFIRST
0
TWBO_MSBFIRST
1
EnumDWT_CapFilterType
TWFT_RED
0
TWFT_GREEN
1
TWFT_BLUE
2
TWFT_NONE
3
TWFT_WHITE
4
TWFT_CYAN
5
TWFT_MAGENTA
6
TWFT_YELLOW
7
TWFT_BLACK
8
EnumDWT_CapFlash
TWFL_NONE
0
TWFL_OFF
1
TWFL_ON
2
TWFL_AUTO
3
TWFL_REDEYE
4
EnumDWT_CapFlipRotation
TWFR_BOOK
0
TWFR_FANFOLD
1
EnumDWT_CapImageFilter
TWIF_NONE
0
TWIF_AUTO
1
TWIF_LOWPASS
2
266
TWIF_BANDPASS
3
TWIF_HIGHPASS
4
TWIF_TEXT
3
TWIF_FINELINE
4
EnumDWT_CapLightPath
TWLP_REFLECTIVE
0
TWLP_TRANSMISSIVE
1
EnumDWT_CapLightSource
TWLS_RED
0
TWLS_GREEN
1
TWLS_BLUE
2
TWLS_NONE
3
TWLS_WHITE
4
TWLS_UV
5
TWLS_IR
6
EnumDWT_MagType
TWMD_MICR
0
TWMD_RAW
1
TWMD_INVALID
2
EnumDWT_CapNoiseFilter
TWNF_NONE
0
TWNF_AUTO
1
TWNF_LONEPIXEL
2
TWNF_MAJORITYRULE
3
EnumDWT_CapORientation
TWOR_ROT0
0
TWOR_ROT90
1
TWOR_ROT180
2
TWOR_ROT270
3
TWOR_PORTRAIT
0
TWOR_LANDSCAPE
3
TWOR_AUTO
4
267
TWOR_AUTOTEXT
5
TWOR_AUTOPICTURE
6
EnumDWT_CapOverscan
TWOV_NONE
0
TWOV_AUTO
1
TWOV_TOPBOTTOM
2
TWOV_LEFTRIGHT
3
TWOV_ALL
4
EnumDWT_CapPixelFlavor
TWPF_CHOCOLATE
0
TWPF_VANILLA
1
EnumDWT_CapPlanarChunky
TWPC_CHUNKY
0
TWPC_PLANAR
1
EnumDWT_DataSourceStatus
TWDSS_CLOSED
0
TWDSS_OPENED
1
TWDSS_ENABLED
2
TWDSS_ACQUIRING
3
EnumDWT_FitWindowType
enumFitWindow
0
enumFitWindowHeight
1
enumFitWindowWidth
2
EnumDWT_PlatformType
enumWindow
0
enumMac
1
enumLinux
2
EnumDWT_UploadDataFormat
Binary
0
Base64
1
EnumDWT_MouseShape
268
Default
0
Hand
1
Crosshair
2
Zoom
3
NWResize
4
EResize
5
NResize
6
Resize
7
Move
8
EnumDWT_Language
English
0
French
1
Arabic
2
Spanish
3
Portuguese
4
German
5
Italian
6
Russian
7
Chinese
8
EnumDWT_InitMsg
Info
1
Error
2
NotInstalledError
3
DownloadError
4
DownloadNotRestartError
5
EnumDWT_Driver
TWAIN
0
ICA
3
SANE
3
TWAIN_AND_ICA
4
EnumDWT_OCRDownloadType
OCRDT_Dll
0
OCRDT_LANGUAGE
1
269
EnumDWT_OCRLanguage
Code
Language
Value
OCRL_ARA
Arabic
ara
OCRL_BEN
Bengali
ben
OCRL_CHI_SIM
Chinese_Simplified
chi_sim
OCRL_CHI_TRA
Chinese_Traditional
chi_tra
OCRL_DEU
German
deu
OCRL_ENG
English
eng
OCRL_FAS
Persian
fas
OCRL_FRA
French
fra
OCRL_HIN
Hindi
hin
OCRL_IND
Indonesian
ind
OCRL_ITA
Italian
ita
OCRL_JAV
Javanese
jav
OCRL_JPN
Japanese
jpn
OCRL_KOR
Korean
kor
OCRL_MAR
Marathi
mar
OCRL_MSA
Malay
msa
OCRL_PAN
Panjabi
pan
OCRL_POR
Portuguese
por
OCRL_RUS
Russian
rus
OCRL_SPA
Spanish
spa
OCRL_SWA
Swahili
swa
OCRL_TAM
Tamil
tam
OCRL_TEL
Telugu
tel
OCRL_THA
Thai
tha
OCRL_TUR
Turkish
tur
OCRL_URD
Urdu
urd
OCRL_VIE
Vietnamese
vie
EnumDWT_OCROutputFormat
OCROF_TEXT
0
Outputs in a plain text format with a .txt extension if
saved as a file.
OCROF_PDFPLAINTEXT
1
Outputs the OCR text results to a PDF. Any images
from the original scanned image are lost.
Outputs the OCR text results to a PDF, with the
270
original scanned image printed overtop.
OCROF_PDFPLAINTEXT_PDFX
3
Outputs the OCR text results to a PDF/A. Any
images from the original scanned image are lost.
OCROF_PDFIMAGEOVERTEXT_PDFX
4
Outputs the OCR text results to a PDF/A, with the
original scanned image printed overtop.
EnumDWT_OCRPageSetMode
OCRPSM_OSD_ONLY
0
Script detection only(OSD).
PSM_AUTO_OSD
1
Automatic page segmentation with orientation and script
detection. (OSD)
PSM_AUTO_ONLY
2
Automatic page segmentation, but no OSD, or OCR.
PSM_AUTO
3
Fully automatic page segmentation, but no OSD. (Default)
PSM_SINGLE_COLUMN
4
Assume a single column of text of variable sizes.
PSM_SINGLE_COLUMN
5
Assume a single uniform block of vertically aligned text.
PSM_SINGLE_BLOCK
6
Assume a single uniform block of text.
PSM_SINGLE_LINE
7
Treat the image as a single text line.
PSM_SINGLE_WORD
8
Treat the image as a single word.
PSM_CIRCLE_WORD
9
Treat the image as a single word in a circle.
PSM_SINGLE_CHAR
10
Treat the image as a single character.
EnumDWT_OCRProRecognitionModule
OCRPM_AUTO
AUTO
OCRPM_MOSTACCURATE
MOSTACCURATE
OCRPM_BALANCED
BALANCED
OCRPM_FASTEST
FASTEST
EnumDWT_OCRProOutputFormat
OCRPFT_TXTS
TXTS
OCRPFT_TXTCSV
TXTCSV
OCRPFT_TXTF
TXTF
OCRPFT_XML
XML
OCRPFT_IOTPDF
IOTPDF
OCRPFT_IOTPDF_MRC
IOTPDF_MRC
EnumDWT_OCRProPDFVersion
OCRPPDFV_0
1.0
OCRPPDFV_1
1.1
OCRPPDFV_2
1.2
271
OCRPPDFV_3
1.3
OCRPPDFV_4
1.4
OCRPPDFV_5
1.5
OCRPPDFV_6
1.6
OCRPPDFV_7
1.7
EnumDWT_OCRProPDFAVersion
OCRPPDFAV_1A
pdf/a-1a
OCRPPDFAV_1B
pdf/a-1b
OCRPPDFAV_2A
pdf/a-2a
OCRPPDFAV_2B
pdf/a-2b
OCRPPDFAV_2U
pdf/a-2u
OCRPPDFAV_3A
pdf/a-3a
OCRPPDFAV_3B
pdf/a-3b
OCRPPDFAV_3U
pdf/a-3u
EnumDWT_OCRProType
OCRDT_File
0
OCRDT_Index
1
EnumDWT_OCRFindTextFlags
OCRFT_WHOLEWORD
1
OCRFT_MATCHCASE
2
OCRFT_FUZZYMATCH
4
EnumDWT_OCRFindTextAction
OCRFT_HIGHLIGHT
0
OCRFT_STRIKEOUT
1
OCRFT_MARKFORREDACT
2
Error List
Error
Code
Error String
0
Successful
-1001
General failure
-1002
Not enough memory to perform operation
-1003
Source Manager unable to find the specified Source
272
-1004
Source is connected to maximum supported number of applications
-1005
Source or Source Manager reported an error to the user and handled the error
-1006
Capability not supported by Source or operation is not supported on capability, or capability had
dependencies on other capabilities and cannot be operated upon at this time
-1009
Unrecognized operation triplet
-1010
Data parameter out of supported range
-1011
Operation out of expected sequence
-1012
Unknown destination in DSM_Entry
-1013
Capability not supported by source
-1014
Operation not supported by capability
-1015
Capability has dependency on other capability and cannot be operated upon at this time
-1016
File System operation is denied (file is protected)
-1017
Operation failed because file already exists
-1018
File not found
-1019
Operation failed because directory is not empty
-1020
The feeder is jammed
-1021
The feeder detected multiple pages
-1022
Error writing file
-1023
The device went offline prior to or during this operation
-1030
Can not open Source Manager "TWain_32.dll" is missing or is in use by another application
-1031
Sequence error. The operation can not be performed upon the current Source Manager or
Source state
-1032
User cancelled the operation
-1033
Invalid index
-1034
Invalid value
-1035
There is no image
-1036
Error reading file
-1070
BMP file or format error
-1071
JPEG file or format error
-1073
Only 24-bit true color and 8-bit gray-scaled images are supported for JPEG compression
-1080
General TIFF error
-1081
TIFF format error or not supported
-1090
BMP format error or not supported
-1100
PNG format error or not supported
-1110
Unrecognized file extension
273
-1200
PDF format error or not supported
-2000
Can not initiate the internet session
-2001
HTTP request error
-2002
HTTP server error
-2003
HTTP process error
-2004
FTP download file is too large
-2007
The system is busy, some operations are not completed. Please try later
-2207
The dynamsoft service installed on your computer is outdated and no longer works with the
JavaScript code on the website
-2208
The connection with the local dynamsoft service encountered a problem and has been reset
-2209
The HTML5 (Chrome&Firefox) edition does not support this method or property
-2300
Http upload error: the HTTP Server cannot empty
-2301
Network error
-2302
The result format is invalid
-2303
Upload cancelled
-2304
Http download error: the url is invalid
-2305
User cancelled the operation
-2306
Upload Error: the upload file cannot be empty
-2307
The width or height you entered is invalid
-2308
The local dynamsoft service has been stopped
-2309
The LocalFile is emtpy in the Function
-2310
The index is out of range
-2311
The RemoteFile is emtpy in Barcode Download Function
-2312
The file length is emtpy
-2313
The size of the images you are about to upload has exceeded the allowed size
-2314
The parameter cannot be empty
-2315
The index is out of range
-2316
The RemoteFile is emtpy in Webcam Download Function
-2317
The RemoteFile is emtpy in Pdf Download Function
-2318
Invalid destination file
-2319
Invalid source file
-2320
Invalid file
-2321
The index is out of range
-2322
The left or top or right or bottom you entered is invalid
-2323
The OCR output format is not supported
274
-2324
The OCR page set mode is not supported
-2325
The current product key is empty or invalid, please contact the site administrator
-2326
The current product key has expired, please contact the site administrator
-2327
The current product key does not support Chrome, please contact the site administrator
-2328
The current product key does not support Firefox, please contact the site administrator
-2329
The current product key does not support IE, please contact the site administrator
-2330
The current product key does not support Edge, please contact the site administrator
-2331
The current product key is a trial version key but your local dynamsoft service is in full version,
please uninstall your local version first and access this page again to install the correct version. If
the issue persists, please contact the site administrator
-2332
The current product key is a full version key but your local dynamsoft service is in trial version,
please uninstall your local version first and access this page again to install the correct version. If
the issue persists, please contact the site administrator
-2333
The current product key is missing the core license, please contact the site administrator
-2334
The current product key does not include a license for reading 1D barcode, please contact the
site administrator
-2335
The current product key does not include a license for reading QRcode barcode, please contact
the site administrator
-2336
The current product key does not include a license for reading PDF417 barcode, please contact
the site administrator
-2337
The current product key does not include a license for reading DataMatrix barcode, please
contact the site administrator
-2338
The current product key does not support Webcam, please contact the site administrator
-2339
The current product key does not support pdf rasterizer, please contact the site administrator
-2340
The current product key does not support OCR, please contact the site administrator
-2341
The current product key does not support OCR pro, please contact the site administrator
-2342
The domain of your current site does not match the domain bound in the current product key,
please contact the site administrator
-2343
The current product key does not support your browser, please contact the site administrator
-2344
The current product key does not support Windows OS, please contact the site administrator
-2345
The current product key does not support MAC OS, please contact the site administrator
-2346
The current product key does not support Linux OS, please contact the site administrator
-2347
The current product key does not support your OS, please contact the site administrator
-2348
The current product key is invalid because it's generated with the licenses of a different major
version
-2349
The current product key does not include a license for reading barcode, please contact the site
administrator
-2350
The indices cannot be empty
-2351
You cannot upload more than one image when the format is BMP, JPG or PNG
-2352
The indices are out of range
275
-2353
The header name being used is a protected keyword and is not allowed
-2354
The header name cannot be empty
-2355
The header name cannot be null
-2356
The header name cannot be undefined
-2357
The header name you entered is invalid
-2358
The type of the parameter indices must be an Array
-2359
The index is out of range
-2360
The index is null or undefined
-2361
You cannot convert more than one image to base64 string when the format is BMP, JPG or PNG
-2362
Convert to base64 failed
-2367
Invalid value for the parameter segmentUploadThreshold
-2368
Invalid value for the parameter moduleSize
-2369
The module for Dynamic Web TWAIN has failed to download
-2370
The current product key is invalid, please contact the site administrator
-2372
You cannot convert to binary more than one image when the format is BMP, JPG or PNG
<=
-3000
See ErrorString property for details
276
Install & Upgrade
Upgrade From Trial or an Old Version
To upgrade Dynamic Web TWAIN from trial or an old version to the latest full version, please follow the steps
below.
For the developer
Basic Steps
Step 1 Update
Resources
on the Development machine
a) Uninstall the trial/old version
Windows: Search Dynamic Web TWAIN in
Control Panel -> Programs and Features
, and remove all
the relevant components there.
macOS: Execute
Applications > Dynamsoft > Dynamic Web TWAIN SDK {Version Number} > Uninstall.pkg
b) Install the latest full version
The download link of the full version can be found in the purchasing email that was sent to the registered
email/purchaser’s email. If you purchased the SDK but lost the download link of the full version, please
request the download again.
c) Replace the whole
Resources
folder of Dynamic Web TWAIN in your application with the
Resources
folder of the full version. Typically, you can find it at the following path
Windows:
macOS:
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {Version Number}
Applications > Dynamsoft > Dynamic Web TWAIN SDK {Version Number}
Step 2 Update the License
a) Replace the product key In the file
Dynamsoft.WebTwainEnv.ProductKey
dynamsoft.webtwain.config.js
, search for
. Input the ProductKeys you received.
Dynamsoft.WebTwainEnv.Containers = [{ContainerId:'dwtcontrolContainer', Width:270, Height:350}];
// Please note that the license key is not the same thing as the Product Key.
// You need to use your license keys to generate a Product Key.
// For more info about how to generate a product key, please check the reference below.
Dynamsoft.WebTwainEnv.ProductKey = '88FFAA09C42D5DE******;t0076lQAAAGNcO61He******';
b) Set
Dynamsoft.WebTwainEnv.Trial
In the file
to
dynamsoft.webtwain.config.js
false
if it's
true
, search for
Dynamsoft.WebTwainEnv.Trial
, and set it to
false
manually.
Step 3 Deploy the full version to the server
After you have finished the testing on your dev machines, you can update your application on the server
accordingly.
For silent upgrade
277
For version 14.3 and above, if you'd like the upgrade to be silent for the end users. The following extra steps are
needed before you deploy your application to the server
a) Download the following files and put them in the correct directory (create the directory if it doesn't exist)
For Windows users, put the following files under
/Resources/dist/win/
https://tst.dynamsoft.com/libs/dwt/14.3/dist/win/WinDWT_14.2.0.1025.zip
https://tst.dynamsoft.com/libs/dwt/14.3/dist/win/Pdf.zip
For macOS users, put the following files under
/Resources/dist/mac/
https://tst.dynamsoft.com/libs/dwt/14.3/dist/mac/MacDWT_14.1.0.0828.zip
https://tst.dynamsoft.com/libs/dwt/14.3/dist/mac/MacPdf.zip
For Linux users, put the following files under
/Resources/dist/linux/
https://tst.dynamsoft.com/libs/dwt/14.3/dist/linux/LinuxDWT_14.1.0.0828.zip
https://tst.dynamsoft.com/libs/dwt/14.3/dist/linux/LinuxPdf.zip
b) Add the configuration
Dynamsoft.WebTwainEnv.IfInstallDWTModuleWithZIP = true
in the file
dynamsoft.webtwain.config.js
For the end users
Download and install the new version when you see the prompt to do so. This only needs to be done once.
For silent upgrade, the end users don't need to do anything.
NOTE If you are upgrading from a very old version (at least 2 major versions apart like from v12 to v14),
more steps may be needed, feel free to contact Dynamsoft Support Team for more information.
Install on the Client Machines
Dynamic Web TWAIN is a 100% client-side SDK, every client machine needs to install its components in order to
use the SDK. Over the years, Dynamsoft has made many efforts to make the process as smooth as possible.
Here we'll talk about how the installation is done in version 14.3 (latest as of November, 2018).
HTML5 editions
Install Dynamsoft Service
When the client first visit the web page which has Dynamic Web TWAIN implemented, the automatic
initialization of the SDK which is built in its JavaScript library will try to establish connection with the
Dynamsoft Service which is expected to be installed locally.
NOTE: the initialization happens after the DOMContentLoaded event has been fired.
The connection will be attempted twice for each of three pre-defined ports. Depending on whether the
protocol is HTTP or HTTPS, the ports are 18625, 18993, 18627 or 18626, 18994, 18628.
Should the connection fails, it means the service is not installed and the following prompt will come up and
ask the end user to download and install the service.
278
NOTE: the same prompt will appear no matter whether the client OS is Windows, macOS or Linux. But
the file you download differs on different Systems. On Windows and macOS, the users can double
click the downloaded installer to install the SDK. On Linux, however, the users will need to run either
one of the following command to install it
Debian / Ubuntu
dpkg -i DynamsoftServiceSetup.deb
Fedora
rpm -ivh DynamsoftServiceSetup.rpm
Install Dynamic Web TWAIN
In version 14.2 and above, Dynamic Web TWAIN and its PDF Rasterizer add-on are installed together with
the Dynamsoft Service. But in versions 13.0 ~ 14.1, Dynamic Web TWAIN is installed separately. In these
versions, once the Service is installed, the JavaScript library will continue to check whether the library file for
Dynamic Web TWAIN is installed (
.dll/.bundle/.so
for Windows/macOS/Linux). The pre-defined ports for
Dynamic Web TWAIN are 18622/18995/18620 (HTTP) or 18623/18996/18621 (HTTPS). If the library isn't
found, the service will attempt to download the file (a
.zip
file that contains the library) and put it in place.
No user-interaction needed for this step.
NOTE: On Windows, should the downloading or installing of the
.zip
come up to allow the user to download and install the library manually.
279
file fails, an extra prompt will
ActiveX Edition
For IE 6~9 on Windows, ActiveX is used. In v14.1 and v14.2, if it's not installed, the following message will
appear where the component is expected to be on the page to allow the user to download and install the ActiveX.
For v14.3 and above, the prompt will be the same as the HTML5 edition
280
NOTE In v14.2 and above, the ActiveX edition is installed together with the Dynamsoft Service and the
HTML5 edition.
For more information about the installation files in version 14.1. Check out About the Distribution Files
Install/Uninstall Silently
To silently install Dynamsoft Service via Command Line, you need to first have the file
DynamsoftServiceSetup.msi
which can be found in the installation folder of Dynamic Web TWAIN which is typically located at
C:\Program Files (x86)\Dynamsoft\Dynamic Web TWAIN SDK {Version No.} {Trial}\Resources\dist\win
Please run the CMD as administrator, and enter the following line of code with the relevant
.msi
name.
C:\Users\{User}\{DWT Path}>msiexec /i DynamsoftServiceSetup.msi /quiet
To silently uninstall Dynamic Web TWAIN, you can replace the
/i
parameter with
/x
.
C:\Users\{User}\{DWT Path}>msiexec /x DynamsoftServiceSetup.msi /quiet
If you want to create an install/uninstall log, you can use a command line which looks like this:
C:\Users\{User}\{DWT Path}>msiexec /x DynamsoftServiceSetup.msi /quiet /L*V "C:\log\example.log"
If you can't find the
.msi
, feel free to contact Dynamsoft Support Team.
Note: if you are a system administrator, you can also use the
.msi
to remotely install the software to all the end-
user machines through Group Policy. Check out the article from Microsoft.
Uninstall on the Client Machines
The step one is always to close the browsers to make sure the SDK is not in use.
On Windows
ActiveX
1. Uninstall the DynamicWebTWAINActiveX through Control Panel. The names for the program are
TWAIN Trial x86
&
Dynamic Web
Dynamic Web TWAIN Trial x64
2. Remove it by using the tool called
DWTICSActiveXClearTool.exe
HTML5
1. Remove the Dynamsoft Service through Control Panel. The name is
2. Remove the folder
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService
Dynamsoft Service
.
and all files under it
On macOS
Run the file
Uninstall.pkg
to uninstall it. The file can be found in
{installed version No.} >
281
Go > Applications > Dynamsoft > WebTwain >
On Linux
Run the file
uninstall.sh
to uninstall it. The file can be found in
282
opt/dynamsoft/DynmasoftService
Deploy & Distribute
Environmental Requirements
Sever Side
Dynamic Web TWAIN runs 100% on the client-side, thus it doesn't matter what operating system runs on the
server. The role of the server is to hold the Resources of the SDK and supply them when needed. No matter what
web server is being used, you must make sure that it has the following MIME types set up correctly
Extension
MIME Type
Required by
.css
text/css
All Editions
.js
application/javascript
All Editions
.zip
application/x-zip-compressed
All Editions
.cab
application/vnd.ms-cab-compressed
ActiveX
.exe
application/octet-stream
ActiveX
.msi
application/octet-stream
HTML5 for Windows
.pkg
application/pkg-mac
HTML5 for macOS
.rpm
audio/x-pn-realaudio-plugin
HTML5 for Linux
.deb
application/x-debian-package
HTMl5 for Linux
Client Side
Check out About Editions
About the Running Services
On Windows
There are three always-running processes by default. All of them are called
same file
DynamsoftService.exe
Dynamsoft Service
and uses the
. However they are started with different arguments.
The main process is started without any argument.
`C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\DynamsoftService.exe`
Then there is a monitor process which is meant to monitor the main process and automatically start it in case it
crashes
`C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\DynamsoftService.exe -asmonitor Global\Dynamsoft_1.4_73769109_stop_se
rvice_event Global\Dynamsoft_1.4_73769078_certcheck_event`
The last always-running process is meant to support the SSL certificate for Firefox
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\DynamsoftService.exe" "-certcheck" "1160"
"Global\Dynamsoft_1.4_73770140_1_certcheck_event
283
Then each time you open a browser tab to use Dynamic Web TWAIN, two more processes will appear which are
Dynamsoft Service, also using the file
DynamsoftService.exe
. It's started like this
"-scan" "\\.\pipe\dynamsoftscan_14.1_1160_52" "0" "Global\ss342249531_53_1160" "0"
"C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\dwt_trial_14.1.0.0828.dll"
Dynamsoft Scanning New Module which uses the file
DSSCN.exe
. It's started like this
"-scan" "\\.\pipe\dynamsoftscan_14.1_1160_50" "1" "Global\ss342249250_51_1160" "0"
"C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\dwt_trial_14.1.0.0828.dll"
About the Distribution Files
Like any other libraries, you need to include the resource files of Dynamic Web TWAIN to use it in your
project. The library is distributed as multiple JavaScript files, a CSS file and multiple binary files. From
version 14.1, the files are organized as shown below
Resources
addon
dynamsoft.upload.js
dynamsoft.webtwain.addon.pdf.js
dist
linux
DynamsoftServiceSetup.deb
DynamsoftServiceSetup.rpm
LinuxDWT_Trial_14.1.0.0828.zip
LinuxPdf.zip
mac
DynamsoftServiceSetup.pkg
MacDWT_Trial_14.1.0.0828.zip
MacPdf.zip
win
ActiveX
DynamicWebTWAIN.cab
DynamicWebTWAINx64.cab
DynamicWebTWAINActiveX.exe
WebTwainMSITrialX64.msi
WebTwainMSITrialX86.msi
DynamsoftServiceSetup.msi
WinDWT_Trial_14.1.0.0828.zip
WinDWT_Trial_14.1.0.0828_x64.zip
DynamicWebTWAINModuleTrial.msi
DynamsoftPDFRasterizerModule.msi
Pdf.zip
Pdfx64.zip
serviceupdate
LinuxDSUpdate_14.1.0.0828.zip
MacDSUpdate_14.1.0.0828.zip
WinDSUpdate_14.1.0.0828.zip
WinDSUpdate_14.1.0.0828_x64.zip
LICENSE
284
Readme.txt
dynamsoft.webtwain.config.js
dynamsoft.webtwain.css
dynamsoft.webtwain.initiate.js
dynamsoft.webtwain.install.js
As you can see, there are more than 20 files. Depending on how you design your application, you can remove
some of them to keep only the necessary files. The purpose of these files is detailed below to help you better
understand them.
JavaScript, CSS, etc.
Readme.txt
This file contains information about the resources files.
dynamsoft.webtwain.config.js
This file is used to make basic configuration of Dynamic Web TWAIN. It's where you enter the product key
for the product and to change the initial viewer size, etc.
dynamsoft.webtwain.initiate.js
This file is the core of the Dynamic Web TWAIN JavaScript Library. You're not supposed to change it without
consulting the Dynamsoft Support Team.
dynamsoft.webtwain.install.js
This file is used to configure the dialogs which are shown when Dynamic Web TWAIN is not installed or
needs to be upgraded. This file is already referenced inside the
dynamsoft.webtwain.initiate.js
dynamsoft.webtwain.css
This file contains the style definitions for all the elements of built-in image viewer, progress bar, dialogs, etc.
addon/dynamsoft.webtwain.addon.pdf.js
This file contains the functionalities of the PDF Rasterizer addon. You're not supposed to change it without
consulting the Dynamsoft Support Team.
addon/dynamsoft.upload.js
This file defines the interfaces of the Dynamsoft Upload Module.
Binary files
Under
dist/win/
The following files are for end users who use IE 10/11, Edge, Chrome or Firefox on Windows (Windows
XP/7/8/2008/2012/2016 and 10; 32-bit and 64-bit)
DynamsoftServiceSetup.msi
This Dynamsoft Service needs to be manually installed on end-user machine. For controlled environment,
you can also use it to silently deploy the service to all end-user machines.
WinDWT_*_*.*.*.*.zip
WinDWT_*-*.*.*.*_x64.zip
285
These
files contain the core scanning library which is TWAIN-based. Please keep it in the Resources
.zip
folder on your HTTP server. The file will be automatically and silently deployed to the end-user machine once
the Dynamsoft Service is installed. You must make sure that your HTTP server is able to serve
DynamicWebTWAINModule.msi
or
files.
.zip
DynamicWebTWAINModuleTrial.msi
In case the automatic deplyment of the
.zip
files fails, a prompt will come up and provide this
.msi
file for
end users to download and install the core scanning library.
The following files are for Windows end users who use IE 6/7/8/9. As these old versions of IE don't support
HTML5 and still rely on the old ActiveX technology. We still provide the ActiveX to support them.
ActiveX/DynamicWebTWAINActiveX.exe
This is the default package to be downloaded in an automatic prompt, the end user needs to install it
manually.
ActiveX/WebTwainMSIX64.msi
or
WebTwainMSITrialX64.msi
ActiveX/WebTwainMSIX86.msi
or
WebTwainMSITrialX86.msi
These
files are mainly designed for silent group deployment in a controlled environment.
.msi
ActiveX/DynamicWebTWAIN.cab
These
ActiveX/DynamicWebTWAINx64.cab
files are Microsoft's legacy way to install ActiveX in Internet Explorer. If you prefer using them,
.cab
you can set
Pdf.zip
and
ActiveXInstallWithCAB
and
to
true
in
dynamsoft.webtwain.config.js
.
Pdfx64.zip
These files are used to install the PDF Rasterizer on the client machine.
Under dist/mac/
The following files are for end users who use Safari, Chrome or Firefox on mac OS (OS X 10.6.8+)
DynamsoftServiceSetup.pkg
This Dynamsoft Service needs to be manually installed on end-user machine.
MacDWT_*.*.*.*.zip
These
files contain the core scanning library which is TWAIN|ICA-based. Please keep it in the
.zip
Resources folder on your HTTP server. The file will be automatically and silently deployed to the end-user
machine once the Dynamsoft Service is installed. You must make sure that your HTTP server is able to
serve
.zip
files.
MacPdf.zip
This file is used to install the PDF Rasterizer on the client machine.
Under dist/linux
The following files are for end users who use Chrome or Firefox on Linux (Ubuntu 12.0.4+, Debian 8+,
Fedora 24+, mint 18.3; 64-bit)
DynamsoftServiceSetup.deb
or
DynamsoftServiceSetup.rpm
This Dynamsoft Service needs to be manually installed on Debian/Ubuntu/mint or Fedora end-user machine.
286
LinuxDWT_*.*.*.*.zip
These
.zip
files contain the core scanning library which is SANE-based. Please keep it in the Resources
folder on your HTTP server. The file will be automatically and silently deployed to the end-user machine once
the Dynamsoft Service is installed. You must make sure that your HTTP server is able to serve
.zip
files.
LinuxPdf.zip
This file is used to install the PDF Rasterizer on the client machine.
Under dist/serviceupdate
WinDSUpdate_14.1.0.0828.zip
WinDSUpdate_14.1.0.0828_x64.zip
MacDSUpdate_14.1.0.0828.zip
LinuxDSUpdate_14.1.0.0828.zip
These files are used to update the Dynamsoft Service. The update is disabled by default but can be enabled
by setting
IfUpdateService
to
true
in
dynamsoft.webtwain.config.js
287
.
License & Price
Update the Product Key
To update your application to use a new trial key or a full version key. You only need to find the file
dynamsoft.webtwain.config.js
and replace the key in it
Dynamsoft.WebTwainEnv.ProductKey = '{the new key}';
For the full version, you also need to make sure that you have set the following
Dynamsoft.WebTwainEnv.Trial = false;
If you are using the trial version but doesn't have a valid key, you can request a trial key here.
If you can't find the file
dynamsoft.webtwain.config.js
, you might be using a file called
dynamsoft.webtwain.min.js
instead. In this case, you can simply write the following line in your own javascript code before using any APIs of
the Dynamic Web TWAIN SDK.
Dynamsoft.WebTwainEnv.ProductKey = '{the new key}';
Decide On Required Licenses
Dynamic Web TWAIN is licensed on a per-Server per-Application basis and it comes in several different editions.
To determine which licenses you need for your application, you basically need to be sure of the following. For
more info, check out the License Agreement.
1. What operating sytems and browsers your clients use. More info>>
2. How many web servers (physical or virtual) will the application be deployed to.
NOTE:
It doesn't matter what operating system the server runs.
The license is perpetual by default. However, we also offer other options like annual license, revenue share, etc..
Feel free to contact Dynamsoft Sales Team for more information.
288
TroubleShooting
Confirm Hardware Compatibility
In order to support the widest range of scanners, Dynamic Web TWAIN is designed strictly by the following
standards
Windows:
macOS:
Linux:
TWAIN Specification
TWAIN Specification
&
Image Capture Class
SANE
Therefore, as long as your scanner is compliant with the above standard on the specific OS, it is supported. Here
we'll talk a bit on how to find a supported device.
macOS: Apple maintains a list themselves. Check out Printer and scanner software for macOS High Sierra,
Sierra, El Capitan, Yosemite, and Mavericks
Linux: Check out SANE: Supported Devices
Windows: The TWAIN specification is a 25+ years old standard widely accepted by scanner vendors. So it is
very easy to find a compatible scanner for your Windows clients because almost all models of all brands of
scanners in the market nowadays support TWAIN. If you want to verify if a scanner driver is TWAIN
compatible, you can refer to twain-certified-drivers. However, this list is not complete which means you might
not find your device there. In this case, you can also use a tool to help verify whether your device is TWAINcompliant. The tool is called Twacker and it's developed by the TWAIN Working Group. To use it to verify
your device, the steps are
Download and install the tool
Open the installed program
Select your device
289
If your device is not listed, please check if the driver is installed. Or, you can try running Twacker as
"Admin" since you may not have permission to access the data source.
Choose the settings and try scanning
If the scanning is successful without any errors, then your device should be TWAIN compliant. You can also
290
try other commands and see how it works
If your scanner doesn’t work with TWACKER, please check your scanner model online and make sure you
have installed the (latest) TWAIN driver.
Get Detailed Info of Issues
To catch more detailed information for troubleshooting issues with Dynamic Web TWAIN, there are a few things
to try.
Collect Logs
For HTML5 edition for Windows/macOS/Linux, the log files are located in
Windows:
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\log
macOS:
Go > Applications > Dynamsoft > DynamsoftService > {installed version No.} > log
Linux:
/opt/dynamsoft/DynamsoftService/log
To get logs for a particular issue, the recommended steps are
1. Delete old logs
2. Change
LogLevel
to
14
in the file
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\log\DSConfiguration.ini
3. Reproduce the issue
NOTE:
291
1. Enabling the debug mode will slow down the performance of the scan page. Don't forget to change
LogLevel
back to
6
.
2. On macOS, also collect the
system.log
file. To locate it,type
/var/log
in
Go > Go to Folder…
For ActiveX, the steps to collect the log are different
1. Download the tool DebugView, unzip and open
2. Set
LogLevel
to
1
Dbgview.exe
in JavaScript
DWObject.LogLevel = 1;
3. In
Dbgview.exe
, click
Ctrl + X
to clear display
4. Reproduce the issue in Internet Explorer
5. In
Dbgview.exe
, click
Ctrl + S
to save the log file
Check out How to Read Log on how to read the log file.
Collect Dump files
On Windows, if the HTML5 edition of Dynamic Web TWAIN crashes, it'll generate a dump file automatically under
C:\Windows\SysWOW64\Dynamsoft\DynamsoftService\dump
. To troubleshoot with the dump file, please send it to
Dynamsoft Support Team and describe the issue in details (including steps to reproduce the issue if possible).
How to Read Log
Question 1 : What are these log files for?
Answer :
dss.log --> For Dynamsoft Service
nw.log --> Details about the network traffic
wts.log --> For the client part of Dynamic Web TWAIN HTMl5 edition
wtss.log --> For the server part of Dynamic Web TWAIN HTMl5 edition
Question 2 : What info do we see if Dynamic Web TWAIN SDK is not doing anything?
Answer :
There is a regular polling going on every 30 seconds, in the log, it looks like this
Client-side:
[Process:
1716 Thread: 17652] [05/23/2018 17:43:45.075] [Debug-0]: CClientProxy::Send begin task=DefaultSourceName s
eq=18975 status=8 event=11
[Process:
1716 Thread: 17652] [05/23/2018 17:43:45.090] [Debug-0]: CClientProxy::Send end 0
[Process:
1716 Thread: 17652] [05/23/2018 17:44:15.150] [Debug-0]: CClientProxy::Send begin task=DefaultSourceName s
eq=18976 status=8 event=11
[Process:
1716 Thread: 17652] [05/23/2018 17:44:15.156] [Debug-0]: CClientProxy::Send end 0
Server-side:
[Process:
5364 Thread:
7536] [05/23/2018 18:01:20.930] [Debug-0]: CTwainServer::receive1 task=DefaultSourceName seq
=18478 status=8 event=11
292
Question 3 : What does a command to the service look like? >
Answer : It looks like the following with "id" used to identify which client sent the command
cmd = [{
"id" : "467653534",
"method" : "GetImageByIndex",
"parameter" : [ 0, 581, 511 ]
}].
Question 4 : What basic infomration can we get from the log? >
Answer :
The Operating system
Windows info: 6.2.9200 Pack: 0.0 Other:PID=2 Type=1 Mask=256
The version of Dynamsoft Web TWAIN (wts.log)
Activex Version info:32c0048, Dynamic Web TWAIN 14.0 Trial, 14, 0, 0, 0618, x64:0
The version of Dynamosft Service (dss.log)
Current version info: Dynamsoft Service 1, 4, 0, 0618.
The current LogLevel
Log Level = 14, 0.
Websocket listening ports
[Debug-0]: dwt_command, Websocket connection initialized.
[Info-0]: Create websocket context succeed at default 127.0.0.1:18625, use_ssl = false!
[Info-0]: Start websocket service succeed. port = [18625], use_ssl = false.
[Process: 16784 Thread: 15400] [05/23/2018 17:56:44.554] [Info-0]: Websocket Listening starts at port = 18625, use_ss
l = false
[Debug-0]: Get the port number and try creating websocket listening.
[Debug-0]: dwt_command, Websocket connection initialized.
[Info-0]: Create websocket context succeed at default 127.0.0.1:18626, use_ssl = true!
[Info-0]: Add https service succeed! Succeed port = 18626, use_ssl = true.
[Process: 16784 Thread: 10740] [05/23/2018 17:56:46.794] [Info-0]: Websocket Listening starts at port = 18626, use_ss
l = true
[Debug-0]: Get http service parameter
[Debug-0]: Get the port number and try creating websocket listening.
[Info-0]: Add http service succeed! Succeed port = 18622, use_ssl = false.
[Debug-0]: dwt_command, Websocket connection initialized.
[Info-0]: Create websocket context succeed at default 127.0.0.1:18622, use_ssl = false!
[Info-0]: Start websocket service succeed. port = [18622], use_ssl = false.
[Process: 16784 Thread:
9508] [05/23/2018 17:56:48.071] [Info-0]: Websocket Listening starts at port = 18622, use_ss
l = false
Requesting origin
origin:http://127.0.0.1:100
293
How a command worked
result json = [{
"description" : "User cancelled the operation.",
"exception" : -1032,
"id" : "667465648",
"method" : "SelectSource",
"result" : [ false ],
"cmdId" : ""
}].
Sequence in which commands are being called
294
Develop & Customize
Insert Images To a Specified Index
By default, when you scan or load images, they are appended. In other words, they are added to the very
end of the image array in buffer. However, in some business scenarios, the user might want to insert these
new images to a specified index. Unfortunately, Dynamic Web TWAIN doesn't provide a native method for
that. The following code snippet shows how it can be done
Insert when acquiring
function acquireToIndex(index) {
DWObject.IfAppendImage = false;
DWObject.CurrentImageIndexInBuffer = index;
DWObject.RegisterEvent('OnBitmapChanged', function (strUpdatedIndex, operationType, sCurrentIndex) {
if (operationType == 2) { //inserting
DWObject.CurrentImageIndexInBuffer ++;
}
});
DWObject.AcquireImage();
}
Insert when loading
var bPostLoad = false, newIndices = [];
function loadToIndex(index) {
bPostLoad = false;
newIndices = [];
DWObject.IfAppendImage = false;
DWObject.CurrentImageIndexInBuffer = index;
DWObject.RegisterEvent('OnPostLoad', function () {
bPostLoad = true;
for (var j = 0; j < newIndices.length / 2; j++)
if (newIndices[j] != newIndices[newIndices.length - j - 1])
DWObject.SwitchImage(newIndices[j], newIndices[newIndices.length - j - 1]);
DWObject.IfAppendImage = true;
});
DWObject.RegisterEvent('OnBitmapChanged', function (strUpdatedIndex, operationType, sCurrentIndex) {
if (operationType == 2) { //inserting
for (var i = 0; i < newIndices.length; i++)
newIndices[i] += 1;
newIndices.push(parseInt(strUpdatedIndex[0]));
}
});
DWObject.LoadImageEx('', 5);
}
Reuse TWAIN Configurations
Custom DataSource Data or CDD refers to all configurations of a device. Many devices support exporting
CDD to a file or a base64-encoded string to be used later. By using the same CDD, the same device can
always carry out scan jobs with the same configurations. CDD can also be shared among multiple devices
295
to ensure all of them are scanning with the same settings. To use this feature, we have four methods:
SetCustomDSData()
,
SetCustomDSDataEx()
,
GetCustomDSData()
and
GetCustomDSDataEx()
. The typical steps are
1. Show the scanner's User Interface and change all the settings necessary.
2. Perform a scan and remember/save the CDD in the callback of the event
GetCustomDSData()
or
GetCustomDSDataEx()
OnPostAllTransfers
using either
.
3. Later on, when you or any other user who needs to scan with the same settings on the same device (or
device of the same model), you can hide the scanner's own interface and simply use the method
SetCustomDSDataEx()
or
SetCustomDSData()
to pass the CDD to the device.
Code Snippet
var DWObject = null;
var Base64EncodedDSData = "";
function Dynamsoft_OnReady() {
DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
DWObject.RegisterEvent("OnPostAllTransfers", function () {
Base64EncodedDSData = DWObject.GetCustomDSDataEx();
});
}
function AcquireImage() {
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.SelectSource(function () {
var OnAcquireImageSuccess, OnAcquireImageFailure;
OnAcquireImageSuccess = OnAcquireImageFailure = function () {
DWObject.CloseSource();
};
DWObject.OpenSource();
if (Base64EncodedDSData != "") {
DWObject.IfShowUI = false;
DWObject.SetCustomDSDataEx(Base64EncodedDSData);
} else {
DWObject.IfShowUI = true;
}
DWObject.AcquireImage(OnAcquireImageSuccess, OnAcquireImageFailure);
}, function () { console.log("Failed to Select A Source!"); });
}
TWAIN Capability Negotiation
How can I set resolution in the X and Y direction separately
With capability negotiation, you can use the capabilities ICAP_XRESOLUTION and ICAP_YRESOLUTION
to set resolution in the X and Y direction separately.
Code Snippet
DWObject.SelectSource();
DWObject.OpenSource();
//Set X-RESOLUTION current value.
DWObject.Capability = EnumDWT_Cap.ICAP_XRESOLUTION;
DWObject.CapType = EnumDWT_CapType.TWON_RANGE;
DWObject.CapValue = 300;
if (DWObject.CapSet())
alert("Successful");
else
alert("Source doesn't support this capability");
//Set Y-RESOLUTION current value.
296
DWObject.Capability = EnumDWT_Cap.ICAP_YRESOLUTION;
DWObject.CapType = EnumDWT_CapType.TWON_RANGE;
DWObject.CapValue = 200;
if (DWObject.CapSet())
alert("Successful");
else
alert("Source doesn't support this capability");
DWObjet.AcquireImage();
For more information, please refer to How to Perform Capability Negotiation.
How to detect and discard blank pages automatically
If the TWAIN driver of your device supports discarding blank pages, you can use the driver's built-in
feature.
You can set the
IfShowUI
property to true to display the User Interface (UI) of the source and you can
check the option there (it normally reads 'discard blank')
If you don't want to show the user interface of the source, you can set
negotiate the
ICAP_AUTODISCARDBLANKPAGES
IfAutoDiscardBlankpages
to true or
capability in code to discard blank page automatically. Please
NOTE that this property or capability only works if the scanner itself supports the feature (on the hardware
level).
Code Snippet
DWObject.SelectSource();
DWObject.OpenSource;
DWObject.IfShowUI = false;
//*Use the property
DWObject.IfAutoDiscardBlankpages = true;
//*Use capability negotiation
DWObject.Capability = EnumDWT_Cap.ICAP_AUTODISCARDBLANKPAGES;
DWObject.CapType = EnumDWT_CapType.TWON_ONEVALUE;
DWObject.CapValue = -1;//Auto
if(DWObject.CapSet){
alert("Successful!");
}
DWObject.AcquireImage();
If the scanner itself doesn't support discarding blank pages, you can also use the method
IsBlankImageExpress()
can do it in the
to do this as a workaround. To detect and discard blank pages automatically, you
OnPostTransfer
event which fires after each transfer.
Code Snippet
function DWObject_OnPostTransfer() {
DWObject.BlankImageMaxStdDev = 20;
if (DWObject.IsBlankImageExpress(DWObject.CurrentImageIndexInBuffer)) {
DWObject.RemoveImage(DWObject.CurrentImageIndexInBuffer);
}
}
NOTE: In many cases, the scanned blank image may come with some noises which would affect the result
returned by IsBlankImageExpress. To improve the result, you may adjust the value of
BlankImageMaxStdDev Property. The default value is 1 (0 means single-color image). Thus, by increasing
the value a little bit (e.g. to 20), noises on images are ignored so a blank image can be detected faster.
297
For more information, please refer to How to Perform Capability Negotiation.
How to rotate the scanned image data prior to transfer
With capability negotiation, you can use the capability ICAP_ROTATION to rotate the scanned image data
before it's transferred.
Note: Before using these methods, please make sure that the driver of your device supports automatic
rotating.
Code Snippet
function btnScan()
{
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.MaxImagesInBuffer = 4;
/*============== rotate ==============*/
DWObject.Capability = EnumDWT_Cap.ICAP_ROTATION;
DWObject.CapType
=
EnumDWT_CapType.TWON_ONEVALUE;
DWObject.CapValue = 270; //270 degree rotation
if (DWObject.CapSet())
alert("Successful");
else
alert("Source doesn't support this capability");
DWObject.IfDisableSourceAfterAcquire = true;
DWObject.AcquireImage();
}
For more information, please refer to How to Perform Capability Negotiation.
How to use custom capabilities of your TWAIN device
To use a custom capability of your TWAIN driver, you need to know what the capability code is first. You
can follow the steps below:
Install the TWAIN sample application.
Use the TWAIN Sample App to open the source and then check what the hexadecimal value of the capability
is.
298
As an example, the code 0x8001 is for the highlighted custom capability above. Now we can use the
following code to negotiate the capability.
Code Snippet
DWObject.SelectSource();
DWObject.OpenSource();
DWObject.Capability = 0x8001;
DWObject.CapType = 5; //TWON_ONEVALUE
DWObject.CapValue = 1;
if (DWObject.CapSet())
alert("successful");
else
alert("Source doesn't support this capatiblity");
For more information, please refer to How to Perform Capability Negotiation.
299
Details on the Upload Feature
How to upload images directly to Database
To upload images to the server and save them directly into database, you simply need to rewrite the action
page on the server. The following is an example written in
C#
and uses MSSQL as the database
try {
int iFileLength;
HttpFileCollection files = HttpContext.Current.Request.Files;
HttpPostedFile uploadfile = files["RemoteFile"];
string strImageName = uploadfile.FileName;
iFileLength = uploadfile.ContentLength;
Byte[] inputBuffer = new Byte[iFileLength];
System.IO.Stream inputStream;
inputStream = uploadfile.InputStream;
inputStream.Read(inputBuffer, 0, iFileLength);
inputStream.Close();
string sql_insertData = "INSERT INTO " + tableName + " (document_name, document_data) VALUES (@document_name, @do
cument_data)";
using(System.Data.SqlClient.SqlCommand sqlcmd_insertData = new System.Data.SqlClient.SqlCommand(sql_insertData, C
onnection)) {
sqlcmd_insertData.Parameters.Add("@document_data", System.Data.SqlDbType.Binary, iFileLength).Value = inputBu
ffer;
sqlcmd_insertData.Parameters.Add("@document_name", System.Data.SqlDbType.VarChar, 255).Value = strImageName;
sqlcmd_insertData.ExecuteScalar();
}
Connection.Close();
} catch (Exception) {}
If you use languges like PHP, JSP, etc., you can check out sample scripts as part of the official upload sample.
How to upload images through methods like AJAX instead of built-in methods
Basically, the workflow would be like this:
1. Scan images to the control.
2. Use the method
ConvertToBase64()
or
ConvertToBlob()
to convert the images in the buffer to a Base64-
encoded string or a Blob object.
3. Upload the string or the Blob to the server
We'll use the method
ConvertToBase64()
as an example in the code sample below. Note that
C#
is used on the
server-side.
Client-Side
// Select all images
var aryIndices = [];
for (var i = 0; i < DWObject.HowManyImagesInBuffer; i++) {
aryIndices.push(i);
}
DWObject.ConvertToBase64(aryIndices, EnumDWT_ImageType.IT_PDF, asyncSuccessFunc, asyncFailureFunc);
function asyncSuccessFunc(result) {
var param = encodeURIComponent("ImageName") + "=" + encodeURIComponent("uploadedImages.pdf") + "&" + encodeURICom
ponent("RemoteFile") + "=" + encodeURIComponent(result);
//You can upload the image data from here
makeRequest(strActionPage, param, false);
}
300
function asyncFailureFunc(errorCode, errorString) {
alert("ErrorCode: " + errorCode + "\r" + "ErrorString:" + errorString);
}
//AJAX
function makeRequest(url, parameter, flg) {
if (window.XMLHttpRequest) {
xhr = new XMLHttpRequest(); // Set up the request.
} else {
if (window.ActiveXObject) {
try {
xhr = new ActiveXObject("MSXML2.XMLHTTP.3.0");
} catch (ex) {
alert(ex);
}
}
}
if (xhr) {
if (flg) {
xhr.open("GET", url, true); // Open the connection.
xhr.onreadystatechange = requestresultCat;
xhr.setRequestHeader("If-Modified-Since", "0");
xhr.send(null);
} else {
xhr.open("POST", url, false);
if (parameter != null) {
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.send(parameter); // Send the Data.
} else {
xhr.send(null);
}
}
} else {
AppendMessage("<b>Sorry, but I couldn't create an XMLHttpRequest!</b> ");
}
}
function requestresult() {
if (xhr.readyState == 4) {
if (xhr.status == 200) { // File(s) uploaded.
var outMsg;
if (xhr.responseXML & amp; & amp; xhr.responseXML.documentElement) {
outMsg = xhr.responseXML;
alert(xhr.responseText);
}
}
}
}
Server-Side
try {
string imageName = HttpContext.Current.Request.Form["ImageName"];
string imageData = HttpContext.Current.Request.Form["RemoteFile"];
string Path = System.Web.HttpContext.Current.Request.MapPath(".") + "/ImageScanned/";
if (!Directory.Exists(Path)) {
Directory.CreateDirectory(Path);
}
string outputFileName = Path + imageName;
// Convert the Base64 UUEncoded input into binary output.
byte[] binaryData;
try {
binaryData = System.Convert.FromBase64String(imageData);
301
} catch (System.ArgumentNullException) {
System.Console.WriteLine("Base 64 string is null.");
return;
} catch (System.FormatException) {
System.Console.WriteLine("Base 64 string length is not " +
"4 or is not an even multiple of 4.");
return;
}
// Write out the decoded data.
System.IO.FileStream outFile;
try {
outFile = new System.IO.FileStream(outputFileName,
System.IO.FileMode.Create,
System.IO.FileAccess.Write);
outFile.Write(binaryData, 0, binaryData.Length);
outFile.Close();
} catch (System.Exception exp) {}
} catch (Exception exc) {}
How to upload multiple files at a time
Scenario
After scanning multiple files, you might want to upload them one by one as individual images. Before version
13.1, you have to call the upload method(s) multiple times. In v13.1+, you can do this in one go.
Solution
Use the methods
ConvertToBlob()
and
HTTPUpload()
.
Steps:
In JavaScript, write code similar to the following
var i = 0;
DWObject.ClearAllHTTPFormField();
DWObject.SetHTTPFormField("UploadedImagesCount", DWObject.HowManyImagesInBuffer);
function asyncFailureFunc(errorCode, errorString) {
alert("ErrorCode: " + errorCode + "\r" + "ErrorString:" + errorString);
}
var convertImage = function (_index) {
DWObject.ConvertToBlob([_index], EnumDWT_ImageType.IT_JPG,
function (result) {
DWObject.SetHTTPFormField('image_' + _index, result, 'JPG_image_' + _index);
i++;
if (i < DWObject.HowManyImagesInBuffer) {
convertImage(i);
} else {
DWObject.HTTPUpload("http://yourserver/youractionpage.aspx", function () {
console.log('success')
}, function () {
console.log('failure');
});
}
}, asyncFailureFunc);
};
convertImage(0);
302
On the server, add an action page to process the uploaded data
<%@ Page Language="C#" %>
<%
try
{
String strImageName;
String strInfo = HttpContext.Current.Request["UploadedImagesCount"];
short uploadedImagesCount = Convert.ToInt16(strInfo);
HttpFileCollection files = HttpContext.Current.Request.Files;
for (short i = 0; i < uploadedImagesCount; i++)
{
HttpPostedFile uploadfile = files["image_" + i.ToString()];
strImageName = uploadfile.FileName;
uploadfile.SaveAs(Server.MapPath(".") + "\\UploadedImages\\" + strImageName + ".jpg");
}
}
catch
{}
%>
How to use FileUploader to do the upload
In Dynamic Web TWAIN Version 14.0, we added a new upload module called
jobs. The following shows how to use this new module to do the upload.
Step:
Reference the
dynamsoft.upload.js
file