npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

web-twain-plus

v18.0.2

Published

Dynamic Web TWAIN is a TWAIN/ICA/SANE-based scanning SDK software specifically designed for web applications running on Windows/macOS/Linux. With just a few lines of code, you can develop robust applications to scan documents from TWAIN/ICA/SANE-compatibl

Downloads

335

Readme

Dynamic Web TWAIN SDK for Scanner and Camera

version downloads jsdelivr

Dynamic Web TWAIN is a cross-platform scanning SDK designed for web document management applications. With just a few lines of JavaScript code, you can develop robust web applications to scan documents, edit images and save them to file systems. To see it in action, please visit this online demo

Note: Dynamic Web TWAIN SDK v18.0 is built in this package. For more detail, check the Version Info.

Table of Contents

Supported Environments

Supported Image Capturing Devices

  • Physical Document Scanners
  • Desktop Webcam
  • Mobile Camera

Supported Web Browsers

  • Chrome
  • Firefox
  • Edge
  • Safari

Supported OSs

  • Windows
  • Linux
  • macOS
  • Android / iOS (Remote scanner or camera)

Supported CPU Architectures

  • x86/x64
  • MIPS64
  • ARM64

License Key

Installation

  • Official web site

    Dynamic Web TWAIN SDK for Windows, Linux, macOS

  • NPM

    npm install web-twain-plus

A Virtual Scanner

If you do not have a physical scanner to test on Windows, you can install a virtual scanner.

Read more here.

Deployment

Dynamic Web TWAIN relies on the files in the /dist/ folder to work. Make sure to put these files on your server and correctly refer to them by specifying the path with ResourcesPath (relative and absolute paths are both fine).

If you are making use of the CDN jsDelivr, you will still need to host the /dist/ folder somewhere on your server and refer to it by specifying the path with ResourcesPath. This is because file types like .msi are not allowed by this CDN.

Quick Start

Step 1 Create a HTML page and load dynamsoft.webtwain.min.js into your page:

<!DOCTYPE html>
<html>
<head>
 <title>Hello World</title>
 <script src="dist/dynamsoft.webtwain.min.js"></script>
</head>
<body>
</body>
</html>

Note that a relative path is used. You might want to change it based on where you are putting your code. The best practise is to put all the files on your own server and under the same domain as your web application.

Step 2 Add a script tag and make initial settings:

<!DOCTYPE html>
<html>
<head>
 <title>Hello World</title>
 <script src="dist/dynamsoft.webtwain.min.js"></script>
</head>
<body>
 <script type="text/javascript">
   Dynamsoft.DWT.ResourcesPath = "dist";
   Dynamsoft.DWT.ProductKey = 't0140cQMAA...';
   Dynamsoft.DWT.Containers = [{ ContainerId: 'dwtcontrolContainer', Width: 270, Height: 350 }];
 </script>
</body>
</html>

Note that ResourcesPath must be set in order to use the library.

  1. ResourcesPath is a relative path to where you put the directory "/dist/" and all the files in it.
  2. If you don't have a valid ProductKey, you can request a trial key to use.

Step 3 Write code to use the package to do a simple document scan

The following code demonstrates the minimum code needed to use the package. Note the addition of HTML elements as well as JavaScript code. For more sophisticated sample or demo, check out the Sample Gallery and our Github Repositories.

<!DOCTYPE html>
<html>
<head>
 <title>Hello World</title>
 <script src="dist/dynamsoft.webtwain.min.js"></script>
</head>
<body>
 <input type="button" value="Scan" onclick="AcquireImage();" />
 <div id="dwtcontrolContainer"></div>
 <script type="text/javascript">
   Dynamsoft.DWT.ResourcesPath = "dist";
   Dynamsoft.DWT.ProductKey = 't0140cQMAA...'; // Put your own key here
   Dynamsoft.DWT.Containers = [{ ContainerId: 'dwtcontrolContainer', Width: 270, Height: 350 }];
   window.onload = function () {
     Dynamsoft.DWT.Load();
   };
   var DWObject;
   function Dynamsoft_OnReady() {
     // dwtcontrolContainer is the id of the DIV to create the WebTwain instance in.
     DWObject = Dynamsoft.DWT.GetWebTwain('dwtcontrolContainer');
   }
   function AcquireImage() {
     if (DWObject) {
       DWObject.SelectSourceAsync().then(function(){
         return DWObject.AcquireImageAsync({
           PixelType: Dynamsoft.DWT.EnumDWT_PixelType.TWPT_RGB,
           Resolution: 200,
           IfDisableSourceAfterAcquire: true 
         });
       }).then(function(){
         return DWObject.CloseSourceAsync();
       }).catch(function (exp) {
         alert(exp.message);
       });
     }
   }
 </script>
</body>
</html>

Documentation

Features

Dynamsoft Service for Scanner

| Features | Windows | Linux | macOS| | ------------- |:-------------:| -----:| -----:| | Supports up to TWAIN specification 2.3 | :heavy_check_mark: | :x: |:x:| | SANE compatible | :x: | :heavy_check_mark:|:x:| | Supports up to TWAIN specification 1.9; ICA compatible | :x:| :x: | :heavy_check_mark: | | Supports capturing document | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Supports editing document | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Optional disk caching mechanism for high volume scanning (thousands of pages) | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Built-In Auto Document Feeder (ADF) and multiple image acquisition | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Offers duplex scanning mode | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Supports blank page detection | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Supports setting up image acquisition parameters (resolution, pixel type, bit depth, brightness, contrast, page size, unit, etc.) | :heavy_check_mark: |:heavy_check_mark: |:heavy_check_mark:| | Provides native and disk file image transfer modes | :heavy_check_mark: | :heavy_check_mark: |:heavy_check_mark:| | Buffered memory transfer mode | :heavy_check_mark: | :x: |:x:|

More

WebAssembly for Camera

| Features | Desktop | Mobile | | ------------- |:-------------:| -----:| | Document capture | :heavy_check_mark: | :heavy_check_mark: | | Document edge detection | :heavy_check_mark: | :heavy_check_mark: | | Document perspective correction | :heavy_check_mark: | :heavy_check_mark: | | Document post-processing by filters| :heavy_check_mark: | :heavy_check_mark: | | Front and rear camera switching |:heavy_check_mark: | :heavy_check_mark: | | Dedicated image and PDF viewer|:heavy_check_mark: | :heavy_check_mark: | | Built-in ready-to-use UI| :heavy_check_mark: | :heavy_check_mark: | | SIMD and WebGL acceleration | :heavy_check_mark: | :heavy_check_mark: | | Multi-Format export and sharing | :heavy_check_mark: | :heavy_check_mark: |

More

Contact Us

Contact Dynamsoft to resolve any issue you encounter with the library.

License Agreement

https://www.dynamsoft.com/Products/WebTWAIN_License.aspx

Versions

Dynamsoft Service (DynamsoftService.exe, 64bit)

v18.0 (build version 1, 8, 0, 1025)

Dynamsoft Service Manager (DWASManager_18001025.dll, 64bit)

v18.0 (build version 18, 0, 0, 1025)

Device Manager (DeviceManager_18001025.dll, 64bit)

v18.0 (build version 18, 0, 0, 1025)

Dynamic Web TWAIN (dwt_18.0.0.1025.dll, 64bit)

v18.0 (build version 18, 0, 0, 1025)

Dynamsoft PDF Rasterizer (DynamicPdfRx64_11.4.1.1025.dll, 64bit)

v18.0 (build version 11, 4, 1, 1025)

Dynamsoft Barcode Reader (dbrx64_9.4.0.1025.dll, 64bit)

v9.4.0 (build version 9, 4, 0, 0823)

Dynamsoft Webcam Addon (DynamicWebcamx64_15.0.0.0625.dll, 64bit)

v18.0 (build version 15, 0, 0, 0625)

Dynamsoft Upload Module (UploadModule_1.8.0.1025.dll, 64bit)

v18.0 (build version 1, 8, 0, 1025)

Changelog

Check out the release notes of the Dynamic Web TWAIN library.

Note

If you are upgrading from the old versions to V17.1+, please add the following code after Dynamsoft.DWT.ProductKey to make Dynamsoft.DWT.Load take effect.

Dynamsoft.DWT.Containers = [{ ContainerId: 'dwtcontrolContainer', Width: 270, Height: 350 }];

Otherwise, the initialization will fail.