Reconstruct code

This commit is contained in:
CPunisher 2020-05-09 00:04:36 +08:00
parent c680be15a1
commit 0034589837
27 changed files with 741 additions and 486 deletions

View File

@ -10,9 +10,9 @@ export const changeStyle = index => ({
index index
}) })
export const createParam = (rendererIndex, params) => ({ export const createParam = (paramInfo, paramValue) => ({
type: actionTypes.CREATE_PARAM, type: actionTypes.CREATE_PARAM,
rendererIndex, params paramInfo, paramValue
}) })
export const changeParam = (rendererIndex, paramIndex, value) => ({ export const changeParam = (rendererIndex, paramIndex, value) => ({

View File

@ -1,10 +0,0 @@
import React from "react";
import './Qrcode.css'
import {defaultRenderer} from "../utils/util";
export default class QrRendererBlank extends React.Component {
render() {
return defaultRenderer(this.props.qrcode);
}
}

View File

@ -1,113 +0,0 @@
import React from "react";
import './Qrcode.css'
import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
import {rand, defaultRenderer} 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;
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(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
else if (type == 1)
pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
else if (type == 2)
pointList.push(<circle key={id++} opacity={opacity} fill="black" cx={x + 0.5} cy={y + 0.5} r={size / 2} />)
}
else if (typeTable[x][y] == QRPointType.POS_CENTER) {
if (posType == 0) {
pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
} else if (posType == 1) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
pointList.push(<circle key={id++} fill="none" strokeWidth="1" stroke="black" cx={x + 0.5} cy={y + 0.5} r={3} />)
} else if (posType == 2) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
pointList.push(<circle key={id++} fill="none" strokeWidth="0.15" strokeDasharray="0.5,0.5" stroke="black" cx={x + 0.5} cy={y + 0.5} r={3} />)
for (let w = 0; w < vw.length; w++) {
pointList.push(<circle key={id++} fill="black" cx={x + vw[w] + 0.5} cy={y + 0.5} r={0.5} />)
}
for (let h = 0; h < vh.length; h++) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + vh[h] + 0.5} r={0.5} />)
}
}
}
else if (typeTable[x][y] == QRPointType.POS_OTHER) {
if (posType == 0) {
pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
}
}
else {
if (type == 0)
pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
else if (type == 1)
pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
else if (type == 2)
pointList.push(<circle opacity={opacity} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={0.5 * rand(0.33,1.0)} />)
}
}
}
return pointList;
}
export default 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 defaultRenderer(this.props.qrcode, listPoint(this.props));
}
}

View File

