qr-style
v1.1.0
Published
A QR code styling library
Downloads
15
Maintainers
Readme
qr-style
🇨🇳 中文 | English
生成二维码、设置二维码样式。
安装
npm install qr-style
使用
import QR from 'qr-style';
const qr = new QR({
text: '996',
canvas: document.createElement('canvas'),
});
document.body.appendChild(qr.canvas);
qr.text = 'hi~';
setTimeout(() => {
qr.text = 'hello';
}, 1000);
// -------------------------------------------------------------------------
const qr = new QR({
text: 'sleep',
onGenerated({ canvas }) {
document.body.appendChild(canvas);
},
});
qr.text = 'dinner';
qr.text = 'launch';
APIs
constructor
export type OnGenerated = (options: {
qr: QR;
canvas: HTMLCanvasElement;
svg: SVGElement;
}) => void;
export interface QROptions {
// 二维码编码内容
text: string;
// 二维码类型,默认 canvas
type?: 'canvas' | 'svg';
// 二维码配置,参考 toJSON 方法的返回值
qrOptions?: Partial<QR>;
// 二维码生成后回调,任意配置被修改都会重新生成二维码
onGenerated?: OnGenerated;
// 是否启用 utf8 编码,默认 true
utf8Enabled?: boolean;
// 二维码生成以及更新后绘制在这个canvas上
canvas?: HTMLCanvasElement;
}
示例:
const qr = new QR({
text: '996',
qrOptions: {
// 背景色相关配置
backgroundColor: {
color: '#ff0000',
},
},
type: 'canvas',
onGenerated: ({ canvas }) => {
console.log('onGenerated');
document.body.appendChild(canvas);
},
});
// -------------------------------------------------------------------------
const qr = new QR({
text: '996',
canvas: document.getElementById('canvas'),
});
// 二维码生成后会更新到传入的canvas上
qr.text = 'hi~';
属性
所有属性设置后会直接重新生成二维码。
const qr = new QR({
text: 'foo',
});
text
二维码编码内容
qr.text = 'bar';
errorCorrectionLevel
二维码错误纠正等级,可选值:
- L
- M
- Q
- H
qr.errorCorrectionLevel = 'L';
version
码等级,可选值:
- 0-40,0 会自动计算
qr.version = 0;
height
二维码高度
qr.height = 300;
width
二维码宽度
qr.width = 300;
type
生成的类型,可选值:
- canvas
- svg
qr.type = 'svg';
mode
编码类型,可选值:
- Numeric
- Alphanumeric
- Byte
- Kanji
qr.mode = 'Numeric';
margin
二维码边距
qr.margin = 10;
image 中间图相关
image
中间图URL,默认会放在正中间
qr.image = 'https://example.com/image.png';
*imageWidth
无效,后续实现
图片宽度,暂时无效,qr-code-styling 提供的宽度是0-0.5,后续会扩展成px。
imageMargin
图片边距。
qr.imageMargin = 10;
*imageStyle
无效,后续实现
图片样式,可选值:
- normal
- circle
- rounded
- square
qr.imageStyle = 'rounded';
*imageShadow
无效,后续实现
图片阴影,可选值:
- none
- l1
- l2
- l3
- l4
- l5
CSS box-shadow
样式
qr.imageShadow = 'l1';
*imageShadowColor
无效,后续实现
图片阴影颜色
qr.imageShadowColor = '#ff0000';
hideBehindImageDots
是否隐藏图片背后的码点
qr.hideBehindImageDots = true;
saveImageAsBase64BlobWhenTypeIsSVG
二维码类型为 svg 时,是否保存为 base64 blob,nodejs环境下生效。
qr.saveImageAsBase64BlobWhenTypeIsSVG = true;
imageCrossOrigin
图片跨域,默认 anonymous
,可选值:
- anonymous
- use-credentials
qr.imageCrossOrigin = 'anonymous';
backgroundColor
二维码背景色,支持图片、渐变、纯色,参考 ElementColor。
qr.backgroundColor.color = '#ff0000';
dotsStyle
码点样式,可选值:
- square
- dots
- classy
- classy-rounded
- square
- extra-rounded
以下可选值只在canvas生效:
- rhombus
- thin-rhombus
- thin-dots
- this-square
- square-rounded
部份码点样式会导致扫码困难,主要是难以用码眼定位二维码,可以结合码眼样式一起调整。
qr.dotsStyle = 'classy';
dotsColor
码点颜色,参考 ElementColor。
qr.dotsColor.color = '#ff0000';
cornersDotStyle
码眼样式,可选值:
- square
- dot
qr.cornersDotStyle = 'dot';
cornersDotColor
码眼颜色,参考 ElementColor。
qr.cornersDotColor.color = '#ff0000';
cornersSquareStyle
码眼样式,可选值:
- square
- dot
- extra-rounded
qr.cornersSquareStyle = 'square';
cornersSquareColor
码眼颜色,参考 ElementColor。
qr.cornersSquareColor.color = '#ff0000';
方法
getRawData
返回二维码图片的 blob 或者 buffer(nodejs)。
// 'png' | 'jpeg' | 'webp' | 'svg'
qr.getRawData('png');
saveAs
保存二维码图片到本地。
// 'png' | 'jpeg' | 'webp' | 'svg'
qr.saveAs('qr');
qr.saveAs('qr', 'jpeg');
merge
合并二维码配置,会覆盖当前二维码配置,并重新生成二维码。
qr.merge({
text: 'foo',
});
toJSON
返回二维码配置,可以用于 merge
方法,也可以在实例化时传给 qrOptions
参数。
const qrOptions = qr.toJSON();
fromJSON
从二维码配置中恢复二维码实例,和merge的作用一致,只是个别名。
qr.fromJSON({
text: 'foo',
});
waitForSetting
适用于要设置一批配置的场景,过程中会暂停生成。
// bad ways
qr.text = 'foo';
qr.errorCorrectionLevel = 'L';
qr.version = 0;
qr.height = 300;
qr.width = 300;
qr.type = 'svg';
qr.mode = 'Numeric';
// good ways
qr.waitForSetting((qr) => {
qr.text = 'foo';
qr.errorCorrectionLevel = 'L';
qr.version = 0;
qr.height = 300;
qr.width = 300;
qr.type = 'svg';
qr.mode = 'Numeric';
});
也可以用merge代替
qr.merge({
text: 'foo',
errorCorrectionLevel: 'L',
version: 0,
height: 300,
width: 300,
type: 'svg',
mode: 'Numeric',
});
getters
canvas
渲染二维码的canvas元素.
const canvas = qr.canvas;
svg
渲染二维吗的svg元素。
const svg = qr.svg;
事件
onGenerated
二维码生成后回调,任意配置被修改都会重新生成二维码。
qr.onGenerated = () => {
console.log('onGenerated');
};
// after setting text, will call onGenerated
qr.text = 'foo';
ElementColor
图片暂不支持,后续实现
用于维护颜色信息,支持渐变、纯色、图片。
// 签名
interface ElementColor {
colorType: 'solid' | 'gradient' | 'image';
color: string;
gradient: Gradient;
image: string;
imageOpacity: number;
}
interface Gradient {
// from to
gradientColor: [string, string];
gradientDirection: 'toRight' | 'toLeft' | 'toTop' | 'toBottom' | 'toTopRight' | 'toTopLeft' | 'toBottomRight' | 'toBottomLeft';
gradientType: 'linear' | 'radial';
}
设置颜色
qr.backgroundColor.color = '#ff0000';
设置渐变色
qr.backgroundColor.colorType = 'gradient';
qr.backgroundColor.gradient.gradientType = 'linear';
qr.backgroundColor.gradient.gradientColor = ['#ff0000', '#00ff00'];
qr.backgroundColor.gradient.gradientDirection = 'toRight';
TODOs
- [√] 更多码点样式
- [ ] 背景支持图片
- [ ] 更多码眼样式
- [ ] 码点支持图片
- [ ] 支持中间图尺寸
- [ ] 支持中间其他样式(投影、裁剪样式、图片位置等)
- [ ] 支持添加边框
- [ ] 支持更多层渐变色
- [ ] 支持中间文字
- [ ] 支持二维码旋转
- [ ] 完善Node.js支持
鸣谢
项目基于 qr-code-styling,扩展项目qr-code-styling-extra。