parent
2b106ad642
commit
672549f4ac
@ -0,0 +1,30 @@
|
|||||||
|
# editorconfig.org
|
||||||
|
|
||||||
|
root = true
|
||||||
|
|
||||||
|
|
||||||
|
[*]
|
||||||
|
charset = utf-8
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 4
|
||||||
|
end_of_line = lf
|
||||||
|
insert_final_newline = true
|
||||||
|
trim_trailing_whitespace = true
|
||||||
|
|
||||||
|
|
||||||
|
[package.json]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
|
||||||
|
[.travis.yml]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
|
||||||
|
|
||||||
|
[*.md]
|
||||||
|
trim_trailing_whitespace = false
|
||||||
|
|
||||||
|
|
||||||
|
[*.jade]
|
||||||
|
trim_trailing_whitespace = false
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@ -1,92 +0,0 @@
|
|||||||
/*jshint node: true */
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = function (make) {
|
|
||||||
|
|
||||||
|
|
||||||
var path = require('path'),
|
|
||||||
pkg = require('./package.json'),
|
|
||||||
|
|
||||||
$ = make.fQuery,
|
|
||||||
|
|
||||||
root = path.resolve(__dirname),
|
|
||||||
src = path.join(root, 'src'),
|
|
||||||
dist = path.join(root, 'dist'),
|
|
||||||
build = path.join(root, 'build');
|
|
||||||
|
|
||||||
|
|
||||||
make.version('=0.11.0');
|
|
||||||
make.defaults('release');
|
|
||||||
|
|
||||||
|
|
||||||
make.target('clean', [], 'delete build folder').sync(function () {
|
|
||||||
|
|
||||||
$.DELETE(build);
|
|
||||||
$.DELETE(dist);
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
make.target('lint', [], 'lint all JavaScript files with JSHint').sync(function () {
|
|
||||||
|
|
||||||
var options = {
|
|
||||||
// Enforcing Options
|
|
||||||
bitwise: true,
|
|
||||||
curly: true,
|
|
||||||
eqeqeq: true,
|
|
||||||
forin: true,
|
|
||||||
latedef: true,
|
|
||||||
newcap: true,
|
|
||||||
noempty: true,
|
|
||||||
plusplus: true,
|
|
||||||
trailing: true,
|
|
||||||
undef: true,
|
|
||||||
|
|
||||||
// Environments
|
|
||||||
browser: true
|
|
||||||
},
|
|
||||||
global = {
|
|
||||||
'jQuery': true,
|
|
||||||
'qrcode': true
|
|
||||||
};
|
|
||||||
|
|
||||||
$(src + ': jquery.qrcode.js, demo/scripts.js').log(-3)
|
|
||||||
.jshint(options, global);
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
make.target('build', ['clean', 'lint'], 'build all files').sync(function () {
|
|
||||||
|
|
||||||
var header = '/* ' + pkg.displayName + ' ' + pkg.version + ' - ' + pkg.homepage + ' - uses //github.com/kazuhikoarase/qrcode-generator (MIT) */\n';
|
|
||||||
var env = {pkg: pkg};
|
|
||||||
|
|
||||||
$(src + ': jquery.qrcode.js')
|
|
||||||
.includify()
|
|
||||||
.handlebars(env)
|
|
||||||
.wrap(header)
|
|
||||||
.WRITE($.map.p(src, dist))
|
|
||||||
.WRITE($.map.p(src, build).s('.js', '-' + pkg.version + '.js'))
|
|
||||||
.uglifyjs()
|
|
||||||
.wrap(header)
|
|
||||||
.WRITE($.map.p(src, dist).s('.js', '.min.js'))
|
|
||||||
.WRITE($.map.p(src, build).s('.js', '-' + pkg.version + '.min.js'));
|
|
||||||
|
|
||||||
$(src + ': **, ! *.js')
|
|
||||||
.handlebars(env)
|
|
||||||
.WRITE($.map.p(src, build));
|
|
||||||
|
|
||||||
$(root + ': *.md')
|
|
||||||
.handlebars(env)
|
|
||||||
.WRITE($.map.p(root, build));
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
make.target('release', ['build'], 'create a zipball').async(function (done, fail) {
|
|
||||||
|
|
||||||
$(build + ': **').shzip({
|
|
||||||
target: path.join(build, pkg.name + '-' + pkg.version + '.zip'),
|
|
||||||
dir: build,
|
|
||||||
callback: done
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
@ -0,0 +1,87 @@
|
|||||||
|
/*jshint node: true */
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = function (suite) {
|
||||||
|
|
||||||
|
|
||||||
|
var path = require('path');
|
||||||
|
var root = path.resolve(__dirname);
|
||||||
|
var src = path.join(root, 'src');
|
||||||
|
var dist = path.join(root, 'dist');
|
||||||
|
var build = path.join(root, 'build');
|
||||||
|
|
||||||
|
var $ = require('fquery');
|
||||||
|
$.plugin('fquery-handlebars');
|
||||||
|
$.plugin('fquery-includeit');
|
||||||
|
$.plugin('fquery-jshint');
|
||||||
|
$.plugin('fquery-jszip');
|
||||||
|
$.plugin('fquery-uglifyjs');
|
||||||
|
|
||||||
|
|
||||||
|
suite.defaults('release');
|
||||||
|
|
||||||
|
|
||||||
|
suite.target('clean', [], 'delete build folder').task(function () {
|
||||||
|
|
||||||
|
$([build, dist], {dirs: true}).delete();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
suite.target('lint', [], 'lint all JavaScript files with JSHint').task(function () {
|
||||||
|
|
||||||
|
var options = {
|
||||||
|
// Enforcing Options
|
||||||
|
bitwise: true,
|
||||||
|
curly: true,
|
||||||
|
eqeqeq: true,
|
||||||
|
forin: true,
|
||||||
|
latedef: true,
|
||||||
|
newcap: true,
|
||||||
|
noempty: true,
|
||||||
|
plusplus: true,
|
||||||
|
trailing: true,
|
||||||
|
undef: true,
|
||||||
|
|
||||||
|
// Environments
|
||||||
|
browser: true
|
||||||
|
};
|
||||||
|
var global = {
|
||||||
|
'jQuery': true,
|
||||||
|
'qrcode': true
|
||||||
|
};
|
||||||
|
|
||||||
|
$(src + ': jquery.qrcode.js, demo/scripts.js')
|
||||||
|
.jshint(options, global);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
suite.target('release', ['clean', 'lint'], 'build all files and create a zipball').task(function () {
|
||||||
|
|
||||||
|
var pkg = require('./package.json');
|
||||||
|
var header = '/* ' + pkg.displayName + ' ' + pkg.version + ' - ' + pkg.homepage + ' - uses //github.com/kazuhikoarase/qrcode-generator (MIT) */\n';
|
||||||
|
var target = path.join(build, pkg.name + '-' + pkg.version + '.zip');
|
||||||
|
var env = {pkg: pkg};
|
||||||
|
|
||||||
|
$(src + ': jquery.qrcode.js')
|
||||||
|
.includeit()
|
||||||
|
.wrap(header)
|
||||||
|
.write($.map.p(src, dist), true)
|
||||||
|
.write($.map.p(src, build).s('.js', '-' + pkg.version + '.js'), true)
|
||||||
|
.uglifyjs()
|
||||||
|
.wrap(header)
|
||||||
|
.write($.map.p(src, dist).s('.js', '.min.js'), true)
|
||||||
|
.write($.map.p(src, build).s('.js', '-' + pkg.version + '.min.js'), true);
|
||||||
|
|
||||||
|
$(src + ': **, ! *.js')
|
||||||
|
.handlebars(env)
|
||||||
|
.write($.map.p(src, build), true);
|
||||||
|
|
||||||
|
$(root + ': *.md')
|
||||||
|
.write($.map.p(root, build), true);
|
||||||
|
|
||||||
|
$(build + ': **')
|
||||||
|
.jszip({dir: build})
|
||||||
|
.write(target, true);
|
||||||
|
});
|
||||||
|
};
|
@ -1,103 +1,104 @@
|
|||||||
|
(function () {
|
||||||
|
'use strict';
|
||||||
|
|
||||||
(function ($) {
|
var $ = jQuery;
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var isOpera = Object.prototype.toString.call(window.opera) === '[object Opera]',
|
var isOpera = Object.prototype.toString.call(window.opera) === '[object Opera]',
|
||||||
|
|
||||||
guiValuePairs = [
|
guiValuePairs = [
|
||||||
["size", "px"],
|
["size", "px"],
|
||||||
["minversion", ""],
|
["minversion", ""],
|
||||||
["quiet", " modules"],
|
["quiet", " modules"],
|
||||||
["radius", "%"],
|
["radius", "%"],
|
||||||
["msize", "%"],
|
["msize", "%"],
|
||||||
["mposx", "%"],
|
["mposx", "%"],
|
||||||
["mposy", "%"]
|
["mposy", "%"]
|
||||||
],
|
],
|
||||||
|
|
||||||
updateGui = function () {
|
updateGui = function () {
|
||||||
|
|
||||||
$.each(guiValuePairs, function (idx, pair) {
|
$.each(guiValuePairs, function (idx, pair) {
|
||||||
|
|
||||||
var $label = $('label[for="' + pair[0] + '"]');
|
var $label = $('label[for="' + pair[0] + '"]');
|
||||||
|
|
||||||
$label.text($label.text().replace(/:.*/, ': ' + $('#' + pair[0]).val() + pair[1]));
|
$label.text($label.text().replace(/:.*/, ': ' + $('#' + pair[0]).val() + pair[1]));
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
updateQrCode = function () {
|
updateQrCode = function () {
|
||||||
|
|
||||||
var options = {
|
var options = {
|
||||||
render: $("#render").val(),
|
render: $("#render").val(),
|
||||||
ecLevel: $("#eclevel").val(),
|
ecLevel: $("#eclevel").val(),
|
||||||
minVersion: parseInt($("#minversion").val(), 10),
|
minVersion: parseInt($("#minversion").val(), 10),
|
||||||
|
|
||||||
fill: $("#fill").val(),
|
fill: $("#fill").val(),
|
||||||
background: $("#background").val(),
|
background: $("#background").val(),
|
||||||
// fill: $("#img-buffer")[0],
|
// fill: $("#img-buffer")[0],
|
||||||
|
|
||||||
text: $("#text").val(),
|
text: $("#text").val(),
|
||||||
size: parseInt($("#size").val(), 10),
|
size: parseInt($("#size").val(), 10),
|
||||||
radius: parseInt($("#radius").val(), 10) * 0.01,
|
radius: parseInt($("#radius").val(), 10) * 0.01,
|
||||||
quiet: parseInt($("#quiet").val(), 10),
|
quiet: parseInt($("#quiet").val(), 10),
|
||||||
|
|
||||||
mode: parseInt($("#mode").val(), 10),
|
mode: parseInt($("#mode").val(), 10),
|
||||||
|
|
||||||
mSize: parseInt($("#msize").val(), 10) * 0.01,
|
mSize: parseInt($("#msize").val(), 10) * 0.01,
|
||||||
mPosX: parseInt($("#mposx").val(), 10) * 0.01,
|
mPosX: parseInt($("#mposx").val(), 10) * 0.01,
|
||||||
mPosY: parseInt($("#mposy").val(), 10) * 0.01,
|
mPosY: parseInt($("#mposy").val(), 10) * 0.01,
|
||||||
|
|
||||||
label: $("#label").val(),
|
label: $("#label").val(),
|
||||||
fontname: $("#font").val(),
|
fontname: $("#font").val(),
|
||||||
fontcolor: $("#fontcolor").val(),
|
fontcolor: $("#fontcolor").val(),
|
||||||
|
|
||||||
image: $("#img-buffer")[0]
|
image: $("#img-buffer")[0]
|
||||||
};
|
};
|
||||||
|
|
||||||
$("#container").empty().qrcode(options);
|
$("#container").empty().qrcode(options);
|
||||||
},
|
},
|
||||||
|
|
||||||
update = function () {
|
update = function () {
|
||||||
|
|
||||||
updateGui();
|
updateGui();
|
||||||
updateQrCode();
|
updateQrCode();
|
||||||
},
|
},
|
||||||
|
|
||||||
onImageInput = function () {
|
onImageInput = function () {
|
||||||
|
|
||||||
var input = $("#image")[0];
|
var input = $("#image")[0];
|
||||||
|
|
||||||
if (input.files && input.files[0]) {
|
if (input.files && input.files[0]) {
|
||||||
|
|
||||||
var reader = new FileReader();
|
var reader = new FileReader();
|
||||||
|
|
||||||
reader.onload = function (event) {
|
reader.onload = function (event) {
|
||||||
$("#img-buffer").attr("src", event.target.result);
|
$("#img-buffer").attr("src", event.target.result);
|
||||||
$("#mode").val("4");
|
$("#mode").val("4");
|
||||||
setTimeout(update, 250);
|
setTimeout(update, 250);
|
||||||
};
|
};
|
||||||
reader.readAsDataURL(input.files[0]);
|
reader.readAsDataURL(input.files[0]);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
download = function (event) {
|
download = function (event) {
|
||||||
|
|
||||||
var data = $("#container canvas")[0].toDataURL('image/png');
|
var data = $("#container canvas")[0].toDataURL('image/png');
|
||||||
$("#download").attr("href", data);
|
$("#download").attr("href", data);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
$(function () {
|
$(function () {
|
||||||
|
|
||||||
if (isOpera) {
|
if (isOpera) {
|
||||||
$('html').addClass('opera');
|
$('html').addClass('opera');
|
||||||
$('#radius').prop('disabled', true);
|
$('#radius').prop('disabled', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$("#download").on("click", download);
|
$("#download").on("click", download);
|
||||||
$("#image").on('change', onImageInput);
|
$("#image").on('change', onImageInput);
|
||||||
$("input, textarea, select").on("input change", update);
|
$("input, textarea, select").on("input change", update);
|
||||||
$(window).load(update);
|
$(window).load(update);
|
||||||
update();
|
update();
|
||||||
});
|
});
|
||||||
|
|
||||||
}(jQuery));
|
}());
|
||||||
|
@ -1,112 +1,111 @@
|
|||||||
|
|
||||||
body {
|
body {
|
||||||
font-family: Ubuntu;
|
font-family: Ubuntu;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
background: repeat url("back.png");
|
background: repeat url("back.png");
|
||||||
}
|
}
|
||||||
|
|
||||||
#banner {
|
#banner {
|
||||||
display: block;
|
display: block;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
color: rgb(29, 119, 194);
|
color: rgb(29, 119, 194);
|
||||||
padding: 12px 0 0;
|
padding: 12px 0 0;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
#banner:hover {
|
#banner:hover {
|
||||||
color: #333;
|
color: #333;
|
||||||
}
|
}
|
||||||
|
|
||||||
#container {
|
#container {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
margin: 20px auto;
|
margin: 20px auto;
|
||||||
box-shadow: 0 0 16px rgba(0,0,0,0.5);
|
box-shadow: 0 0 16px rgba(0,0,0,0.5);
|
||||||
}
|
}
|
||||||
|
|
||||||
#container > * {
|
#container > * {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
.control {
|
.control {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
background-color: #f8f8f8;
|
background-color: #f8f8f8;
|
||||||
top: 0;
|
top: 0;
|
||||||
width: 190px;
|
width: 190px;
|
||||||
box-shadow: 0 0 32px rgba(0,0,0,0.5);
|
box-shadow: 0 0 32px rgba(0,0,0,0.5);
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
}
|
||||||
|
|
||||||
.control.left {
|
.control.left {
|
||||||
left: 0;
|
left: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.control.right {
|
.control.right {
|
||||||
right: 0;
|
right: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
hr {
|
hr {
|
||||||
margin: 12px 0 0;
|
margin: 12px 0 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
border: none;
|
border: none;
|
||||||
height: 1px;
|
height: 1px;
|
||||||
background-color: rgba(0,0,0,0.1);
|
background-color: rgba(0,0,0,0.1);
|
||||||
}
|
}
|
||||||
|
|
||||||
label {
|
label {
|
||||||
font-size: 10px;
|
font-size: 10px;
|
||||||
color: #bbb;
|
color: #bbb;
|
||||||
padding: 12px 4px 0 4px;
|
padding: 12px 4px 0 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
html.opera label[for="radius"] {
|
html.opera label[for="radius"] {
|
||||||
color: #e55;
|
color: #e55;
|
||||||
}
|
}
|
||||||
|
|
||||||
#download {
|
#download {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
display: block;
|
display: block;
|
||||||
color: #555;
|
color: #555;
|
||||||
background-color: #ddd;
|
background-color: #ddd;
|
||||||
margin: 4px;
|
margin: 4px;
|
||||||
padding: 8px 0;
|
padding: 8px 0;
|
||||||
border: 1px solid #ddd;
|
border: 1px solid #ddd;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
input, textarea, select {
|
input, textarea, select {
|
||||||
font-family: Ubuntu;
|
font-family: Ubuntu;
|
||||||
display: block;
|
display: block;
|
||||||
background-color: #fff;
|
background-color: #fff;
|
||||||
margin: 2px;
|
margin: 2px;
|
||||||
padding: 0 2px;
|
padding: 0 2px;
|
||||||
border: 1px solid #ddd;
|
border: 1px solid #ddd;
|
||||||
width: 180px;
|
width: 180px;
|
||||||
height: 22px;
|
height: 22px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#text {
|
#text {
|
||||||
height: 48px;
|
height: 48px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#img-buffer {
|
#img-buffer {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
input[type="range"] {
|
input[type="range"] {
|
||||||
-webkit-appearance: none;
|
-webkit-appearance: none;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
input::-webkit-slider-thumb {
|
input::-webkit-slider-thumb {
|
||||||
-webkit-appearance: none;
|
-webkit-appearance: none;
|
||||||
width: 16px;
|
width: 16px;
|
||||||
height: 16px;
|
height: 16px;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #aaa), color-stop(1, #aaa) );
|
background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #aaa), color-stop(1, #aaa) );
|
||||||
}
|
}
|
||||||
|
@ -1,469 +1,471 @@
|
|||||||
(function ($) {
|
(function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var $ = jQuery;
|
||||||
// Wrapper for the original QR code generator.
|
|
||||||
var QRCode = function (text, level, version, quiet) {
|
// Wrapper for the original QR code generator.
|
||||||
|
var QRCode = function (text, level, version, quiet) {
|
||||||
|
|
||||||
|
// `qrcode` is the single public function that will be defined by the `QR Code Generator`
|
||||||
|
// at the end of the file.
|
||||||
|
var qr = qrcode(version, level);
|
||||||
|
qr.addData(text);
|
||||||
|
qr.make();
|
||||||
|
|
||||||
|
quiet = quiet || 0;
|
||||||
|
|
||||||
|
var qrModuleCount = qr.getModuleCount(),
|
||||||
|
quietModuleCount = qr.getModuleCount() + 2*quiet,
|
||||||
|
isDark = function (row, col) {
|
||||||
|
|
||||||
|
row -= quiet;
|
||||||
|
col -= quiet;
|
||||||
|
|
||||||
|
if (row < 0 || row >= qrModuleCount || col < 0 || col >= qrModuleCount) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return qr.isDark(row, col);
|
||||||
|
},
|
||||||
|
addBlank = function (l, t, r, b) {
|
||||||
|
|
||||||
|
var prevIsDark = this.isDark,
|
||||||
|
moduleSize = 1 / quietModuleCount;
|
||||||
|
|
||||||
|
this.isDark = function (row, col) {
|
||||||
|
|
||||||
|
var ml = col * moduleSize,
|
||||||
|
mt = row * moduleSize,
|
||||||
|
mr = ml + moduleSize,
|
||||||
|
mb = mt + moduleSize;
|
||||||
|
|
||||||
|
return prevIsDark(row, col) && (l > mr || ml > r || t > mb || mt > b);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
this.text = text;
|
||||||
|
this.level = level;
|
||||||
|
this.version = version;
|
||||||
|
this.moduleCount = quietModuleCount;
|
||||||
|
this.isDark = isDark;
|
||||||
|
this.addBlank = addBlank;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Check if canvas is available in the browser (as Modernizr does)
|
||||||
|
canvasAvailable = (function () {
|
||||||
|
|
||||||
|
var elem = document.createElement('canvas');
|
||||||
|
return !!(elem.getContext && elem.getContext('2d'));
|
||||||
|
}()),
|
||||||
|
|
||||||
|
arcToAvailable = Object.prototype.toString.call(window.opera) !== '[object Opera]',
|
||||||
|
|
||||||
|
// Returns a minimal QR code for the given text starting with version `minVersion`.
|
||||||
|
// Returns `null` if `text` is too long to be encoded in `maxVersion`.
|
||||||
|
createQRCode = function (text, level, minVersion, maxVersion, quiet) {
|
||||||
|
|
||||||
|
minVersion = Math.max(1, minVersion || 1);
|
||||||
|
maxVersion = Math.min(40, maxVersion || 40);
|
||||||
|
for (var version = minVersion; version <= maxVersion; version += 1) {
|
||||||
|
try {
|
||||||
|
return new QRCode(text, level, version, quiet);
|
||||||
|
} catch (err) {}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawBackgroundLabel = function (qr, context, settings) {
|
||||||
|
|
||||||
|
var size = settings.size,
|
||||||
|
font = "bold " + (settings.mSize * size) + "px " + settings.fontname,
|
||||||
|
ctx = $('<canvas/>')[0].getContext("2d");
|
||||||
|
|
||||||
|
ctx.font = font;
|
||||||
|
|
||||||
|
var w = ctx.measureText(settings.label).width,
|
||||||
|
sh = settings.mSize,
|
||||||
|
sw = w / size,
|
||||||
|
sl = (1 - sw) * settings.mPosX,
|
||||||
|
st = (1 - sh) * settings.mPosY,
|
||||||
|
sr = sl + sw,
|
||||||
|
sb = st + sh,
|
||||||
|
pad = 0.01;
|
||||||
|
|
||||||
|
if (settings.mode === 1) {
|
||||||
|
// Strip
|
||||||
|
qr.addBlank(0, st - pad, size, sb + pad);
|
||||||
|
} else {
|
||||||
|
// Box
|
||||||
|
qr.addBlank(sl - pad, st - pad, sr + pad, sb + pad);
|
||||||
|
}
|
||||||
|
|
||||||
|
context.fillStyle = settings.fontcolor;
|
||||||
|
context.font = font;
|
||||||
|
context.fillText(settings.label, sl*size, st*size + 0.75 * settings.mSize * size);
|
||||||
|
},
|
||||||
|
|
||||||
|
drawBackgroundImage = function (qr, context, settings) {
|
||||||
|
|
||||||
|
var size = settings.size,
|
||||||
|
w = settings.image.naturalWidth || 1,
|
||||||
|
h = settings.image.naturalHeight || 1,
|
||||||
|
sh = settings.mSize,
|
||||||
|
sw = sh * w / h,
|
||||||
|
sl = (1 - sw) * settings.mPosX,
|
||||||
|
st = (1 - sh) * settings.mPosY,
|
||||||
|
sr = sl + sw,
|
||||||
|
sb = st + sh,
|
||||||
|
pad = 0.01;
|
||||||
|
|
||||||
|
if (settings.mode === 3) {
|
||||||
|
// Strip
|
||||||
|
qr.addBlank(0, st - pad, size, sb + pad);
|
||||||
|
} else {
|
||||||
|
// Box
|
||||||
|
qr.addBlank(sl - pad, st - pad, sr + pad, sb + pad);
|
||||||
|
}
|
||||||
|
|
||||||
|
context.drawImage(settings.image, sl*size, st*size, sw*size, sh*size);
|
||||||
|
},
|
||||||
|
|
||||||
|
drawBackground = function (qr, context, settings) {
|
||||||
|
|
||||||
|
if ($(settings.background).is('img')) {
|
||||||
|
context.drawImage(settings.background, 0, 0, settings.size, settings.size);
|
||||||
|
} else if (settings.background) {
|
||||||
|
context.fillStyle = settings.background;
|
||||||
|
context.fillRect(settings.left, settings.top, settings.size, settings.size);
|
||||||
|
}
|
||||||
|
|
||||||
|
var mode = settings.mode;
|
||||||
|
if (mode === 1 || mode === 2) {
|
||||||
|
drawBackgroundLabel(qr, context, settings);
|
||||||
|
} else if (mode === 3 || mode === 4) {
|
||||||
|
drawBackgroundImage(qr, context, settings);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawModuleDefault = function (qr, context, settings, left, top, width, row, col) {
|
||||||
|
|
||||||
|
if (qr.isDark(row, col)) {
|
||||||
|
context.rect(left, top, width, width);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawModuleRoundedDark = function (ctx, l, t, r, b, rad, nw, ne, se, sw) {
|
||||||
|
|
||||||
|
if (nw) {
|
||||||
|
ctx.moveTo(l + rad, t);
|
||||||
|
} else {
|
||||||
|
ctx.moveTo(l, t);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ne) {
|
||||||
|
ctx.lineTo(r - rad, t);
|
||||||
|
ctx.arcTo(r, t, r, b, rad);
|
||||||
|
} else {
|
||||||
|
ctx.lineTo(r, t);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (se) {
|
||||||
|
ctx.lineTo(r, b - rad);
|
||||||
|
ctx.arcTo(r, b, l, b, rad);
|
||||||
|
} else {
|
||||||
|
ctx.lineTo(r, b);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sw) {
|
||||||
|
ctx.lineTo(l + rad, b);
|
||||||
|
ctx.arcTo(l, b, l, t, rad);
|
||||||
|
} else {
|
||||||
|
ctx.lineTo(l, b);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nw) {
|
||||||
|
ctx.lineTo(l, t + rad);
|
||||||
|
ctx.arcTo(l, t, r, t, rad);
|
||||||
|
} else {
|
||||||
|
ctx.lineTo(l, t);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawModuleRoundendLight = function (ctx, l, t, r, b, rad, nw, ne, se, sw) {
|
||||||
|
|
||||||
|
if (nw) {
|
||||||
|
ctx.moveTo(l + rad, t);
|
||||||
|
ctx.lineTo(l, t);
|
||||||
|
ctx.lineTo(l, t + rad);
|
||||||
|
ctx.arcTo(l, t, l + rad, t, rad);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ne) {
|
||||||
|
ctx.moveTo(r - rad, t);
|
||||||
|
ctx.lineTo(r, t);
|
||||||
|
ctx.lineTo(r, t + rad);
|
||||||
|
ctx.arcTo(r, t, r - rad, t, rad);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (se) {
|
||||||
|
ctx.moveTo(r - rad, b);
|
||||||
|
ctx.lineTo(r, b);
|
||||||
|
ctx.lineTo(r, b - rad);
|
||||||
|
ctx.arcTo(r, b, r - rad, b, rad);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sw) {
|
||||||
|
ctx.moveTo(l + rad, b);
|
||||||
|
ctx.lineTo(l, b);
|
||||||
|
ctx.lineTo(l, b - rad);
|
||||||
|
ctx.arcTo(l, b, l + rad, b, rad);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawModuleRounded = function (qr, context, settings, left, top, width, row, col) {
|
||||||
|
|
||||||
|
var isDark = qr.isDark,
|
||||||
|
right = left + width,
|
||||||
|
bottom = top + width,
|
||||||
|
radius = settings.radius * width,
|
||||||
|
rowT = row - 1,
|
||||||
|
rowB = row + 1,
|
||||||
|
colL = col - 1,
|
||||||
|
colR = col + 1,
|
||||||
|
center = isDark(row, col),
|
||||||
|
northwest = isDark(rowT, colL),
|
||||||
|
north = isDark(rowT, col),
|
||||||
|
northeast = isDark(rowT, colR),
|
||||||
|
east = isDark(row, colR),
|
||||||
|
southeast = isDark(rowB, colR),
|
||||||
|
south = isDark(rowB, col),
|
||||||
|
southwest = isDark(rowB, colL),
|
||||||
|
west = isDark(row, colL);
|
||||||
|
|
||||||
|
if (center) {
|
||||||
|
drawModuleRoundedDark(context, left, top, right, bottom, radius, !north && !west, !north && !east, !south && !east, !south && !west);
|
||||||
|
} else {
|
||||||
|
drawModuleRoundendLight(context, left, top, right, bottom, radius, north && west && northwest, north && east && northeast, south && east && southeast, south && west && southwest);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
drawModules = function (qr, context, settings) {
|
||||||
|
|
||||||
|
var moduleCount = qr.moduleCount,
|
||||||
|
moduleSize = settings.size / moduleCount,
|
||||||
|
fn = drawModuleDefault,
|
||||||
|
row, col;
|
||||||
|
|
||||||
|
if (arcToAvailable && settings.radius > 0 && settings.radius <= 0.5) {
|
||||||
|
fn = drawModuleRounded;
|
||||||
|
}
|
||||||
|
|
||||||
|
context.beginPath();
|
||||||
|
for (row = 0; row < moduleCount; row += 1) {
|
||||||
|
for (col = 0; col < moduleCount; col += 1) {
|
||||||
|
|
||||||
|
var l = settings.left + col * moduleSize,
|
||||||
|
t = settings.top + row * moduleSize,
|
||||||
|
w = moduleSize;
|
||||||
|
|
||||||
|
fn(qr, context, settings, l, t, w, row, col);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($(settings.fill).is('img')) {
|
||||||
|
context.strokeStyle = 'rgba(0,0,0,0.5)';
|
||||||
|
context.lineWidth = 2;
|
||||||
|
context.stroke();
|
||||||
|
var prev = context.globalCompositeOperation;
|
||||||
|
context.globalCompositeOperation = "destination-out";
|
||||||
|
context.fill();
|
||||||
|
context.globalCompositeOperation = prev;
|
||||||
|
|
||||||
|
context.clip();
|
||||||
|
context.drawImage(settings.fill, 0, 0, settings.size, settings.size);
|
||||||
|
context.restore();
|
||||||
|
} else {
|
||||||
|
context.fillStyle = settings.fill;
|
||||||
|
context.fill();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// Draws QR code to the given `canvas` and returns it.
|
||||||
|
drawOnCanvas = function (canvas, settings) {
|
||||||
|
|
||||||
|
var qr = createQRCode(settings.text, settings.ecLevel, settings.minVersion, settings.maxVersion, settings.quiet);
|
||||||
|
if (!qr) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
var $canvas = $(canvas).data('qrcode', qr),
|
||||||
|
context = $canvas[0].getContext('2d');
|
||||||
|
|
||||||
|
drawBackground(qr, context, settings);
|
||||||
|
drawModules(qr, context, settings);
|
||||||
|
|
||||||
|
return $canvas;
|
||||||
|
},
|
||||||
|
|
||||||
|
// Returns a `canvas` element representing the QR code for the given settings.
|
||||||
|
createCanvas = function (settings) {
|
||||||
|
|
||||||
|
var $canvas = $('<canvas/>').attr('width', settings.size).attr('height', settings.size);
|
||||||
|
return drawOnCanvas($canvas, settings);
|
||||||
|
},
|
||||||
|
|
||||||
|
// Returns an `image` element representing the QR code for the given settings.
|
||||||
|
createImage = function (settings) {
|
||||||
|
|
||||||
|
return $('<img/>').attr('src', createCanvas(settings)[0].toDataURL('image/png'));
|
||||||
|
},
|
||||||
|
|
||||||
|
// Returns a `div` element representing the QR code for the given settings.
|
||||||
|
createDiv = function (settings) {
|
||||||
|
|
||||||
|
var qr = createQRCode(settings.text, settings.ecLevel, settings.minVersion, settings.maxVersion, settings.quiet);
|
||||||
|
if (!qr) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// some shortcuts to improve compression
|
||||||
|
var settings_size = settings.size,
|
||||||
|
settings_bgColor = settings.background,
|
||||||
|
math_floor = Math.floor,
|
||||||
|
|
||||||
|
moduleCount = qr.moduleCount,
|
||||||
|
moduleSize = math_floor(settings_size / moduleCount),
|
||||||
|
offset = math_floor(0.5 * (settings_size - moduleSize * moduleCount)),
|
||||||
|
|
||||||
|
row, col,
|
||||||
|
|
||||||
|
containerCSS = {
|
||||||
|
position: 'relative',
|
||||||
|
left: 0,
|
||||||
|
top: 0,
|
||||||
|
padding: 0,
|
||||||
|
margin: 0,
|
||||||
|
width: settings_size,
|
||||||
|
height: settings_size
|
||||||
|
},
|
||||||
|
darkCSS = {
|
||||||
|
position: 'absolute',
|
||||||
|
padding: 0,
|
||||||
|
margin: 0,
|
||||||
|
width: moduleSize,
|
||||||
|
height: moduleSize,
|
||||||
|
'background-color': settings.fill
|
||||||
|
},
|
||||||
|
|
||||||
|
$div = $('<div/>').data('qrcode', qr).css(containerCSS);
|
||||||
|
|
||||||
|
if (settings_bgColor) {
|
||||||
|
$div.css('background-color', settings_bgColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (row = 0; row < moduleCount; row += 1) {
|
||||||
|
for (col = 0; col < moduleCount; col += 1) {
|
||||||
|
if (qr.isDark(row, col)) {
|
||||||
|
$('<div/>')
|
||||||
|
.css(darkCSS)
|
||||||
|
.css({
|
||||||
|
left: offset + col * moduleSize,
|
||||||
|
top: offset + row * moduleSize
|
||||||
|
})
|
||||||
|
.appendTo($div);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $div;
|
||||||
|
},
|
||||||
|
|
||||||
|
createHTML = function (settings) {
|
||||||
|
|
||||||
|
if (canvasAvailable && settings.render === 'canvas') {
|
||||||
|
return createCanvas(settings);
|
||||||
|
} else if (canvasAvailable && settings.render === 'image') {
|
||||||
|
return createImage(settings);
|
||||||
|
}
|
||||||
|
|
||||||
// `qrcode` is the single public function that will be defined by the `QR Code Generator`
|
return createDiv(settings);
|
||||||
// at the end of the file.
|
},
|
||||||
var qr = qrcode(version, level);
|
|
||||||
qr.addData(text);
|
|
||||||
qr.make();
|
|
||||||
|
|
||||||
quiet = quiet || 0;
|
|
||||||
|
|
||||||
var qrModuleCount = qr.getModuleCount(),
|
|
||||||
quietModuleCount = qr.getModuleCount() + 2*quiet,
|
|
||||||
isDark = function (row, col) {
|
|
||||||
|
|
||||||
row -= quiet;
|
|
||||||
col -= quiet;
|
|
||||||
|
|
||||||
if (row < 0 || row >= qrModuleCount || col < 0 || col >= qrModuleCount) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return qr.isDark(row, col);
|
|
||||||
},
|
|
||||||
addBlank = function (l, t, r, b) {
|
|
||||||
|
|
||||||
var prevIsDark = this.isDark,
|
|
||||||
moduleSize = 1 / quietModuleCount;
|
|
||||||
|
|
||||||
this.isDark = function (row, col) {
|
|
||||||
|
|
||||||
var ml = col * moduleSize,
|
|
||||||
mt = row * moduleSize,
|
|
||||||
mr = ml + moduleSize,
|
|
||||||
mb = mt + moduleSize;
|
|
||||||
|
|
||||||
return prevIsDark(row, col) && (l > mr || ml > r || t > mb || mt > b);
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
this.text = text;
|
|
||||||
this.level = level;
|
|
||||||
this.version = version;
|
|
||||||
this.moduleCount = quietModuleCount;
|
|
||||||
this.isDark = isDark;
|
|
||||||
this.addBlank = addBlank;
|
|
||||||
},
|
|
||||||
|
|
||||||
// Check if canvas is available in the browser (as Modernizr does)
|
|
||||||
canvasAvailable = (function () {
|
|
||||||
|
|
||||||
var elem = document.createElement('canvas');
|
|
||||||
return !!(elem.getContext && elem.getContext('2d'));
|
|
||||||
}()),
|
|
||||||
|
|
||||||
arcToAvailable = Object.prototype.toString.call(window.opera) !== '[object Opera]',
|
|
||||||
|
|
||||||
// Returns a minimal QR code for the given text starting with version `minVersion`.
|
|
||||||
// Returns `null` if `text` is too long to be encoded in `maxVersion`.
|
|
||||||
createQRCode = function (text, level, minVersion, maxVersion, quiet) {
|
|
||||||
|
|
||||||
minVersion = Math.max(1, minVersion || 1);
|
|
||||||
maxVersion = Math.min(40, maxVersion || 40);
|
|
||||||
for (var version = minVersion; version <= maxVersion; version += 1) {
|
|
||||||
try {
|
|
||||||
return new QRCode(text, level, version, quiet);
|
|
||||||
} catch (err) {}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawBackgroundLabel = function (qr, context, settings) {
|
|
||||||
|
|
||||||
var size = settings.size,
|
|
||||||
font = "bold " + (settings.mSize * size) + "px " + settings.fontname,
|
|
||||||
ctx = $('<canvas/>')[0].getContext("2d");
|
|
||||||
|
|
||||||
ctx.font = font;
|
|
||||||
|
|
||||||
var w = ctx.measureText(settings.label).width,
|
|
||||||
sh = settings.mSize,
|
|
||||||
sw = w / size,
|
|
||||||
sl = (1 - sw) * settings.mPosX,
|
|
||||||
st = (1 - sh) * settings.mPosY,
|
|
||||||
sr = sl + sw,
|
|
||||||
sb = st + sh,
|
|
||||||
pad = 0.01;
|
|
||||||
|
|
||||||
if (settings.mode === 1) {
|
|
||||||
// Strip
|
|
||||||
qr.addBlank(0, st - pad, size, sb + pad);
|
|
||||||
} else {
|
|
||||||
// Box
|
|
||||||
qr.addBlank(sl - pad, st - pad, sr + pad, sb + pad);
|
|
||||||
}
|
|
||||||
|
|
||||||
context.fillStyle = settings.fontcolor;
|
|
||||||
context.font = font;
|
|
||||||
context.fillText(settings.label, sl*size, st*size + 0.75 * settings.mSize * size);
|
|
||||||
},
|
|
||||||
|
|
||||||
drawBackgroundImage = function (qr, context, settings) {
|
|
||||||
|
|
||||||
var size = settings.size,
|
|
||||||
w = settings.image.naturalWidth || 1,
|
|
||||||
h = settings.image.naturalHeight || 1,
|
|
||||||
sh = settings.mSize,
|
|
||||||
sw = sh * w / h,
|
|
||||||
sl = (1 - sw) * settings.mPosX,
|
|
||||||
st = (1 - sh) * settings.mPosY,
|
|
||||||
sr = sl + sw,
|
|
||||||
sb = st + sh,
|
|
||||||
pad = 0.01;
|
|
||||||
|
|
||||||
if (settings.mode === 3) {
|
|
||||||
// Strip
|
|
||||||
qr.addBlank(0, st - pad, size, sb + pad);
|
|
||||||
} else {
|
|
||||||
// Box
|
|
||||||
qr.addBlank(sl - pad, st - pad, sr + pad, sb + pad);
|
|
||||||
}
|
|
||||||
|
|
||||||
context.drawImage(settings.image, sl*size, st*size, sw*size, sh*size);
|
|
||||||
},
|
|
||||||
|
|
||||||
drawBackground = function (qr, context, settings) {
|
|
||||||
|
|
||||||
if ($(settings.background).is('img')) {
|
|
||||||
context.drawImage(settings.background, 0, 0, settings.size, settings.size);
|
|
||||||
} else if (settings.background) {
|
|
||||||
context.fillStyle = settings.background;
|
|
||||||
context.fillRect(settings.left, settings.top, settings.size, settings.size);
|
|
||||||
}
|
|
||||||
|
|
||||||
var mode = settings.mode;
|
|
||||||
if (mode === 1 || mode === 2) {
|
|
||||||
drawBackgroundLabel(qr, context, settings);
|
|
||||||
} else if (mode === 3 || mode === 4) {
|
|
||||||
drawBackgroundImage(qr, context, settings);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawModuleDefault = function (qr, context, settings, left, top, width, row, col) {
|
|
||||||
|
|
||||||
if (qr.isDark(row, col)) {
|
|
||||||
context.rect(left, top, width, width);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawModuleRoundedDark = function (ctx, l, t, r, b, rad, nw, ne, se, sw) {
|
|
||||||
|
|
||||||
if (nw) {
|
|
||||||
ctx.moveTo(l + rad, t);
|
|
||||||
} else {
|
|
||||||
ctx.moveTo(l, t);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ne) {
|
|
||||||
ctx.lineTo(r - rad, t);
|
|
||||||
ctx.arcTo(r, t, r, b, rad);
|
|
||||||
} else {
|
|
||||||
ctx.lineTo(r, t);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (se) {
|
|
||||||
ctx.lineTo(r, b - rad);
|
|
||||||
ctx.arcTo(r, b, l, b, rad);
|
|
||||||
} else {
|
|
||||||
ctx.lineTo(r, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sw) {
|
|
||||||
ctx.lineTo(l + rad, b);
|
|
||||||
ctx.arcTo(l, b, l, t, rad);
|
|
||||||
} else {
|
|
||||||
ctx.lineTo(l, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (nw) {
|
|
||||||
ctx.lineTo(l, t + rad);
|
|
||||||
ctx.arcTo(l, t, r, t, rad);
|
|
||||||
} else {
|
|
||||||
ctx.lineTo(l, t);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawModuleRoundendLight = function (ctx, l, t, r, b, rad, nw, ne, se, sw) {
|
|
||||||
|
|
||||||
if (nw) {
|
|
||||||
ctx.moveTo(l + rad, t);
|
|
||||||
ctx.lineTo(l, t);
|
|
||||||
ctx.lineTo(l, t + rad);
|
|
||||||
ctx.arcTo(l, t, l + rad, t, rad);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ne) {
|
|
||||||
ctx.moveTo(r - rad, t);
|
|
||||||
ctx.lineTo(r, t);
|
|
||||||
ctx.lineTo(r, t + rad);
|
|
||||||
ctx.arcTo(r, t, r - rad, t, rad);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (se) {
|
|
||||||
ctx.moveTo(r - rad, b);
|
|
||||||
ctx.lineTo(r, b);
|
|
||||||
ctx.lineTo(r, b - rad);
|
|
||||||
ctx.arcTo(r, b, r - rad, b, rad);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sw) {
|
|
||||||
ctx.moveTo(l + rad, b);
|
|
||||||
ctx.lineTo(l, b);
|
|
||||||
ctx.lineTo(l, b - rad);
|
|
||||||
ctx.arcTo(l, b, l + rad, b, rad);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawModuleRounded = function (qr, context, settings, left, top, width, row, col) {
|
|
||||||
|
|
||||||
var isDark = qr.isDark,
|
|
||||||
right = left + width,
|
|
||||||
bottom = top + width,
|
|
||||||
radius = settings.radius * width,
|
|
||||||
rowT = row - 1,
|
|
||||||
rowB = row + 1,
|
|
||||||
colL = col - 1,
|
|
||||||
colR = col + 1,
|
|
||||||
center = isDark(row, col),
|
|
||||||
northwest = isDark(rowT, colL),
|
|
||||||
north = isDark(rowT, col),
|
|
||||||
northeast = isDark(rowT, colR),
|
|
||||||
east = isDark(row, colR),
|
|
||||||
southeast = isDark(rowB, colR),
|
|
||||||
south = isDark(rowB, col),
|
|
||||||
southwest = isDark(rowB, colL),
|
|
||||||
west = isDark(row, colL);
|
|
||||||
|
|
||||||
if (center) {
|
|
||||||
drawModuleRoundedDark(context, left, top, right, bottom, radius, !north && !west, !north && !east, !south && !east, !south && !west);
|
|
||||||
} else {
|
|
||||||
drawModuleRoundendLight(context, left, top, right, bottom, radius, north && west && northwest, north && east && northeast, south && east && southeast, south && west && southwest);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
drawModules = function (qr, context, settings) {
|
|
||||||
|
|
||||||
var moduleCount = qr.moduleCount,
|
|
||||||
moduleSize = settings.size / moduleCount,
|
|
||||||
fn = drawModuleDefault,
|
|
||||||
row, col;
|
|
||||||
|
|
||||||
if (arcToAvailable && settings.radius > 0 && settings.radius <= 0.5) {
|
|
||||||
fn = drawModuleRounded;
|
|
||||||
}
|
|
||||||
|
|
||||||
context.beginPath();
|
|
||||||
for (row = 0; row < moduleCount; row += 1) {
|
|
||||||
for (col = 0; col < moduleCount; col += 1) {
|
|
||||||
|
|
||||||
var l = settings.left + col * moduleSize,
|
|
||||||
t = settings.top + row * moduleSize,
|
|
||||||
w = moduleSize;
|
|
||||||
|
|
||||||
fn(qr, context, settings, l, t, w, row, col);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($(settings.fill).is('img')) {
|
|
||||||
context.strokeStyle = 'rgba(0,0,0,0.5)';
|
|
||||||
context.lineWidth = 2;
|
|
||||||
context.stroke();
|
|
||||||
var prev = context.globalCompositeOperation;
|
|
||||||
context.globalCompositeOperation = "destination-out";
|
|
||||||
context.fill();
|
|
||||||
context.globalCompositeOperation = prev;
|
|
||||||
|
|
||||||
context.clip();
|
|
||||||
context.drawImage(settings.fill, 0, 0, settings.size, settings.size);
|
|
||||||
context.restore();
|
|
||||||
} else {
|
|
||||||
context.fillStyle = settings.fill;
|
|
||||||
context.fill();
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
// Draws QR code to the given `canvas` and returns it.
|
|
||||||
drawOnCanvas = function (canvas, settings) {
|
|
||||||
|
|
||||||
var qr = createQRCode(settings.text, settings.ecLevel, settings.minVersion, settings.maxVersion, settings.quiet);
|
|
||||||
if (!qr) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
var $canvas = $(canvas).data('qrcode', qr),
|
|
||||||
context = $canvas[0].getContext('2d');
|
|
||||||
|
|
||||||
drawBackground(qr, context, settings);
|
|
||||||
drawModules(qr, context, settings);
|
|
||||||
|
|
||||||
return $canvas;
|
|
||||||
},
|
|
||||||
|
|
||||||
// Returns a `canvas` element representing the QR code for the given settings.
|
|
||||||
createCanvas = function (settings) {
|
|
||||||
|
|
||||||
var $canvas = $('<canvas/>').attr('width', settings.size).attr('height', settings.size);
|
|
||||||
return drawOnCanvas($canvas, settings);
|
|
||||||
},
|
|
||||||
|
|
||||||
// Returns an `image` element representing the QR code for the given settings.
|
|
||||||
createImage = function (settings) {
|
|
||||||
|
|
||||||
return $('<img/>').attr('src', createCanvas(settings)[0].toDataURL('image/png'));
|
|
||||||
},
|
|
||||||
|
|
||||||
// Returns a `div` element representing the QR code for the given settings.
|
|
||||||
createDiv = function (settings) {
|
|
||||||
|
|
||||||
var qr = createQRCode(settings.text, settings.ecLevel, settings.minVersion, settings.maxVersion, settings.quiet);
|
|
||||||
if (!qr) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// some shortcuts to improve compression
|
|
||||||
var settings_size = settings.size,
|
|
||||||
settings_bgColor = settings.background,
|
|
||||||
math_floor = Math.floor,
|
|
||||||
|
|
||||||
moduleCount = qr.moduleCount,
|
|
||||||
moduleSize = math_floor(settings_size / moduleCount),
|
|
||||||
offset = math_floor(0.5 * (settings_size - moduleSize * moduleCount)),
|
|
||||||
|
|
||||||
row, col,
|
|
||||||
|
|
||||||
containerCSS = {
|
|
||||||
position: 'relative',
|
|
||||||
left: 0,
|
|
||||||
top: 0,
|
|
||||||
padding: 0,
|
|
||||||
margin: 0,
|
|
||||||
width: settings_size,
|
|
||||||
height: settings_size
|
|
||||||
},
|
|
||||||
darkCSS = {
|
|
||||||
position: 'absolute',
|
|
||||||
padding: 0,
|
|
||||||
margin: 0,
|
|
||||||
width: moduleSize,
|
|
||||||
height: moduleSize,
|
|
||||||
'background-color': settings.fill
|
|
||||||
},
|
|
||||||
|
|
||||||
$div = $('<div/>').data('qrcode', qr).css(containerCSS);
|
|
||||||
|
|
||||||
if (settings_bgColor) {
|
|
||||||
$div.css('background-color', settings_bgColor);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (row = 0; row < moduleCount; row += 1) {
|
|
||||||
for (col = 0; col < moduleCount; col += 1) {
|
|
||||||
if (qr.isDark(row, col)) {
|
|
||||||
$('<div/>')
|
|
||||||
.css(darkCSS)
|
|
||||||
.css({
|
|
||||||
left: offset + col * moduleSize,
|
|
||||||
top: offset + row * moduleSize
|
|
||||||
})
|
|
||||||
.appendTo($div);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $div;
|
|
||||||
},
|
|
||||||
|
|
||||||
createHTML = function (settings) {
|
|
||||||
|
|
||||||
if (canvasAvailable && settings.render === 'canvas') {
|
|
||||||
return createCanvas(settings);
|
|
||||||
} else if (canvasAvailable && settings.render === 'image') {
|
|
||||||
return createImage(settings);
|
|
||||||
}
|
|
||||||
|
|
||||||
return createDiv(settings);
|
|
||||||
},
|
|
||||||
|
|
||||||
// Plugin
|
|
||||||
// ======
|
|
||||||
|
|
||||||
// Default settings
|
|
||||||
// ----------------
|
|
||||||
defaults = {
|
|
||||||
|
|
||||||
// render method: `'canvas'`, `'image'` or `'div'`
|
// Plugin
|
||||||
render: 'canvas',
|
// ======
|
||||||
|
|
||||||
// version range somewhere in 1 .. 40
|
// Default settings
|
||||||
minVersion: 1,
|
// ----------------
|
||||||
maxVersion: 40,
|
defaults = {
|
||||||
|
|
||||||
// error correction level: `'L'`, `'M'`, `'Q'` or `'H'`
|
|
||||||
ecLevel: 'L',
|
|
||||||
|
|
||||||
// offset in pixel if drawn onto existing canvas
|
|
||||||
left: 0,
|
|
||||||
top: 0,
|
|
||||||
|
|
||||||
// size in pixel
|
|
||||||
size: 200,
|
|
||||||
|
|
||||||
// code color or image element
|
|
||||||
fill: '#000',
|
|
||||||
|
|
||||||
// background color or image element, `null` for transparent background
|
|
||||||
background: null,
|
|
||||||
|
|
||||||
// content
|
|
||||||
text: 'no text',
|
|
||||||
|
|
||||||
// corner radius relative to module width: 0.0 .. 0.5
|
|
||||||
radius: 0,
|
|
||||||
|
|
||||||
// quiet zone in modules
|
|
||||||
quiet: 0,
|
|
||||||
|
|
||||||
// modes
|
|
||||||
// 0: normal
|
|
||||||
// 1: label strip
|
|
||||||
// 2: label box
|
|
||||||
// 3: image strip
|
|
||||||
// 4: image box
|
|
||||||
mode: 0,
|
|
||||||
|
|
||||||
mSize: 0.1,
|
|
||||||
mPosX: 0.5,
|
|
||||||
mPosY: 0.5,
|
|
||||||
|
|
||||||
label: 'no label',
|
|
||||||
fontname: 'sans',
|
|
||||||
fontcolor: '#000',
|
|
||||||
|
|
||||||
image: null
|
|
||||||
};
|
|
||||||
|
|
||||||
// Register the plugin
|
|
||||||
// -------------------
|
|
||||||
$.fn.qrcode = function(options) {
|
|
||||||
|
|
||||||
var settings = $.extend({}, defaults, options);
|
// render method: `'canvas'`, `'image'` or `'div'`
|
||||||
|
render: 'canvas',
|
||||||
|
|
||||||
return this.each(function () {
|
// version range somewhere in 1 .. 40
|
||||||
|
minVersion: 1,
|
||||||
|
maxVersion: 40,
|
||||||
|
|
||||||
|
// error correction level: `'L'`, `'M'`, `'Q'` or `'H'`
|
||||||
|
ecLevel: 'L',
|
||||||
|
|
||||||
|
// offset in pixel if drawn onto existing canvas
|
||||||
|
left: 0,
|
||||||
|
top: 0,
|
||||||
|
|
||||||
|
// size in pixel
|
||||||
|
size: 200,
|
||||||
|
|
||||||
|
// code color or image element
|
||||||
|
fill: '#000',
|
||||||
|
|
||||||
|
// background color or image element, `null` for transparent background
|
||||||
|
background: null,
|
||||||
|
|
||||||
|
// content
|
||||||
|
text: 'no text',
|
||||||
|
|
||||||
|
// corner radius relative to module width: 0.0 .. 0.5
|
||||||
|
radius: 0,
|
||||||
|
|
||||||
|
// quiet zone in modules
|
||||||
|
quiet: 0,
|
||||||
|
|
||||||
|
// modes
|
||||||
|
// 0: normal
|
||||||
|
// 1: label strip
|
||||||
|
// 2: label box
|
||||||
|
// 3: image strip
|
||||||
|
// 4: image box
|
||||||
|
mode: 0,
|
||||||
|
|
||||||
|
mSize: 0.1,
|
||||||
|
mPosX: 0.5,
|
||||||
|
mPosY: 0.5,
|
||||||
|
|
||||||
|
label: 'no label',
|
||||||
|
fontname: 'sans',
|
||||||
|
fontcolor: '#000',
|
||||||
|
|
||||||
|
image: null
|
||||||
|
};
|
||||||
|
|
||||||
if (this.nodeName.toLowerCase() === 'canvas') {
|
// Register the plugin
|
||||||
drawOnCanvas(this, settings);
|
// -------------------
|
||||||
} else {
|
$.fn.qrcode = function(options) {
|
||||||
$(this).append(createHTML(settings));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// jQuery.qrcode plug in code ends here
|
var settings = $.extend({}, defaults, options);
|
||||||
|
|
||||||
// QR Code Generator
|
return this.each(function () {
|
||||||
// =================
|
|
||||||
// @include "qrcode.js"
|
|
||||||
|
|
||||||
}(jQuery));
|
if (this.nodeName.toLowerCase() === 'canvas') {
|
||||||
|
drawOnCanvas(this, settings);
|
||||||
|
} else {
|
||||||
|
$(this).append(createHTML(settings));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// jQuery.qrcode plug in code ends here
|
||||||
|
|
||||||
|
|
||||||
|
// QR Code Generator
|
||||||
|
// =================
|
||||||
|
// @include "qrcode.js"
|
||||||
|
|
||||||
|
}());
|
||||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue