当前位置: 首页 > news >正文

vue,uniapp生成二维码

话不多说直接开干

先是vue的

1,首先按照一下依赖

npm install --save qrcode

2,在需要使用的页面引入

import QRCode from 'qrcode';

3,使用

 const codeDetail = (item) => {//这个item.code是要生成的数据,我的是一串数字QRCode.toDataURL(item.code).then((img) => {console.log(img);这个img是图片路径,赋值给img标签即可显示});};

然后是uniapp

//

1,新建一个js文件夹,把以下代码放进来,代码我放在最后了,js文件名为uqrcode.js

2,在使用的页面引用

import UQrocode from "../../pages/uqrcode.js";

3,在使用前需要有一个画布

 <canvas canvas-id="qrcode" style="width: 30px; height: 30px"></canvas>

4,使用

   UQrocode.make({
//canvasId要和上面画布的id是一样的canvasId:'qrcode',componentInstance:this,text:'你要生成的内容',size:30//尺寸,margin:0})},

下面附上js代码

// uqrcode.js
//---------------------------------------------------------------------
// github https://github.com/Sansnn/uQRCode
//---------------------------------------------------------------------let uQRCode = {};(function() {//---------------------------------------------------------------------// QRCode for JavaScript//// Copyright (c) 2009 Kazuhiko Arase//// URL: http://www.d-project.com///// Licensed under the MIT license://   http://www.opensource.org/licenses/mit-license.php//// The word "QR Code" is registered trademark of // DENSO WAVE INCORPORATED//   http://www.denso-wave.com/qrcode/faqpatent-e.html////---------------------------------------------------------------------//---------------------------------------------------------------------// QR8bitByte//---------------------------------------------------------------------function QR8bitByte(data) {this.mode = QRMode.MODE_8BIT_BYTE;this.data = data;}QR8bitByte.prototype = {getLength: function(buffer) {return this.data.length;},write: function(buffer) {for (var i = 0; i < this.data.length; i++) {// not JIS ...buffer.put(this.data.charCodeAt(i), 8);}}};//---------------------------------------------------------------------// QRCode//---------------------------------------------------------------------function QRCode(typeNumber, errorCorrectLevel) {this.typeNumber = typeNumber;this.errorCorrectLevel = errorCorrectLevel;this.modules = null;this.moduleCount = 0;this.dataCache = null;this.dataList = new Array();}QRCode.prototype = {addData: function(data) {var newData = new QR8bitByte(data);this.dataList.push(newData);this.dataCache = null;},isDark: function(row, col) {if (row < 0 || this.moduleCount <= row || col < 0 || this.moduleCount <= col) {throw new Error(row + "," + col);}return this.modules[row][col];},getModuleCount: function() {return this.moduleCount;},make: function() {// Calculate automatically typeNumber if provided is < 1if (this.typeNumber < 1) {var typeNumber = 1;for (typeNumber = 1; typeNumber < 40; typeNumber++) {var rsBlocks = QRRSBlock.getRSBlocks(typeNumber, this.errorCorrectLevel);var buffer = new QRBitBuffer();var totalDataCount = 0;for (var i = 0; i < rsBlocks.length; i++) {totalDataCount += rsBlocks[i].dataCount;}for (var i = 0; i < this.dataList.length; i++) {var data = this.dataList[i];buffer.put(data.mode, 4);buffer.put(data.getLength(), QRUtil.getLengthInBits(data.mode, typeNumber));data.write(buffer);}if (buffer.getLengthInBits() <= totalDataCount * 8)break;}this.typeNumber = typeNumber;}this.makeImpl(false, this.getBestMaskPattern());},makeImpl: function(test, maskPattern) {this.moduleCount = this.typeNumber * 4 + 17;this.modules = new Array(this.moduleCount);for (var row = 0; row < this.moduleCount; row++) {this.modules[row] = new Array(this.moduleCount);for (var col = 0; col < this.moduleCount; col++) {this.modules[row][col] = null; //(col + row) % 3;}}this.setupPositionProbePattern(0, 0);this.setupPositionProbePattern(this.moduleCount - 7, 0);this.setupPositionProbePattern(0, this.moduleCount - 7);this.setupPositionAdjustPattern();this.setupTimingPattern();this.setupTypeInfo(test, maskPattern);if (this.typeNumber >= 7) {this.setupTypeNumber(test);}if (this.dataCache == null) {this.dataCache = QRCode.createData(this.typeNumber, this.errorCorrectLevel, this.dataList);}this.mapData(this.dataCache, maskPattern);},setupPositionProbePattern: function(row, col) {for (var r = -1; r <= 7; r++) {if (row + r <= -1 || this.moduleCount <= row + r) continue;for (var c = -1; c <= 7; c++) {if (col + c <= -1 || this.moduleCount <= col + c) continue;if ((0 <= r && r <= 6 && (c == 0 || c == 6)) ||(0 <= c && c <= 6 && (r == 0 || r == 6)) ||(2 <= r && r <= 4 && 2 <= c && c <= 4)) {this.modules[row + r][col + c] = true;} else {this.modules[row + r][col + c] = false;}}}},getBestMaskPattern: function() {var minLostPoint = 0;var pattern = 0;for (var i = 0; i < 8; i++) {this.makeImpl(true, i);var lostPoint = QRUtil.getLostPoint(this);if (i == 0 || minLostPoint > lostPoint) {minLostPoint = lostPoint;pattern = i;}}return pattern;},createMovieClip: function(target_mc, instance_name, depth) {var qr_mc = target_mc.createEmptyMovieClip(instance_name, depth);var cs = 1;this.make();for (var row = 0; row < this.modules.length; row++) {var y = row * cs;for (var col = 0; col < this.modules[row].length; col++) {var x = col * cs;var dark = this.modules[row][col];if (dark) {qr_mc.beginFill(0, 100);qr_mc.moveTo(x, y);qr_mc.lineTo(x + cs, y);qr_mc.lineTo(x + cs, y + cs);qr_mc.lineTo(x, y + cs);qr_mc.endFill();}}}return qr_mc;},setupTimingPattern: function() {for (var r = 8; r < this.moduleCount - 8; r++) {if (this.modules[r][6] != null) {continue;}this.modules[r][6] = (r % 2 == 0);}for (var c = 8; c < this.moduleCount - 8; c++) {if (this.modules[6][c] != null) {continue;}this.modules[6][c] = (c % 2 == 0);}},setupPositionAdjustPattern: function() {var pos = QRUtil.getPatternPosition(this.typeNumber);for (var i = 0; i < pos.length; i++) {for (var j = 0; j < pos.length; j++) {var row = pos[i];var col = pos[j];if (this.modules[row][col] != null) {continue;}for (var r = -2; r <= 2; r++) {for (var c = -2; c <= 2; c++) {if (r == -2 || r == 2 || c == -2 || c == 2 ||(r == 0 && c == 0)) {this.modules[row + r][col + c] = true;} else {this.modules[row + r][col + c] = false;}}}}}},setupTypeNumber: function(test) {var bits = QRUtil.getBCHTypeNumber(this.typeNumber);for (var i = 0; i < 18; i++) {var mod = (!test && ((bits >> i) & 1) == 1);this.modules[Math.floor(i / 3)][i % 3 + this.moduleCount - 8 - 3] = mod;}for (var i = 0; i < 18; i++) {var mod = (!test && ((bits >> i) & 1) == 1);this.modules[i % 3 + this.moduleCount - 8 - 3][Math.floor(i / 3)] = mod;}},setupTypeInfo: function(test, maskPattern) {var data = (this.errorCorrectLevel << 3) | maskPattern;var bits = QRUtil.getBCHTypeInfo(data);// vertical		for (var i = 0; i < 15; i++) {var mod = (!test && ((bits >> i) & 1) == 1);if (i < 6) {this.modules[i][8] = mod;} else if (i < 8) {this.modules[i + 1][8] = mod;} else {this.modules[this.moduleCount - 15 + i][8] = mod;}}// horizontalfor (var i = 0; i < 15; i++) {var mod = (!test && ((bits >> i) & 1) == 1);if (i < 8) {this.modules[8][this.moduleCount - i - 1] = mod;} else if (i < 9) {this.modules[8][15 - i - 1 + 1] = mod;} else {this.modules[8][15 - i - 1] = mod;}}// fixed modulethis.modules[this.moduleCount - 8][8] = (!test);},mapData: function(data, maskPattern) {var inc = -1;var row = this.moduleCount - 1;var bitIndex = 7;var byteIndex = 0;for (var col = this.moduleCount - 1; col > 0; col -= 2) {if (col == 6) col--;while (true) {for (var c = 0; c < 2; c++) {if (this.modules[row][col - c] == null) {var dark = false;if (byteIndex < data.length) {dark = (((data[byteIndex] >>> bitIndex) & 1) == 1);}var mask = QRUtil.getMask(maskPattern, row, col - c);if (mask) {dark = !dark;}this.modules[row][col - c] = dark;bitIndex--;if (bitIndex == -1) {byteIndex++;bitIndex = 7;}}}row += inc;if (row < 0 || this.moduleCount <= row) {row -= inc;inc = -inc;break;}}}}};QRCode.PAD0 = 0xEC;QRCode.PAD1 = 0x11;QRCode.createData = function(typeNumber, errorCorrectLevel, dataList) {var rsBlocks = QRRSBlock.getRSBlocks(typeNumber, errorCorrectLevel);var buffer = new QRBitBuffer();for (var i = 0; i < dataList.length; i++) {var data = dataList[i];buffer.put(data.mode, 4);buffer.put(data.getLength(), QRUtil.getLengthInBits(data.mode, typeNumber));data.write(buffer);}// calc num max data.var totalDataCount = 0;for (var i = 0; i < rsBlocks.length; i++) {totalDataCount += rsBlocks[i].dataCount;}if (buffer.getLengthInBits() > totalDataCount * 8) {throw new Error("code length overflow. (" +buffer.getLengthInBits() +">" +totalDataCount * 8 +")");}// end codeif (buffer.getLengthInBits() + 4 <= totalDataCount * 8) {buffer.put(0, 4);}// paddingwhile (buffer.getLengthInBits() % 8 != 0) {buffer.putBit(false);}// paddingwhile (true) {if (buffer.getLengthInBits() >= totalDataCount * 8) {break;}buffer.put(QRCode.PAD0, 8);if (buffer.getLengthInBits() >= totalDataCount * 8) {break;}buffer.put(QRCode.PAD1, 8);}return QRCode.createBytes(buffer, rsBlocks);}QRCode.createBytes = function(buffer, rsBlocks) {var offset = 0;var maxDcCount = 0;var maxEcCount = 0;var dcdata = new Array(rsBlocks.length);var ecdata = new Array(rsBlocks.length);for (var r = 0; r < rsBlocks.length; r++) {var dcCount = rsBlocks[r].dataCount;var ecCount = rsBlocks[r].totalCount - dcCount;maxDcCount = Math.max(maxDcCount, dcCount);maxEcCount = Math.max(maxEcCount, ecCount);dcdata[r] = new Array(dcCount);for (var i = 0; i < dcdata[r].length; i++) {dcdata[r][i] = 0xff & buffer.buffer[i + offset];}offset += dcCount;var rsPoly = QRUtil.getErrorCorrectPolynomial(ecCount);var rawPoly = new QRPolynomial(dcdata[r], rsPoly.getLength() - 1);var modPoly = rawPoly.mod(rsPoly);ecdata[r] = new Array(rsPoly.getLength() - 1);for (var i = 0; i < ecdata[r].length; i++) {var modIndex = i + modPoly.getLength() - ecdata[r].length;ecdata[r][i] = (modIndex >= 0) ? modPoly.get(modIndex) : 0;}}var totalCodeCount = 0;for (var i = 0; i < rsBlocks.length; i++) {totalCodeCount += rsBlocks[i].totalCount;}var data = new Array(totalCodeCount);var index = 0;for (var i = 0; i < maxDcCount; i++) {for (var r = 0; r < rsBlocks.length; r++) {if (i < dcdata[r].length) {data[index++] = dcdata[r][i];}}}for (var i = 0; i < maxEcCount; i++) {for (var r = 0; r < rsBlocks.length; r++) {if (i < ecdata[r].length) {data[index++] = ecdata[r][i];}}}return data;}//---------------------------------------------------------------------// QRMode//---------------------------------------------------------------------var QRMode = {MODE_NUMBER: 1 << 0,MODE_ALPHA_NUM: 1 << 1,MODE_8BIT_BYTE: 1 << 2,MODE_KANJI: 1 << 3};//---------------------------------------------------------------------// QRErrorCorrectLevel//---------------------------------------------------------------------var QRErrorCorrectLevel = {L: 1,M: 0,Q: 3,H: 2};//---------------------------------------------------------------------// QRMaskPattern//---------------------------------------------------------------------var QRMaskPattern = {PATTERN000: 0,PATTERN001: 1,PATTERN010: 2,PATTERN011: 3,PATTERN100: 4,PATTERN101: 5,PATTERN110: 6,PATTERN111: 7};//---------------------------------------------------------------------// QRUtil//---------------------------------------------------------------------var QRUtil = {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: (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0),G18: (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0),G15_MASK: (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1),getBCHTypeInfo: function(data) {var d = data << 10;while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15) >= 0) {d ^= (QRUtil.G15 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15)));}return ((data << 10) | d) ^ QRUtil.G15_MASK;},getBCHTypeNumber: function(data) {var d = data << 12;while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18) >= 0) {d ^= (QRUtil.G18 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18)));}return (data << 12) | d;},getBCHDigit: function(data) {var digit = 0;while (data != 0) {digit++;data >>>= 1;}return digit;},getPatternPosition: function(typeNumber) {return QRUtil.PATTERN_POSITION_TABLE[typeNumber - 1];},getMask: function(maskPattern, i, j) {switch (maskPattern) {case QRMaskPattern.PATTERN000:return (i + j) % 2 == 0;case QRMaskPattern.PATTERN001:return i % 2 == 0;case QRMaskPattern.PATTERN010:return j % 3 == 0;case QRMaskPattern.PATTERN011:return (i + j) % 3 == 0;case QRMaskPattern.PATTERN100:return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 == 0;case QRMaskPattern.PATTERN101:return (i * j) % 2 + (i * j) % 3 == 0;case QRMaskPattern.PATTERN110:return ((i * j) % 2 + (i * j) % 3) % 2 == 0;case QRMaskPattern.PATTERN111:return ((i * j) % 3 + (i + j) % 2) % 2 == 0;default:throw new Error("bad maskPattern:" + maskPattern);}},getErrorCorrectPolynomial: function(errorCorrectLength) {var a = new QRPolynomial([1], 0);for (var i = 0; i < errorCorrectLength; i++) {a = a.multiply(new QRPolynomial([1, QRMath.gexp(i)], 0));}return a;},getLengthInBits: function(mode, type) {if (1 <= type && type < 10) {// 1 - 9switch (mode) {case QRMode.MODE_NUMBER:return 10;case QRMode.MODE_ALPHA_NUM:return 9;case QRMode.MODE_8BIT_BYTE:return 8;case QRMode.MODE_KANJI:return 8;default:throw new Error("mode:" + mode);}} else if (type < 27) {// 10 - 26switch (mode) {case QRMode.MODE_NUMBER:return 12;case QRMode.MODE_ALPHA_NUM:return 11;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 10;default:throw new Error("mode:" + mode);}} else if (type < 41) {// 27 - 40switch (mode) {case QRMode.MODE_NUMBER:return 14;case QRMode.MODE_ALPHA_NUM:return 13;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 12;default:throw new Error("mode:" + mode);}} else {throw new Error("type:" + type);}},getLostPoint: function(qrCode) {var moduleCount = qrCode.getModuleCount();var lostPoint = 0;// LEVEL1for (var row = 0; row < moduleCount; row++) {for (var col = 0; col < moduleCount; col++) {var sameCount = 0;var dark = qrCode.isDark(row, col);for (var r = -1; r <= 1; r++) {if (row + r < 0 || moduleCount <= row + r) {continue;}for (var c = -1; c <= 1; c++) {if (col + c < 0 || moduleCount <= col + c) {continue;}if (r == 0 && c == 0) {continue;}if (dark == qrCode.isDark(row + r, col + c)) {sameCount++;}}}if (sameCount > 5) {lostPoint += (3 + sameCount - 5);}}}// LEVEL2for (var row = 0; row < moduleCount - 1; row++) {for (var col = 0; col < moduleCount - 1; col++) {var count = 0;if (qrCode.isDark(row, col)) count++;if (qrCode.isDark(row + 1, col)) count++;if (qrCode.isDark(row, col + 1)) count++;if (qrCode.isDark(row + 1, col + 1)) count++;if (count == 0 || count == 4) {lostPoint += 3;}}}// LEVEL3for (var row = 0; row < moduleCount; row++) {for (var col = 0; col < moduleCount - 6; col++) {if (qrCode.isDark(row, col) &&!qrCode.isDark(row, col + 1) &&qrCode.isDark(row, col + 2) &&qrCode.isDark(row, col + 3) &&qrCode.isDark(row, col + 4) &&!qrCode.isDark(row, col + 5) &&qrCode.isDark(row, col + 6)) {lostPoint += 40;}}}for (var col = 0; col < moduleCount; col++) {for (var row = 0; row < moduleCount - 6; row++) {if (qrCode.isDark(row, col) &&!qrCode.isDark(row + 1, col) &&qrCode.isDark(row + 2, col) &&qrCode.isDark(row + 3, col) &&qrCode.isDark(row + 4, col) &&!qrCode.isDark(row + 5, col) &&qrCode.isDark(row + 6, col)) {lostPoint += 40;}}}// LEVEL4var darkCount = 0;for (var col = 0; col < moduleCount; col++) {for (var row = 0; row < moduleCount; row++) {if (qrCode.isDark(row, col)) {darkCount++;}}}var ratio = Math.abs(100 * darkCount / moduleCount / moduleCount - 50) / 5;lostPoint += ratio * 10;return lostPoint;}};//---------------------------------------------------------------------// QRMath//---------------------------------------------------------------------var QRMath = {glog: function(n) {if (n < 1) {throw new Error("glog(" + n + ")");}return QRMath.LOG_TABLE[n];},gexp: function(n) {while (n < 0) {n += 255;}while (n >= 256) {n -= 255;}return QRMath.EXP_TABLE[n];},EXP_TABLE: new Array(256),LOG_TABLE: new Array(256)};for (var i = 0; i < 8; i++) {QRMath.EXP_TABLE[i] = 1 << i;}for (var i = 8; i < 256; i++) {QRMath.EXP_TABLE[i] = QRMath.EXP_TABLE[i - 4] ^QRMath.EXP_TABLE[i - 5] ^QRMath.EXP_TABLE[i - 6] ^QRMath.EXP_TABLE[i - 8];}for (var i = 0; i < 255; i++) {QRMath.LOG_TABLE[QRMath.EXP_TABLE[i]] = i;}//---------------------------------------------------------------------// QRPolynomial//---------------------------------------------------------------------function QRPolynomial(num, shift) {if (num.length == undefined) {throw new Error(num.length + "/" + shift);}var offset = 0;while (offset < num.length && num[offset] == 0) {offset++;}this.num = new Array(num.length - offset + shift);for (var i = 0; i < num.length - offset; i++) {this.num[i] = num[i + offset];}}QRPolynomial.prototype = {get: function(index) {return this.num[index];},getLength: function() {return this.num.length;},multiply: function(e) {var num = new Array(this.getLength() + e.getLength() - 1);for (var i = 0; i < this.getLength(); i++) {for (var j = 0; j < e.getLength(); j++) {num[i + j] ^= QRMath.gexp(QRMath.glog(this.get(i)) + QRMath.glog(e.get(j)));}}return new QRPolynomial(num, 0);},mod: function(e) {if (this.getLength() - e.getLength() < 0) {return this;}var ratio = QRMath.glog(this.get(0)) - QRMath.glog(e.get(0));var num = new Array(this.getLength());for (var i = 0; i < this.getLength(); i++) {num[i] = this.get(i);}for (var i = 0; i < e.getLength(); i++) {num[i] ^= QRMath.gexp(QRMath.glog(e.get(i)) + ratio);}// recursive callreturn new QRPolynomial(num, 0).mod(e);}};//---------------------------------------------------------------------// QRRSBlock//---------------------------------------------------------------------function QRRSBlock(totalCount, dataCount) {this.totalCount = totalCount;this.dataCount = dataCount;}QRRSBlock.RS_BLOCK_TABLE = [// L// M// Q// H// 1[1, 26, 19],[1, 26, 16],[1, 26, 13],[1, 26, 9],// 2[1, 44, 34],[1, 44, 28],[1, 44, 22],[1, 44, 16],// 3[1, 70, 55],[1, 70, 44],[2, 35, 17],[2, 35, 13],// 4		[1, 100, 80],[2, 50, 32],[2, 50, 24],[4, 25, 9],// 5[1, 134, 108],[2, 67, 43],[2, 33, 15, 2, 34, 16],[2, 33, 11, 2, 34, 12],// 6[2, 86, 68],[4, 43, 27],[4, 43, 19],[4, 43, 15],// 7		[2, 98, 78],[4, 49, 31],[2, 32, 14, 4, 33, 15],[4, 39, 13, 1, 40, 14],// 8[2, 121, 97],[2, 60, 38, 2, 61, 39],[4, 40, 18, 2, 41, 19],[4, 40, 14, 2, 41, 15],// 9[2, 146, 116],[3, 58, 36, 2, 59, 37],[4, 36, 16, 4, 37, 17],[4, 36, 12, 4, 37, 13],// 10		[2, 86, 68, 2, 87, 69],[4, 69, 43, 1, 70, 44],[6, 43, 19, 2, 44, 20],[6, 43, 15, 2, 44, 16],// 11[4, 101, 81],[1, 80, 50, 4, 81, 51],[4, 50, 22, 4, 51, 23],[3, 36, 12, 8, 37, 13],// 12[2, 116, 92, 2, 117, 93],[6, 58, 36, 2, 59, 37],[4, 46, 20, 6, 47, 21],[7, 42, 14, 4, 43, 15],// 13[4, 133, 107],[8, 59, 37, 1, 60, 38],[8, 44, 20, 4, 45, 21],[12, 33, 11, 4, 34, 12],// 14[3, 145, 115, 1, 146, 116],[4, 64, 40, 5, 65, 41],[11, 36, 16, 5, 37, 17],[11, 36, 12, 5, 37, 13],// 15[5, 109, 87, 1, 110, 88],[5, 65, 41, 5, 66, 42],[5, 54, 24, 7, 55, 25],[11, 36, 12],// 16[5, 122, 98, 1, 123, 99],[7, 73, 45, 3, 74, 46],[15, 43, 19, 2, 44, 20],[3, 45, 15, 13, 46, 16],// 17[1, 135, 107, 5, 136, 108],[10, 74, 46, 1, 75, 47],[1, 50, 22, 15, 51, 23],[2, 42, 14, 17, 43, 15],// 18[5, 150, 120, 1, 151, 121],[9, 69, 43, 4, 70, 44],[17, 50, 22, 1, 51, 23],[2, 42, 14, 19, 43, 15],// 19[3, 141, 113, 4, 142, 114],[3, 70, 44, 11, 71, 45],[17, 47, 21, 4, 48, 22],[9, 39, 13, 16, 40, 14],// 20[3, 135, 107, 5, 136, 108],[3, 67, 41, 13, 68, 42],[15, 54, 24, 5, 55, 25],[15, 43, 15, 10, 44, 16],// 21[4, 144, 116, 4, 145, 117],[17, 68, 42],[17, 50, 22, 6, 51, 23],[19, 46, 16, 6, 47, 17],// 22[2, 139, 111, 7, 140, 112],[17, 74, 46],[7, 54, 24, 16, 55, 25],[34, 37, 13],// 23[4, 151, 121, 5, 152, 122],[4, 75, 47, 14, 76, 48],[11, 54, 24, 14, 55, 25],[16, 45, 15, 14, 46, 16],// 24[6, 147, 117, 4, 148, 118],[6, 73, 45, 14, 74, 46],[11, 54, 24, 16, 55, 25],[30, 46, 16, 2, 47, 17],// 25[8, 132, 106, 4, 133, 107],[8, 75, 47, 13, 76, 48],[7, 54, 24, 22, 55, 25],[22, 45, 15, 13, 46, 16],// 26[10, 142, 114, 2, 143, 115],[19, 74, 46, 4, 75, 47],[28, 50, 22, 6, 51, 23],[33, 46, 16, 4, 47, 17],// 27[8, 152, 122, 4, 153, 123],[22, 73, 45, 3, 74, 46],[8, 53, 23, 26, 54, 24],[12, 45, 15, 28, 46, 16],// 28[3, 147, 117, 10, 148, 118],[3, 73, 45, 23, 74, 46],[4, 54, 24, 31, 55, 25],[11, 45, 15, 31, 46, 16],// 29[7, 146, 116, 7, 147, 117],[21, 73, 45, 7, 74, 46],[1, 53, 23, 37, 54, 24],[19, 45, 15, 26, 46, 16],// 30[5, 145, 115, 10, 146, 116],[19, 75, 47, 10, 76, 48],[15, 54, 24, 25, 55, 25],[23, 45, 15, 25, 46, 16],// 31[13, 145, 115, 3, 146, 116],[2, 74, 46, 29, 75, 47],[42, 54, 24, 1, 55, 25],[23, 45, 15, 28, 46, 16],// 32[17, 145, 115],[10, 74, 46, 23, 75, 47],[10, 54, 24, 35, 55, 25],[19, 45, 15, 35, 46, 16],// 33[17, 145, 115, 1, 146, 116],[14, 74, 46, 21, 75, 47],[29, 54, 24, 19, 55, 25],[11, 45, 15, 46, 46, 16],// 34[13, 145, 115, 6, 146, 116],[14, 74, 46, 23, 75, 47],[44, 54, 24, 7, 55, 25],[59, 46, 16, 1, 47, 17],// 35[12, 151, 121, 7, 152, 122],[12, 75, 47, 26, 76, 48],[39, 54, 24, 14, 55, 25],[22, 45, 15, 41, 46, 16],// 36[6, 151, 121, 14, 152, 122],[6, 75, 47, 34, 76, 48],[46, 54, 24, 10, 55, 25],[2, 45, 15, 64, 46, 16],// 37[17, 152, 122, 4, 153, 123],[29, 74, 46, 14, 75, 47],[49, 54, 24, 10, 55, 25],[24, 45, 15, 46, 46, 16],// 38[4, 152, 122, 18, 153, 123],[13, 74, 46, 32, 75, 47],[48, 54, 24, 14, 55, 25],[42, 45, 15, 32, 46, 16],// 39[20, 147, 117, 4, 148, 118],[40, 75, 47, 7, 76, 48],[43, 54, 24, 22, 55, 25],[10, 45, 15, 67, 46, 16],// 40[19, 148, 118, 6, 149, 119],[18, 75, 47, 31, 76, 48],[34, 54, 24, 34, 55, 25],[20, 45, 15, 61, 46, 16]];QRRSBlock.getRSBlocks = function(typeNumber, errorCorrectLevel) {var rsBlock = QRRSBlock.getRsBlockTable(typeNumber, errorCorrectLevel);if (rsBlock == undefined) {throw new Error("bad rs block @ typeNumber:" + typeNumber + "/errorCorrectLevel:" + errorCorrectLevel);}var length = rsBlock.length / 3;var list = new Array();for (var i = 0; i < length; i++) {var count = rsBlock[i * 3 + 0];var totalCount = rsBlock[i * 3 + 1];var dataCount = rsBlock[i * 3 + 2];for (var j = 0; j < count; j++) {list.push(new QRRSBlock(totalCount, dataCount));}}return list;}QRRSBlock.getRsBlockTable = function(typeNumber, errorCorrectLevel) {switch (errorCorrectLevel) {case QRErrorCorrectLevel.L:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 0];case QRErrorCorrectLevel.M:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 1];case QRErrorCorrectLevel.Q:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 2];case QRErrorCorrectLevel.H:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber - 1) * 4 + 3];default:return undefined;}}//---------------------------------------------------------------------// QRBitBuffer//---------------------------------------------------------------------function QRBitBuffer() {this.buffer = new Array();this.length = 0;}QRBitBuffer.prototype = {get: function(index) {var bufIndex = Math.floor(index / 8);return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1) == 1;},put: function(num, length) {for (var i = 0; i < length; i++) {this.putBit(((num >>> (length - i - 1)) & 1) == 1);}},getLengthInBits: function() {return this.length;},putBit: function(bit) {var bufIndex = Math.floor(this.length / 8);if (this.buffer.length <= bufIndex) {this.buffer.push(0);}if (bit) {this.buffer[bufIndex] |= (0x80 >>> (this.length % 8));}this.length++;}};//---------------------------------------------------------------------// Support Chinese//---------------------------------------------------------------------function utf16To8(text) {var result = '';var c;for (var i = 0; i < text.length; i++) {c = text.charCodeAt(i);if (c >= 0x0001 && c <= 0x007F) {result += text.charAt(i);} else if (c > 0x07FF) {result += String.fromCharCode(0xE0 | c >> 12 & 0x0F);result += String.fromCharCode(0x80 | c >> 6 & 0x3F);result += String.fromCharCode(0x80 | c >> 0 & 0x3F);} else {result += String.fromCharCode(0xC0 | c >> 6 & 0x1F);result += String.fromCharCode(0x80 | c >> 0 & 0x3F);}}return result;}uQRCode = {errorCorrectLevel: QRErrorCorrectLevel,defaults: {size: 354,margin: 0,backgroundColor: '#ffffff',foregroundColor: '#000000',fileType: 'png', // 'jpg', 'png'errorCorrectLevel: QRErrorCorrectLevel.H,typeNumber: -1},make: function(options) {return new Promise((reslove, reject) => {var defaultOptions = {canvasId: options.canvasId,componentInstance: options.componentInstance,text: options.text,size: this.defaults.size,margin: this.defaults.margin,backgroundColor: this.defaults.backgroundColor,foregroundColor: this.defaults.foregroundColor,fileType: this.defaults.fileType,errorCorrectLevel: this.defaults.errorCorrectLevel,typeNumber: this.defaults.typeNumber};if (options) {for (var i in options) {defaultOptions[i] = options[i];}}options = defaultOptions;if (!options.canvasId) {console.error('uQRCode: Please set canvasId!');return;}function createCanvas() {var qrcode = new QRCode(options.typeNumber, options.errorCorrectLevel);qrcode.addData(utf16To8(options.text));qrcode.make();var ctx = uni.createCanvasContext(options.canvasId, options.componentInstance);ctx.setFillStyle(options.backgroundColor);ctx.fillRect(0, 0, options.size, options.size);var tileW = (options.size - options.margin * 2) / qrcode.getModuleCount();var tileH = tileW;for (var row = 0; row < qrcode.getModuleCount(); row++) {for (var col = 0; col < qrcode.getModuleCount(); col++) {var style = qrcode.isDark(row, col) ? options.foregroundColor : options.backgroundColor;ctx.setFillStyle(style);var x = Math.round(col * tileW) + options.margin;var y = Math.round(row * tileH) + options.margin;var w = Math.ceil((col + 1) * tileW) - Math.floor(col * tileW);var h = Math.ceil((row + 1) * tileW) - Math.floor(row * tileW);ctx.fillRect(x, y, w, h);}}setTimeout(function() {ctx.draw(false, (function() {setTimeout(function() {uni.canvasToTempFilePath({canvasId: options.canvasId,fileType: options.fileType,width: options.size,height: options.size,destWidth: options.size,destHeight: options.size,success: function(res) {let resData; // 将统一为base64格式let tempFilePath = res.tempFilePath; // H5为base64,其他为相对路径// #ifdef H5resData = tempFilePath;options.success && options.success(resData);reslove(resData);// #endif// #ifdef APP-PLUSconst path = plus.io.convertLocalFileSystemURL(tempFilePath) // 绝对路径let fileReader = new plus.io.FileReader();fileReader.readAsDataURL(path);fileReader.onloadend = res => {resData = res.target.result;options.success && options.success(resData);reslove(resData);};// #endif// #ifdef MP-WEIXIN || MP-QQ || MP-TOUTIAOuni.getFileSystemManager().readFile({filePath: tempFilePath,encoding: 'base64',success: res => {resData = 'data:image/png;base64,' + res.data;options.success && options.success(resData);reslove(resData);}})// #endif// #ifndef H5 || APP-PLUS || MP-WEIXIN || MP-QQ || MP-TOUTIAOif (plus) {const path = plus.io.convertLocalFileSystemURL(tempFilePath) // 绝对路径let fileReader = new plus.io.FileReader();fileReader.readAsDataURL(path);fileReader.onloadend = res => {resData = res.target.result;options.success && options.success(resData);reslove(resData);};} else {uni.request({url: tempFilePath,method: 'GET',responseType: 'arraybuffer',success: res => {resData = `data:image/png;base64,${uni.arrayBufferToBase64(res.data)}`; // 把arraybuffer转成base64options.success && options.success(resData);reslove(resData);}})}// #endif},fail: function(error) {options.fail && options.fail(error);reject(error);},complete: function(res) {options.complete && options.complete(res);}}, options.componentInstance);}, options.text.length + 100);})());}, 150);}createCanvas();});}}})()export default uQRCode

相关文章:

vue,uniapp生成二维码

话不多说直接开干 先是vue的 1&#xff0c;首先按照一下依赖 npm install --save qrcode 2,在需要使用的页面引入 import QRCode from qrcode; 3,使用 const codeDetail (item) > {//这个item.code是要生成的数据&#xff0c;我的是一串数字QRCode.toDataURL(item.co…...

分类预测 | MATLAB实现SSA-CNN-SVM基于麻雀算法优化卷积支持向量机分类预测

分类预测 | MATLAB实现SSA-CNN-SVM基于麻雀算法优化卷积支持向量机分类预测 目录 分类预测 | MATLAB实现SSA-CNN-SVM基于麻雀算法优化卷积支持向量机分类预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 MATLAB实现SSA-CNN-SVM基于麻雀算法优化卷积支持向量机分类预测…...

STM32启动模式详解

文章目录 前置知识1. 单片机最小系统组成2. BOOT电路3. 三种启动模式4. 存储器映射 从主FLASH启动从系统存储区启动从SRAM启动 前置知识 1. 单片机最小系统组成 一个单片机最小系统由电源、晶振、下载电路、BOOT电路、和复位电路组成。少一个单片机都启动不了。 2. BOOT电路 …...

go语言中的切片

切片底层 切片&#xff08;Slice&#xff09;是一个拥有相同类型元素的可变长度的序列。它是基于数组类型做的一层封装。它非常灵活&#xff0c;支持自动扩容。 切片是一个引用类型&#xff0c;它的内部结构包含地址、长度和容量。切片一般用于快速地操作一块数据集合。 切片…...

HTML-常见标签、HTML5新特性

HTML 软件架构 1.C/S架构 (1) C/S架构即Client/Server&#xff08;客户机/服务器&#xff09;结构。 (2) C/S 架构特点 ​ C/S结构在技术上很成熟&#xff0c;它的主要特点是交互性强、具有安全的存取模式、网络通信量低、响应速度快、利于处理大量数据。但是该结构的程序是…...

微信有自己的“知乎”,微信问一问来了!

这几个月来&#xff0c;微信问一问一直挺火的&#xff0c;有人涨粉&#xff0c;有人变现&#xff0c;有人引流~ 这个全新的流量入口对流量玩家来说又是一波巨大的流量红利。 微信问一问就类似于微信版的知乎&#xff0c;未来将对知乎产生一定竞争压力。 依托于微信这个庞大的流…...

[MyBatis系列③]动态SQL

目录 1、简介 2、if标签 3、foreach标签 4、SQL抽取 ⭐MyBatis系列①&#xff1a;增删改查 ⭐MyBatis系列②&#xff1a;两种Dao开发方式 1、简介 开发中在MyBatis映射文件配置SQL语句&#xff0c;但是前面配置的都是比较简单的&#xff0c;不涉及稍复杂的业务场景。想要应…...

开始MySQL之路—— DDL语法、DML语法、DQL语法基本操作详解

DDL语法 DDL&#xff08;Data Definition Language&#xff09; 数据定义语言&#xff0c;该语言部分包括以下内容。 对数据库的常用操作 对表结构的常用操作 修改表结构 对数据库的常用操作 1: 查看当前所有的数据库 show databases; 2&#xff1a;创建数据库 create dat…...

Java“牵手”天猫整店商品API接口数据,通过店铺ID获取整店商品详情数据,天猫店铺所有商品API申请指南

天猫平台店铺所有商品数据接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取天猫整店的商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片、价格信息等详细信息 。 获取店铺所有商品接口API是一种用于获取电商平台上商品详…...

用AI重构的钉钉,“钱”路在何方?

点击关注 文&#xff5c;郝 鑫&#xff0c;编&#xff5c;刘雨琦 钉钉2023年生态大会&#xff0c;离开了两年的无招&#xff0c;遇到了单飞9天的钉钉。 “做小钉钉、做好钉钉、做酷钉钉”&#xff0c;无招重申了钉钉的方向。 无招提到的三点&#xff0c;再加上“高质量增长”…...

批量根据excel数据绘制柱状图

要批量根据Excel数据绘制柱状图&#xff0c;可以使用Python中的pandas和matplotlib库来实现。下面是示例代码&#xff1a; import pandas as pd import matplotlib.pyplot as plt import os def draw_bar_chart_from_excel(file_path, x_column, y_column, output_folder): …...

浅谈 Java 中的 Lambda 表达式

更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验 Lambda 表达式是一种匿名函数&#xff0c;它可以作为参数传递给方法或存储在变量中。在 Java8 中&#xff0c;它和函数式接口一起&#xff0c;共同构建了函数式编程的框架。 什么是函数式编程 函数式编程是…...

闭包的概念

概念 内层函数可以访问到外层函数的变量和参数&#xff0c;即一个函数和它周围状态捆绑在一起的组合。 举例 函数作为返回值 // 函数作为返回值 function test(){const a 1;return function() {console.log(a:,a);} }const fn test(); const a 6; fn(); // 1 2. 函数作…...

openGauss学习笔记-52 openGauss 高级特性-LLVM

文章目录 openGauss学习笔记-52 openGauss 高级特性-LLVM52.1 适用场景52.2 非适用场景52.3 其他因素对LLVM性能的影响52.4 LLVM使用建议 openGauss学习笔记-52 openGauss 高级特性-LLVM openGauss借助LLVM&#xff08;Low Level Virtual Machine&#xff09;提供的库函数&…...

MySQL 8.0字符集校正

MySQL升级为8.0版本时&#xff0c;之前版本的字符集往往是不同的&#xff0c;需要校正。 执行下面的三个SQL语句的查询结果&#xff0c;可以从库、表、列三个层面对字符集进行校正。 库 select concat(alter database , schema_name, default character set utf8mb4 collate …...

软考:中级软件设计师:数据库恢复与备份,故障与恢复,反规范化

软考&#xff1a;中级软件设计师:数据库恢复与备份 提示&#xff1a;系列被面试官问的问题&#xff0c;我自己当时不会&#xff0c;所以下来自己复盘一下&#xff0c;认真学习和总结&#xff0c;以应对未来更多的可能性 关于互联网大厂的笔试面试&#xff0c;都是需要细心准备…...

Unbutu系统-Docker安装、JDK环境配置,Docker常用指令、Docker安装MySQL、Redis、Tomcat、Nginx,前端后分离项目部署

目录 1、防火墙 1.1、查看防火墙状态 1.2、开启防火墙 1.3、关闭防火墙 1.4、重启防火墙 1.5、查看防火墙版本 2、安装JDK 2.1、官网下载tar包 2.3、解压tar.gz文件 2.4、配置环境变量 2.4.1、查看安装路径 2.4.2、设置环境变量 2.4.3、执行该让环境变量生效 2.4…...

Python绘图系统10:在父组件中使用子组件的函数

文章目录 Combobox绑定事件互相调用源代码 Python绘图系统&#xff1a; &#x1f4c8;从0开始实现一个三维绘图系统自定义控件&#xff1a;坐标设置控件&#x1f4c9;坐标列表控件&#x1f4c9;支持多组数据的绘图系统图表类型和风格&#xff1a;散点图和条形图&#x1f4ca;混…...

【Linux的成长史】Linux的发展史

&#x1f3ac; 博客主页&#xff1a;博主链接 &#x1f3a5; 本文由 M malloc 原创&#xff0c;首发于 CSDN&#x1f649; &#x1f384; 学习专栏推荐&#xff1a;LeetCode刷题集 数据库专栏 初阶数据结构 &#x1f3c5; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如…...

OLED透明屏是什么?什么叫做OLED透明屏的原屏?

OLED透明屏是一种新型的显示技术&#xff0c;具有高对比度、高亮度和能耗低等优势&#xff0c;正被越来越广泛地应用于各个领域中。 在OLED透明屏中&#xff0c;原屏是至关重要的元件之一。本文将深入探讨OLED透明屏原屏的意义、制造过程、品质要求、应用案例和发展趋势&#…...

中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试

作者&#xff1a;Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位&#xff1a;中南大学地球科学与信息物理学院论文标题&#xff1a;BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接&#xff1a;https://arxiv.…...

条件运算符

C中的三目运算符&#xff08;也称条件运算符&#xff0c;英文&#xff1a;ternary operator&#xff09;是一种简洁的条件选择语句&#xff0c;语法如下&#xff1a; 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true&#xff0c;则整个表达式的结果为“表达式1”…...

python如何将word的doc另存为docx

将 DOCX 文件另存为 DOCX 格式&#xff08;Python 实现&#xff09; 在 Python 中&#xff0c;你可以使用 python-docx 库来操作 Word 文档。不过需要注意的是&#xff0c;.doc 是旧的 Word 格式&#xff0c;而 .docx 是新的基于 XML 的格式。python-docx 只能处理 .docx 格式…...

AI+无人机如何守护濒危物种?YOLOv8实现95%精准识别

【导读】 野生动物监测在理解和保护生态系统中发挥着至关重要的作用。然而&#xff0c;传统的野生动物观察方法往往耗时耗力、成本高昂且范围有限。无人机的出现为野生动物监测提供了有前景的替代方案&#xff0c;能够实现大范围覆盖并远程采集数据。尽管具备这些优势&#xf…...

DingDing机器人群消息推送

文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人&#xff0c;点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置&#xff0c;详见说明文档 成功后&#xff0c;记录Webhook 2 API文档说明 点击设置说明 查看自…...

Redis:现代应用开发的高效内存数据存储利器

一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发&#xff0c;其初衷是为了满足他自己的一个项目需求&#xff0c;即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源&#xff0c;Redis凭借其简单易用、…...

【Android】Android 开发 ADB 常用指令

查看当前连接的设备 adb devices 连接设备 adb connect 设备IP 断开已连接的设备 adb disconnect 设备IP 安装应用 adb install 安装包的路径 卸载应用 adb uninstall 应用包名 查看已安装的应用包名 adb shell pm list packages 查看已安装的第三方应用包名 adb shell pm list…...

PHP 8.5 即将发布:管道操作符、强力调试

前不久&#xff0c;PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5&#xff01;作为 PHP 语言的又一次重要迭代&#xff0c;PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是&#xff0c;借助强大的本地开发环境 ServBay&am…...

Bean 作用域有哪些?如何答出技术深度?

导语&#xff1a; Spring 面试绕不开 Bean 的作用域问题&#xff0c;这是面试官考察候选人对 Spring 框架理解深度的常见方式。本文将围绕“Spring 中的 Bean 作用域”展开&#xff0c;结合典型面试题及实战场景&#xff0c;帮你厘清重点&#xff0c;打破模板式回答&#xff0c…...

在 Spring Boot 项目里,MYSQL中json类型字段使用

前言&#xff1a; 因为程序特殊需求导致&#xff0c;需要mysql数据库存储json类型数据&#xff0c;因此记录一下使用流程 1.java实体中新增字段 private List<User> users 2.增加mybatis-plus注解 TableField(typeHandler FastjsonTypeHandler.class) private Lis…...