@ -17,70 +17,7 @@ import QrRendererBlank from "./QrRendererBlank";
import QrRendererRandRect from "./QrRendererRandRect"; import QrRendererRandRect from "./QrRendererRandRect";
import QrRendererDSJ from "./QrRendererDSJ"; import QrRendererDSJ from "./QrRendererDSJ";
const styleList = [
{value: "A1", renderer: QrRendererBase},
{value: "A2", renderer: QrRendererRound},
{value: "A3", renderer: QrRendererRandRound},
{value: "SP — 1", renderer: QrRendererDSJ},
{value: "SP — 2", renderer: QrRendererRandRect},
{value: "C2", renderer: QrRendererBlank},
{value: "D1", renderer: QrRendererBlank},
{value: "D2", renderer: QrRendererBlank},
];
class Qrcode extends React.Component { class Qrcode extends React.Component {
paramInfoBuffer;
paramValueBuffer;
constructor(props) {
super(props);
this.state = {
text: '',
selectedIndex: 0,
options: {text: ''},
qrcode: null,
paramInfo: [],
paramValue: [],
correctLevel: 0
};
this.paramInfoBuffer = new Array(16).fill(new Array(16));
this.paramValueBuffer = new Array(16).fill(new Array(16));
}
componentDidMount() {
const text = 'https://qrbtf.com/';
this.setState({
paramInfo: this.paramInfoBuffer,
paramValue: this.paramValueBuffer,
text: text,
options: {text: text},
qrcode: getQrcodeData({text: text, correctLevel: this.state.correctLevel})
});
}
setParamInfo = (index) => {
const _this = this;
return function (params) {
_this.paramInfoBuffer[index] = params;
_this.paramValueBuffer[index] = params.map(p => {
return p.default
});
}
}
setParamValue = (valueIndex, value) => {
const newValue = this.state.paramValue.slice();
newValue[this.state.selectedIndex][valueIndex] = value;
this.setState({paramValue: newValue});
}
handleCreate = (e) => {
let text = this.state.text
if (text.length <= 0) text = 'https://qrbtf.com/';
this.setState({text: text, options: {text: text}, qrcode: getQrcodeData({text: text, correctLevel: this.state.correctLevel})});
if (e) e.target.blur();
}
downloadSvg = (e) => { downloadSvg = (e) => {
const style = styleList[this.state.selectedIndex] const style = styleList[this.state.selectedIndex]
@ -93,75 +30,6 @@ class Qrcode extends React.Component {
const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[this.state.selectedIndex]}) const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[this.state.selectedIndex]})
saveImg(style.value, ReactDOMServer.renderToString(el), 1500, 1500) saveImg(style.value, ReactDOMServer.renderToString(el), 1500, 1500)
} }
renderParamEditor = (info, index) => {
if (info.choices) {
return (
<select
className="Qr-select"
key={"select_" + this.state.selectedIndex + "_" + index}
value={this.state.paramValue[this.state.selectedIndex][index]}
onChange={(e) => this.setParamValue(index, e.target.value)}>
{
info.choices.map((choice, index) => {
return (
<option key={"option_" + this.state.selectedIndex + "_" + index}
value={index}>
{choice}
</option>
);
})
}
</select>
);
}
else {
return (
<input
type="number"
key={"input_" + this.state.selectedIndex + "_" + index}
className="Qr-input small-input"
placeholder="10"
defaultValue={this.state.paramValue[this.state.selectedIndex][index]}
onBlur={(e) => this.setParamValue(index, e.target.value)}
onKeyPress={(e) => {if(e.key === 'Enter') {this.setParamValue(index, e.target.value); e.target.blur()}}}/>
);
}
}
renderAdjustment = () => {
const target = this.state.paramInfo[this.state.selectedIndex];
if (target instanceof Array) {
return target.map((info, index) => {
return (
<tr key={"tr_" + index}>
<td key={"title_" + index}>{info.key}</td>
<td key={"editor_" + index}>{this.renderParamEditor(info, index)}</td>
</tr>
)
})
}
}
render() {
return (
<div></div>
// <div className="Qr-titled">
// <div className="Qr-Centered title-margin">
// <div className="Qr-s-title">Downloads</div>
// <p className="Qr-s-subtitle">下载二维码 — {styleList[this.state.selectedIndex].value}</p>
// </div>
// <div className="Qr-Centered">
// <div className="div-btn">
// <button className="dl-btn" onClick={this.downloadSvg}>SVG</button>
// <button className="dl-btn" onClick={this.downloadImg}>JPG</button>
// </div>
// <div id="wx-message"></div>
// </div>
//
// </div>
);
}
} }
export default Qrcode; export default Qrcode;

View File

@ -6,6 +6,8 @@ import Header from "../header/Header";
import PartInput from "./PartInput"; import PartInput from "./PartInput";
import PartStyles from "./PartStyles"; import PartStyles from "./PartStyles";
import PartMore from "./PartMore"; import PartMore from "./PartMore";
import PartParams from "./PartParams";
import PartDownload from "./PartDownload";
function App() { function App() {
return ( return (
@ -15,6 +17,8 @@ function App() {
<Header/> <Header/>
<PartInput/> <PartInput/>
<PartStyles/> <PartStyles/>
<PartParams/>
<PartDownload/>
<PartMore/> <PartMore/>
<Footer/> <Footer/>
</div> </div>

View File

@ -0,0 +1,21 @@
import React from 'react';
import './App.css';
const PartDownload = () => (
<div className="Qr-titled">
<div className="Qr-Centered title-margin">
<div className="Qr-s-title">Downloads</div>
<p className="Qr-s-subtitle">下载二维码</p>
</div>
<div className="Qr-Centered">
<div className="div-btn">
<button className="dl-btn">SVG</button>
<button className="dl-btn">JPG</button>
</div>
<div id="wx-message"></div>
</div>
</div>
)
export default PartDownload;

View File

@ -0,0 +1,39 @@
import React from 'react';
import './App.css';
import ParamListViewer from "../../containers/param/ParamListViewer";
const PartParams = () => (
<div className="Qr-titled-nobg">
<div className="Qr-Centered title-margin">
<div className="Qr-s-title">Parameters</div>
<p className="Qr-s-subtitle">参数调整</p>
</div>
<div className="Qr-Centered">
<div className="Qr-div-table">
<table className="Qr-table">
<tbody>
{/*<tr>*/}
{/* <td>容错率</td>*/}
{/* <td>*/}
{/* <select*/}
{/* className="Qr-select"*/}
{/* value={this.state.correctLevel}*/}
{/* onChange={(e) => {*/}
{/* this.setState({correctLevel: parseInt(e.target.value)}, () => this.handleCreate())*/}
{/* }}>*/}
{/* <option value={1}>7%</option>*/}
{/* <option value={0}>15%</option>*/}
{/* <option value={3}>25%</option>*/}
{/* <option value={2}>30%</option>*/}
{/* </select>*/}
{/* </td>*/}
{/*</tr>*/}
<ParamListViewer/>
</tbody>
</table>
</div>
</div>
</div>
)
export default PartParams;

View File

@ -9,7 +9,7 @@ const PartStyles = () => (
<p className="Qr-s-subtitle">点击选择样式</p> <p className="Qr-s-subtitle">点击选择样式</p>
</div> </div>
<div className="Qr-s"> <div className="Qr-s">
<StyleListViewer/> {React.createElement(StyleListViewer())}
</div> </div>
</div> </div>
) )

View File

@ -0,0 +1,39 @@
import React from 'react';
import {ParamTypes} from "../../constant/ParamTypes";
import PropTypes from "prop-types"
import ParamTextViewer from "../../containers/param/ParamTextViewer";
import ParamSelectViewer from "../../containers/param/ParamSelectViewer";
const ParamList = ({ rendererIndex, paramInfo }) => (
paramInfo.map((item, paramIndex) => {
switch (item.type) {
case ParamTypes.TEXT_EDITOR: {
return (
<tr>
<td>{item.key}</td>
<td>
<ParamTextViewer rendererIndex={rendererIndex} paramIndex={paramIndex}/>
</td>
</tr>
)
}
case ParamTypes.SELECTOR: {
return (
<tr>
<td>{item.key}</td>
<td>
<ParamSelectViewer rendererIndex={rendererIndex} paramIndex={paramIndex}/>
</td>
</tr>
)
}
}
})
)
ParamList.propTypes = {
rendererIndex: PropTypes.number.isRequired,
paramInfo: PropTypes.array
}
export default ParamList;

View File

@ -0,0 +1,31 @@
import React from 'react';
import PropTypes from 'prop-types'
import '../Qrcode.css';
const ParamList = ({ rendererIndex, paramIndex, value, info, onChange }) => (
<select
className="Qr-select"
key={"select_" + rendererIndex + "_" + paramIndex}
value={value}
onChange={onChange}>
{
info.choices.map((choice, index) => {
return (
<option key={"option_" + rendererIndex + "_" + paramIndex + "_" + index } value={index}>
{choice}
</option>
);
})
}
</select>
)
ParamList.propTypes = {
rendererIndex: PropTypes.number.isRequired,
paramIndex: PropTypes.number.isRequired,
value: PropTypes.number.isRequired,
info: PropTypes.object.isRequired,
onChange: PropTypes.func.isRequired
}
export default ParamList;

View File

@ -0,0 +1,25 @@
import React from 'react';
import PropTypes from 'prop-types'
import '../Qrcode.css';
const ParamText = ({ rendererIndex, paramIndex, value, onBlur, onKeyPress }) => (
<input
type="number"
key={"input_" + rendererIndex + "_" + paramIndex}
className="Qr-input small-input"
placeholder="10"
defaultValue={value}
onBlur={onBlur}
onKeyPress={onKeyPress}
/>
)
ParamText.propTypes = {
rendererIndex: PropTypes.number.isRequired,
paramIndex: PropTypes.number.isRequired,
value: PropTypes.string.isRequired,
onBlur: PropTypes.func.isRequired,
onKeyPress: PropTypes.func.isRequired
}
export default ParamText;

View File

@ -0,0 +1,75 @@
import React, { useEffect } from "react";
import {defaultViewBox} from "../../utils/util";
import {ParamTypes} from "../../constant/ParamTypes";
import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoints(qrcode, params) {
if (!qrcode) return []
const nCount = qrcode.getModuleCount();
const typeTable = getTypeTable(qrcode);
const pointList = new Array(nCount);
let size = 1.001;
let size2 = 1.001;
let height = params[0];
let height2 = params[1];
let id = 0;
const X = [-Math.sqrt(3)/2, 1/2];
const Y = [ Math.sqrt(3)/2, 1/2];
const Z = [0, 0];
const matrixString = 'matrix(' + String(X[0]) + ', ' + String(X[1]) + ', ' + String(Y[0]) + ', ' + String(Y[1]) + ', ' + String(Z[0]) + ', ' + String(Z[1]) + ')'
if (height <= 0) height = 1.0;
if (height2 <= 0) height2 = 1.0;
for (let x = 0; x < nCount; x++) {
for (let y = 0; y < nCount; y++) {
if (qrcode.isDark(x, y) == false) continue;
else if (typeTable[x][y] == QRPointType.POS_OTHER || typeTable[x][y] == QRPointType.POS_CENTER) {
pointList.push(<rect width={size2} height={size2} key={id++} fill="#FF7F89" x={x + (1 - size2)/2} y={y + (1 - size2)/2} transform={matrixString}/>);
pointList.push(<rect width={height2} height={size2} key={id++} fill="#FFEBF3" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size2)/2 + size2)+','+String(y + (1 - size2)/2)+') '+'skewY(45) '}/>);
pointList.push(<rect width={size2} height={height2} key={id++} fill="#FFD7D9" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size2)/2)+','+String(y + size2 + (1 - size2)/2)+') '+'skewX(45) '}/>);
}
else {
pointList.push(<rect width={size} height={size} key={id++} fill="#FF7F89" x={x + (1 - size)/2} y={y + (1 - size)/2} transform={matrixString}/>);
pointList.push(<rect width={height} height={size} key={id++} fill="#FFEBF3" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size)/2 + size)+','+String(y + (1 - size)/2)+') '+'skewY(45) '}/>);
pointList.push(<rect width={size} height={height} key={id++} fill="#FFD7D9" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size)/2)+','+String(y + size + (1 - size)/2)+') '+'skewX(45) '}/>);
}
}
}
return pointList;
}
function getParamInfo() {
return [
{
type: ParamTypes.TEXT_EDITOR,
key: '柱体高度',
default: 0.5,
},
{
type: ParamTypes.TEXT_EDITOR,
key: '定位点柱体高度',
default: 0.5,
},
];
}
const Renderer25D = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
</svg>
)
}
export default Renderer25D

