由于下个ionic项目需要用到二维码扫描,就提前研究了,为了快速开发,选择使用优秀的第三方。
在网上看许多人都介绍了BarcodeScanner的使用,自己也就搭建了个项目尝试了一番,下面把自己实现得最顺的一次分享给大家。
1,搭建项目,我是使用VS2015搭建的一个空白的ionic项目。
2,添加二维码扫描的插件(如果使用VS,可以直接在插件中安装),cordova安装插件的命令:
cordova plugin add https://github.com/phonegap/phonegap-plugin-barcodescanner
3,在此处下载最新版本的ngCordova,将ng-cordova.min.js拷贝到项目的www/js目录下。
4,在index.html中引入上面的ngCordova,一定要注意引用的位置:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title></title>
<link href="lib/ionic/css/ionic.css" rel="stylesheet">
<link href="css/style.css" rel="stylesheet">
<script src="js/platformOverrides.js"></script>
<!-- ionic/angularjs js -->
<script src="lib/ionic/js/ionic.bundle.js"></script>
<script src="js/ng-cordova.min.js"></script>
<script src="cordova.js"></script>
<!-- your app's js -->
<script src="js/app.js"></script>
<script src="js/ExampleController.js"></script>
</head>
<body ng-app="starter">
<ion-content ng-controller="ExampleController">
<button class="button button-positive" ng-click="scanBarcode()">Scan</button>
</ion-content>
</body>
</html>
5,将ngCordova在app.js中注入:
angular.module('starter', ['ionic', 'ngCordova'])
angular.module('starter')
.controller("ExampleController", function ($scope, $cordovaBarcodeScanner) {
$scope.scanBarcode = function () {
$cordovaBarcodeScanner.scan().then(function (imageData) {
alert(imageData.text);
console.log("Barcode Format -> " + imageData.format);
console.log("Cancelled -> " + imageData.cancelled);
}, function (error) {
console.log("An error happened -> " + error);
});
};
});
<script src="js/ExampleController.js"></script>
8,在index.html中调用我们在ExampleController.js中写的方法:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title></title>
<link href="lib/ionic/css/ionic.css" rel="stylesheet">
<link href="css/style.css" rel="stylesheet">
<script src="js/platformOverrides.js"></script>
<!-- ionic/angularjs js -->
<script src="lib/ionic/js/ionic.bundle.js"></script>
<script src="js/ng-cordova.min.js"></script>
<script src="cordova.js"></script>
<!-- your app's js -->
<script src="js/app.js"></script>
<script src="js/ExampleController.js"></script>
</head>
<body ng-app="starter">
<ion-content ng-controller="ExampleController">
<button class="button button-positive" ng-click="scanBarcode()">Scan</button>
</ion-content>
</body>
</html>
好了,到此就能够成功的实现二维码扫描了。