首 页  -  技术分享  - Cordova各个插件使用介绍系列(四)—canvas2ImagePlugin保存二维码到手机本地

Cordova各个插件使用介绍系列(四)—canvas2ImagePlugin保存二维码到手机本地

分享者:张香君     2016-03-03

在前面几篇文章中简单写了一下,在项目中怎么实现扫描的功能和将信息转化为二维码的功能,现在来介绍一下怎么将生成的二维码保存到手机的本地,这样关于二维码的内容基本上就全面了,好开心~~!

同样的,我还是想说,首先我这个是做基于ionic+ngCordova+Anjularjs的项目,所以,希望大家在看之前已经了解了这三块内容了,不然,可能看起来会有难度的。

一、下载相关的插件的命令:

cordova plugin add https://github.com/devgeeks/Canvas2ImagePlugin.git

 

二、HTML代码:

<div class="col text-center">
    <span>(二维码)</span>

    <div class="cro">
        <div id="Qrcode">
            <div class="cro_left_top"></div>
            <div class="cro_right_top"></div>
            <div class="cro_left_bottom"></div>
            <div class="cro_right_bottom"></div>
        </div>
        <button class="button button-positive"
                ng-click="saveImageQrcode()">保存到手机
        </button>
    </div>
</div>

 

 

三、CSS代码,根据UI实现了如下界面的CSS代码:

 

<style type="text/css">
    .cro {
        width: 300px;
        height: 360px;
        position: relative;
        text-align: center;
        margin: auto;
        background: white;
    }

    .cro_left_top, .cro_right_top, .cro_left_bottom, .cro_right_bottom {
        position: absolute;
        width: 20px;
        height: 20px;
        z-index: 1;
        background: #212A27;
    }

    .cro_left_top {
        top: -1px;
        left: -1px;
        border-radius: 0px 0px 20px 0px;
    }

    .cro_right_top {
        top: -1px;
        right: -1px;
        border-radius: 0px 0px 0px 20px;
    }

    .cro_left_bottom {
        left: -1px;
        bottom: -1px;
        border-radius: 0px 20px 0px 0px;
    }

    .cro_right_bottom {
        right: -1px;
        bottom: -1px;
        border-radius: 20px 0px 0px 0px;
    }
</style>

 

四、JS代码如下:

var qrcode = new QRCode(document.getElementById("Qrcode"), {
    width: 200,
    height: 200
});
qrcode.makeCode("123");

var a = document.getElementById("Qrcode");
var canvas = a.children[4];
canvas.id = "myCanvas";
$scope.saveImage = canvas.toDataURL();

//调用保存二维码图片的函数
$scope.saveImageQrcode = function () {
    console.log(window.canvas2ImagePlugin);
    window.canvas2ImagePlugin.saveImageDataToLibrary(function (msg) {
            console.log(msg);
            $rootScope.alert('图片已保存');
        },
        function (err) {
            console.log(err);
        },
        document.getElementById('myCanvas')
    )
};

可以在模拟器或者真机上运行一下试试了~