View File

@ -1,22 +1,71 @@
import React from "react"; import React, { useEffect } from "react";
import {defaultViewBox} from "../../utils/util"; import {defaultViewBox, rand} from "../../utils/util";
import {ParamTypes} from "../../constant/ParamTypes"; import {ParamTypes} from "../../constant/ParamTypes";
import {createParam} from "../../actions"; import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoints(qrcode, params) { function listPoints(qrcode, params) {
if (!qrcode) return[] if (!qrcode) return []
const nCount = qrcode.getModuleCount(); const nCount = qrcode.getModuleCount();
const pointList = [] const typeTable = getTypeTable(qrcode);
let id = 0 const pointList = new Array(nCount);
let type = params[0];
let size = params[1] / 100;
let opacity = params[2] / 100;
let posType = params[3];
let id = 0;
const vw = [3, -3];
const vh = [3, -3];
if (size <= 0) size = 1.0
for (let x = 0; x < nCount; x++) { for (let x = 0; x < nCount; x++) {
for (let y = 0; y < nCount; y++) { for (let y = 0; y < nCount; y++) {
if (qrcode.isDark(x, y)) { if (qrcode.isDark(x, y) == false) continue;
pointList.push(<rect key={id++} width={1} height={1} fill={"black"} x={x} y={y}/>)
if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) {
if (type == 0)
pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
else if (type == 1)
pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
else if (type == 2)
pointList.push(<circle key={id++} opacity={opacity} fill="black" cx={x + 0.5} cy={y + 0.5} r={size / 2} />)
}
else if (typeTable[x][y] == QRPointType.POS_CENTER) {
if (posType == 0) {
pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
} else if (posType == 1) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
pointList.push(<circle key={id++} fill="none" strokeWidth="1" stroke="black" cx={x + 0.5} cy={y + 0.5} r={3} />)
} else if (posType == 2) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
pointList.push(<circle key={id++} fill="none" strokeWidth="0.15" strokeDasharray="0.5,0.5" stroke="black" cx={x + 0.5} cy={y + 0.5} r={3} />)
for (let w = 0; w < vw.length; w++) {
pointList.push(<circle key={id++} fill="black" cx={x + vw[w] + 0.5} cy={y + 0.5} r={0.5} />)
}
for (let h = 0; h < vh.length; h++) {
pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + vh[h] + 0.5} r={0.5} />)
}
}
}
else if (typeTable[x][y] == QRPointType.POS_OTHER) {
if (posType == 0) {
pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
}
}
else {
if (type == 0)
pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
else if (type == 1)
pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
else if (type == 2)
pointList.push(<circle opacity={opacity} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={0.5 * rand(0.33,1.0)} />)
} }
} }
} }
return pointList; return pointList;
} }
@ -55,23 +104,17 @@ function getParamInfo() {
]; ];
} }
export default class RendererBase extends React.Component { const RendererBase = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
constructor(props) { return (
super(props); <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
} xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
componentDidMount() { </svg>
this.props.setParamInfo(this.props.rendererIndex, getParamInfo()) )
}
render() {
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(this.props.qrcode, this.props.params)}
</svg>
)
}
} }
export default RendererBase

View File

@ -1,31 +1,25 @@
import React from "react"; import React, { useEffect } from "react";
import {defaultViewBox} from "../../utils/util"; import {defaultViewBox} from "../../utils/util";
function listPoints(qrcode, params) { function listPoints(qrcode, params) {
if (!qrcode) return[]
return [] return []
} }
function getParamInfo() { function getParamInfo() {
return [] return [];
} }
export default class RendererBlank extends React.Component { const RenderBlank = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
constructor(props) { return (
super(props); <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
} xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
componentDidMount() { </svg>
} )
render() {
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(this.props.qrcode, this.props.params)}
</svg>
)
}
} }
export default RenderBlank

View File

@ -1,21 +1,20 @@
import React from "react"; import React, { useEffect } from "react";
import './Qrcode.css' import {defaultViewBox} from "../../utils/util";
import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; import {ParamTypes} from "../../constant/ParamTypes";
import {defaultRenderer, rand} from "../utils/util"; import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoint(props) { function listPoints(qrcode, params) {
if (!props.qrcode) return [] if (!qrcode) return []
const qrcode = props.qrcode;
const nCount = qrcode.getModuleCount(); const nCount = qrcode.getModuleCount();
const typeTable = getTypeTable(qrcode); const typeTable = getTypeTable(qrcode);
const pointList = []; const pointList = [];
const g1 = []; const g1 = [];
const g2 = []; const g2 = [];
let width2 = props.params[0] / 100; let width2 = params[0] / 100;
let width1 = props.params[1] / 100; let width1 = params[1] / 100;
let posType = props.params[2]; let posType = params[2];
let id = 0; let id = 0;
if (width2 <= 0) width2 = 80; if (width2 <= 0) width2 = 80;
@ -158,34 +157,41 @@ function listPoint(props) {
return pointList; return pointList;
} }
export default class QrRendererDSJ extends React.Component { function getParamInfo() {
constructor(props) { return [
super(props); {
if (this.props.setParamInfo) { type: ParamTypes.TEXT_EDITOR,
this.props.setParamInfo([ key: '信息点缩放',
{ default: 70,
key: '信息点缩放', },
default: 70, {
}, type: ParamTypes.TEXT_EDITOR,
{ key: 'x 宽度',
key: 'x 宽度', default: 70,
default: 70, },
}, {
{ type: ParamTypes.SELECTOR,
key: '定位点样式', key: '定位点样式',
default: 1, default: 1,
choices: [ choices: [
"矩形", "矩形",
"DSJ", "DSJ",
] ]
}, },
] ]
);
}
}
render() {
return defaultRenderer(this.props.qrcode, listPoint(this.props));
}
} }
const RenderDSJ = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
</svg>
)
}
export default RenderDSJ

File diff suppressed because one or more lines are too long

View File

@ -1,11 +1,11 @@
import React from "react"; import React, { useEffect } from "react";
import './Qrcode.css' import {defaultViewBox, rand} from "../../utils/util";
import {defaultRenderer, rand, randRGB} from "../utils/util"; import {ParamTypes} from "../../constant/ParamTypes";
import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoint(props) { function listPoints(qrcode, params) {
if (!props.qrcode) return [] if (!qrcode) return []
const qrcode = props.qrcode;
const nCount = qrcode.getModuleCount(); const nCount = qrcode.getModuleCount();
const pointList = []; const pointList = [];
let id = 0; let id = 0;
@ -38,9 +38,21 @@ function listPoint(props) {
return pointList; return pointList;
} }
export default class QrRendererRandRect extends React.Component { function getParamInfo() {
render() { return []
return defaultRenderer(this.props.qrcode, listPoint(this.props));
}
} }
const RendererRandRect = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
</svg>
)
}
export default RendererRandRect

