cocosCreator 版本:3.7.2
开发语言:typeScript
我们在游戏开发中,经常会生成一个专属于玩家个人的二维码,比如说推广、充值等功能。
接到这个任务,在网上找了下,还是有很多教程的。但是这些教程大部分都是用QRCode二维码生成库,将js
文件设置成插件的形式。然后用画图组件Graphics
把二维码画出来。
我这里也是用的同样的思路,但是没有用插件的形式。下面说说具体的方法:
新建工程
打开cocosCreator,创建一个新工程。在scene
中添加一个精灵节点,将精灵设置为白色。再在精灵上添加一个Graphics
节点。如下图
注意:这里要设置要精灵和绘图节点的尺寸,最好是2的倍数,而且建议将
Graphics
的锚点设置为(0,0)
核心代码
import { _decorator, Component, Node,Graphics, Color, UITransform } from 'cc';
import { QRCode } from './qr/QRCode';
const { ccclass, property } = _decorator;
let QRErrorCorrectLevel = {
L: 1,
M: 0,
Q: 3,
H: 2
};
@ccclass('qrCode')
export class qrCode extends Component {
@property(Graphics)
graphics:Graphics = null;
start() {
this.qrCode("https://lengmo714.top");
}
private qrCode(url) {
let node = this.graphics;
var qrcode = new QRCode(-1, QRErrorCorrectLevel.H);
qrcode.addData(url);
qrcode.make();
var ctx = node.getComponent(Graphics)!;
ctx.fillColor = Color.BLACK;
var tileW = node.getComponent(UITransform)!.width / qrcode.getModuleCount();
var tileH = node.getComponent(UITransform)!.height / qrcode.getModuleCount();
// draw in the Graphics
for (var row = 0; row < qrcode.getModuleCount(); row++) {
for (var col = 0; col < qrcode.getModuleCount(); col++) {
if (qrcode.isDark(row, col)) {
var w = (Math.ceil((col + 1) * tileW) - Math.floor(col * tileW));
var h = (Math.ceil((row + 1) * tileW) - Math.floor(row * tileW));
ctx.rect(Math.round(col * tileW), Math.round(row * tileH), w, h);
ctx.fill();
} else {
// ctx.fillColor = cc.Color.WHITE;
}
var w = (Math.ceil((col + 1) * tileW) - Math.floor(col * tileW));
}
}
}
}
注意,这里还是要用到画二维码的插件库,只是我没有用这个插件库,qrcode.js
代码转成了ts
代码。
qrcode.js文件下载地址