-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathhtml5-qrcode.js
65 lines (57 loc) · 2.19 KB
/
html5-qrcode.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//---------------------------------------------------------------------
// JavaScript-HTML5 QRCode Generator
//
// Copyright (c) 2011 Amanuel Tewolde
//
// Licensed under the MIT license:
// http://www.opensource.org/licenses/mit-license.php
//
//---------------------------------------------------------------------
// Generates a QRCode of text provided.
// First QRCode is rendered to a canvas.
// The canvas is then turned to an image PNG
// before being returned as an <img> tag.
function showQRCode(text) {
var dotsize = 5; // size of box drawn on canvas
var padding = 10; // (white area around your QRCode)
var black = "rgb(0,0,0)";
var white = "rgb(255,255,255)";
var QRCodeVersion = 15; // 1-40 see http://www.denso-wave.com/qrcode/qrgene2-e.html
var canvas=document.createElement('canvas');
var qrCanvasContext = canvas.getContext('2d');
try {
// QR Code Error Correction Capability
// Higher levels improves error correction capability while decreasing the amount of data QR Code size.
// QRErrorCorrectLevel.L (5%) QRErrorCorrectLevel.M (15%) QRErrorCorrectLevel.Q (25%) QRErrorCorrectLevel.H (30%)
// eg. L can survive approx 5% damage...etc.
var qr = new QRCode(QRCodeVersion, QRErrorCorrectLevel.L);
qr.addData(text);
qr.make();
}
catch(err) {
var errorChild = document.createElement("p");
var errorMSG = document.createTextNode("QR Code FAIL! " + err);
errorChild.appendChild(errorMSG);
return errorChild;
}
var qrsize = qr.getModuleCount();
canvas.setAttribute('height',(qrsize * dotsize) + padding);
canvas.setAttribute('width',(qrsize * dotsize) + padding);
var shiftForPadding = padding/2;
if (canvas.getContext){
for (var r = 0; r < qrsize; r++) {
for (var c = 0; c < qrsize; c++) {
if (qr.isDark(r, c))
qrCanvasContext.fillStyle = black;
else
qrCanvasContext.fillStyle = white;
qrCanvasContext.fillRect ((c*dotsize) +shiftForPadding,(r*dotsize) + shiftForPadding,dotsize,dotsize); // x, y, w, h
}
}
}
var imgElement = document.createElement("img");
imgElement.src = canvas.toDataURL("image/png");
imgElement.height = 220;
imgElement.width = 200;
return imgElement;
}