View File

@ -1,20 +1,19 @@
import React from "react"; import React, { useEffect } from "react";
import './Qrcode.css' import {defaultViewBox, rand} from "../../utils/util";
import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; import {ParamTypes} from "../../constant/ParamTypes";
import {defaultRenderer, rand} from "../utils/util"; import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoint(props) { function listPoints(qrcode, params) {
if (!props.qrcode) return [] if (!qrcode) return []
const qrcode = props.qrcode;
const nCount = qrcode.getModuleCount(); const nCount = qrcode.getModuleCount();
const typeTable = getTypeTable(qrcode); const typeTable = getTypeTable(qrcode);
const pointList = new Array(nCount); const pointList = new Array(nCount);
let type = props.params[0]; let type = params[0];
let size = props.params[1] / 100; let size = params[1] / 100;
let opacity = props.params[2] / 100; let opacity = params[2] / 100;
let posType = props.params[3]; let posType = params[3];
let id = 0; let id = 0;
const vw = [3, -3]; const vw = [3, -3];
@ -70,44 +69,52 @@ function listPoint(props) {
return pointList; return pointList;
} }
export default class QrRendererBase extends React.Component { function getParamInfo() {
constructor(props) { return [
super(props); {
if (this.props.setParamInfo) { type: ParamTypes.SELECTOR,
this.props.setParamInfo([ key: '信息点样式',
{ default: 2,
key: '信息点样式', choices: [
default: 0, "矩形",
choices: [ "圆形",
"矩形", "随机"
"圆形", ]
"随机" },
] {
}, type: ParamTypes.TEXT_EDITOR,
{ key: '信息点缩放',
key: '信息点缩放', default: 80
default: 100 },
}, {
{ type: ParamTypes.TEXT_EDITOR,
key: '信息点不透明度', key: '信息点不透明度',
default: 100, default: 100,
}, },
{ {
key: '定位点样式', type: ParamTypes.SELECTOR,
default: 0, key: '定位点样式',
choices: [ default: 2,
"矩形", choices: [
"圆形", "矩形",
"行星", "圆形",
] "行星",
}, ]
] },
); ];
}
}
render() {
return defaultRenderer(this.props.qrcode, listPoint(this.props));
}
} }
const RendererRandRound = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
</svg>
)
}
export default RendererRandRound

View File

