From 55fc72b34e129fbea9ab4a75965c5155bfc8e625 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Tue, 5 May 2020 21:00:59 +0800
Subject: [PATCH] =?UTF-8?q?=E6=A0=B7=E5=BC=8F=E5=90=88=E5=B9=B6?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/QrRendererBase.js | 22 ++++-
src/components/QrRendererRandRound.js | 127 ++++++++++++++++++++++++++
src/components/QrRendererRound.js | 99 ++++++++++++++------
src/components/Qrcode.js | 3 +-
4 files changed, 219 insertions(+), 32 deletions(-)
create mode 100644 src/components/QrRendererRandRound.js
diff --git a/src/components/QrRendererBase.js b/src/components/QrRendererBase.js
index 97bf7ee..e5ee63f 100644
--- a/src/components/QrRendererBase.js
+++ b/src/components/QrRendererBase.js
@@ -18,6 +18,9 @@ function listPoint(props) {
let id = 0;
console.log(posType)
+ const vw = [3, -3];
+ const vh = [3, -3];
+
if (size <= 0) size = 1.0
for (let x = 0; x < nCount; x++) {
@@ -29,6 +32,8 @@ function listPoint(props) {
pointList.push()
else if (type == 1)
pointList.push()
+ else if (type == 2)
+ pointList.push()
}
else if (typeTable[x][y] == QRPointType.POS_CENTER) {
if (posType == 0) {
@@ -36,6 +41,15 @@ function listPoint(props) {
} else if (posType == 1) {
pointList.push()
pointList.push()
+ } else if (posType == 2) {
+ pointList.push()
+ pointList.push()
+ for (let w = 0; w < vw.length; w++) {
+ pointList.push()
+ }
+ for (let h = 0; h < vh.length; h++) {
+ pointList.push()
+ }
}
}
else if (typeTable[x][y] == QRPointType.POS_OTHER) {
@@ -48,6 +62,8 @@ function listPoint(props) {
pointList.push()
else if (type == 1)
pointList.push()
+ else if (type == 2)
+ pointList.push()
}
}
}
@@ -72,7 +88,8 @@ class QrRendererBase extends React.Component {
default: 0,
choices: [
"矩形",
- "圆形"
+ "圆形",
+ "随机"
]
},
{
@@ -88,7 +105,8 @@ class QrRendererBase extends React.Component {
default: 0,
choices: [
"矩形",
- "圆形"
+ "圆形",
+ "行星",
]
},
]
diff --git a/src/components/QrRendererRandRound.js b/src/components/QrRendererRandRound.js
new file mode 100644
index 0000000..3e13998
--- /dev/null
+++ b/src/components/QrRendererRandRound.js
@@ -0,0 +1,127 @@
+import React from "react";
+import './Qrcode.css'
+import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
+import {rand} from "../utils/util";
+
+function listPoint(props) {
+ if (!props.qrcode) return []
+
+ const qrcode = props.qrcode;
+ const nCount = qrcode.getModuleCount();
+ const typeTable = getTypeTable(qrcode);
+ const pointList = new Array(nCount);
+
+ let type = props.params[0];
+ let size = props.params[1] / 100;
+ let opacity = props.params[2] / 100;
+ let posType = props.params[3];
+ let id = 0;
+ console.log(posType)
+
+ const vw = [3, -3];
+ const vh = [3, -3];
+
+ if (size <= 0) size = 1.0
+
+ for (let x = 0; x < nCount; x++) {
+ for (let y = 0; y < nCount; y++) {
+ if (qrcode.isDark(x, y) == false) continue;
+
+ if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) {
+ if (type == 0)
+ pointList.push()
+ else if (type == 1)
+ pointList.push()
+ else if (type == 2)
+ pointList.push()
+ }
+ else if (typeTable[x][y] == QRPointType.POS_CENTER) {
+ if (posType == 0) {
+ pointList.push();
+ } else if (posType == 1) {
+ pointList.push()
+ pointList.push()
+ } else if (posType == 2) {
+ pointList.push()
+ pointList.push()
+ for (let w = 0; w < vw.length; w++) {
+ pointList.push()
+ }
+ for (let h = 0; h < vh.length; h++) {
+ pointList.push()
+ }
+ }
+ }
+ else if (typeTable[x][y] == QRPointType.POS_OTHER) {
+ if (posType == 0) {
+ pointList.push();
+ }
+ }
+ else {
+ if (type == 0)
+ pointList.push()
+ else if (type == 1)
+ pointList.push()
+ else if (type == 2)
+ pointList.push()
+ }
+ }
+ }
+
+ return pointList;
+}
+
+function calViewBox(props) {
+ if (!props.qrcode) return '0 0 0 0';
+
+ const nCount = props.qrcode.getModuleCount();
+ return String(-nCount / 5) + ' ' + String(-nCount / 5) + ' ' + String(nCount + nCount / 5 * 2) + ' ' + String(nCount + nCount / 5 * 2);
+}
+
+class QrRendererRandRound extends React.Component {
+ constructor(props) {
+ super(props);
+ if (this.props.setParamInfo) {
+ this.props.setParamInfo([
+ {
+ key: '信息点样式',
+ default: 2,
+ choices: [
+ "矩形",
+ "圆形",
+ "随机"
+ ]
+ },
+ {
+ key: '信息点缩放',
+ default: 80
+ },
+ {
+ key: '信息点不透明度',
+ default: 100,
+ },
+ {
+ key: '定位点样式',
+ default: 2,
+ choices: [
+ "矩形",
+ "圆形",
+ "行星",
+ ]
+ },
+ ]
+ );
+ }
+ }
+
+ render() {
+ return (
+
+ );
+ }
+}
+
+export default QrRendererRandRound
diff --git a/src/components/QrRendererRound.js b/src/components/QrRendererRound.js
index 1ad1214..164498d 100644
--- a/src/components/QrRendererRound.js
+++ b/src/components/QrRendererRound.js
@@ -1,7 +1,7 @@
import React from "react";
-import {srand, rand} from "../utils/util";
import './Qrcode.css'
import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
+import {rand} from "../utils/util";
function listPoint(props) {
if (!props.qrcode) return []
@@ -9,30 +9,61 @@ function listPoint(props) {
const qrcode = props.qrcode;
const nCount = qrcode.getModuleCount();
const typeTable = getTypeTable(qrcode);
- const pointList = [];
+ const pointList = new Array(nCount);
+
+ let type = props.params[0];
+ let size = props.params[1] / 100;
+ let opacity = props.params[2] / 100;
+ let posType = props.params[3];
+ let id = 0;
+ console.log(posType)
+
const vw = [3, -3];
const vh = [3, -3];
- let id = 0;
+ if (size <= 0) size = 1.0
+
for (let x = 0; x < nCount; x++) {
for (let y = 0; y < nCount; y++) {
- if (qrcode.isDark(x, y) == false) continue;
+ if (qrcode.isDark(x, y) === false) continue;
- if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) {
- pointList.push()
+ if (typeTable[x][y] === QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) {
+ if (type == 0)
+ pointList.push()
+ else if (type == 1)
+ pointList.push()
+ else if (type == 2)
+ pointList.push()
}
else if (typeTable[x][y] == QRPointType.POS_CENTER) {
- pointList.push()
- pointList.push()
- for (let w = 0; w < vw.length; w++) {
- pointList.push()
- }
- for (let h = 0; h < vh.length; h++) {
- pointList.push()
+ if (posType == 0) {
+ pointList.push();
+ } else if (posType == 1) {
+ pointList.push()
+ pointList.push()
+ } else if (posType == 2) {
+ pointList.push()
+ pointList.push()
+ for (let w = 0; w < vw.length; w++) {
+ pointList.push()
+ }
+ for (let h = 0; h < vh.length; h++) {
+ pointList.push()
+ }
}
}
- else if (typeTable[x][y] != QRPointType.POS_OTHER) {
- pointList.push()
+ else if (typeTable[x][y] == QRPointType.POS_OTHER) {
+ if (posType == 0) {
+ pointList.push();
+ }
+ }
+ else {
+ if (type == 0)
+ pointList.push()
+ else if (type == 1)
+ pointList.push()
+ else if (type == 2)
+ pointList.push()
}
}
}
@@ -53,21 +84,31 @@ class QrRendererRound extends React.Component {
if (this.props.setParamInfo) {
this.props.setParamInfo([
{
- key: 'Choice 1',
- default: 1
- },
- {
- key: 'Choice 2',
- default: 100
- },
- {
- key: 'Select 1',
- default: 0,
+ key: '信息点样式',
+ default: 1,
choices: [
- "Option 1",
- "Option 2"
+ "矩形",
+ "圆形",
+ "随机"
]
- }
+ },
+ {
+ key: '信息点缩放',
+ default: 50
+ },
+ {
+ key: '信息点不透明度',
+ default: 30,
+ },
+ {
+ key: '定位点样式',
+ default: 1,
+ choices: [
+ "矩形",
+ "圆形",
+ "行星",
+ ]
+ },
]
);
}
@@ -75,7 +116,7 @@ class QrRendererRound extends React.Component {
render() {
return (
-
diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index ceef9b0..1ec9493 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -11,6 +11,7 @@ import logo from '../qrbtf-logo.svg';
import QrItem from "./QrItem";
import QrRendererBase from "./QrRendererBase";
import QrRendererRound from "./QrRendererRound";
+import QrRendererRandRound from "./QrRendererRandRound";
import QrRendererBlank from "./QrRendererBlank";
import QrRendererRandRect from "./QrRendererRandRect";
@@ -26,8 +27,8 @@ const currentYear = date.getFullYear();
const styleList = [
{value: "A1", renderer: QrRendererBase},
{value: "A2", renderer: QrRendererRound},
+ {value: "A3", renderer: QrRendererRandRound},
{value: "B1", renderer: QrRendererRandRect},
- {value: "B2", renderer: QrRendererBlank},
{value: "C1", renderer: QrRendererBlank},
{value: "C2", renderer: QrRendererBlank},
{value: "D1", renderer: QrRendererBlank},