Vue web项目转5+app过程中,实现二维码扫描。

<template>

  <div id="div_page">

    <div class="scan">

      <div id="bcid"></div>

    </div>

  </div>

</template>

<script>

import Vue from "vue";

import { Notify } from "vant";

let scan = null;

let scanTip = null;

let bFlash = null;

let bAlbum = null;

//设置扫码框样式和位置

let styles = {

  frameColor: "#1294cb",

  scanbarColor: "#1294cb",

  top: "44px",

  left: "0px",

  width: "100%",

  height: "100%",

  position: "fixed",

  zindex: 1,

};

//设置扫码格式

let filter = [plus.barcode.QR]; //扫码格式 空为全类型

export default {

  data () {

    return {

      codeUrl: "",

      flash: false,

    };

  },

  mounted () {

    this.startRecognize();

    this.startScan();

    let flag = this.isWindowBrowser();

    if (!flag) {

      plus.key.addEventListener("backbutton", this.backScan, false);

    }

  },

  destroyed () {

    plus.key.removeEventListener("backbutton", this.backScan, false);

  },

  methods: {

    backScan () {

      scan.close(); //关闭条码识别控件

      scan.cancel();

      scanTip.close();

      bFlash.close();

      bAlbum.close();

    },

    //创建扫描控件

    startRecognize () {

      if (!window.plus) return;

      scan = plus.barcode.create("bcid", filter, styles);

      scan.onmarked = this.onmarked;

      plus.webview.currentWebview().append(scan);

      this.createView();

      this.startScan();

    },

    createView () {

      let _this = this

      //扫码框下提示文字

      scanTip = new plus.nativeObj.View(

        "scanTip",

        {

          top: "65%",

          left: "5%",

          height: "20%",

          width: "90%",

        },

        [

          {

            tag: "font",

            fontSrc: '_www/helloh5.ttf',

            id: "font",

            text: "将手机和二维码置于平行状态即可自动扫描",

            textStyles: {

              size: "16px",

              color: "#ffffff",

            },

            position: {

              width: "100%",

            },

          },

        ]

      );

      //闪光灯

      bFlash = new plus.nativeObj.View('nbutton', {

        bottom: '20px',

        left: '5%',

        width: '40%',

        height: '44px'

      }, [{

        tag: 'rect',

        id: 'rect',

        rectStyles: {

          radius: '8px',

          color: 'rgba(0,0,0,0.5)'

        }

      }, {

        tag: 'font',

        id: 'text',

        text: '闪光灯',

        textStyles: {

          color: '#FFFFFF'

        }

      }]);

      let that = _this

      bFlash.addEventListener('touchend', function (e) {

        that.flash = !that.flash;

        scan.setFlash(that.flash);

      }, false);

      //相册

      bAlbum = new plus.nativeObj.View('nbutton', {

        bottom: '20px',

        left: '55%',

        width: '40%',

        height: '44px'

      }, [{

        tag: 'rect',

        id: 'rect',

        rectStyles: {

          radius: '8px',

          color: 'rgba(0,0,0,0.5)'

        }

      }, {

        tag: 'font',

        id: 'text',

        text: '相册',

        textStyles: {

          color: '#FFFFFF'

        }

      }]);

      bAlbum.addEventListener('touchend', function (e) {

        plus.gallery.pick(

          function (path) {

            plus.barcode.scan(path, that.onmarked, function (error) {

              plus.nativeUI.alert("无法识别此图片");

            });

          },

          function (err) {

            plus.nativeUI.alert("请选择正确的二维码图片");

          }

        );

      }, false);

      plus.webview.currentWebview().append(scanTip);

      plus.webview.currentWebview().append(bFlash);

      plus.webview.currentWebview().append(bAlbum);

    },

    onmarked (type, result, file) {

      result = result.replace(/\n/g, "");

      this.codeUrl = result;

      if (result != "") {

        this.scanSuccess();

      }

    },

    //开始扫描

    startScan () {

      if (!window.plus) return;

      scan.start();

    },

    //扫描成功后带参数跳转

    scanSuccess () {

      let arr = [];

      let result = this.codeUrl;

console.log("result ")

//关闭组件,不然会继续显示

      scan.cancel();

      scan.close();

      scanTip.close();

      bFlash.close();

      bAlbum.close();

    },

  },

};

</script>



以上就是h5 barcode的实现代码,目前问题是无法在view视图层显示图片,正在解决。欢迎大家提问或者给出解决意见。

原生控件对象可用于在屏幕上绘制图片或文本内容,当控件不再使用时需要调用close方法销毁控件。

NView不支持zindex,后显示的覆盖先显示的;

调用Webview窗口对象的append方法添加到Webview中,显示在父窗口所有子Webview的上面;不添加到Webview窗口对象,显示在所有Webview的上面。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342