@ -1,20 +1,19 @@
import React from "react"; import React, { useEffect } from "react";
import './Qrcode.css' import {defaultViewBox, rand} from "../../utils/util";
import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; import {ParamTypes} from "../../constant/ParamTypes";
import {defaultRenderer, rand} from "../utils/util"; import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler";
function listPoint(props) { function listPoints(qrcode, params) {
if (!props.qrcode) return [] if (!qrcode) return []
const qrcode = props.qrcode;
const nCount = qrcode.getModuleCount(); const nCount = qrcode.getModuleCount();
const typeTable = getTypeTable(qrcode); const typeTable = getTypeTable(qrcode);
const pointList = new Array(nCount); const pointList = new Array(nCount);
let type = props.params[0]; let type = params[0];
let size = props.params[1] / 100; let size = params[1] / 100;
let opacity = props.params[2] / 100; let opacity = params[2] / 100;
let posType = props.params[3]; let posType = params[3];
let id = 0; let id = 0;
const vw = [3, -3]; const vw = [3, -3];
@ -70,44 +69,52 @@ function listPoint(props) {
return pointList; return pointList;
} }
export default class QrRendererRound extends React.Component { function getParamInfo() {
constructor(props) { return [
super(props); {
if (this.props.setParamInfo) { type: ParamTypes.SELECTOR,
this.props.setParamInfo([ key: '信息点样式',
{ default: 1,
key: '信息点样式', choices: [
default: 1, "矩形",
choices: [ "圆形",
"矩形", "随机"
"圆形", ]
"随机" },
] {
}, type: ParamTypes.TEXT_EDITOR,
{ key: '信息点缩放',
key: '信息点缩放', default: 50
default: 50 },
}, {
{ type: ParamTypes.TEXT_EDITOR,
key: '信息点不透明度', key: '信息点不透明度',
default: 30, default: 30,
}, },
{ {
key: '定位点样式', type: ParamTypes.SELECTOR,
default: 1, key: '定位点样式',
choices: [ default: 1,
"矩形", choices: [
"圆形", "矩形",
"行星", "圆形",
] "行星",
}, ]
] },
); ]
}
}
render() {
return defaultRenderer(this.props.qrcode, listPoint(this.props));
}
} }
const RendererRound = ({ qrcode, params, setParamInfo}) => {
useEffect(() => {
setParamInfo(getParamInfo());
}, [setParamInfo]);
return (
<svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
{listPoints(qrcode, params)}
</svg>
)
}
export default RendererRound

View File

@ -1,6 +1,6 @@
import React from "react";
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { genQRInfo } from "../actions"; import { genQRInfo } from "../actions";
import React from "react";
const InputText = ({ dispatch }) => ( const InputText = ({ dispatch }) => (
<div className="Qr-Centered"> <div className="Qr-Centered">

View File

@ -1,6 +1,4 @@
import React from "react";
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import {createParam} from "../actions";
const mapStateToProps = (state, ownProps) => ({ const mapStateToProps = (state, ownProps) => ({
qrcode: state.qrcode, qrcode: state.qrcode,
@ -8,8 +6,8 @@ const mapStateToProps = (state, ownProps) => ({
rendererIndex: ownProps.index rendererIndex: ownProps.index
}) })
const mapDispatchToProps = (dispatch) => ({ const mapDispatchToProps = (dispatch, ownProps) => ({
setParamInfo: (index, params) => dispatch(createParam(index, params)), setParamInfo: (params) => ownProps.setParamInfo(ownProps.index, params)
}) })
export default function Renderer(WrappedRenderer) { export default function Renderer(WrappedRenderer) {

View File

@ -1,27 +1,42 @@
import React from "react"; import {connect, useDispatch} from 'react-redux';
import { connect } from 'react-redux'; import {changeStyle, createParam} from "../actions";
import {changeStyle} from "../actions";
import StyleList from "../components/style/StyleList"; import StyleList from "../components/style/StyleList";
import Renderer from "./Renderer"; import Renderer from "./Renderer";
import RendererBlank from "../components/renderer/RendererBlank"; import RendererBlank from "../components/renderer/RendererBlank";
import RendererBase from "../components/renderer/RendererBase"; import RendererBase from "../components/renderer/RendererBase";
import RendererDSJ from "../components/renderer/RendererDSJ";
import RendererRound from "../components/renderer/RendererRound";
import RendererRandRound from "../components/renderer/RendererRandRound";
import RendererRandRect from "../components/renderer/RendererRandRect";
import Renderer25D from "../components/renderer/Renderer25D";
import RendererImage from "../components/renderer/RendererImage";
import * as React from "react";
const styles = [ const styles = [
{value: 'A1', renderer: RendererBase}, {value: "A1", renderer: RendererBase},
{value: 'A2', renderer: RendererBlank}, {value: "A2", renderer: RendererRound},
{value: 'B1', renderer: RendererBlank}, {value: "A3", renderer: RendererRandRound},
{value: 'B2', renderer: RendererBlank}, {value: "SP — 1", renderer: RendererDSJ},
{value: 'C1', renderer: RendererBlank}, {value: "SP — 2", renderer: RendererRandRect},
{value: 'C2', renderer: RendererBlank}, {value: "B1", renderer: Renderer25D},
{value: 'D1', renderer: RendererBlank}, {value: "C1", renderer: RendererImage},
{value: "D1", renderer: RendererBlank},
] ]
const paramInfoBuffer = new Array(16).fill(new Array(16))
const paramValueBuffer = new Array(16).fill(new Array(16))
const setParamInfo = (renderIndex, paramInfo) => {
paramInfoBuffer[renderIndex] = paramInfo
paramValueBuffer[renderIndex] = paramInfo.map(item => item.default)
}
const mapStateToProps = state => ({ const mapStateToProps = state => ({
styles: styles.map((style, index) => { styles: styles.map((style, index) => {
return { return {
value: style.value, value: style.value,
selected: state.selectedIndex == index, selected: state.selectedIndex == index,
renderer: React.createElement(Renderer(style.renderer), {index: index}) renderer: React.createElement(Renderer(style.renderer), {index: index, setParamInfo: setParamInfo})
} }
}) })
}) })
@ -30,7 +45,11 @@ const mapDispatchToProps = dispatch => ({
onSelected: index => dispatch(changeStyle(index)) onSelected: index => dispatch(changeStyle(index))
}) })
export default connect( const StyleListViewer = () => {
mapStateToProps, let res = connect(mapStateToProps, mapDispatchToProps)(StyleList)
mapDispatchToProps const dispatch = useDispatch()
)(StyleList) dispatch(createParam(paramInfoBuffer, paramValueBuffer))
return res;
}
export default StyleListViewer;

View File

@ -0,0 +1,9 @@
import { connect } from 'react-redux';
import ParamList from "../../components/param/ParamList";
const mapStateToProps = (state) => ({
rendererIndex: state.selectedIndex,
paramInfo: state.paramInfo[state.selectedIndex]
})
export default connect(mapStateToProps, null)(ParamList)

View File

@ -0,0 +1,18 @@
import { connect } from 'react-redux';
import {changeParam} from "../../actions";
import ParamSelect from "../../components/param/ParamSelect";
const mapStateToProps = (state, ownProps) => ({
rendererIndex: ownProps.rendererIndex,
paramIndex: ownProps.paramIndex,
value: state.paramValue[ownProps.rendererIndex][ownProps.paramIndex],
info: state.paramInfo[ownProps.rendererIndex][ownProps.paramIndex],
})
const mapDispatchToProps = (dispatch, ownProps) => ({
onChange: (e) => {
dispatch(changeParam(ownProps.rendererIndex, ownProps.paramIndex, e.target.value))
}
})
export default connect(mapStateToProps, mapDispatchToProps)(ParamSelect);

View File

@ -0,0 +1,21 @@
import { connect } from 'react-redux';
import ParamText from "../../components/param/ParamText";
import {changeParam} from "../../actions";
const mapStateToProps = (state, ownProps) => ({
rendererIndex: ownProps.rendererIndex,
paramIndex: ownProps.paramIndex,
value: state.paramValue[ownProps.rendererIndex][ownProps.paramIndex]
})
const mapDispatchToProps = (dispatch, ownProps) => ({
onBlur: (e) => dispatch(changeParam(ownProps.rendererIndex, ownProps.paramIndex, e.target.value)),
onKeyPress: (e) => {
if(e.key === 'Enter') {
dispatch(changeParam(ownProps.rendererIndex, ownProps.paramIndex, e.target.value));
e.target.blur()
}
}
})
export default connect(mapStateToProps, mapDispatchToProps)(ParamText);

View File

@ -1,4 +1,3 @@
import { combineReducers } from "redux";
import {getQrcodeData} from "../utils/qrcodeHandler"; import {getQrcodeData} from "../utils/qrcodeHandler";
import {actionTypes} from "../constant/ActionTypes"; import {actionTypes} from "../constant/ActionTypes";
@ -10,6 +9,7 @@ const initialState = {
} }
export default function appReducer(state = initialState, action) { export default function appReducer(state = initialState, action) {
console.log(state)
switch (action.type) { switch (action.type) {
case actionTypes.GENERATE_QR_INFO: { case actionTypes.GENERATE_QR_INFO: {
return Object.assign({}, state, { return Object.assign({}, state, {
@ -23,21 +23,20 @@ export default function appReducer(state = initialState, action) {
} }
case actionTypes.CREATE_PARAM: { case actionTypes.CREATE_PARAM: {
return Object.assign({}, state, { return Object.assign({}, state, {
paramInfo: Object.assign([], [...state.paramInfo], { paramInfo: action.paramInfo,
[action.rendererIndex]: action.params paramValue: action.paramValue
}), })
paramValue: Object.assign([], [...state.paramValue], {
[action.rendererIndex]: action.params.map(obj => obj.default)
})
});
} }
case actionTypes.CHANGE_PARAM: { case actionTypes.CHANGE_PARAM: {
return Object.assign({}, state, { return Object.assign({}, state, {
paramValue: Object.assign([], [...state.paramValue], { paramValue: state.paramValue.map((item, index) => {
[action.rendererIndex]: if (index != action.rendererIndex) {
Object.assign([], [...state.paramValue[action.rendererIndex]], { return item;
[action.paramIndex]: action.value }
})
const newItem = item.slice();
newItem[action.paramIndex] = action.value;
return newItem;
}) })
}); });
} }

View File

@ -1,5 +1,3 @@
import React from "react";
let seed = 0; let seed = 0;
export function srand(sd) { export function srand(sd) {