qrcode.vue
Advanced tools
Comparing version 1.6.3 to 1.7.0
@@ -0,1 +1,7 @@ | ||
## [1.7.0] | ||
### Feature | ||
- Support generate Qrcode as svg. | ||
## [1.6.3] - 2019-09-16 | ||
@@ -2,0 +8,0 @@ |
/*! | ||
* qrcode.vue v1.6.3 | ||
* A Vue component for QRCode. | ||
* qrcode.vue v1.7.0 | ||
* A Vue component to generate QRCode. | ||
* © 2017-2019 @scopewu(https://github.com/scopewu) | ||
@@ -926,2 +926,43 @@ * MIT License. | ||
return utf8Str; | ||
} | ||
function generatePath(modules) { | ||
var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; | ||
var ops = []; | ||
modules.forEach(function (row, y) { | ||
var start = null; | ||
row.forEach(function (cell, x) { | ||
if (!cell && start !== null) { | ||
// M0 0h7v1H0z injects the space with the move and drops the comma, | ||
// saving a char per operation | ||
ops.push("M".concat(start + margin, " ").concat(y + margin, "h").concat(x - start, "v1H").concat(start + margin, "z")); | ||
start = null; | ||
return; | ||
} // end of row, clean up or skip | ||
if (x === row.length - 1) { | ||
if (!cell) { | ||
// We would have closed the op above already so this can only mean | ||
// 2+ light modules in a row. | ||
return; | ||
} | ||
if (start === null) { | ||
// Just a single dark module. | ||
ops.push("M".concat(x + margin, ",").concat(y + margin, " h1v1H").concat(x + margin, "z")); | ||
} else { | ||
// Otherwise finish the current line. | ||
ops.push("M".concat(start + margin, ",").concat(y + margin, " h").concat(x + 1 - start, "v1H").concat(start + margin, "z")); | ||
} | ||
return; | ||
} | ||
if (cell && start === null) { | ||
start = x; | ||
} | ||
}); | ||
}); | ||
return ops.join(''); | ||
} // @vue/component | ||
@@ -962,4 +1003,18 @@ | ||
default: '#000' | ||
}, | ||
renderAs: { | ||
type: String, | ||
required: false, | ||
default: 'canvas', | ||
validator: function validator(as) { | ||
return ['canvas', 'svg'].indexOf(as) > -1; | ||
} | ||
} | ||
}, | ||
data: function data() { | ||
return { | ||
numCells: 0, | ||
fgPath: '' | ||
}; | ||
}, | ||
updated: function updated() { | ||
@@ -977,3 +1032,4 @@ this.render(); | ||
background = this.background, | ||
foreground = this.foreground; | ||
foreground = this.foreground, | ||
renderAs = this.renderAs; | ||
@@ -987,4 +1043,2 @@ var _size = size >>> 0; // size to number | ||
qrCode.make(); | ||
var canvas = this.$refs['qrcode-vue']; | ||
var ctx = canvas.getContext('2d'); | ||
var cells = qrCode.modules; | ||
@@ -994,12 +1048,26 @@ var tileW = _size / cells.length; | ||
var scale = window.devicePixelRatio || 1; | ||
canvas.height = canvas.width = _size * scale; | ||
ctx.scale(scale, scale); | ||
cells.forEach(function (row, rdx) { | ||
row.forEach(function (cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background; | ||
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW); | ||
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH); | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h); | ||
if (renderAs === 'svg') { | ||
this.numCells = cells.length; // Drawing strategy: instead of a rect per module, we're going to create a | ||
// single path for the dark modules and layer that on top of a light rect, | ||
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's | ||
// way faster than DOM ops. | ||
// For level 1, 441 nodes -> 2 | ||
// For level 40, 31329 -> 2 | ||
this.fgPath = generatePath(cells); | ||
} else { | ||
var canvas = this.$refs['qrcode-vue']; | ||
var ctx = canvas.getContext('2d'); | ||
canvas.height = canvas.width = _size * scale; | ||
ctx.scale(scale, scale); | ||
cells.forEach(function (row, rdx) { | ||
row.forEach(function (cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background; | ||
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW); | ||
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH); | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h); | ||
}); | ||
}); | ||
}); | ||
} | ||
} | ||
@@ -1013,3 +1081,6 @@ }, | ||
foreground = this.foreground, | ||
size = this.size; | ||
size = this.size, | ||
renderAs = this.renderAs, | ||
numCells = this.numCells, | ||
fgPath = this.fgPath; | ||
return createElement('div', { | ||
@@ -1023,5 +1094,26 @@ class: this.class || className, | ||
} | ||
}, [createElement('canvas', { | ||
}, [renderAs === 'svg' ? createElement('svg', { | ||
attrs: { | ||
height: size, | ||
width: size, | ||
shapeRendering: 'crispEdges', | ||
viewBox: "0 0 ".concat(numCells, " ").concat(numCells) | ||
}, | ||
style: { | ||
width: size + 'px', | ||
height: size + 'px' | ||
} | ||
}, [createElement('path', { | ||
attrs: { | ||
fill: background, | ||
d: "M0,0 h".concat(numCells, "v").concat(numCells, "H0z") | ||
} | ||
}), createElement('path', { | ||
attrs: { | ||
fill: foreground, | ||
d: fgPath | ||
} | ||
})]) : createElement('canvas', { | ||
attrs: { | ||
height: size, | ||
width: size | ||
@@ -1028,0 +1120,0 @@ }, |
/*! | ||
* qrcode.vue v1.6.3 | ||
* A Vue component for QRCode. | ||
* qrcode.vue v1.7.0 | ||
* A Vue component to generate QRCode. | ||
* © 2017-2019 @scopewu(https://github.com/scopewu) | ||
@@ -932,2 +932,43 @@ * MIT License. | ||
return utf8Str; | ||
} | ||
function generatePath(modules) { | ||
var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; | ||
var ops = []; | ||
modules.forEach(function (row, y) { | ||
var start = null; | ||
row.forEach(function (cell, x) { | ||
if (!cell && start !== null) { | ||
// M0 0h7v1H0z injects the space with the move and drops the comma, | ||
// saving a char per operation | ||
ops.push("M".concat(start + margin, " ").concat(y + margin, "h").concat(x - start, "v1H").concat(start + margin, "z")); | ||
start = null; | ||
return; | ||
} // end of row, clean up or skip | ||
if (x === row.length - 1) { | ||
if (!cell) { | ||
// We would have closed the op above already so this can only mean | ||
// 2+ light modules in a row. | ||
return; | ||
} | ||
if (start === null) { | ||
// Just a single dark module. | ||
ops.push("M".concat(x + margin, ",").concat(y + margin, " h1v1H").concat(x + margin, "z")); | ||
} else { | ||
// Otherwise finish the current line. | ||
ops.push("M".concat(start + margin, ",").concat(y + margin, " h").concat(x + 1 - start, "v1H").concat(start + margin, "z")); | ||
} | ||
return; | ||
} | ||
if (cell && start === null) { | ||
start = x; | ||
} | ||
}); | ||
}); | ||
return ops.join(''); | ||
} // @vue/component | ||
@@ -968,4 +1009,18 @@ | ||
default: '#000' | ||
}, | ||
renderAs: { | ||
type: String, | ||
required: false, | ||
default: 'canvas', | ||
validator: function validator(as) { | ||
return ['canvas', 'svg'].indexOf(as) > -1; | ||
} | ||
} | ||
}, | ||
data: function data() { | ||
return { | ||
numCells: 0, | ||
fgPath: '' | ||
}; | ||
}, | ||
updated: function updated() { | ||
@@ -983,3 +1038,4 @@ this.render(); | ||
background = this.background, | ||
foreground = this.foreground; | ||
foreground = this.foreground, | ||
renderAs = this.renderAs; | ||
@@ -993,4 +1049,2 @@ var _size = size >>> 0; // size to number | ||
qrCode.make(); | ||
var canvas = this.$refs['qrcode-vue']; | ||
var ctx = canvas.getContext('2d'); | ||
var cells = qrCode.modules; | ||
@@ -1000,12 +1054,26 @@ var tileW = _size / cells.length; | ||
var scale = window.devicePixelRatio || 1; | ||
canvas.height = canvas.width = _size * scale; | ||
ctx.scale(scale, scale); | ||
cells.forEach(function (row, rdx) { | ||
row.forEach(function (cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background; | ||
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW); | ||
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH); | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h); | ||
if (renderAs === 'svg') { | ||
this.numCells = cells.length; // Drawing strategy: instead of a rect per module, we're going to create a | ||
// single path for the dark modules and layer that on top of a light rect, | ||
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's | ||
// way faster than DOM ops. | ||
// For level 1, 441 nodes -> 2 | ||
// For level 40, 31329 -> 2 | ||
this.fgPath = generatePath(cells); | ||
} else { | ||
var canvas = this.$refs['qrcode-vue']; | ||
var ctx = canvas.getContext('2d'); | ||
canvas.height = canvas.width = _size * scale; | ||
ctx.scale(scale, scale); | ||
cells.forEach(function (row, rdx) { | ||
row.forEach(function (cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background; | ||
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW); | ||
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH); | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h); | ||
}); | ||
}); | ||
}); | ||
} | ||
} | ||
@@ -1019,3 +1087,6 @@ }, | ||
foreground = this.foreground, | ||
size = this.size; | ||
size = this.size, | ||
renderAs = this.renderAs, | ||
numCells = this.numCells, | ||
fgPath = this.fgPath; | ||
return createElement('div', { | ||
@@ -1029,5 +1100,26 @@ class: this.class || className, | ||
} | ||
}, [createElement('canvas', { | ||
}, [renderAs === 'svg' ? createElement('svg', { | ||
attrs: { | ||
height: size, | ||
width: size, | ||
shapeRendering: 'crispEdges', | ||
viewBox: "0 0 ".concat(numCells, " ").concat(numCells) | ||
}, | ||
style: { | ||
width: size + 'px', | ||
height: size + 'px' | ||
} | ||
}, [createElement('path', { | ||
attrs: { | ||
fill: background, | ||
d: "M0,0 h".concat(numCells, "v").concat(numCells, "H0z") | ||
} | ||
}), createElement('path', { | ||
attrs: { | ||
fill: foreground, | ||
d: fgPath | ||
} | ||
})]) : createElement('canvas', { | ||
attrs: { | ||
height: size, | ||
width: size | ||
@@ -1034,0 +1126,0 @@ }, |
/*! | ||
* qrcode.vue v1.6.3 | ||
* A Vue component for QRCode. | ||
* qrcode.vue v1.7.0 | ||
* A Vue component to generate QRCode. | ||
* © 2017-2019 @scopewu(https://github.com/scopewu) | ||
* MIT License. | ||
*/ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).QrcodeVue=e()}(this,function(){"use strict";var r=1,o=2,n=4,i=8;function t(t){this.mode=n,this.data=t}t.prototype={getLength:function(t){return this.data.length},write:function(t){for(var e=0;e<this.data.length;e++)t.put(this.data.charCodeAt(e),8)}};var a=t,f={L:1,M:0,Q:3,H:2};function l(t,e){this.totalCount=t,this.dataCount=e}l.RS_BLOCK_TABLE=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12],[5,122,98,1,123,99],[7,73,45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]],l.getRSBlocks=function(t,e){var r=l.getRsBlockTable(t,e);if(null==r)throw Error("bad rs block @ typeNumber:"+t+"/errorCorrectLevel:"+e);for(var o=r.length/3,n=[],i=0;i<o;i++)for(var a=r[3*i+0],s=r[3*i+1],u=r[3*i+2],h=0;h<a;h++)n.push(new l(s,u));return n},l.getRsBlockTable=function(t,e){switch(e){case f.L:return l.RS_BLOCK_TABLE[4*(t-1)+0];case f.M:return l.RS_BLOCK_TABLE[4*(t-1)+1];case f.Q:return l.RS_BLOCK_TABLE[4*(t-1)+2];case f.H:return l.RS_BLOCK_TABLE[4*(t-1)+3];default:return}};var u=l;function e(){this.buffer=[],this.length=0}e.prototype={get:function(t){return 1==(this.buffer[Math.floor(t/8)]>>>7-t%8&1)},put:function(t,e){for(var r=0;r<e;r++)this.putBit(1==(t>>>e-r-1&1))},getLengthInBits:function(){return this.length},putBit:function(t){var e=Math.floor(this.length/8);e<this.buffer.length||this.buffer.push(0),t&&(this.buffer[e]|=128>>>this.length%8),this.length++}};for(var h=e,s={glog:function(t){if(t<1)throw Error("glog("+t+")");return s.LOG_TABLE[t]},gexp:function(t){for(;t<0;)t+=255;for(;256<=t;)t-=255;return s.EXP_TABLE[t]},EXP_TABLE:Array(256),LOG_TABLE:Array(256)},g=0;g<8;g++)s.EXP_TABLE[g]=1<<g;for(g=8;g<256;g++)s.EXP_TABLE[g]=s.EXP_TABLE[g-4]^s.EXP_TABLE[g-5]^s.EXP_TABLE[g-6]^s.EXP_TABLE[g-8];for(g=0;g<255;g++)s.LOG_TABLE[s.EXP_TABLE[g]]=g;var d=s;function c(t,e){if(null==t.length)throw Error(t.length+"/"+e);for(var r=0;r<t.length&&0==t[r];)r++;this.num=Array(t.length-r+e);for(var o=0;o<t.length-r;o++)this.num[o]=t[o+r]}c.prototype={get:function(t){return this.num[t]},getLength:function(){return this.num.length},multiply:function(t){for(var e=Array(this.getLength()+t.getLength()-1),r=0;r<this.getLength();r++)for(var o=0;o<t.getLength();o++)e[r+o]^=d.gexp(d.glog(this.get(r))+d.glog(t.get(o)));return new c(e,0)},mod:function(t){if(this.getLength()-t.getLength()<0)return this;for(var e=d.glog(this.get(0))-d.glog(t.get(0)),r=Array(this.getLength()),o=0;o<this.getLength();o++)r[o]=this.get(o);for(o=0;o<t.getLength();o++)r[o]^=d.gexp(d.glog(t.get(o))+e);return new c(r,0).mod(t)}};var p=c,m=0,v=1,C=2,L=3,B=4,y=5,P=6,k=7,E={PATTERN_POSITION_TABLE:[[],[6,18],[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],G15:1335,G18:7973,G15_MASK:21522,getBCHTypeInfo:function(t){for(var e=t<<10;0<=E.getBCHDigit(e)-E.getBCHDigit(E.G15);)e^=E.G15<<E.getBCHDigit(e)-E.getBCHDigit(E.G15);return(t<<10|e)^E.G15_MASK},getBCHTypeNumber:function(t){for(var e=t<<12;0<=E.getBCHDigit(e)-E.getBCHDigit(E.G18);)e^=E.G18<<E.getBCHDigit(e)-E.getBCHDigit(E.G18);return t<<12|e},getBCHDigit:function(t){for(var e=0;0!=t;)e++,t>>>=1;return e},getPatternPosition:function(t){return E.PATTERN_POSITION_TABLE[t-1]},getMask:function(t,e,r){switch(t){case m:return(e+r)%2==0;case v:return e%2==0;case C:return r%3==0;case L:return(e+r)%3==0;case B:return(Math.floor(e/2)+Math.floor(r/3))%2==0;case y:return e*r%2+e*r%3==0;case P:return(e*r%2+e*r%3)%2==0;case k:return(e*r%3+(e+r)%2)%2==0;default:throw Error("bad maskPattern:"+t)}},getErrorCorrectPolynomial:function(t){for(var e=new p([1],0),r=0;r<t;r++)e=e.multiply(new p([1,d.gexp(r)],0));return e},getLengthInBits:function(t,e){if(1<=e&&e<10)switch(t){case r:return 10;case o:return 9;case n:case i:return 8;default:throw Error("mode:"+t)}else if(e<27)switch(t){case r:return 12;case o:return 11;case n:return 16;case i:return 10;default:throw Error("mode:"+t)}else{if(41<=e)throw Error("type:"+e);switch(t){case r:return 14;case o:return 13;case n:return 16;case i:return 12;default:throw Error("mode:"+t)}}},getLostPoint:function(t){for(var e=t.getModuleCount(),r=0,o=0;o<e;o++)for(var n=0;n<e;n++){for(var i=0,a=t.isDark(o,n),s=-1;s<=1;s++)if(0<=o+s&&o+s<e)for(var u=-1;u<=1;u++)0<=n+u&&n+u<e&&(0==s&&0==u||a==t.isDark(o+s,n+u)&&i++);5<i&&(r+=3+i-5)}for(o=0;o<e-1;o++)for(n=0;n<e-1;n++){var h=0;t.isDark(o,n)&&h++,t.isDark(o+1,n)&&h++,t.isDark(o,n+1)&&h++,t.isDark(o+1,n+1)&&h++,0!=h&&4!=h||(r+=3)}for(o=0;o<e;o++)for(n=0;n<e-6;n++)t.isDark(o,n)&&!t.isDark(o,n+1)&&t.isDark(o,n+2)&&t.isDark(o,n+3)&&t.isDark(o,n+4)&&!t.isDark(o,n+5)&&t.isDark(o,n+6)&&(r+=40);for(n=0;n<e;n++)for(o=0;o<e-6;o++)t.isDark(o,n)&&!t.isDark(o+1,n)&&t.isDark(o+2,n)&&t.isDark(o+3,n)&&t.isDark(o+4,n)&&!t.isDark(o+5,n)&&t.isDark(o+6,n)&&(r+=40);var l=0;for(n=0;n<e;n++)for(o=0;o<e;o++)t.isDark(o,n)&&l++;return r+=10*(Math.abs(100*l/e/e-50)/5)}},A=E;function D(t,e){this.typeNumber=t,this.errorCorrectLevel=e,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}var T=D.prototype;T.addData=function(t){var e=new a(t);this.dataList.push(e),this.dataCache=null},T.isDark=function(t,e){if(t<0||this.moduleCount<=t||e<0||this.moduleCount<=e)throw Error(t+","+e);return this.modules[t][e]},T.getModuleCount=function(){return this.moduleCount},T.make=function(){if(this.typeNumber<1){var t=1;for(t=1;t<40;t++){for(var e=u.getRSBlocks(t,this.errorCorrectLevel),r=new h,o=0,n=0;n<e.length;n++)o+=e[n].dataCount;for(n=0;n<this.dataList.length;n++){var i=this.dataList[n];r.put(i.mode,4),r.put(i.getLength(),A.getLengthInBits(i.mode,t)),i.write(r)}if(r.getLengthInBits()<=8*o)break}this.typeNumber=t}this.makeImpl(!1,this.getBestMaskPattern())},T.makeImpl=function(t,e){this.moduleCount=4*this.typeNumber+17,this.modules=Array(this.moduleCount);for(var r=0;r<this.moduleCount;r++){this.modules[r]=Array(this.moduleCount);for(var o=0;o<this.moduleCount;o++)this.modules[r][o]=null}this.setupPositionProbePattern(0,0),this.setupPositionProbePattern(this.moduleCount-7,0),this.setupPositionProbePattern(0,this.moduleCount-7),this.setupPositionAdjustPattern(),this.setupTimingPattern(),this.setupTypeInfo(t,e),this.typeNumber<7||this.setupTypeNumber(t),null==this.dataCache&&(this.dataCache=D.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,e)},T.setupPositionProbePattern=function(t,e){for(var r=-1;r<=7;r++)if(-1<t+r&&t+r<this.moduleCount)for(var o=-1;o<=7;o++)-1<e+o&&e+o<this.moduleCount&&(this.modules[t+r][e+o]=!((r<0||6<r||0!=o&&6!=o)&&(o<0||6<o||0!=r&&6!=r)&&(r<2||4<r||o<2||4<o)))},T.getBestMaskPattern=function(){for(var t=0,e=0,r=0;r<8;r++){this.makeImpl(!0,r);var o=A.getLostPoint(this);0!=r&&t<=o||(t=o,e=r)}return e},T.createMovieClip=function(t,e,r){var o=t.createEmptyMovieClip(e,r);this.make();for(var n=0;n<this.modules.length;n++)for(var i=1*n,a=0;a<this.modules[n].length;a++){var s=1*a;this.modules[n][a]&&(o.beginFill(0,100),o.moveTo(s,i),o.lineTo(1+s,i),o.lineTo(1+s,1+i),o.lineTo(s,1+i),o.endFill())}return o},T.setupTimingPattern=function(){for(var t=8;t<this.moduleCount-8;t++)null==this.modules[t][6]&&(this.modules[t][6]=t%2==0);for(var e=8;e<this.moduleCount-8;e++)null==this.modules[6][e]&&(this.modules[6][e]=e%2==0)},T.setupPositionAdjustPattern=function(){for(var t=A.getPatternPosition(this.typeNumber),e=0;e<t.length;e++)for(var r=0;r<t.length;r++){var o=t[e],n=t[r];if(null==this.modules[o][n])for(var i=-2;i<=2;i++)for(var a=-2;a<=2;a++)this.modules[o+i][n+a]=-2==i||2==i||-2==a||2==a||0==i&&0==a}},T.setupTypeNumber=function(t){for(var e=A.getBCHTypeNumber(this.typeNumber),r=0;r<18;r++){var o=!t&&1==(e>>r&1);this.modules[Math.floor(r/3)][r%3+this.moduleCount-8-3]=o}for(r=0;r<18;r++){o=!t&&1==(e>>r&1);this.modules[r%3+this.moduleCount-8-3][Math.floor(r/3)]=o}},T.setupTypeInfo=function(t,e){for(var r=A.getBCHTypeInfo(this.errorCorrectLevel<<3|e),o=0;o<15;o++){var n=!t&&1==(r>>o&1);o<6?this.modules[o][8]=n:o<8?this.modules[o+1][8]=n:this.modules[this.moduleCount-15+o][8]=n}for(o=0;o<15;o++){n=!t&&1==(r>>o&1);o<8?this.modules[8][this.moduleCount-o-1]=n:o<9?this.modules[8][15-o-1+1]=n:this.modules[8][15-o-1]=n}this.modules[this.moduleCount-8][8]=!t},T.mapData=function(t,e){for(var r=-1,o=this.moduleCount-1,n=7,i=0,a=this.moduleCount-1;0<a;a-=2)for(6==a&&a--;;){for(var s=0;s<2;s++)if(null==this.modules[o][a-s]){var u=!1;i<t.length&&(u=1==(t[i]>>>n&1)),A.getMask(e,o,a-s)&&(u=!u),this.modules[o][a-s]=u,-1==--n&&(i++,n=7)}if((o+=r)<0||this.moduleCount<=o){o-=r,r=-r;break}}},D.PAD0=236,D.PAD1=17,D.createData=function(t,e,r){for(var o=u.getRSBlocks(t,e),n=new h,i=0;i<r.length;i++){var a=r[i];n.put(a.mode,4),n.put(a.getLength(),A.getLengthInBits(a.mode,t)),a.write(n)}var s=0;for(i=0;i<o.length;i++)s+=o[i].dataCount;if(n.getLengthInBits()>8*s)throw Error("code length overflow. ("+n.getLengthInBits()+">"+8*s+")");for(n.getLengthInBits()+4>8*s||n.put(0,4);n.getLengthInBits()%8!=0;)n.putBit(!1);for(;n.getLengthInBits()<8*s&&(n.put(D.PAD0,8),n.getLengthInBits()<8*s);)n.put(D.PAD1,8);return D.createBytes(n,o)},D.createBytes=function(t,e){for(var r=0,o=0,n=0,i=Array(e.length),a=Array(e.length),s=0;s<e.length;s++){var u=e[s].dataCount,h=e[s].totalCount-u;o=Math.max(o,u),n=Math.max(n,h),i[s]=Array(u);for(var l=0;l<i[s].length;l++)i[s][l]=255&t.buffer[l+r];r+=u;var f=A.getErrorCorrectPolynomial(h),g=new p(i[s],f.getLength()-1).mod(f);a[s]=Array(f.getLength()-1);for(l=0;l<a[s].length;l++){var d=l+g.getLength()-a[s].length;a[s][l]=d<0?0:g.get(d)}}var c=0;for(l=0;l<e.length;l++)c+=e[l].totalCount;var m=Array(c),v=0;for(l=0;l<o;l++)for(s=0;s<e.length;s++)l<i[s].length&&(m[v++]=i[s][l]);for(l=0;l<n;l++)for(s=0;s<e.length;s++)l<a[s].length&&(m[v++]=a[s][l]);return m};var b=D;return{props:{value:{type:String,required:!0,default:""},className:{type:String,default:""},size:{type:[Number,String],default:100,validator:function(t){return!0!==isNaN(+t)}},level:{type:String,default:"L",validator:function(t){return!!~["L","Q","M","H"].indexOf(t)}},background:{type:String,default:"#fff"},foreground:{type:String,default:"#000"}},updated:function(){this.render()},mounted:function(){this.render()},methods:{render:function(){var t=this.value,i=this.background,a=this.foreground,e=this.size>>>0,r=new b(-1,f[this.level]);r.addData(function(t){for(var e="",r=0;r<t.length;r++){var o=t.charCodeAt(r);o<128?e+=String.fromCharCode(o):(o<2048?e+=String.fromCharCode(192|o>>6):(o<55296||57344<=o?e+=String.fromCharCode(224|o>>12):(o=65536+((1023&o)<<10|1023&t.charCodeAt(++r)),e+=String.fromCharCode(240|o>>18),e+=String.fromCharCode(128|o>>12&63)),e+=String.fromCharCode(128|o>>6&63)),e+=String.fromCharCode(128|63&o))}return e}(t)),r.make();var o=this.$refs["qrcode-vue"],s=o.getContext("2d"),n=r.modules,u=e/n.length,h=e/n.length,l=window.devicePixelRatio||1;o.height=o.width=e*l,s.scale(l,l),n.forEach(function(t,n){t.forEach(function(t,e){s.fillStyle=t?a:i;var r=Math.ceil((e+1)*u)-Math.floor(e*u),o=Math.ceil((n+1)*h)-Math.floor(n*h);s.fillRect(Math.round(e*u),Math.round(n*h),r,o)})})}},render:function(t){var e=this.size;return t("div",{class:this.class||this.className,attrs:{value:this.value,level:this.level,background:this.background,foreground:this.foreground}},[t("canvas",{attrs:{height:e,width:e},style:{width:e+"px",height:e+"px"},ref:"qrcode-vue"},[])])}}}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).QrcodeVue=e()}(this,function(){"use strict";var r=1,n=2,o=4,i=8;function t(t){this.mode=o,this.data=t}t.prototype={getLength:function(t){return this.data.length},write:function(t){for(var e=0;e<this.data.length;e++)t.put(this.data.charCodeAt(e),8)}};var a=t,g={L:1,M:0,Q:3,H:2};function l(t,e){this.totalCount=t,this.dataCount=e}l.RS_BLOCK_TABLE=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12],[5,122,98,1,123,99],[7,73,45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]],l.getRSBlocks=function(t,e){var r=l.getRsBlockTable(t,e);if(null==r)throw Error("bad rs block @ typeNumber:"+t+"/errorCorrectLevel:"+e);for(var n=r.length/3,o=[],i=0;i<n;i++)for(var a=r[3*i+0],s=r[3*i+1],u=r[3*i+2],h=0;h<a;h++)o.push(new l(s,u));return o},l.getRsBlockTable=function(t,e){switch(e){case g.L:return l.RS_BLOCK_TABLE[4*(t-1)+0];case g.M:return l.RS_BLOCK_TABLE[4*(t-1)+1];case g.Q:return l.RS_BLOCK_TABLE[4*(t-1)+2];case g.H:return l.RS_BLOCK_TABLE[4*(t-1)+3];default:return}};var u=l;function e(){this.buffer=[],this.length=0}e.prototype={get:function(t){return 1==(this.buffer[Math.floor(t/8)]>>>7-t%8&1)},put:function(t,e){for(var r=0;r<e;r++)this.putBit(1==(t>>>e-r-1&1))},getLengthInBits:function(){return this.length},putBit:function(t){var e=Math.floor(this.length/8);e<this.buffer.length||this.buffer.push(0),t&&(this.buffer[e]|=128>>>this.length%8),this.length++}};for(var h=e,s={glog:function(t){if(t<1)throw Error("glog("+t+")");return s.LOG_TABLE[t]},gexp:function(t){for(;t<0;)t+=255;for(;256<=t;)t-=255;return s.EXP_TABLE[t]},EXP_TABLE:Array(256),LOG_TABLE:Array(256)},f=0;f<8;f++)s.EXP_TABLE[f]=1<<f;for(f=8;f<256;f++)s.EXP_TABLE[f]=s.EXP_TABLE[f-4]^s.EXP_TABLE[f-5]^s.EXP_TABLE[f-6]^s.EXP_TABLE[f-8];for(f=0;f<255;f++)s.LOG_TABLE[s.EXP_TABLE[f]]=f;var c=s;function d(t,e){if(null==t.length)throw Error(t.length+"/"+e);for(var r=0;r<t.length&&0==t[r];)r++;this.num=Array(t.length-r+e);for(var n=0;n<t.length-r;n++)this.num[n]=t[n+r]}d.prototype={get:function(t){return this.num[t]},getLength:function(){return this.num.length},multiply:function(t){for(var e=Array(this.getLength()+t.getLength()-1),r=0;r<this.getLength();r++)for(var n=0;n<t.getLength();n++)e[r+n]^=c.gexp(c.glog(this.get(r))+c.glog(t.get(n)));return new d(e,0)},mod:function(t){if(this.getLength()-t.getLength()<0)return this;for(var e=c.glog(this.get(0))-c.glog(t.get(0)),r=Array(this.getLength()),n=0;n<this.getLength();n++)r[n]=this.get(n);for(n=0;n<t.getLength();n++)r[n]^=c.gexp(c.glog(t.get(n))+e);return new d(r,0).mod(t)}};var p=d,m=0,v=1,C=2,L=3,B=4,y=5,P=6,E=7,A={PATTERN_POSITION_TABLE:[[],[6,18],[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],G15:1335,G18:7973,G15_MASK:21522,getBCHTypeInfo:function(t){for(var e=t<<10;0<=A.getBCHDigit(e)-A.getBCHDigit(A.G15);)e^=A.G15<<A.getBCHDigit(e)-A.getBCHDigit(A.G15);return(t<<10|e)^A.G15_MASK},getBCHTypeNumber:function(t){for(var e=t<<12;0<=A.getBCHDigit(e)-A.getBCHDigit(A.G18);)e^=A.G18<<A.getBCHDigit(e)-A.getBCHDigit(A.G18);return t<<12|e},getBCHDigit:function(t){for(var e=0;0!=t;)e++,t>>>=1;return e},getPatternPosition:function(t){return A.PATTERN_POSITION_TABLE[t-1]},getMask:function(t,e,r){switch(t){case m:return(e+r)%2==0;case v:return e%2==0;case C:return r%3==0;case L:return(e+r)%3==0;case B:return(Math.floor(e/2)+Math.floor(r/3))%2==0;case y:return e*r%2+e*r%3==0;case P:return(e*r%2+e*r%3)%2==0;case E:return(e*r%3+(e+r)%2)%2==0;default:throw Error("bad maskPattern:"+t)}},getErrorCorrectPolynomial:function(t){for(var e=new p([1],0),r=0;r<t;r++)e=e.multiply(new p([1,c.gexp(r)],0));return e},getLengthInBits:function(t,e){if(1<=e&&e<10)switch(t){case r:return 10;case n:return 9;case o:case i:return 8;default:throw Error("mode:"+t)}else if(e<27)switch(t){case r:return 12;case n:return 11;case o:return 16;case i:return 10;default:throw Error("mode:"+t)}else{if(41<=e)throw Error("type:"+e);switch(t){case r:return 14;case n:return 13;case o:return 16;case i:return 12;default:throw Error("mode:"+t)}}},getLostPoint:function(t){for(var e=t.getModuleCount(),r=0,n=0;n<e;n++)for(var o=0;o<e;o++){for(var i=0,a=t.isDark(n,o),s=-1;s<=1;s++)if(0<=n+s&&n+s<e)for(var u=-1;u<=1;u++)0<=o+u&&o+u<e&&(0==s&&0==u||a==t.isDark(n+s,o+u)&&i++);5<i&&(r+=3+i-5)}for(n=0;n<e-1;n++)for(o=0;o<e-1;o++){var h=0;t.isDark(n,o)&&h++,t.isDark(n+1,o)&&h++,t.isDark(n,o+1)&&h++,t.isDark(n+1,o+1)&&h++,0!=h&&4!=h||(r+=3)}for(n=0;n<e;n++)for(o=0;o<e-6;o++)t.isDark(n,o)&&!t.isDark(n,o+1)&&t.isDark(n,o+2)&&t.isDark(n,o+3)&&t.isDark(n,o+4)&&!t.isDark(n,o+5)&&t.isDark(n,o+6)&&(r+=40);for(o=0;o<e;o++)for(n=0;n<e-6;n++)t.isDark(n,o)&&!t.isDark(n+1,o)&&t.isDark(n+2,o)&&t.isDark(n+3,o)&&t.isDark(n+4,o)&&!t.isDark(n+5,o)&&t.isDark(n+6,o)&&(r+=40);var l=0;for(o=0;o<e;o++)for(n=0;n<e;n++)t.isDark(n,o)&&l++;return r+=10*(Math.abs(100*l/e/e-50)/5)}},k=A;function D(t,e){this.typeNumber=t,this.errorCorrectLevel=e,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}var T=D.prototype;T.addData=function(t){var e=new a(t);this.dataList.push(e),this.dataCache=null},T.isDark=function(t,e){if(t<0||this.moduleCount<=t||e<0||this.moduleCount<=e)throw Error(t+","+e);return this.modules[t][e]},T.getModuleCount=function(){return this.moduleCount},T.make=function(){if(this.typeNumber<1){var t=1;for(t=1;t<40;t++){for(var e=u.getRSBlocks(t,this.errorCorrectLevel),r=new h,n=0,o=0;o<e.length;o++)n+=e[o].dataCount;for(o=0;o<this.dataList.length;o++){var i=this.dataList[o];r.put(i.mode,4),r.put(i.getLength(),k.getLengthInBits(i.mode,t)),i.write(r)}if(r.getLengthInBits()<=8*n)break}this.typeNumber=t}this.makeImpl(!1,this.getBestMaskPattern())},T.makeImpl=function(t,e){this.moduleCount=4*this.typeNumber+17,this.modules=Array(this.moduleCount);for(var r=0;r<this.moduleCount;r++){this.modules[r]=Array(this.moduleCount);for(var n=0;n<this.moduleCount;n++)this.modules[r][n]=null}this.setupPositionProbePattern(0,0),this.setupPositionProbePattern(this.moduleCount-7,0),this.setupPositionProbePattern(0,this.moduleCount-7),this.setupPositionAdjustPattern(),this.setupTimingPattern(),this.setupTypeInfo(t,e),this.typeNumber<7||this.setupTypeNumber(t),null==this.dataCache&&(this.dataCache=D.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,e)},T.setupPositionProbePattern=function(t,e){for(var r=-1;r<=7;r++)if(-1<t+r&&t+r<this.moduleCount)for(var n=-1;n<=7;n++)-1<e+n&&e+n<this.moduleCount&&(this.modules[t+r][e+n]=!((r<0||6<r||0!=n&&6!=n)&&(n<0||6<n||0!=r&&6!=r)&&(r<2||4<r||n<2||4<n)))},T.getBestMaskPattern=function(){for(var t=0,e=0,r=0;r<8;r++){this.makeImpl(!0,r);var n=k.getLostPoint(this);0!=r&&t<=n||(t=n,e=r)}return e},T.createMovieClip=function(t,e,r){var n=t.createEmptyMovieClip(e,r);this.make();for(var o=0;o<this.modules.length;o++)for(var i=1*o,a=0;a<this.modules[o].length;a++){var s=1*a;this.modules[o][a]&&(n.beginFill(0,100),n.moveTo(s,i),n.lineTo(1+s,i),n.lineTo(1+s,1+i),n.lineTo(s,1+i),n.endFill())}return n},T.setupTimingPattern=function(){for(var t=8;t<this.moduleCount-8;t++)null==this.modules[t][6]&&(this.modules[t][6]=t%2==0);for(var e=8;e<this.moduleCount-8;e++)null==this.modules[6][e]&&(this.modules[6][e]=e%2==0)},T.setupPositionAdjustPattern=function(){for(var t=k.getPatternPosition(this.typeNumber),e=0;e<t.length;e++)for(var r=0;r<t.length;r++){var n=t[e],o=t[r];if(null==this.modules[n][o])for(var i=-2;i<=2;i++)for(var a=-2;a<=2;a++)this.modules[n+i][o+a]=-2==i||2==i||-2==a||2==a||0==i&&0==a}},T.setupTypeNumber=function(t){for(var e=k.getBCHTypeNumber(this.typeNumber),r=0;r<18;r++){var n=!t&&1==(e>>r&1);this.modules[Math.floor(r/3)][r%3+this.moduleCount-8-3]=n}for(r=0;r<18;r++){n=!t&&1==(e>>r&1);this.modules[r%3+this.moduleCount-8-3][Math.floor(r/3)]=n}},T.setupTypeInfo=function(t,e){for(var r=k.getBCHTypeInfo(this.errorCorrectLevel<<3|e),n=0;n<15;n++){var o=!t&&1==(r>>n&1);n<6?this.modules[n][8]=o:n<8?this.modules[n+1][8]=o:this.modules[this.moduleCount-15+n][8]=o}for(n=0;n<15;n++){o=!t&&1==(r>>n&1);n<8?this.modules[8][this.moduleCount-n-1]=o:n<9?this.modules[8][15-n-1+1]=o:this.modules[8][15-n-1]=o}this.modules[this.moduleCount-8][8]=!t},T.mapData=function(t,e){for(var r=-1,n=this.moduleCount-1,o=7,i=0,a=this.moduleCount-1;0<a;a-=2)for(6==a&&a--;;){for(var s=0;s<2;s++)if(null==this.modules[n][a-s]){var u=!1;i<t.length&&(u=1==(t[i]>>>o&1)),k.getMask(e,n,a-s)&&(u=!u),this.modules[n][a-s]=u,-1==--o&&(i++,o=7)}if((n+=r)<0||this.moduleCount<=n){n-=r,r=-r;break}}},D.PAD0=236,D.PAD1=17,D.createData=function(t,e,r){for(var n=u.getRSBlocks(t,e),o=new h,i=0;i<r.length;i++){var a=r[i];o.put(a.mode,4),o.put(a.getLength(),k.getLengthInBits(a.mode,t)),a.write(o)}var s=0;for(i=0;i<n.length;i++)s+=n[i].dataCount;if(o.getLengthInBits()>8*s)throw Error("code length overflow. ("+o.getLengthInBits()+">"+8*s+")");for(o.getLengthInBits()+4>8*s||o.put(0,4);o.getLengthInBits()%8!=0;)o.putBit(!1);for(;o.getLengthInBits()<8*s&&(o.put(D.PAD0,8),o.getLengthInBits()<8*s);)o.put(D.PAD1,8);return D.createBytes(o,n)},D.createBytes=function(t,e){for(var r=0,n=0,o=0,i=Array(e.length),a=Array(e.length),s=0;s<e.length;s++){var u=e[s].dataCount,h=e[s].totalCount-u;n=Math.max(n,u),o=Math.max(o,h),i[s]=Array(u);for(var l=0;l<i[s].length;l++)i[s][l]=255&t.buffer[l+r];r+=u;var f=k.getErrorCorrectPolynomial(h),g=new p(i[s],f.getLength()-1).mod(f);a[s]=Array(f.getLength()-1);for(l=0;l<a[s].length;l++){var c=l+g.getLength()-a[s].length;a[s][l]=c<0?0:g.get(c)}}var d=0;for(l=0;l<e.length;l++)d+=e[l].totalCount;var m=Array(d),v=0;for(l=0;l<n;l++)for(s=0;s<e.length;s++)l<i[s].length&&(m[v++]=i[s][l]);for(l=0;l<o;l++)for(s=0;s<e.length;s++)l<a[s].length&&(m[v++]=a[s][l]);return m};var b=D;return{props:{value:{type:String,required:!0,default:""},className:{type:String,default:""},size:{type:[Number,String],default:100,validator:function(t){return!0!==isNaN(+t)}},level:{type:String,default:"L",validator:function(t){return!!~["L","Q","M","H"].indexOf(t)}},background:{type:String,default:"#fff"},foreground:{type:String,default:"#000"},renderAs:{type:String,required:!1,default:"canvas",validator:function(t){return!!~["canvas","svg"].indexOf(t)}}},data:function(){return{numCells:0,fgPath:""}},updated:function(){this.render()},mounted:function(){this.render()},methods:{render:function(){var t=this.value,i=this.background,a=this.foreground,e=this.renderAs,r=this.size>>>0,n=new b(-1,g[this.level]);n.addData(function(t){for(var e="",r=0;r<t.length;r++){var n=t.charCodeAt(r);n<128?e+=String.fromCharCode(n):(n<2048?e+=String.fromCharCode(192|n>>6):(n<55296||57344<=n?e+=String.fromCharCode(224|n>>12):(n=65536+((1023&n)<<10|1023&t.charCodeAt(++r)),e+=String.fromCharCode(240|n>>18),e+=String.fromCharCode(128|n>>12&63)),e+=String.fromCharCode(128|n>>6&63)),e+=String.fromCharCode(128|63&n))}return e}(t)),n.make();var o=n.modules,s=r/o.length,u=r/o.length,h=window.devicePixelRatio||1;if("svg"===e)this.numCells=o.length,this.fgPath=function(t,e){var i=1<arguments.length&&void 0!==e?e:0,a=[];return t.forEach(function(r,n){var o=null;r.forEach(function(t,e){if(!t&&null!==o)return a.push("M".concat(o+i," ").concat(n+i,"h").concat(e-o,"v1H").concat(o+i,"z")),void(o=null);if(e!==r.length-1)t&&null===o&&(o=e);else{if(!t)return;a.push(null===o?"M".concat(e+i,",").concat(n+i," h1v1H").concat(e+i,"z"):"M".concat(o+i,",").concat(n+i," h").concat(e+1-o,"v1H").concat(o+i,"z"))}})}),a.join("")}(o);else{var l=this.$refs["qrcode-vue"],f=l.getContext("2d");l.height=l.width=r*h,f.scale(h,h),o.forEach(function(t,o){t.forEach(function(t,e){f.fillStyle=t?a:i;var r=Math.ceil((e+1)*s)-Math.floor(e*s),n=Math.ceil((o+1)*u)-Math.floor(o*u);f.fillRect(Math.round(e*s),Math.round(o*u),r,n)})})}}},render:function(t){var e=this.background,r=this.foreground,n=this.size,o=this.numCells,i=this.fgPath;return t("div",{class:this.class||this.className,attrs:{value:this.value,level:this.level,background:e,foreground:r}},["svg"===this.renderAs?t("svg",{attrs:{height:n,width:n,shapeRendering:"crispEdges",viewBox:"0 0 ".concat(o," ").concat(o)},style:{width:n+"px",height:n+"px"}},[t("path",{attrs:{fill:e,d:"M0,0 h".concat(o,"v").concat(o,"H0z")}}),t("path",{attrs:{fill:r,d:i}})]):t("canvas",{attrs:{height:n,width:n},style:{width:n+"px",height:n+"px"},ref:"qrcode-vue"},[])])}}}); |
@@ -10,2 +10,5 @@ import Vue from 'vue' | ||
el: '#root', | ||
components: { | ||
QrcodeVue, | ||
}, | ||
data: { | ||
@@ -17,6 +20,7 @@ value: 'https://example.com', | ||
foreground: '#000000', | ||
renderAs: 'svg', | ||
}, | ||
template: `<form class="form-horizontal"> | ||
<div class="form-group"> | ||
<label for="inputEmail3" class="col-sm-2 control-label">Value:</label> | ||
<label class="col-sm-2 control-label">Value:</label> | ||
<div class="col-sm-10"> | ||
@@ -27,6 +31,6 @@ <textarea v-model="value" class="form-control" rows="3"></textarea> | ||
<div class="form-group"> | ||
<label for="inputPassword3" class="col-sm-2 control-label">Size:</label> | ||
<label class="col-sm-2 control-label">Size:</label> | ||
<div class="col-sm-10"> | ||
<div class="form-control-static"> | ||
<input type="range" v-model="size" min="100" max="800"> | ||
<input type="range" v-model="size" min="100" max="800" step="20"> | ||
</div> | ||
@@ -36,4 +40,13 @@ </div> | ||
<div class="form-group"> | ||
<label for="inputPassword3" class="col-sm-2 control-label">Level:</label> | ||
<label class="col-sm-2 control-label">Level:</label> | ||
<div class="col-sm-10"> | ||
<select v-model="renderAs" class="form-control"> | ||
<option value="svg">svg</option> | ||
<option value="canvas">canvas</option> | ||
</select> | ||
</div> | ||
</div> | ||
<div class="form-group"> | ||
<label class="col-sm-2 control-label">Level:</label> | ||
<div class="col-sm-10"> | ||
<select v-model="level" class="form-control"> | ||
@@ -48,3 +61,3 @@ <option value="L">L</option> | ||
<div class="form-group"> | ||
<label for="inputPassword3" class="col-sm-2 control-label">Background:</label> | ||
<label class="col-sm-2 control-label">Background:</label> | ||
<div class="col-sm-10"> | ||
@@ -57,3 +70,3 @@ <div class="form-control-static"> | ||
<div class="form-group"> | ||
<label for="inputPassword3" class="col-sm-2 control-label">Foreground:</label> | ||
<label class="col-sm-2 control-label">Foreground:</label> | ||
<div class="col-sm-10"> | ||
@@ -66,6 +79,6 @@ <div class="form-control-static"> | ||
<div class="form-group"> | ||
<label for="inputPassword3" class="col-sm-2 control-label">QR_CODE:</label> | ||
<label class="col-sm-2 control-label">QR_CODE:</label> | ||
<div class="col-sm-10"> | ||
<div class="form-control-static"> | ||
<qrcode-vue class="qrcode" :value="value" :size="size" :level="level" :background="background" :foreground="foreground"/> | ||
<qrcode-vue class="qrcode" :value="value" :renderAs="renderAs" :size="size" :level="level" :background="background" :foreground="foreground"/> | ||
</div> | ||
@@ -75,5 +88,2 @@ </div> | ||
</form>`, | ||
components: { | ||
QrcodeVue, | ||
}, | ||
}) |
{ | ||
"name": "qrcode.vue", | ||
"version": "1.6.3", | ||
"description": "A Vue component for QRCode.", | ||
"version": "1.7.0", | ||
"description": "A Vue component to generate QRCode.", | ||
"main": "dist/qrcode.vue.js", | ||
@@ -26,3 +26,4 @@ "module": "dist/qrcode.vue.esm.js", | ||
"code", | ||
"qrcode" | ||
"qrcode", | ||
"二维码" | ||
], | ||
@@ -29,0 +30,0 @@ "files": [ |
@@ -84,2 +84,9 @@ # qrcode.vue | ||
### renderAs | ||
- Type: `string` | ||
- Default: `canvas` | ||
生成二维码的 HTML 标签,可选 `canvas` 或 `svg`。 | ||
### background | ||
@@ -86,0 +93,0 @@ |
# qrcode.vue | ||
A Vue.js component for [QRCode](https://en.wikipedia.org/wiki/QR_code). | ||
A Vue.js component to generate [QRCode](https://en.wikipedia.org/wiki/QR_code). | ||
@@ -86,2 +86,9 @@ [![Build Status](https://travis-ci.org/scopewu/qrcode.vue.svg?branch=master)](https://travis-ci.org/scopewu/qrcode.vue) | ||
### renderAs | ||
- Type: `string` | ||
- Default: `canvas` | ||
Generate QRcode as `canvas` or `svg`. | ||
### background | ||
@@ -88,0 +95,0 @@ |
148
src/index.js
@@ -40,2 +40,45 @@ import QRCode from 'qr.js/lib/QRCode' | ||
function generatePath(modules, margin = 0) { | ||
const ops = [] | ||
modules.forEach(function(row, y) { | ||
let start = null | ||
row.forEach(function(cell, x) { | ||
if (!cell && start !== null) { | ||
// M0 0h7v1H0z injects the space with the move and drops the comma, | ||
// saving a char per operation | ||
ops.push( | ||
`M${start + margin} ${y + margin}h${x - start}v1H${start + margin}z` | ||
) | ||
start = null | ||
return | ||
} | ||
// end of row, clean up or skip | ||
if (x === row.length - 1) { | ||
if (!cell) { | ||
// We would have closed the op above already so this can only mean | ||
// 2+ light modules in a row. | ||
return | ||
} | ||
if (start === null) { | ||
// Just a single dark module. | ||
ops.push(`M${x + margin},${y + margin} h1v1H${x + margin}z`) | ||
} else { | ||
// Otherwise finish the current line. | ||
ops.push( | ||
`M${start + margin},${y + margin} h${x + 1 - start}v1H${start + | ||
margin}z` | ||
) | ||
} | ||
return | ||
} | ||
if (cell && start === null) { | ||
start = x | ||
} | ||
}) | ||
}) | ||
return ops.join('') | ||
} | ||
// @vue/component | ||
@@ -71,3 +114,15 @@ const QrcodeVue = { | ||
}, | ||
renderAs: { | ||
type: String, | ||
required: false, | ||
default: 'canvas', | ||
validator: (as) => ['canvas', 'svg'].indexOf(as) > -1, | ||
}, | ||
}, | ||
data() { | ||
return { | ||
numCells: 0, | ||
fgPath: '', | ||
} | ||
}, | ||
updated() { | ||
@@ -81,3 +136,3 @@ this.render() | ||
render() { | ||
const { value, size, level, background, foreground } = this | ||
const { value, size, level, background, foreground, renderAs } = this | ||
const _size = size >>> 0 // size to number | ||
@@ -90,5 +145,2 @@ | ||
const canvas = this.$refs['qrcode-vue'] | ||
const ctx = canvas.getContext('2d') | ||
const cells = qrCode.modules | ||
@@ -98,17 +150,43 @@ const tileW = _size / cells.length | ||
const scale = window.devicePixelRatio || 1 | ||
canvas.height = canvas.width = _size * scale | ||
ctx.scale(scale, scale) | ||
cells.forEach(function(row, rdx) { | ||
row.forEach(function(cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background | ||
const w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW) | ||
const h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH) | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h) | ||
if (renderAs === 'svg') { | ||
this.numCells = cells.length | ||
// Drawing strategy: instead of a rect per module, we're going to create a | ||
// single path for the dark modules and layer that on top of a light rect, | ||
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's | ||
// way faster than DOM ops. | ||
// For level 1, 441 nodes -> 2 | ||
// For level 40, 31329 -> 2 | ||
this.fgPath = generatePath(cells); | ||
} else { | ||
const canvas = this.$refs['qrcode-vue'] | ||
const ctx = canvas.getContext('2d') | ||
canvas.height = canvas.width = _size * scale | ||
ctx.scale(scale, scale) | ||
cells.forEach(function(row, rdx) { | ||
row.forEach(function(cell, cdx) { | ||
ctx.fillStyle = cell ? foreground : background | ||
const w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW) | ||
const h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH) | ||
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h) | ||
}) | ||
}) | ||
}) | ||
} | ||
}, | ||
}, | ||
render(createElement) { | ||
const { className, value, level, background, foreground, size } = this | ||
const { | ||
className, | ||
value, | ||
level, | ||
background, | ||
foreground, | ||
size, | ||
renderAs, | ||
numCells, | ||
fgPath, | ||
} = this | ||
@@ -122,11 +200,35 @@ return createElement( | ||
[ | ||
createElement( | ||
'canvas', | ||
{ | ||
attrs: { height: size, width: size }, | ||
style: { width: size + 'px', height: size + 'px' }, | ||
ref: 'qrcode-vue', | ||
}, | ||
[] | ||
), | ||
renderAs === 'svg' | ||
? createElement( | ||
'svg', | ||
{ | ||
attrs: { | ||
height: size, | ||
width: size, | ||
shapeRendering: 'crispEdges', | ||
viewBox: `0 0 ${numCells} ${numCells}`, | ||
}, | ||
style: { width: size + 'px', height: size + 'px' }, | ||
}, | ||
[ | ||
createElement('path', { | ||
attrs: { | ||
fill: background, | ||
d: `M0,0 h${numCells}v${numCells}H0z`, | ||
}, | ||
}), | ||
createElement('path', { | ||
attrs: { fill: foreground, d: fgPath }, | ||
}), | ||
] | ||
) | ||
: createElement( | ||
'canvas', | ||
{ | ||
attrs: { height: size, width: size }, | ||
style: { width: size + 'px', height: size + 'px' }, | ||
ref: 'qrcode-vue', | ||
}, | ||
[] | ||
), | ||
] | ||
@@ -133,0 +235,0 @@ ) |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
105839
2242
117