彩票走势图

如何使Dynamic Web TWAIN与Polymer Shadow DOM一起使用?

翻译|使用教程|编辑:杨鹏连|2021-03-31 09:39:34.670|阅读 150 次

概述:本文分享了如何将Dynamic Web TWAIN SDK集成到Polymer项目中,以便在Web浏览器中扫描文档。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

Dynamic Web TWAIN是一个专为Web应用程序设计的TWAIN扫描识别控件。你只需在TWAIN接口写几行代码,就可以用兼容TWAIN的扫描仪扫描文档或从数码相机/采集卡中获取图像。然后用户可以编辑图像并将图像保存为多种格式,用户可保存图像到远程数据库或者SharePoint。该TWAIN控件还支持上传和处理本地图像。

点击下载Dynamic Web TWAIN正式版

过去,Dynamic Web TWAIN仅支持HTML DOM元素。某些基于Shadow DOM的Web框架(例如Polymer)无法与Dynamic Web TWAIN一起使用。从版本16.1开始,Dynamic Web TWAIN与Shadow DOM完全兼容。本文分享了如何将Dynamic Web TWAIN SDK集成到Polymer项目中,以便在Web浏览器中扫描文档。

动态Web TWAIN快速入门

  • 下载Dynamic Web TWAIN SDK。
  • 复制** Dynamic Web TWAIN SDK \ Resources **文件夹到您的项目根目录。
  • 创建一个HTML文件并从GitHub获取完整的示例代码:
<!DOCTYPE html>
<html>
<head>
    <title>Hello World</title>
    <script type="text/javascript" src="Resources/dynamsoft.webtwain.initiate.js"></script>
    <script type="text/javascript" src="Resources/dynamsoft.webtwain.config.js"></script>
</head>
<body>
    <div id="dwtcontrolContainer" ></div>
    <input type="button" value="Scan" onclick="AcquireImage();" />
    <script type="text/javascript">
        Dynamsoft.WebTwainEnv.ProductKey = "LICENSE-KEY";
        function AcquireImage() {
          var DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
          if (DWObject) { 
            DWObject.SelectSource(function () { 
              var OnAcquireImageSuccess = OnAcquireImageFailure = function () {
                  DWObject.CloseSource();
              };
              DWObject.OpenSource();
              DWObject.IfDisableSourceAfterAcquire = true;
              DWObject.AcquireImage(OnAcquireImageSuccess, OnAcquireImageFailure);
                      }, function () {
              console.log('SelectSource failed!');
                      });
          }
        }
    </script>
</body>
</html>
通过这些步骤,完成了一个简单的Web文档管理应用程序。如果没有网络服务器,我们可以通过双击HTML文件来立即运行网络文档扫描器应用程序。

网页文件扫描

要使应用正常运行,需要有效的许可证密钥。获得30天的免费试用许可证并更新代码:

Dynamsoft.WebTwainEnv.ProductKey = "LICENSE-KEY";
用于扫描文档的聚合物项目

安装Polymer CLI:

npm i -g polymer-cli
之后,我们可以使用模板初始化Polymer项目:
mkdir polymer-document-scan
cd polymer-document-scan
polymer init polymer-3-starter-kit
npm start

聚合物项目

将Dynamic Web TWAIN集成到Polymer项目中

现在,让我们通过在src / my-view.js中的HTML模板中添加Div元素和Button元素来修改默认UI :

class MyView1 extends PolymerElement {
  static get template() {
    return html`
      <style include="shared-styles">
        :host {
          display: block;
 
          padding: 10px;
        }
      </style>
 
      <div class="card">
      <div id="dwtcontrolContainer"></div>
      <button on-click="handleClick">scan</button>
      </div>
    `;
  }
 
  handleClick() {
    if (DWObject) {
      
    }
  }
}

将扫描模块添加到Polymer项目

如果我们使用“ Hello World”示例代码,它将无法初始化Dynamic Web TWAIN对象:

var DWObject = Dynamsoft.WebTwainEnv.GetWebTwain('dwtcontrolContainer');
原因是找不到元素。要调查此问题,请打开开发人员控制台。

影子DOM

开发者控制台显示Div元素是Shadow DOM的子元素。这是获取Shadow DOM元素的JS代码:

document.querySelector("body > my-app").shadowRoot.querySelector("app-drawer-layout > app-header-layout > iron-pages > my-view1").shadowRoot.querySelector("#dwtcontrolContainer")
该代码可以简化如下:
this.shadowRoot.querySelector('#dwtcontrolContainer');
由于Dynamic Web TWAIN支持Shadow DOM,因此我们可以使用以下bind()方法轻松地使用Shadow DOM元素初始化Dynamic Web TWAIN对象:
ready() {
    super.ready();
    // TODO: initialization
    this.initializeDWT();
  }

  initializeDWT() {
    // Dynamsoft.WebTwainEnv.ProductKey = "LICENSE-KEY";
    Dynamsoft.WebTwainEnv.CreateDWTObjectEx({ WebTwainId: 'Viewer' }, (obj) => {
      this.dwtObj = obj;
      obj.Viewer.bind(this.shadowRoot.querySelector('#dwtcontrolContainer'));
      obj.Viewer.width = 560;
      obj.Viewer.height = 600;
      obj.Viewer.show();

      var count = obj.SourceCount;
      for (var i = 0; i < count; i++) {
        this.shadowRoot.querySelector('#source').options.add(new Option(obj.GetSourceNameItems(i), i));
      }

    }, function (e) {
      console.log(e)
    });
  }
我们创建一个单击事件以触发文档扫描。
handleClick() {
    var obj = this.dwtObj;
    if (obj) {
      var onSuccess, onFailure;
      onSuccess = onFailure = function () {
        obj.CloseSource();
      };

      obj.SelectSourceByIndex(this.shadowRoot.querySelector('#source').selectedIndex); 
      obj.OpenSource();
      obj.IfDisableSourceAfterAcquire = true; 
      obj.AcquireImage(onSuccess, onFailure);
    }
  }
最后,Polymer中实现的Web文档扫描应用程序可以成功运行。

Polymer Shadow DOM文档扫描


想要购买Dynamsoft Barcode Reader正版授权,或了解更多产品信息请点击


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@capbkgr.cn

文章转载自:

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP