├── .gitignore ├── LICENSE ├── README.md ├── cloudfunctions ├── checkeText │ ├── config.json │ ├── index.js │ └── package.json ├── decode │ ├── config.json │ ├── index.js │ ├── package.json │ └── yarn.lock ├── deleteUserQR │ ├── config.json │ ├── index.js │ ├── package-lock.json │ └── package.json ├── getQRElementList │ ├── config.json │ ├── index.js │ ├── package-lock.json │ └── package.json ├── login │ ├── config.json │ ├── index.js │ ├── package.json │ └── yarn.lock ├── publishQR │ ├── config.json │ ├── index.js │ ├── package-lock.json │ └── package.json ├── reportQRLike │ ├── config.json │ ├── index.js │ ├── package-lock.json │ └── package.json ├── uploadImg │ ├── config.json │ ├── index.js │ ├── package-lock.json │ ├── package.json │ └── yarn.lock └── uploadQRElement │ ├── config.json │ ├── index.js │ ├── package-lock.json │ └── package.json ├── miniprogram ├── app.js ├── app.json ├── app.wxss ├── components │ ├── avatar │ │ ├── avatar.js │ │ ├── avatar.json │ │ ├── avatar.wxml │ │ └── avatar.wxss │ ├── btn │ │ ├── btn.js │ │ ├── btn.json │ │ ├── btn.wxml │ │ └── btn.wxss │ ├── cell │ │ ├── cell.js │ │ ├── cell.json │ │ ├── cell.wxml │ │ └── cell.wxss │ ├── contain │ │ ├── contain.js │ │ ├── contain.json │ │ ├── contain.wxml │ │ └── contain.wxss │ ├── icon │ │ ├── icon.js │ │ ├── icon.json │ │ ├── icon.wxml │ │ └── icon.wxss │ ├── missbox │ │ ├── missbox.js │ │ ├── missbox.json │ │ ├── missbox.wxml │ │ └── missbox.wxss │ ├── navbar │ │ ├── navbar.js │ │ ├── navbar.json │ │ ├── navbar.wxml │ │ └── navbar.wxss │ ├── page │ │ ├── page.js │ │ ├── page.json │ │ ├── page.wxml │ │ └── page.wxss │ ├── popbox │ │ ├── popbox.js │ │ ├── popbox.json │ │ ├── popbox.wxml │ │ └── popbox.wxss │ └── styleitem │ │ ├── styleitem.js │ │ ├── styleitem.json │ │ ├── styleitem.wxml │ │ └── styleitem.wxss ├── images │ ├── demo.png │ ├── img │ │ ├── bg.png │ │ ├── col2.png │ │ ├── col3.png │ │ ├── col4.png │ │ ├── eye.png │ │ ├── one.png │ │ ├── po7.png │ │ ├── re7.png │ │ ├── row2.png │ │ ├── row3.png │ │ ├── row4.png │ │ └── tian.png │ ├── logo.png │ └── upload │ │ ├── col2.png │ │ ├── col3.png │ │ ├── col4.png │ │ ├── demo.png │ │ ├── demo1.png │ │ ├── demo2.png │ │ ├── eye.png │ │ ├── grid.png │ │ ├── one.png │ │ ├── po7.png │ │ ├── re7.png │ │ ├── row2.png │ │ ├── row3.png │ │ ├── row4.png │ │ ├── rule-1.png │ │ ├── rule-2.png │ │ ├── rule-3.png │ │ ├── rule.png │ │ ├── rules.png │ │ └── tian.png ├── js │ ├── artqrcoed.js │ ├── common.js │ └── getqrcode.js ├── pages │ ├── checkqr │ │ ├── checkqr.js │ │ ├── checkqr.json │ │ ├── checkqr.wxml │ │ └── checkqr.wxss │ ├── designrule │ │ ├── designrule.js │ │ ├── designrule.json │ │ ├── designrule.wxml │ │ └── designrule.wxss │ ├── imgmade │ │ ├── imgmade.js │ │ ├── imgmade.json │ │ ├── imgmade.wxml │ │ └── imgmade.wxss │ ├── index │ │ ├── index.js │ │ ├── index.json │ │ ├── index.wxml │ │ └── index.wxss │ ├── myqrlist │ │ ├── myqrlist.js │ │ ├── myqrlist.json │ │ ├── myqrlist.wxml │ │ └── myqrlist.wxss │ ├── qrcode │ │ ├── qrcode.js │ │ ├── qrcode.json │ │ ├── qrcode.wxml │ │ └── qrcode.wxss │ ├── qrlist │ │ ├── qrlist.js │ │ ├── qrlist.json │ │ ├── qrlist.wxml │ │ └── qrlist.wxss │ ├── txtmade │ │ ├── txtmade.js │ │ ├── txtmade.json │ │ ├── txtmade.wxml │ │ └── txtmade.wxss │ └── upload │ │ ├── upload.js │ │ ├── upload.json │ │ ├── upload.wxml │ │ └── upload.wxss └── sitemap.json ├── package-lock.json ├── package.json ├── project.config.json ├── project.private.config.json └── readme ├── cover.png ├── toolcode.jpg ├── 上传.gif ├── 上传指引.gif ├── 图片生成.gif ├── 我的生成.gif ├── 我的素材.gif ├── 文字生成.gif ├── 流程.mp4 ├── 社区.gif ├── 艺术例子.png ├── 首页.gif └── 黑白例子.png /.gitignore: -------------------------------------------------------------------------------- 1 | # Windows 2 | [Dd]esktop.ini 3 | Thumbs.db 4 | $RECYCLE.BIN/ 5 | 6 | # macOS 7 | .DS_Store 8 | .fseventsd 9 | .Spotlight-V100 10 | .TemporaryItems 11 | .Trashes 12 | 13 | # Node.js 14 | node_modules/ 15 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Apache License 2 | Version 2.0, January 2004 3 | http://www.apache.org/licenses/ 4 | 5 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 6 | 7 | 1. Definitions. 8 | 9 | "License" shall mean the terms and conditions for use, reproduction, 10 | and distribution as defined by Sections 1 through 9 of this document. 11 | 12 | "Licensor" shall mean the copyright owner or entity authorized by 13 | the copyright owner that is granting the License. 14 | 15 | "Legal Entity" shall mean the union of the acting entity and all 16 | other entities that control, are controlled by, or are under common 17 | control with that entity. For the purposes of this definition, 18 | "control" means (i) the power, direct or indirect, to cause the 19 | direction or management of such entity, whether by contract or 20 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 21 | outstanding shares, or (iii) beneficial ownership of such entity. 22 | 23 | "You" (or "Your") shall mean an individual or Legal Entity 24 | exercising permissions granted by this License. 25 | 26 | "Source" form shall mean the preferred form for making modifications, 27 | including but not limited to software source code, documentation 28 | source, and configuration files. 29 | 30 | "Object" form shall mean any form resulting from mechanical 31 | transformation or translation of a Source form, including but 32 | not limited to compiled object code, generated documentation, 33 | and conversions to other media types. 34 | 35 | "Work" shall mean the work of authorship, whether in Source or 36 | Object form, made available under the License, as indicated by a 37 | copyright notice that is included in or attached to the work 38 | (an example is provided in the Appendix below). 39 | 40 | "Derivative Works" shall mean any work, whether in Source or Object 41 | form, that is based on (or derived from) the Work and for which the 42 | editorial revisions, annotations, elaborations, or other modifications 43 | represent, as a whole, an original work of authorship. For the purposes 44 | of this License, Derivative Works shall not include works that remain 45 | separable from, or merely link (or bind by name) to the interfaces of, 46 | the Work and Derivative Works thereof. 47 | 48 | "Contribution" shall mean any work of authorship, including 49 | the original version of the Work and any modifications or additions 50 | to that Work or Derivative Works thereof, that is intentionally 51 | submitted to Licensor for inclusion in the Work by the copyright owner 52 | or by an individual or Legal Entity authorized to submit on behalf of 53 | the copyright owner. For the purposes of this definition, "submitted" 54 | means any form of electronic, verbal, or written communication sent 55 | to the Licensor or its representatives, including but not limited to 56 | communication on electronic mailing lists, source code control systems, 57 | and issue tracking systems that are managed by, or on behalf of, the 58 | Licensor for the purpose of discussing and improving the Work, but 59 | excluding communication that is conspicuously marked or otherwise 60 | designated in writing by the copyright owner as "Not a Contribution." 61 | 62 | "Contributor" shall mean Licensor and any individual or Legal Entity 63 | on behalf of whom a Contribution has been received by Licensor and 64 | subsequently incorporated within the Work. 65 | 66 | 2. Grant of Copyright License. Subject to the terms and conditions of 67 | this License, each Contributor hereby grants to You a perpetual, 68 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 69 | copyright license to reproduce, prepare Derivative Works of, 70 | publicly display, publicly perform, sublicense, and distribute the 71 | Work and such Derivative Works in Source or Object form. 72 | 73 | 3. Grant of Patent License. Subject to the terms and conditions of 74 | this License, each Contributor hereby grants to You a perpetual, 75 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 76 | (except as stated in this section) patent license to make, have made, 77 | use, offer to sell, sell, import, and otherwise transfer the Work, 78 | where such license applies only to those patent claims licensable 79 | by such Contributor that are necessarily infringed by their 80 | Contribution(s) alone or by combination of their Contribution(s) 81 | with the Work to which such Contribution(s) was submitted. If You 82 | institute patent litigation against any entity (including a 83 | cross-claim or counterclaim in a lawsuit) alleging that the Work 84 | or a Contribution incorporated within the Work constitutes direct 85 | or contributory patent infringement, then any patent licenses 86 | granted to You under this License for that Work shall terminate 87 | as of the date such litigation is filed. 88 | 89 | 4. Redistribution. You may reproduce and distribute copies of the 90 | Work or Derivative Works thereof in any medium, with or without 91 | modifications, and in Source or Object form, provided that You 92 | meet the following conditions: 93 | 94 | (a) You must give any other recipients of the Work or 95 | Derivative Works a copy of this License; and 96 | 97 | (b) You must cause any modified files to carry prominent notices 98 | stating that You changed the files; and 99 | 100 | (c) You must retain, in the Source form of any Derivative Works 101 | that You distribute, all copyright, patent, trademark, and 102 | attribution notices from the Source form of the Work, 103 | excluding those notices that do not pertain to any part of 104 | the Derivative Works; and 105 | 106 | (d) If the Work includes a "NOTICE" text file as part of its 107 | distribution, then any Derivative Works that You distribute must 108 | include a readable copy of the attribution notices contained 109 | within such NOTICE file, excluding those notices that do not 110 | pertain to any part of the Derivative Works, in at least one 111 | of the following places: within a NOTICE text file distributed 112 | as part of the Derivative Works; within the Source form or 113 | documentation, if provided along with the Derivative Works; or, 114 | within a display generated by the Derivative Works, if and 115 | wherever such third-party notices normally appear. The contents 116 | of the NOTICE file are for informational purposes only and 117 | do not modify the License. You may add Your own attribution 118 | notices within Derivative Works that You distribute, alongside 119 | or as an addendum to the NOTICE text from the Work, provided 120 | that such additional attribution notices cannot be construed 121 | as modifying the License. 122 | 123 | You may add Your own copyright statement to Your modifications and 124 | may provide additional or different license terms and conditions 125 | for use, reproduction, or distribution of Your modifications, or 126 | for any such Derivative Works as a whole, provided Your use, 127 | reproduction, and distribution of the Work otherwise complies with 128 | the conditions stated in this License. 129 | 130 | 5. Submission of Contributions. Unless You explicitly state otherwise, 131 | any Contribution intentionally submitted for inclusion in the Work 132 | by You to the Licensor shall be under the terms and conditions of 133 | this License, without any additional terms or conditions. 134 | Notwithstanding the above, nothing herein shall supersede or modify 135 | the terms of any separate license agreement you may have executed 136 | with Licensor regarding such Contributions. 137 | 138 | 6. Trademarks. This License does not grant permission to use the trade 139 | names, trademarks, service marks, or product names of the Licensor, 140 | except as required for reasonable and customary use in describing the 141 | origin of the Work and reproducing the content of the NOTICE file. 142 | 143 | 7. Disclaimer of Warranty. Unless required by applicable law or 144 | agreed to in writing, Licensor provides the Work (and each 145 | Contributor provides its Contributions) on an "AS IS" BASIS, 146 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 147 | implied, including, without limitation, any warranties or conditions 148 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 149 | PARTICULAR PURPOSE. You are solely responsible for determining the 150 | appropriateness of using or redistributing the Work and assume any 151 | risks associated with Your exercise of permissions under this License. 152 | 153 | 8. Limitation of Liability. In no event and under no legal theory, 154 | whether in tort (including negligence), contract, or otherwise, 155 | unless required by applicable law (such as deliberate and grossly 156 | negligent acts) or agreed to in writing, shall any Contributor be 157 | liable to You for damages, including any direct, indirect, special, 158 | incidental, or consequential damages of any character arising as a 159 | result of this License or out of the use or inability to use the 160 | Work (including but not limited to damages for loss of goodwill, 161 | work stoppage, computer failure or malfunction, or any and all 162 | other commercial damages or losses), even if such Contributor 163 | has been advised of the possibility of such damages. 164 | 165 | 9. Accepting Warranty or Additional Liability. While redistributing 166 | the Work or Derivative Works thereof, You may choose to offer, 167 | and charge a fee for, acceptance of support, warranty, indemnity, 168 | or other liability obligations and/or rights consistent with this 169 | License. However, in accepting such obligations, You may act only 170 | on Your own behalf and on Your sole responsibility, not on behalf 171 | of any other Contributor, and only if You agree to indemnify, 172 | defend, and hold each Contributor harmless for any liability 173 | incurred by, or claims asserted against, such Contributor by reason 174 | of your accepting any such warranty or additional liability. 175 | 176 | END OF TERMS AND CONDITIONS 177 | 178 | APPENDIX: How to apply the Apache License to your work. 179 | 180 | To apply the Apache License to your work, attach the following 181 | boilerplate notice, with the fields enclosed by brackets "[]" 182 | replaced with your own identifying information. (Don't include 183 | the brackets!) The text should be enclosed in the appropriate 184 | comment syntax for the file format. We also recommend that a 185 | file or class name and description of purpose be included on the 186 | same "printed page" as the copyright notice for easier 187 | identification within third-party archives. 188 | 189 | Copyright [yyyy] [name of copyright owner] 190 | 191 | Licensed under the Apache License, Version 2.0 (the "License"); 192 | you may not use this file except in compliance with the License. 193 | You may obtain a copy of the License at 194 | 195 | http://www.apache.org/licenses/LICENSE-2.0 196 | 197 | Unless required by applicable law or agreed to in writing, software 198 | distributed under the License is distributed on an "AS IS" BASIS, 199 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 200 | See the License for the specific language governing permissions and 201 | limitations under the License. 202 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # 【云开发应用】-【艺术二维码生成器小程序】 2 | ## 体验二维码 3 | ![image.png](./readme/toolcode.jpg) 4 | 5 | - 队伍名称:喜儿战队 6 | - 队伍成员:[Chenyating](https://github.com/Chenyating),[bigbinhe](https://github.com/xbin0316) 7 | 8 | ## 作品简介: 9 | 当我们在日常生活中总会出现各种各样的二维码,但黑白的颜色放置在绚丽的海报上,就会显得奇奇怪怪。也会降低人们扫码的欲望。 10 | 11 | 12 | 13 | 但如果是这样的二维码呢,是否在你眼前一亮呢,你是否很想去试一下,会扫出个什么样的内容呢。 14 | 15 | 16 | 17 | 现在就用一款这样的工具,能够帮你将无聊乏味的黑白二维码转化成艺术二维码。不管是文字,还是网址,几秒美化。同时还可以自己上传设置素材,生成专属的艺术二维码。 18 | 19 | ### 封面图 20 | 21 | 22 | ## 作品类型: 23 | - 小程序 24 | - 工具类 25 | 26 | ## 云开发能力应用情况: 27 | - 使用云函数 28 | - 云数据库 29 | 30 | ## 功能模块介绍 31 | 32 | ### 首页 33 | 34 | 35 | - 二维码生成:用户可直接s输入文字生成艺术二维码 36 | - 二维码美化:用户可以用现有的黑白二维码转为艺术二维码 37 | - 社区:用户可以看到所有用户上传的艺术二维码风格模版; 38 | - 我的:用户可创建自定义定艺术二维码风格素材包。 39 | 40 | ### 二维码生成 41 | 42 | 43 | - 填写内容:文字、网址均可 44 | - 选择风格:跳转页生成艺术二维码的风格 45 | - 生成二维码 46 | 47 | ### 美化二维码 48 | 49 | 50 | - 上传图片:上传黑白二维码 51 | - 选择风格:跳转页生成艺术二维码的风格 52 | - 生成二维码 53 | 54 | ### 社区 55 | 56 | 57 | - 用户进入页面,展示所有用户上传的艺术二维码风格模板列表。 58 | - 用户点击其中一个模板,可以进行自定义定制艺术二维码。 59 | 60 | ### 我的 61 | 62 | 63 | - 当用户进入到我的页面,拉取用户所创建的素材包列表。 64 | - 用户可以对素材包进行管理:删除,上传素材包 65 | 66 | ### 上传 67 | 68 | 69 | - 用户根据示意图,上传对应的图片素材,至少上传3张基础元素图。 70 | - 点击“上传”,用户最后确认上次素材包,并取名提交。 71 | - 当用户点击“问号”icon时,用户可以了解上传规则。 72 | 73 | ### 上传规则 74 | 75 | 76 | - 当用户在上传页点击“问号”icon时,用户可以了解上传以及设计规则。 77 | - 阅读完毕可跳转回上传页面 78 | 79 | ### 模板生成艺术二维码 80 | 81 | 82 | - 用户选取艺术二维码模板后,跳转到创建二维码页。 83 | - “文字生成”点击后,弹出弹框,输入:文字,网址点击生成即可获得艺术二维码。 84 | - “二维码美化”点击后,弹出弹框,用户上传黑白二维码后,点击生成即可获得艺术二维码。 85 | 86 | ## 整体流程 87 | 90 | 91 | ## 源码链接 92 | https://github.com/Chenyating/qrcode.git 93 | 喜欢的朋友可以给这个项目个start~谢谢撒~٩(๑❛ᴗ❛๑)۶ 94 | 95 | ## 学习与参考 96 | - [小程序开发文档](https://developers.weixin.qq.com/miniprogram/dev/framework/) 97 | - [艺术二维码生成原理](https://blog.csdn.net/lemisi/article/details/88831289?spm=1001.2014.3001.5502) 98 | - [artqrcode源码](https://github.com/Chenyating/qrcode) 99 | -------------------------------------------------------------------------------- /cloudfunctions/checkeText/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | "subscribeMessage.send" 5 | ] 6 | } 7 | } -------------------------------------------------------------------------------- /cloudfunctions/checkeText/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入// 云函数入口文件 2 | const cloud = require('wx-server-sdk'); 3 | const request = require('request'); 4 | 5 | cloud.init({ 6 | env: 'xier-8gptzwg769125208' 7 | }); 8 | 9 | // 云函数入口函数 10 | exports.main = async (event, context) => { 11 | let text = event.txt; 12 | const wxContext = cloud.getWXContext(); 13 | const open_id = wxContext.OPENID; 14 | const result = await cloud.openapi.security.msgSecCheck({ 15 | "openid": open_id, 16 | "scene": 1, 17 | "version": 2, 18 | "content": text 19 | }) 20 | return result.result.suggest; 21 | } -------------------------------------------------------------------------------- /cloudfunctions/checkeText/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "checkeText", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.6.3" 13 | } 14 | } -------------------------------------------------------------------------------- /cloudfunctions/decode/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/decode/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入// 云函数入口文件 2 | const cloud = require('wx-server-sdk'); 3 | const request = require('request'); 4 | 5 | cloud.init({ 6 | env: 'xier-8gptzwg769125208' 7 | }); 8 | 9 | // 云函数入口函数 10 | exports.main = async (event, context) => { 11 | let token = await getWechatAccessToken(); 12 | const fileid = event.fileid; 13 | let img = await getimg(token.access_token, fileid); 14 | let qrtext=await scanqrcode(img,token); 15 | return qrtext.code_results; 16 | } 17 | 18 | // 获取公众号access_token 19 | async function getWechatAccessToken() { 20 | let appid = 'wxdb5a9d708acf35ee'; //微信公众号开发者id 21 | let secret = '731ce47411ac051989925ed55854c528'; //微信公众号开发者secret_key 22 | let token_url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${appid}&secret=${secret}`; 23 | let rp = options => 24 | new Promise((resolve, reject) => { 25 | request(options, (error, response, body) => { 26 | if (error) { 27 | reject(error); 28 | } 29 | resolve(response); 30 | }); 31 | }); 32 | let result = await rp({ 33 | url: token_url, 34 | method: 'GET' 35 | }); 36 | return (typeof result.body === 'object') ? result.body : JSON.parse(result.body); 37 | } 38 | 39 | async function scanqrcode(imgurl, token) { 40 | let token_url = `https://api.weixin.qq.com/cv/img/qrcode?img_url=${imgurl}&access_token=${token.access_token}`; 41 | let rp1 = options => 42 | new Promise((resolve, reject) => { 43 | request(options, (error, response, body) => { 44 | if (error) { 45 | reject(error); 46 | } 47 | resolve(response); 48 | }); 49 | }); 50 | let result = await rp1({ 51 | url: token_url, 52 | method: 'POST' 53 | }); 54 | var res=JSON.parse(result.body) 55 | return res 56 | } 57 | 58 | async function getimg(token, fileid) { 59 | var fileid=fileid; 60 | let token_url = `https://api.weixin.qq.com/tcb/batchdownloadfile?access_token=${token}`; 61 | var data={ 62 | "env": "xier-8gptzwg769125208", 63 | "file_list": [{ 64 | "fileid": fileid, 65 | "max_age": 7200 66 | }] 67 | }; 68 | let rp2 = options => 69 | new Promise((resolve, reject) => { 70 | request(options, (error, response, body) => { 71 | if (error) { 72 | reject(error); 73 | } 74 | resolve(response); 75 | }); 76 | }); 77 | let result2 = await rp2({ 78 | url: token_url, 79 | body:JSON.stringify(data), 80 | method: 'POST' 81 | }); 82 | var res=JSON.parse(result2.body) 83 | return res.file_list[0].download_url; 84 | } -------------------------------------------------------------------------------- /cloudfunctions/decode/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "decode", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.5.1" 13 | } 14 | } -------------------------------------------------------------------------------- /cloudfunctions/deleteUserQR/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/deleteUserQR/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入口文件 2 | const cloud = require('wx-server-sdk') 3 | cloud.init({ 4 | env: 'xier-8gptzwg769125208' 5 | }); 6 | 7 | //获取数据库引用 8 | const db = cloud.database({ 9 | throwOnNotFound: false 10 | }); 11 | const collection_qr_element_list = db.collection('QR_Element_LIST'); 12 | const _ = db.command; 13 | 14 | // 云函数入口函数 15 | exports.main = async (event, context) => { 16 | const wxContext = cloud.getWXContext(); 17 | const open_id = wxContext.OPENID; 18 | const qr_id = event.qr_id_array; 19 | const rs = { 20 | code: 0, 21 | msg: '' 22 | }; 23 | if (!qr_id || !qr_id.length) { 24 | rs.code = -1; 25 | rs.msg = "未指定qr_id"; 26 | return rs; 27 | } 28 | const db_process = await collection_qr_element_list.where({ 29 | _id:_.in(qr_id), 30 | _open_id:open_id 31 | }); 32 | const qr_record = await db_process.get(); 33 | if (!qr_record.data || !qr_record.data.length) { 34 | rs.code = -2; 35 | rs.msg = "未找到_id对应素材包,有可能已经被删除"; 36 | return rs; 37 | } 38 | return db_process.remove().then(() => { 39 | rs.code = 0; 40 | rs.msg = "删除成功"; 41 | return rs; 42 | }).catch(err => { 43 | rs.code = -3; 44 | rs.msg = JSON.stringify(err); 45 | return rs; 46 | }); 47 | } -------------------------------------------------------------------------------- /cloudfunctions/deleteUserQR/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "deleteUserQR", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /cloudfunctions/getQRElementList/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/getQRElementList/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入口文件 2 | const cloud = require('wx-server-sdk') 3 | 4 | cloud.init({ 5 | env: 'xier-8gptzwg769125208' 6 | }); 7 | 8 | //获取数据库引用 9 | const db = cloud.database({ 10 | throwOnNotFound: false 11 | }); 12 | const collection_qr_element_list = db.collection('QR_Element_LIST'); 13 | 14 | // 云函数入口函数 15 | exports.main = async (event, context) => { 16 | const rs = { 17 | code: 0, 18 | msg: null 19 | }; 20 | let { 21 | limit, 22 | page_index, 23 | self, 24 | order, 25 | datatype 26 | } = event; 27 | let open_id; 28 | limit += 0; 29 | page_index += 0; 30 | if (isNaN(limit) || isNaN(page_index)) { 31 | rs.code = -1; 32 | rs.msg = 'limit和page_index参数不正确'; 33 | return rs; 34 | } 35 | limit > 20 && (limit = 20); 36 | let db_process; 37 | //获取此用户的 38 | if (self) { 39 | const wxContext = cloud.getWXContext() 40 | open_id = wxContext.OPENID; 41 | db_process = await collection_qr_element_list.where({ 42 | _open_id: open_id 43 | }); 44 | } 45 | //获取全部列表 46 | else { 47 | if (datatype==0||datatype==undefined) { 48 | db_process = await collection_qr_element_list; 49 | } 50 | if (datatype==1) { 51 | db_process = await collection_qr_element_list.where({ 52 | publish: true 53 | }); 54 | } 55 | if (datatype==2) { 56 | db_process = await collection_qr_element_list.where({ 57 | publish: false 58 | }); 59 | } 60 | } 61 | 62 | //排序 63 | // if (order != 'like') { 64 | // db_process = await db_process.orderBy('_like', 'desc'); 65 | // } else { 66 | db_process = await db_process.orderBy('_upload_time', 'asc'); 67 | // } 68 | 69 | // 先取出集合记录总数 70 | const countResult = await db_process.count(); 71 | const total = countResult.total; 72 | const start = page_index * limit; 73 | return db_process.skip(start).limit(limit).get().then(list => { 74 | rs.code = 0; 75 | rs.msg = "success"; 76 | list.data.forEach(item => { 77 | delete item._open_id; 78 | }); 79 | rs.data = { 80 | total: total, 81 | page_index: page_index, 82 | limit: limit, 83 | list: list.data 84 | }; 85 | return rs; 86 | }).catch(err => { 87 | rs.code = -2; 88 | rs.msg = JSON.stringify(err); 89 | return rs; 90 | }); 91 | } -------------------------------------------------------------------------------- /cloudfunctions/getQRElementList/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "getQRElementList", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /cloudfunctions/login/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/login/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入口文件 2 | const cloud = require('wx-server-sdk') 3 | 4 | cloud.init() 5 | 6 | // 云函数入口函数 7 | exports.main = async (event, context) => { 8 | const wxContext = cloud.getWXContext() 9 | 10 | return { 11 | openid: wxContext.OPENID 12 | } 13 | } -------------------------------------------------------------------------------- /cloudfunctions/login/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "login", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.5.1" 13 | } 14 | } -------------------------------------------------------------------------------- /cloudfunctions/publishQR/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/publishQR/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入口文件 2 | const cloud = require('wx-server-sdk'); 3 | cloud.init({ 4 | env: 'xier-8gptzwg769125208' 5 | }); 6 | //获取数据库引用 7 | const db = cloud.database({ 8 | throwOnNotFound: false 9 | }); 10 | const collection_qr_element_list = db.collection('QR_Element_LIST'); 11 | 12 | // 云函数入口函数 13 | exports.main = async (event, context) => { 14 | const wxContext = cloud.getWXContext(); 15 | const open_id = wxContext.OPENID; 16 | const qr_id = event.qr_id; 17 | const publish=event.publish; 18 | var ifadmin = false; 19 | if (open_id == "oTeIY4x2XbUh-zDPgz11RdynsOTs") { 20 | ifadmin = true; 21 | } 22 | if (ifadmin) { 23 | collection_qr_element_list .doc(qr_id).update({ 24 | // data 传入需要局部更新的数据 25 | data: { 26 | // 表示将 done 字段置为 true 27 | publish: publish 28 | }, 29 | success: function(res) { 30 | return "yyds" 31 | } 32 | }) 33 | } 34 | } -------------------------------------------------------------------------------- /cloudfunctions/publishQR/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "publishQR", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /cloudfunctions/reportQRLike/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/reportQRLike/index.js: -------------------------------------------------------------------------------- 1 | // 云函数入口文件 2 | const cloud = require('wx-server-sdk'); 3 | cloud.init({ 4 | env: 'xier-8gptzwg769125208' 5 | }); 6 | //获取数据库引用 7 | const db = cloud.database({ 8 | throwOnNotFound: false 9 | }); 10 | const collection_qr_element_list = db.collection('QR_Element_LIST'); 11 | const collection_like_record = db.collection('QRLikeRecord'); 12 | 13 | // 云函数入口函数 14 | exports.main = async (event, context) => { 15 | const wxContext = cloud.getWXContext(); 16 | const open_id = wxContext.OPENID; 17 | const qr_id = event.qr_id; 18 | const rs = { 19 | code: 0, 20 | msg: '' 21 | }; 22 | if (!qr_id) { 23 | rs.code = -1; 24 | rs.msg = "未指定qr_id"; 25 | return rs; 26 | }; 27 | if (!open_id) { 28 | rs.code = -1; 29 | rs.msg = "未获取到用户信息"; 30 | return rs; 31 | } 32 | const stage_time = Date.now() / 60000 >> 0; 33 | 34 | //查询数据库此用户该时间段已上传次数 35 | let like_db_process = await collection_like_record.where({ 36 | open_id: open_id 37 | }); 38 | let _id; 39 | let user_record = await like_db_process.get(); 40 | user_record = user_record.data[0]; 41 | if (user_record) { 42 | _id = user_record._id; 43 | } else { 44 | _id = await collection_like_record.add({ 45 | data: { 46 | stage_time: stage_time, 47 | stage_sum: 0, 48 | open_id 49 | } 50 | }).then(rs => rs._id).catch(err => null); 51 | user_record = await like_db_process.get(); 52 | user_record = user_record.data[0]; 53 | } 54 | let stage_sum; 55 | if (user_record.stage_time === stage_time) { 56 | stage_sum = user_record.stage_sum; 57 | } else { 58 | user_record.stage_time = stage_time; 59 | stage_sum = 0; 60 | } 61 | if (stage_sum > 30) { 62 | rs.code = -2; 63 | rs.msg = "已超出点赞次数,请稍后再试"; 64 | return rs; 65 | } 66 | ++stage_sum; 67 | collection_like_record.doc(_id).update({ 68 | data: { 69 | stage_sum, 70 | stage_time 71 | } 72 | }); 73 | 74 | const qr_db_process = await collection_qr_element_list.doc(qr_id); 75 | const qr_record = await qr_db_process.get(); 76 | if (!qr_record.data) { 77 | rs.code = -3; 78 | rs.msg = "未找到此素材包,有可能已经被删除"; 79 | return rs; 80 | } 81 | qr_like_sum = qr_record.data._like; 82 | ++qr_like_sum; 83 | return qr_db_process.update({data:{ 84 | _like:qr_like_sum 85 | }}).then(()=>{ 86 | rs.code = 0; 87 | rs.msg = '点赞成功'; 88 | rs._id = _id; 89 | rs.like = qr_like_sum; 90 | return rs; 91 | }).catch(err=>{ 92 | rs.code = -4; 93 | rs.msg = JSON.stringify(err); 94 | return rs; 95 | }); 96 | } -------------------------------------------------------------------------------- /cloudfunctions/reportQRLike/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "reportQRLike", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /cloudfunctions/uploadImg/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/uploadImg/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * 每位用户每分钟只能上传30张照片 3 | */ 4 | 5 | // 云函数入口文件 6 | const cloud = require('wx-server-sdk'); 7 | 8 | cloud.init({ 9 | env: 'xier-8gptzwg769125208' 10 | }); 11 | const db = cloud.database({ 12 | throwOnNotFound: false 13 | }); 14 | const collection_img_record = db.collection('ImgUploadRecord'); 15 | 16 | // 云函数入口函数 17 | exports.main = async (event, context) => { 18 | const rs = { 19 | code: 0, 20 | msg: '' 21 | }; 22 | const file_data = event.file_data; 23 | if (!file_data) { 24 | rs.code = -1; 25 | rs.msg = "未传入base64图片" 26 | return rs; 27 | } 28 | const wxContext = cloud.getWXContext(); 29 | const open_id = wxContext.OPENID; 30 | if (!open_id) { 31 | rs.code = -2; 32 | rs.msg = "未获取到用户信息" 33 | return rs; 34 | } 35 | 36 | //查询数据库此用户该时间段已上传次数 37 | const stage_time = Date.now() / 60000 >> 0; 38 | let db_process = await collection_img_record.where({ 39 | open_id:open_id 40 | }); 41 | let _id; 42 | let user_record = await db_process.get(); 43 | user_record = user_record.data[0]; 44 | if(user_record){ 45 | _id = user_record._id; 46 | }else{ 47 | _id = await collection_img_record.add({ 48 | data:{ 49 | stage_time:stage_time, 50 | stage_sum:0, 51 | open_id 52 | } 53 | }).then(rs=>rs._id).catch(err=>null); 54 | user_record = await db_process.get(); 55 | user_record = user_record.data[0]; 56 | } 57 | let stage_sum; 58 | if(user_record.stage_time === stage_time){ 59 | stage_sum = user_record.stage_sum; 60 | }else{ 61 | user_record.stage_time = stage_time; 62 | stage_sum = 0; 63 | } 64 | if(stage_sum > 30){ 65 | rs.code = -3; 66 | rs.msg = "已超出上传张数,请稍后再试"; 67 | return rs; 68 | } 69 | ++stage_sum; 70 | const file_path = `user_upload_qr_element/${open_id}_${stage_time}_${stage_sum}_${Math.random() * 10000000 >> 0}`; 71 | return await cloud.uploadFile({ 72 | cloudPath: file_path, 73 | fileContent: new Buffer(file_data, 'base64') 74 | }).then(up_rs=>{ 75 | return collection_img_record.doc(_id).update({data:{ 76 | stage_sum, 77 | stage_time 78 | }}).then(()=>{ 79 | rs.code = 0; 80 | rs.msg = "上传成功"; 81 | rs.fileID = up_rs.fileID; 82 | return rs; 83 | }); 84 | }).catch(err=>{ 85 | rs.code = -4; 86 | rs.msg = JSON.stringify(err) 87 | return rs; 88 | }); 89 | } -------------------------------------------------------------------------------- /cloudfunctions/uploadImg/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "uploadImg", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /cloudfunctions/uploadQRElement/config.json: -------------------------------------------------------------------------------- 1 | { 2 | "permissions": { 3 | "openapi": [ 4 | ] 5 | } 6 | } -------------------------------------------------------------------------------- /cloudfunctions/uploadQRElement/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * 每位用户每分钟只能上传10套素材 3 | */ 4 | 5 | // 云函数入口文件 6 | const cloud = require('wx-server-sdk'); 7 | const env = 'xier-8gptzwg769125208'; 8 | cloud.init({ 9 | env 10 | }); 11 | const db = cloud.database({ 12 | throwOnNotFound: false 13 | }); 14 | const collection_qr_element_list = db.collection('QR_Element_LIST'); 15 | const collection_qr_upload_record = db.collection('QRUploadRecord'); 16 | 17 | const url_root = `cloud://${env}`; 18 | const checkPicUrl = function (pic_url) { 19 | if (typeof pic_url !== 'string') return ''; 20 | if (pic_url.indexOf(url_root) === 0) { 21 | return pic_url; 22 | } else { 23 | return ''; 24 | }; 25 | }; 26 | const htmlspecialchars = function (str) { 27 | str = str.replace(/&/g, '&'); 28 | str = str.replace(//g, '>'); 30 | str = str.replace(/"/g, '"'); 31 | str = str.replace(/'/g, '''); 32 | return str; 33 | }; 34 | 35 | // 云函数入口函数 36 | exports.main = async (event, context) => { 37 | const wxContext = cloud.getWXContext(); 38 | const open_id = wxContext.OPENID; 39 | const rs = { 40 | code: 0, 41 | msg: '' 42 | }; 43 | if (!open_id) { 44 | rs.code = -1; 45 | rs.msg = "未获取到用户信息"; 46 | return rs; 47 | } 48 | let { 49 | col2, 50 | col3, 51 | col4, 52 | cover, 53 | element_name, 54 | eye, 55 | one, 56 | po7, 57 | re7, 58 | row2, 59 | row3, 60 | row4, 61 | tian, 62 | _author_avatar, 63 | _author_name, 64 | publish 65 | } = event; 66 | if (!element_name) { 67 | rs.code = -2; 68 | rs.msg = "未填名称"; 69 | return rs; 70 | }; 71 | if (!_author_name) { 72 | rs.code = -2; 73 | rs.msg = "未填用户名称"; 74 | return rs; 75 | }; 76 | element_name = htmlspecialchars(element_name); 77 | _author_name = htmlspecialchars(_author_name); 78 | 79 | if (!checkPicUrl(eye) || !checkPicUrl(one)) { 80 | rs.code = -2; 81 | rs.msg = "eye和one格式错误"; 82 | return rs; 83 | }; 84 | //查询数据库此用户该时间段已上传次数 85 | const stage_time = Date.now() / 60000 >> 0; 86 | let qr_upload_db_process = await collection_qr_upload_record.where({ 87 | open_id: open_id 88 | }); 89 | let _id; 90 | let user_record = await qr_upload_db_process.get(); 91 | user_record = user_record.data[0]; 92 | if (user_record) { 93 | _id = user_record._id; 94 | } else { 95 | _id = await collection_qr_upload_record.add({ 96 | data: { 97 | stage_time: stage_time, 98 | stage_sum: 0, 99 | open_id 100 | } 101 | }).then(rs => rs._id).catch(err => null); 102 | user_record = await qr_upload_db_process.get(); 103 | user_record = user_record.data[0]; 104 | } 105 | let stage_sum; 106 | if (user_record.stage_time === stage_time) { 107 | stage_sum = user_record.stage_sum; 108 | } else { 109 | user_record.stage_time = stage_time; 110 | stage_sum = 0; 111 | } 112 | if (stage_sum > 10) { 113 | rs.code = -2; 114 | rs.msg = "上传过于频繁,请稍后再试"; 115 | return rs; 116 | } 117 | ++stage_sum; 118 | collection_qr_upload_record.doc(_id).update({ 119 | data: { 120 | stage_sum, 121 | stage_time 122 | } 123 | }); 124 | 125 | //素材包存入数据库 126 | return collection_qr_element_list.add({ 127 | data: { 128 | _open_id: open_id, 129 | _like: 0, 130 | col2:checkPicUrl(col2), 131 | col3:checkPicUrl(col3), 132 | col4:checkPicUrl(col4), 133 | cover:checkPicUrl(cover), 134 | element_name, 135 | eye:checkPicUrl(eye), 136 | one:checkPicUrl(one), 137 | po7:checkPicUrl(po7), 138 | re7:checkPicUrl(re7), 139 | row2:checkPicUrl(row2), 140 | row3:checkPicUrl(row3), 141 | row4:checkPicUrl(row4), 142 | tian:checkPicUrl(tian), 143 | _author_avatar, 144 | _author_name, 145 | publish:false 146 | } 147 | }).then(add_rs => { 148 | console.log(add_rs); 149 | rs.code = 0; 150 | rs.msg = "上传成功"; 151 | return rs; 152 | }).catch(add_err => { 153 | rs.code = -3; 154 | rs.msg = JSON.stringify(add_err); 155 | console.error(add_err); 156 | return rs; 157 | }); 158 | } -------------------------------------------------------------------------------- /cloudfunctions/uploadQRElement/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "uploadQRElement", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "wx-server-sdk": "~2.4.0" 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /miniprogram/app.js: -------------------------------------------------------------------------------- 1 | //app.js 2 | App({ 3 | globalData: {}, 4 | onLaunch: function () { 5 | if (!wx.cloud) { 6 | console.error('请使用 2.2.3 或以上的基础库以使用云能力') 7 | } else { 8 | wx.cloud.init({ 9 | // env 参数说明: 10 | // env 参数决定接下来小程序发起的云开发调用(wx.cloud.xxx)会默认请求到哪个云环境的资源 11 | // 此处请填入环境 ID, 环境 ID 可打开云控制台查看 12 | // 如不填则使用默认环境(第一个创建的环境) 13 | // env: 'my-env-id', 14 | traceUser: true, 15 | }) 16 | } 17 | } 18 | }) -------------------------------------------------------------------------------- /miniprogram/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "pages": [ 3 | "pages/index/index", 4 | "pages/txtmade/txtmade", 5 | "pages/imgmade/imgmade", 6 | "pages/qrlist/qrlist", 7 | "pages/myqrlist/myqrlist", 8 | "pages/qrcode/qrcode", 9 | "pages/upload/upload", 10 | "pages/designrule/designrule", 11 | "pages/checkqr/checkqr" 12 | ], 13 | "window": { 14 | "backgroundColor": "#F6F6F6", 15 | "backgroundTextStyle": "light", 16 | "navigationBarBackgroundColor": "#F6F6F6", 17 | "navigationBarTitleText": "二维艺术码", 18 | "navigationBarTextStyle": "black", 19 | "navigationStyle": "custom" 20 | }, 21 | "sitemapLocation": "sitemap.json", 22 | "style": "v2" 23 | } -------------------------------------------------------------------------------- /miniprogram/app.wxss: -------------------------------------------------------------------------------- 1 | page{ 2 | background: url('https://7869-xier-8gptzwg769125208-1258411243.tcb.qcloud.la/assets/bg.png?sign=5aa09eff50836205f5eb23728c3e91ce&t=1623425293'),#8EC590; 3 | background-size: cover; 4 | background-position: bottom; 5 | /* 以下是颜色token */ 6 | /* 主题色 */ 7 | /* 主色 */ 8 | --brand-1: #FFE142; 9 | --brand-2: #D098FF; 10 | --box-shadow:4rpx 4rpx 0rpx #419646; 11 | --tip-1:#286432; 12 | 13 | --size-txt-base:32rpx; 14 | --size-txt-1:25rpx; 15 | --size-txt-2:20rpx; 16 | } 17 | -------------------------------------------------------------------------------- /miniprogram/components/avatar/avatar.js: -------------------------------------------------------------------------------- 1 | // components/avatar/avatar.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | size: { 8 | type: String, 9 | value: '120' 10 | }, 11 | borderWidth: { 12 | type: String, 13 | value: '4' 14 | }, 15 | src: { 16 | type: String, 17 | value: '' 18 | }, 19 | }, 20 | 21 | /** 22 | * 组件的初始数据 23 | */ 24 | data: { 25 | 26 | }, 27 | 28 | /** 29 | * 组件的方法列表 30 | */ 31 | methods: { 32 | 33 | } 34 | }) -------------------------------------------------------------------------------- /miniprogram/components/avatar/avatar.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/avatar/avatar.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | -------------------------------------------------------------------------------- /miniprogram/components/avatar/avatar.wxss: -------------------------------------------------------------------------------- 1 | /* components/avatar/avatar.wxss */ 2 | /* components/avatar/avatar.wxss */ 3 | .avatar { 4 | display: inline-block; 5 | width: 100%; 6 | height: 100%; 7 | border-radius: 100%; 8 | overflow: hidden; 9 | border: 4rpx solid #000000; 10 | box-sizing: border-box; 11 | box-shadow: var(--box-shadow); 12 | background: #fff; 13 | } 14 | 15 | .avatar image { 16 | width: 100%; 17 | height: 100%; 18 | border-radius: 100%; 19 | } -------------------------------------------------------------------------------- /miniprogram/components/btn/btn.js: -------------------------------------------------------------------------------- 1 | // components/btn/btn.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | block: { 8 | type: Boolean, 9 | value: false 10 | }, 11 | primary: { 12 | type: Boolean, 13 | value: false 14 | } 15 | }, 16 | 17 | /** 18 | * 组件的初始数据 19 | */ 20 | data: { 21 | 22 | }, 23 | 24 | /** 25 | * 组件的方法列表 26 | */ 27 | methods: { 28 | 29 | } 30 | }) -------------------------------------------------------------------------------- /miniprogram/components/btn/btn.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/btn/btn.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | -------------------------------------------------------------------------------- /miniprogram/components/btn/btn.wxss: -------------------------------------------------------------------------------- 1 | /* components/btn/btn.wxss */ 2 | .btn { 3 | display: inline-block; 4 | border: 4rpx solid #000000; 5 | box-shadow: var(--box-shadow); 6 | border-radius: 40rpx; 7 | font-size: 36rpx; 8 | text-align: center; 9 | padding: 0 30rpx; 10 | line-height: 80rpx; 11 | box-sizing: border-box; 12 | margin: 15rpx; 13 | } 14 | .btn--block{ 15 | display: block; 16 | margin: 15rpx auto; 17 | width: 250rpx; 18 | } 19 | .btn-default{ 20 | background: #FFFFFF; 21 | } 22 | .btn--primary{ 23 | background: #FFE142; 24 | } -------------------------------------------------------------------------------- /miniprogram/components/cell/cell.js: -------------------------------------------------------------------------------- 1 | // components/cell/cell.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | 8 | }, 9 | 10 | /** 11 | * 组件的初始数据 12 | */ 13 | data: { 14 | 15 | }, 16 | 17 | /** 18 | * 组件的方法列表 19 | */ 20 | methods: { 21 | 22 | } 23 | }) 24 | -------------------------------------------------------------------------------- /miniprogram/components/cell/cell.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/cell/cell.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | -------------------------------------------------------------------------------- /miniprogram/components/cell/cell.wxss: -------------------------------------------------------------------------------- 1 | /* components/cell/cell.wxss */ 2 | .cell{ 3 | width: 100%; 4 | background: #FFFFFF; 5 | border: 4rpx solid #000000; 6 | box-shadow: 0rpx 4rpx 0rpx #000; 7 | border-radius: 32rpx; 8 | box-sizing: border-box; 9 | } -------------------------------------------------------------------------------- /miniprogram/components/contain/contain.js: -------------------------------------------------------------------------------- 1 | // components/navigationbar/navigationbar.js 2 | Component({ 3 | options: { 4 | multipleSlots: true // 在组件定义时的选项中启用多slot支持 5 | }, 6 | /** 7 | * 组件的初始数据 8 | */ 9 | data: { 10 | height: 0, 11 | }, 12 | // 胶囊按钮高度获取 13 | ready() { 14 | wx.getSystemInfo({ 15 | success: (e) => { 16 | let info = wx.getMenuButtonBoundingClientRect(); 17 | this.setData({ 18 | height: (1.5*info.top)+info.height, // 返回按钮与文本的位置 19 | }); 20 | }, 21 | }); 22 | } 23 | }) -------------------------------------------------------------------------------- /miniprogram/components/contain/contain.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/contain/contain.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | -------------------------------------------------------------------------------- /miniprogram/components/contain/contain.wxss: -------------------------------------------------------------------------------- 1 | /* components/contain/contain.wxss */ 2 | .contain{ 3 | height: 100%; 4 | overflow: scroll; 5 | box-sizing: border-box; 6 | } -------------------------------------------------------------------------------- /miniprogram/components/icon/icon.js: -------------------------------------------------------------------------------- 1 | // components/activity/activity.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | type:{ 8 | type:String, 9 | value:'arrow' 10 | }, 11 | size:{ 12 | type:String, 13 | value:'80' 14 | }, 15 | round:{ 16 | type:Boolean, 17 | value:false 18 | }, 19 | border:{ 20 | type:Boolean, 21 | value:true 22 | }, 23 | }, 24 | 25 | /** 26 | * 组件的初始数据 27 | */ 28 | data: { 29 | 30 | }, 31 | 32 | /** 33 | * 组件的方法列表 34 | */ 35 | methods: { 36 | 37 | } 38 | }) 39 | -------------------------------------------------------------------------------- /miniprogram/components/icon/icon.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/icon/icon.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /miniprogram/components/missbox/missbox.js: -------------------------------------------------------------------------------- 1 | // components/activity/activity.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | type:{ 8 | type:String, 9 | value:'arrow' 10 | }, 11 | size:{ 12 | type:String, 13 | value:'300' 14 | }, 15 | tit:{ 16 | type:String, 17 | value:'暂无数据哦' 18 | }, 19 | dark:{ 20 | type:Boolean, 21 | value:false 22 | }, 23 | }, 24 | 25 | /** 26 | * 组件的初始数据 27 | */ 28 | data: { 29 | 30 | }, 31 | 32 | /** 33 | * 组件的方法列表 34 | */ 35 | methods: { 36 | 37 | } 38 | }) 39 | -------------------------------------------------------------------------------- /miniprogram/components/missbox/missbox.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": {} 4 | } -------------------------------------------------------------------------------- /miniprogram/components/missbox/missbox.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | {{tit}} 7 | -------------------------------------------------------------------------------- /miniprogram/components/missbox/missbox.wxss: -------------------------------------------------------------------------------- 1 | /* components/missbox/missbox.wxss */ 2 | 3 | .miss-box{ 4 | text-align: center; 5 | color: #fff; 6 | } 7 | 8 | .miss { 9 | width: 100%; 10 | height: 350rpx; 11 | box-sizing: border-box; 12 | margin: 50rpx auto; 13 | display: inline-flex; 14 | align-items: center; 15 | justify-content: center; 16 | } 17 | .tit{ 18 | font-size: 36rpx; 19 | font-weight: bold; 20 | margin-bottom: 100rpx; 21 | } 22 | .miss-nodata{ 23 | width: 100%; 24 | height: 100%; 25 | background-image: url(""); 26 | background-size: contain; 27 | background-position: center center; 28 | background-repeat: no-repeat; 29 | } 30 | .miss-err{ 31 | width: 100%; 32 | height: 100%; 33 | background-image: url(""); 34 | background-size: contain; 35 | background-position: center center; 36 | background-repeat: no-repeat; 37 | } 38 | 39 | .miss-loading { 40 | margin: 0 auto; 41 | width: 40rpx !important; 42 | height: 40rpx !important; 43 | border-radius: 40rpx; 44 | background-color: #FFE142; 45 | position: relative; 46 | animation: dot 1s linear infinite forwards; 47 | animation-delay: .2s; 48 | } 49 | 50 | .miss-loading::after { 51 | position: absolute; 52 | content: ''; 53 | width: 40rpx; 54 | height: 40rpx; 55 | border-radius: 40rpx; 56 | background-color: #FFE142; 57 | left: 100rpx; 58 | animation: dot 1s linear infinite; 59 | 60 | } 61 | 62 | .miss-loading::before { 63 | position: absolute; 64 | content: ''; 65 | width: 40rpx; 66 | height: 40rpx; 67 | border-radius: 40rpx; 68 | background-color: #FFE142; 69 | right: 100rpx; 70 | animation: dot 1s linear infinite forwards; 71 | animation-delay: .4s; 72 | 73 | } 74 | 75 | @keyframes dot { 76 | from { 77 | background-color: transparent; 78 | } 79 | 80 | to { 81 | background-color: #FFE142; 82 | } 83 | } -------------------------------------------------------------------------------- /miniprogram/components/navbar/navbar.js: -------------------------------------------------------------------------------- 1 | // components/navigationbar/navigationbar.js 2 | Component({ 3 | options: { 4 | multipleSlots: true // 在组件定义时的选项中启用多slot支持 5 | }, 6 | /** 7 | * 组件的属性列表 8 | */ 9 | properties: { 10 | title: { 11 | type: String, 12 | value: '' 13 | }, 14 | color: { 15 | type: String, 16 | value: '#fff' 17 | }, 18 | bgColor: { 19 | type: String, 20 | value: 'transparent' 21 | }, 22 | delta:{ 23 | type: Number, 24 | value: 2 25 | } 26 | }, 27 | 28 | /** 29 | * 组件的初始数据 30 | */ 31 | data: { 32 | navPadding: 0, // 返回按钮与文本的位置 33 | navHeight: 0, 34 | 35 | }, 36 | // 胶囊按钮高度获取 37 | ready() { 38 | wx.getSystemInfo({ 39 | success: (e) => { 40 | let info = wx.getMenuButtonBoundingClientRect(); 41 | this.setData({ 42 | navPadding: info.top, // 返回按钮与文本的位置 43 | navHeight: info.height, 44 | }); 45 | }, 46 | }); 47 | }, 48 | /** 49 | * 组件的方法列表 50 | */ 51 | methods: { 52 | goBack() { 53 | wx.navigateBack({ 54 | delta: this.data.delta 55 | }) 56 | } 57 | }, 58 | }) -------------------------------------------------------------------------------- /miniprogram/components/navbar/navbar.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": { 4 | "icon":"../icon/icon" 5 | } 6 | } -------------------------------------------------------------------------------- /miniprogram/components/navbar/navbar.wxml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 8 | 9 | {{title}} 10 | 11 | 12 | -------------------------------------------------------------------------------- /miniprogram/components/navbar/navbar.wxss: -------------------------------------------------------------------------------- 1 | /* components/navbar/navbar.wxss */ 2 | /* components/navigationbar/navigationbar.wxss */ 3 | .nav-box { 4 | display: flex; 5 | align-items: center; 6 | justify-content: center; 7 | box-sizing: content-box; 8 | position: fixed; 9 | top: 0; 10 | left: 0; 11 | width: 100%; 12 | text-align: center; 13 | z-index: 2; 14 | } 15 | 16 | .nav-box .nav-icon { 17 | width: 70rpx; 18 | height: 70rpx; 19 | position: absolute; 20 | left: 32rpx; 21 | background: #fff; 22 | border: 4rpx solid #18191F; 23 | box-sizing: border-box; 24 | border-radius: 70rpx; 25 | box-shadow: var(--box-shadow); 26 | } 27 | 28 | .nav-box .nav-icon::after { 29 | content: ''; 30 | position: absolute; 31 | top: 0; 32 | bottom: -1rpx; 33 | right: 0; 34 | left: 3px; 35 | margin: auto; 36 | width: 20rpx; 37 | height: 20rpx; 38 | border-top: 5rpx solid #18191F; 39 | border-right: 5rpx solid #18191F; 40 | transform: rotate(-135deg); 41 | border-radius: 5rpx; 42 | } 43 | 44 | .nav-box .nav-tit { 45 | font-weight: normal; 46 | font-size: 36rpx; 47 | color: #fff; 48 | font-weight: bold; 49 | text-align: center; 50 | } -------------------------------------------------------------------------------- /miniprogram/components/page/page.js: -------------------------------------------------------------------------------- 1 | // components/page/page.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | pageid: { 8 | type: Number, 9 | value: 0 10 | }, 11 | pagenum: { 12 | type: Number, 13 | value: 0 14 | } 15 | }, 16 | 17 | /** 18 | * 组件的初始数据 19 | */ 20 | data: { 21 | 22 | }, 23 | 24 | /** 25 | * 组件的方法列表 26 | */ 27 | methods: { 28 | prepage() { 29 | this.triggerEvent('prepage', false); 30 | }, 31 | nextpage() { 32 | this.triggerEvent('nextpage', false); 33 | }, 34 | } 35 | }) -------------------------------------------------------------------------------- /miniprogram/components/page/page.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": { 4 | "icon":"../icon/icon", 5 | "btn":"../btn/btn" 6 | } 7 | } -------------------------------------------------------------------------------- /miniprogram/components/page/page.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | {{pageid}}/{{pagenum}} 5 | 6 | -------------------------------------------------------------------------------- /miniprogram/components/page/page.wxss: -------------------------------------------------------------------------------- 1 | /* components/page/page.wxss */ 2 | .page { 3 | display: flex; 4 | align-items: center; 5 | width: 490rpx; 6 | justify-content: space-between; 7 | margin: 20rpx auto; 8 | } -------------------------------------------------------------------------------- /miniprogram/components/popbox/popbox.js: -------------------------------------------------------------------------------- 1 | // components/popbox/popbox.js 2 | Component({ 3 | // 启用插槽 4 | options: { 5 | multipleSlots: true 6 | }, 7 | /** 8 | * 组件的属性列表 9 | */ 10 | properties: { 11 | }, 12 | 13 | /** 14 | * 组件的初始数据 15 | */ 16 | data: { 17 | }, 18 | 19 | /** 20 | * 组件的方法列表 21 | */ 22 | methods: { 23 | close() { 24 | this.triggerEvent('close', false); 25 | }, 26 | }, 27 | }) -------------------------------------------------------------------------------- /miniprogram/components/popbox/popbox.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": { 4 | "cell":"../cell/cell", 5 | "icon":"../icon/icon" 6 | } 7 | } -------------------------------------------------------------------------------- /miniprogram/components/popbox/popbox.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | -------------------------------------------------------------------------------- /miniprogram/components/popbox/popbox.wxss: -------------------------------------------------------------------------------- 1 | /* components/popbox/popbox.wxss */ 2 | /* components/popbox/popbox.wxss */ 3 | .popbox-box { 4 | position: relative; 5 | position: fixed; 6 | top: 0; 7 | left: 0; 8 | z-index: 99; 9 | display: flex; 10 | justify-content: center; 11 | width: 100%; 12 | height: 100%; 13 | background: rgba(0, 0, 0, 0.7); 14 | align-items: center; 15 | overflow: hidden; 16 | } 17 | 18 | .popbox { 19 | width: 600rpx; 20 | margin: 0 auto; 21 | box-sizing: border-box; 22 | position: relative; 23 | } 24 | 25 | .content { 26 | padding: 50rpx 30rpx; 27 | background: #fff; 28 | border: 4rpx solid #000000; 29 | box-sizing: border-box; 30 | box-shadow: var(--box-shadow); 31 | background: #fff; 32 | border-radius: 32rpx; 33 | } 34 | 35 | /* 按钮 */ 36 | .popbox-box .popbox-close { 37 | position: absolute; 38 | right: -40rpx; 39 | top: -40rpx; 40 | } -------------------------------------------------------------------------------- /miniprogram/components/styleitem/styleitem.js: -------------------------------------------------------------------------------- 1 | // pages/styleitem/styleitem.js 2 | Component({ 3 | /** 4 | * 组件的属性列表 5 | */ 6 | properties: { 7 | cover: { 8 | type: String, 9 | value: '' 10 | }, 11 | tit: { 12 | type: String, 13 | value: '标题名称' 14 | }, 15 | avatar: { 16 | type: String, 17 | value: '' 18 | }, 19 | username: { 20 | type: String, 21 | value: 'xierchen' 22 | }, 23 | num: { 24 | type: Number, 25 | value: 0 26 | } 27 | }, 28 | 29 | /** 30 | * 组件的初始数据 31 | */ 32 | data: { 33 | 34 | }, 35 | 36 | /** 37 | * 组件的方法列表 38 | */ 39 | methods: { 40 | 41 | } 42 | }) -------------------------------------------------------------------------------- /miniprogram/components/styleitem/styleitem.json: -------------------------------------------------------------------------------- 1 | { 2 | "component": true, 3 | "usingComponents": { 4 | "cell":"../cell/cell", 5 | "avatar":"../avatar/avatar" 6 | } 7 | } -------------------------------------------------------------------------------- /miniprogram/components/styleitem/styleitem.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | {{tit}} 9 | 10 | 14 | 15 | {{num}} 16 | 17 | 18 | 19 | 20 | -------------------------------------------------------------------------------- /miniprogram/components/styleitem/styleitem.wxss: -------------------------------------------------------------------------------- 1 | /* pages/styleitem/styleitem.wxss */ 2 | .item { 3 | width: 330rpx; 4 | box-sizing: border-box; 5 | display: inline-block; 6 | } 7 | 8 | .img { 9 | margin: 20rpx; 10 | margin-right: 30rpx; 11 | width:280rpx; 12 | height: 280rpx; 13 | } 14 | 15 | .img image { 16 | width: 100%; 17 | height: 100%; 18 | border: 4rpx solid #FFFFFF; 19 | border-radius: 25rpx; 20 | box-sizing: border-box; 21 | } 22 | 23 | /* 内容 */ 24 | .content { 25 | margin: 15rpx; 26 | } 27 | 28 | .tit { 29 | font-size: 36rpx; 30 | font-weight: bold; 31 | margin-bottom: 10rpx; 32 | text-align: left; 33 | } 34 | 35 | .user { 36 | display: flex; 37 | align-items: center; 38 | justify-content: space-between; 39 | } 40 | 41 | .user-info { 42 | display: flex; 43 | align-items: center; 44 | } 45 | 46 | .user-name { 47 | margin-left: 15rpx; 48 | font-size: 24rpx; 49 | } 50 | 51 | .user-num { 52 | position: relative; 53 | display: flex; 54 | align-items: center; 55 | font-size: 24rpx; 56 | } 57 | 58 | .user-num::before { 59 | content: ''; 60 | background-image: url(''); 61 | width: 27rpx; 62 | height: 27rpx; 63 | background-size: contain; 64 | } -------------------------------------------------------------------------------- /miniprogram/images/demo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/demo.png -------------------------------------------------------------------------------- /miniprogram/images/img/bg.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/bg.png -------------------------------------------------------------------------------- /miniprogram/images/img/col2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/col2.png -------------------------------------------------------------------------------- /miniprogram/images/img/col3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/col3.png -------------------------------------------------------------------------------- /miniprogram/images/img/col4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/col4.png -------------------------------------------------------------------------------- /miniprogram/images/img/eye.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/eye.png -------------------------------------------------------------------------------- /miniprogram/images/img/one.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/one.png -------------------------------------------------------------------------------- /miniprogram/images/img/po7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/po7.png -------------------------------------------------------------------------------- /miniprogram/images/img/re7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/re7.png -------------------------------------------------------------------------------- /miniprogram/images/img/row2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/row2.png -------------------------------------------------------------------------------- /miniprogram/images/img/row3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/row3.png -------------------------------------------------------------------------------- /miniprogram/images/img/row4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/row4.png -------------------------------------------------------------------------------- /miniprogram/images/img/tian.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/img/tian.png -------------------------------------------------------------------------------- /miniprogram/images/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/logo.png -------------------------------------------------------------------------------- /miniprogram/images/upload/col2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/col2.png -------------------------------------------------------------------------------- /miniprogram/images/upload/col3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/col3.png -------------------------------------------------------------------------------- /miniprogram/images/upload/col4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/col4.png -------------------------------------------------------------------------------- /miniprogram/images/upload/demo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/demo.png -------------------------------------------------------------------------------- /miniprogram/images/upload/demo1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/demo1.png -------------------------------------------------------------------------------- /miniprogram/images/upload/demo2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/demo2.png -------------------------------------------------------------------------------- /miniprogram/images/upload/eye.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/eye.png -------------------------------------------------------------------------------- /miniprogram/images/upload/grid.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/grid.png -------------------------------------------------------------------------------- /miniprogram/images/upload/one.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/one.png -------------------------------------------------------------------------------- /miniprogram/images/upload/po7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/po7.png -------------------------------------------------------------------------------- /miniprogram/images/upload/re7.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/re7.png -------------------------------------------------------------------------------- /miniprogram/images/upload/row2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/row2.png -------------------------------------------------------------------------------- /miniprogram/images/upload/row3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/row3.png -------------------------------------------------------------------------------- /miniprogram/images/upload/row4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/row4.png -------------------------------------------------------------------------------- /miniprogram/images/upload/rule-1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/rule-1.png -------------------------------------------------------------------------------- /miniprogram/images/upload/rule-2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/rule-2.png -------------------------------------------------------------------------------- /miniprogram/images/upload/rule-3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/rule-3.png -------------------------------------------------------------------------------- /miniprogram/images/upload/rule.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/rule.png -------------------------------------------------------------------------------- /miniprogram/images/upload/rules.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/rules.png -------------------------------------------------------------------------------- /miniprogram/images/upload/tian.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/miniprogram/images/upload/tian.png -------------------------------------------------------------------------------- /miniprogram/js/artqrcoed.js: -------------------------------------------------------------------------------- 1 | // import drawQrcode from './weapp.qrcode.min.js'; 2 | import QRCode from './getqrcode.js'; 3 | 4 | var datalist = []; 5 | var datacol = null; 6 | var unit = null; 7 | 8 | function getqrcode(qrinfo, imginfo) { 9 | return new Promise((resolve, reject) => { 10 | var qrcodedata = new QRCode({ 11 | width: qrinfo.size, 12 | height: qrinfo.size, 13 | text: qrinfo.text, 14 | colorDark: "black", 15 | colorLight: "transparent", 16 | }); 17 | var qrcode = qrcodedata._oQRCode.modules; 18 | var array = []; 19 | var n = 0; 20 | for (let i = 0; i < qrcode.length; i++) { 21 | array[i] = []; 22 | // 首先遍历tr数组 23 | for (let j = 0; j < qrcode[i].length; j++) { 24 | array[i][j] = []; //第一个是上色情况,第二个是记录情况 25 | // 遍历每个tr里的td,记录每个td的上色情况; 26 | if (qrcode[i][j] == true) { 27 | array[i][j][0] = 1; 28 | array[i][j][1] = 0; 29 | } else { 30 | array[i][j][0] = 0; 31 | array[i][j][1] = 1; 32 | } 33 | n++; 34 | // 首先把3个大框框保存下来; 35 | if ((i < 7 && j < 7) || (i > qrcode.length - 8 && j < 8) || (i < 8 && j > qrcode.length - 8)) { 36 | array[i][j][1] = 1; 37 | } 38 | } 39 | } 40 | // 重新赋值 41 | datalist = array; 42 | datacol = qrcode.length; 43 | unit = (qrinfo.size / datacol).toFixed(2); 44 | var cyt = wx.createCanvasContext(qrinfo.canvasid); 45 | cyt.clearRect(0, 0, qrinfo.size, qrinfo.size); 46 | beginDraw(imginfo, cyt); 47 | resolve() 48 | }) 49 | } 50 | 51 | function getdataimg(qrinfo) { 52 | return new Promise((resolve, reject) => { 53 | var getdata = getimgdata(qrinfo); 54 | getdata.then((res) => { 55 | var getcodetext = new QRDecode(); 56 | var text = getcodetext.decodeImageData(res, qrinfo.size, qrinfo.size); 57 | qrinfo.text = text; 58 | resolve(text); 59 | }) 60 | }) 61 | } 62 | //获取图片像素点 63 | function getimgdata(qrinfo) { 64 | return new Promise((reslove, reject) => { 65 | setTimeout(() => { 66 | wx.canvasGetImageData({ 67 | canvasId: qrinfo.canvasid, 68 | x: 0, 69 | y: 0, 70 | width: qrinfo.size, 71 | height: qrinfo.size, 72 | success(res) { 73 | reslove(res) 74 | }, 75 | }) 76 | }, 1000) 77 | }) 78 | } 79 | 80 | function beginDraw(imginfo, cyt) { 81 | countType(cyt, "array4", 4, imginfo); 82 | countTian(cyt, imginfo.tian); 83 | countType(cyt, "array3", 3, imginfo); 84 | count7(cyt, imginfo); 85 | countType(cyt, "array2", 2, imginfo); 86 | count1(cyt, imginfo.one); 87 | painEye(cyt, imginfo.eye, datacol, unit); 88 | } 89 | // 绘制艺术二维码 90 | function pain(cyt, arrayName, width, height, img) { 91 | //以Canvas画布上的坐标(10,10)为起始点,绘制图像 //图像的宽度和高度分别缩放到350px和100px 92 | if (arrayName.length != 0) { 93 | for (let i = 0; i < arrayName.length; i++) { 94 | cyt.drawImage(img, arrayName[i][0] * unit, arrayName[i][1] * unit, width * unit, height * unit); 95 | } 96 | } else { 97 | return; 98 | } 99 | } 100 | // 绘制艺术二维码 101 | // 对象,图片,长度,单元尺寸 102 | function painEye(cyt, eyeImguUrl, datalistlength, unit) { 103 | cyt.drawImage(eyeImguUrl, 0, 0, 7 * unit, 7 * unit); 104 | cyt.drawImage(eyeImguUrl, (datalistlength - 7) * unit, 0 * unit, 7 * unit, 7 * unit); 105 | cyt.drawImage(eyeImguUrl, 0 * unit, (datalistlength - 7) * unit, 7 * unit, 7 * unit); 106 | cyt.draw(); 107 | } 108 | /* 109 | * 返回判断条件;当数量为4、3、2个方块的; 110 | * 类型有:col和row; 111 | * i,j此时遍历的条件; 112 | */ 113 | function condition(arraylist, num, type, i, j) { 114 | if (num == 4 && type == "row") { 115 | return (arraylist[i][j][0] == 1 && 116 | arraylist[i][j][1] == 0 && 117 | arraylist[i][j + 1][0] == 1 && 118 | arraylist[i][j + 1][1] == 0 && 119 | arraylist[i][j + 2][0] == 1 && 120 | arraylist[i][j + 2][1] == 0 && 121 | arraylist[i][j + 3][0] == 1 && 122 | arraylist[i][j + 3][1] == 0) 123 | } 124 | if (num == 4 && type == "col") { 125 | return (arraylist[i][j][0] == 1 && 126 | arraylist[i][j][1] == 0 && 127 | arraylist[i + 1][j][0] == 1 && 128 | arraylist[i + 1][j][1] == 0 && 129 | arraylist[i + 2][j][0] == 1 && 130 | arraylist[i + 2][j][1] == 0 && 131 | arraylist[i + 3][j][0] == 1 && 132 | arraylist[i + 3][j][1] == 0) 133 | } 134 | if (num == 3 && type == "row") { 135 | return (arraylist[i][j][0] == 1 && 136 | arraylist[i][j][1] == 0 && 137 | arraylist[i][j + 1][0] == 1 && 138 | arraylist[i][j + 1][1] == 0 && 139 | arraylist[i][j + 2][0] == 1 && 140 | arraylist[i][j + 2][1] == 0) 141 | } 142 | if (num == 3 && type == "col") { 143 | return (arraylist[i][j][0] == 1 && 144 | arraylist[i][j][1] == 0 && 145 | arraylist[i + 1][j][0] == 1 && 146 | arraylist[i + 1][j][1] == 0 && 147 | arraylist[i + 2][j][0] == 1 && 148 | arraylist[i + 2][j][1] == 0) 149 | } 150 | if (num == 2 && type == "row") { 151 | return (arraylist[i][j][0] == 1 && 152 | arraylist[i][j][1] == 0 && 153 | arraylist[i][j + 1][0] == 1 && 154 | arraylist[i][j + 1][1] == 0) 155 | } 156 | if (num == 2 && type == "col") { 157 | return (arraylist[i][j][0] == 1 && 158 | arraylist[i][j][1] == 0 && 159 | arraylist[i + 1][j][0] == 1 && 160 | arraylist[i + 1][j][1] == 0) 161 | } 162 | } 163 | /* 164 | *返回判断条件;当数量为4、3、2个方块的; 165 | * 类型有:col和row; 166 | * i,j此时遍历的条件; 167 | */ 168 | function countType(cyt, arrayType, num, imginfo) { 169 | var obj = { 170 | array4: { 171 | row: null, 172 | col: null 173 | }, 174 | array3: { 175 | row: null, 176 | col: null 177 | }, 178 | array2: { 179 | row: null, 180 | col: null 181 | }, 182 | } 183 | var col = 0; 184 | obj[arrayType].col = []; 185 | var row = 0; 186 | obj[arrayType].row = []; 187 | if (imginfo[`row${num}`] || imginfo[`col${num}`]) { 188 | for (let i = 0; i < datacol; i++) { 189 | // 遍历每一个数组里的值 190 | for (let j = 0; j < datacol; j++) { 191 | // 如果这个小方块没有上色或者这个小方块被记录过了,那么我们就不用管它了! 192 | if (datalist[i][j][1] == 1) { 193 | continue; 194 | } else { 195 | // 随机记录行竖4 196 | if (parseInt(Math.random() * 2) == 1) { 197 | if (imginfo[`col${num}`]) { 198 | // 判断是否超出; 199 | if (i >= datacol - num) { 200 | continue; 201 | } else { 202 | // 否则判断他是否是竖4。 203 | if (condition(datalist, num, "col", i, j)) { 204 | // 现在col4已经被记录了; 205 | for (let k = 0; k < num; k++) { 206 | datalist[i + k][j][1] = 1 207 | } 208 | // 把竖4的i,j记录进去; 209 | // 开始收收集4行的小方块数据; 210 | obj[arrayType].col[col] = []; 211 | obj[arrayType].col[col][0] = j; 212 | obj[arrayType].col[col][1] = i 213 | col = col + 1; 214 | } else { 215 | continue; 216 | } 217 | } 218 | } else { 219 | continue; 220 | } 221 | } else { 222 | if (imginfo[`row${num}`]) { 223 | if (j >= datacol - num) { 224 | continue; 225 | } else { 226 | 227 | if (condition(datalist, num, "row", i, j)) { 228 | // 现在row4已经被记录了; 229 | for (let k = 0; k < num; k++) { 230 | datalist[i][j + k][1] = 1 231 | } 232 | // 把横4的i,j记录进去; 233 | obj[arrayType].row[row] = []; 234 | obj[arrayType].row[row][0] = j; 235 | obj[arrayType].row[row][1] = i 236 | row = row + 1; 237 | } else { 238 | continue; 239 | } 240 | } 241 | } else { 242 | continue 243 | } 244 | } 245 | } 246 | } 247 | } 248 | if (imginfo[`col${num}`]) { 249 | pain(cyt, obj[arrayType].col, 1, num, imginfo[`col${num}`]); 250 | } 251 | if (imginfo[`row${num}`]) { 252 | pain(cyt, obj[arrayType].row, num, 1, imginfo[`row${num}`]); 253 | } 254 | } else { 255 | return 256 | } 257 | } 258 | // 统计田 259 | function countTian(cyt, img) { 260 | if (img) { 261 | var tian = 0; 262 | var arrayTian = []; 263 | for (let i = 0; i < datacol - 2; i++) { 264 | // 遍历每一个数组里的值 265 | for (let j = 0; j < datacol - 2; j++) { 266 | // 如果这个小方块没有上色或者这个小方块被记录过了,那么我们就不用管它了! 267 | if (datalist[i][j][1] == 1) { 268 | continue; 269 | } else { 270 | if ( 271 | datalist[i][j][0] == 1 && 272 | datalist[i][j][1] == 0 && 273 | datalist[i + 1][j][0] == 1 && 274 | datalist[i + 1][j][1] == 0 && 275 | datalist[i][j + 1][0] == 1 && 276 | datalist[i][j + 1][1] == 0 && 277 | datalist[i + 1][j + 1][0] == 1 && 278 | datalist[i + 1][j + 1][1] == 0) { 279 | // 现在positive7已经被记录了; 280 | datalist[i][j][1] = 1 281 | datalist[i + 1][j][1] = 1 282 | datalist[i][j + 1][1] = 1 283 | datalist[i + 1][j + 1][1] = 1 284 | // 把竖7的i,j记录进去; 285 | // 开始收收集7行的小方块数据; 286 | arrayTian[tian] = []; 287 | arrayTian[tian][0] = j; 288 | arrayTian[tian][1] = i 289 | tian = tian + 1; 290 | } else { 291 | continue; 292 | } 293 | } 294 | } 295 | } 296 | pain(cyt, arrayTian, 2, 2, img); 297 | } else { 298 | return 299 | } 300 | 301 | } 302 | // 统计方块反7正7的个数 303 | function count7(cyt, imginfo) { 304 | var positive7 = 0; 305 | var reverse7 = 0; 306 | var arrayPositive7 = []; 307 | var arrayRever7 = []; 308 | if (imginfo.re7 || imginfo.po7) { 309 | for (let i = 0; i < datacol - 2; i++) { 310 | // 遍历每一个数组里的值 311 | for (let j = 0; j < datacol - 2; j++) { 312 | // 如果这个小方块没有上色或者这个小方块被记录过了,那么我们就不用管它了! 313 | if (datalist[i][j][1] == 1) { 314 | continue; 315 | } else { 316 | // 随机记录正反7 317 | if (parseInt(Math.random() * 2) == 1) { 318 | if (imginfo.po7) { 319 | // 判断是否超出; 320 | // 否则判断他是否是正7。 321 | if (datalist[i][j][0] == 1 && 322 | datalist[i][j][1] == 0 && 323 | datalist[i + 1][j][0] == 0 && 324 | datalist[i][j + 1][0] == 1 && 325 | datalist[i][j + 1][1] == 0 && 326 | datalist[i + 1][j + 1][0] == 1 && 327 | datalist[i + 1][j + 1][1] == 0) { 328 | // 现在positive7已经被记录了; 329 | datalist[i][j][1] = 1 330 | datalist[i][j + 1][1] = 1 331 | datalist[i + 1][j + 1][1] = 1 332 | // 把竖7的i,j记录进去; 333 | // 开始收收集7行的小方块数据; 334 | arrayPositive7[positive7] = []; 335 | arrayPositive7[positive7][0] = j; 336 | arrayPositive7[positive7][1] = i 337 | positive7 = positive7 + 1; 338 | } else { 339 | continue; 340 | } 341 | } else { 342 | continue 343 | } 344 | } else { 345 | if (imginfo.re7) { 346 | // 反7 347 | if (datalist[i][j][0] == 1 && 348 | datalist[i][j][1] == 0 && 349 | datalist[i + 1][j + 1][0] == 0 && 350 | datalist[i][j + 1][0] == 1 && 351 | datalist[i][j + 1][1] == 0 && 352 | datalist[i + 1][j][0] == 1 && 353 | datalist[i + 1][j][1] == 0) { 354 | // 现在positive7已经被记录了; 355 | datalist[i][j][1] = 1 356 | datalist[i][j + 1][1] = 1 357 | datalist[i + 1][j][1] = 1 358 | // 把竖7的i,j记录进去; 359 | // 开始收收集7行的小方块数据; 360 | arrayRever7[reverse7] = []; 361 | arrayRever7[reverse7][0] = j; 362 | arrayRever7[reverse7][1] = i 363 | reverse7 = reverse7 + 1; 364 | } else { 365 | continue; 366 | } 367 | } else { 368 | continue 369 | } 370 | // 开始收收集7行的小方块数据; 371 | // 否则判断他是否是横7。 372 | } 373 | } 374 | } 375 | } 376 | if (imginfo.re7) { 377 | pain(cyt, arrayRever7, 2, 2, imginfo.re7) 378 | } 379 | if (imginfo.po7) { 380 | pain(cyt, arrayPositive7, 2, 2, imginfo.po7) 381 | } 382 | } else { 383 | return 384 | } 385 | } 386 | // 统计剩余1单个方块 387 | function count1(cyt, img) { 388 | if (img) { 389 | var col1 = 0; 390 | var array1 = []; 391 | for (let i = 0; i < datacol; i++) { 392 | // 遍历每一个数组里的值 393 | for (let j = 0; j < datacol; j++) { 394 | // 如果这个小方块没有上色或者这个小方块被记录过了,那么我们就不用管它了! 395 | if (datalist[i][j][1] == 1) { 396 | continue; 397 | } else { 398 | datalist[i][j][1] = 1 399 | // 剩下的按单个记录保存; 400 | array1[col1] = []; 401 | array1[col1][0] = j; 402 | array1[col1][1] = i 403 | col1 = col1 + 1; 404 | } 405 | } 406 | } 407 | pain(cyt, array1, 1, 1, img); 408 | } else { 409 | return 410 | } 411 | } 412 | export default { 413 | getqrcode 414 | }; -------------------------------------------------------------------------------- /miniprogram/js/common.js: -------------------------------------------------------------------------------- 1 | // 图片转base64 2 | function urlTobase64(imgPath) { 3 | return new Promise((resolve, reject) => { 4 | //读取图片的base64文件内容 5 | wx.getFileSystemManager().readFile({ 6 | filePath: imgPath, //选择图片返回的相对路径 7 | encoding: 'base64', //编码格式 8 | success: (res) => { 9 | var data = res.data; 10 | resolve(data) 11 | }, //成功的回调 12 | fail: (err) => { 13 | reject(err) 14 | } 15 | }) 16 | }) 17 | } 18 | // 上传单张图片 19 | function uploadSingleImg(base64) { 20 | return new Promise((resolve, reject) => { 21 | wx.cloud.callFunction({ 22 | // 需调用的云函数名 23 | name: 'uploadImg', 24 | // 传给云函数的参数 25 | data: { 26 | file_data: base64 27 | }, 28 | // 成功回调 29 | complete: (res) => { 30 | resolve(res.result.fileID) 31 | } 32 | }) 33 | }) 34 | } 35 | 36 | async function checkText(text) { 37 | return new Promise((resolve, reject) => { 38 | // 先鉴黄 39 | wx.cloud.callFunction({ 40 | // 需调用的云函数名 41 | name: 'checkeText', 42 | // 传给云函数的参数 43 | data: { 44 | txt: text 45 | }, 46 | // 成功回调 47 | complete: (res) => { 48 | resolve(res.result); // 将结果传递给 resolve 方法 49 | }, 50 | // 失败回调 51 | fail: (error) => { 52 | reject(error); // 如果有错误,传递给 reject 方法 53 | } 54 | }); 55 | }); 56 | } 57 | 58 | export default { 59 | urlTobase64, 60 | uploadSingleImg, 61 | checkText 62 | } -------------------------------------------------------------------------------- /miniprogram/js/getqrcode.js: -------------------------------------------------------------------------------- 1 | /** 2 | * @fileoverview 3 | * - Using the 'QRCode for Javascript library' 4 | * - Fixed dataset of 'QRCode for Javascript library' for support full-spec. 5 | * - this library has no dependencies. 6 | * 7 | * @author davidshimjs 8 | * @see http://www.d-project.com/ 9 | * @see http://jeromeetienne.github.com/jquery-qrcode/ 10 | */ 11 | var QRCode; 12 | 13 | //--------------------------------------------------------------------- 14 | // QRCode for JavaScript 15 | // 16 | // Copyright (c) 2009 Kazuhiko Arase 17 | // 18 | // URL: http://www.d-project.com/ 19 | // 20 | // Licensed under the MIT license: 21 | // http://www.opensource.org/licenses/mit-license.php 22 | // 23 | // The word "QR Code" is registered trademark of 24 | // DENSO WAVE INCORPORATED 25 | // http://www.denso-wave.com/qrcode/faqpatent-e.html 26 | // 27 | //--------------------------------------------------------------------- 28 | function QR8bitByte(data) { 29 | this.mode = QRMode.MODE_8BIT_BYTE; 30 | this.data = data; 31 | this.parsedData = []; 32 | 33 | // Added to support UTF-8 Characters 34 | for (var i = 0, l = this.data.length; i < l; i++) { 35 | var byteArray = []; 36 | var code = this.data.charCodeAt(i); 37 | 38 | if (code > 0x10000) { 39 | byteArray[0] = 0xF0 | ((code & 0x1C0000) >>> 18); 40 | byteArray[1] = 0x80 | ((code & 0x3F000) >>> 12); 41 | byteArray[2] = 0x80 | ((code & 0xFC0) >>> 6); 42 | byteArray[3] = 0x80 | (code & 0x3F); 43 | } else if (code > 0x800) { 44 | byteArray[0] = 0xE0 | ((code & 0xF000) >>> 12); 45 | byteArray[1] = 0x80 | ((code & 0xFC0) >>> 6); 46 | byteArray[2] = 0x80 | (code & 0x3F); 47 | } else if (code > 0x80) { 48 | byteArray[0] = 0xC0 | ((code & 0x7C0) >>> 6); 49 | byteArray[1] = 0x80 | (code & 0x3F); 50 | } else { 51 | byteArray[0] = code; 52 | } 53 | 54 | this.parsedData.push(byteArray); 55 | } 56 | 57 | this.parsedData = Array.prototype.concat.apply([], this.parsedData); 58 | 59 | if (this.parsedData.length != this.data.length) { 60 | this.parsedData.unshift(191); 61 | this.parsedData.unshift(187); 62 | this.parsedData.unshift(239); 63 | } 64 | } 65 | 66 | QR8bitByte.prototype = { 67 | getLength: function (buffer) { 68 | return this.parsedData.length; 69 | }, 70 | write: function (buffer) { 71 | for (var i = 0, l = this.parsedData.length; i < l; i++) { 72 | buffer.put(this.parsedData[i], 8); 73 | } 74 | } 75 | }; 76 | 77 | function QRCodeModel(typeNumber, errorCorrectLevel) { 78 | this.typeNumber = typeNumber; 79 | this.errorCorrectLevel = errorCorrectLevel; 80 | this.modules = null; 81 | this.moduleCount = 0; 82 | this.dataCache = null; 83 | this.dataList = []; 84 | } 85 | 86 | QRCodeModel.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);} 87 | return this.modules[row][col];},getModuleCount:function(){return this.moduleCount;},make:function(){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=7){this.setupTypeNumber(test);} 89 | if(this.dataCache==null){this.dataCache=QRCodeModel.createData(this.typeNumber,this.errorCorrectLevel,this.dataList);} 90 | 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;}} 91 | 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>i)&1)==1);this.modules[Math.floor(i/3)][i%3+this.moduleCount-8-3]=mod;} 97 | 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);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;}} 98 | for(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;}} 99 | this.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>>bitIndex)&1)==1);} 100 | var mask=QRUtil.getMask(maskPattern,row,col-c);if(mask){dark=!dark;} 101 | this.modules[row][col-c]=dark;bitIndex--;if(bitIndex==-1){byteIndex++;bitIndex=7;}}} 102 | row+=inc;if(row<0||this.moduleCount<=row){row-=inc;inc=-inc;break;}}}}};QRCodeModel.PAD0=0xEC;QRCodeModel.PAD1=0x11;QRCodeModel.createData=function(typeNumber,errorCorrectLevel,dataList){var rsBlocks=QRRSBlock.getRSBlocks(typeNumber,errorCorrectLevel);var buffer=new QRBitBuffer();for(var i=0;itotalDataCount*8){throw new Error("code length overflow. (" 105 | +buffer.getLengthInBits() 106 | +">" 107 | +totalDataCount*8 108 | +")");} 109 | if(buffer.getLengthInBits()+4<=totalDataCount*8){buffer.put(0,4);} 110 | while(buffer.getLengthInBits()%8!=0){buffer.putBit(false);} 111 | while(true){if(buffer.getLengthInBits()>=totalDataCount*8){break;} 112 | buffer.put(QRCodeModel.PAD0,8);if(buffer.getLengthInBits()>=totalDataCount*8){break;} 113 | buffer.put(QRCodeModel.PAD1,8);} 114 | return QRCodeModel.createBytes(buffer,rsBlocks);};QRCodeModel.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=0)?modPoly.get(modIndex):0;}} 116 | var totalCodeCount=0;for(var i=0;i=0){d^=(QRUtil.G15<<(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G15)));} 120 | 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)));} 121 | return(data<<12)|d;},getBCHDigit:function(data){var digit=0;while(data!=0){digit++;data>>>=1;} 122 | 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;i5){lostPoint+=(3+sameCount-5);}}} 128 | for(var row=0;row=256){n-=255;} 135 | 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<>>(7-index%8))&1)==1;},put:function(num,length){for(var i=0;i>>(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);} 150 | if(bit){this.buffer[bufIndex]|=(0x80>>>(this.length%8));} 151 | this.length++;}};var QRCodeLimitLength=[[17,14,11,7],[32,26,20,14],[53,42,32,24],[78,62,46,34],[106,84,60,44],[134,106,74,58],[154,122,86,64],[192,152,108,84],[230,180,130,98],[271,213,151,119],[321,251,177,137],[367,287,203,155],[425,331,241,177],[458,362,258,194],[520,412,292,220],[586,450,322,250],[644,504,364,280],[718,560,394,310],[792,624,442,338],[858,666,482,382],[929,711,509,403],[1003,779,565,439],[1091,857,611,461],[1171,911,661,511],[1273,997,715,535],[1367,1059,751,593],[1465,1125,805,625],[1528,1190,868,658],[1628,1264,908,698],[1732,1370,982,742],[1840,1452,1030,790],[1952,1538,1112,842],[2068,1628,1168,898],[2188,1722,1228,958],[2303,1809,1283,983],[2431,1911,1351,1051],[2563,1989,1423,1093],[2699,2099,1499,1139],[2809,2213,1579,1219],[2953,2331,1663,1273]]; 152 | 153 | function _isSupportCanvas() { 154 | return typeof CanvasRenderingContext2D != "undefined"; 155 | } 156 | 157 | // android 2.x doesn't support Data-URI spec 158 | // function _getAndroid() { 159 | // var android = false; 160 | // // var sAgent = navigator.userAgent; 161 | 162 | // if (/android/i.test(sAgent)) { // android 163 | // android = true; 164 | // var aMat = sAgent.toString().match(/android ([0-9]\.[0-9])/i); 165 | 166 | // if (aMat && aMat[1]) { 167 | // android = parseFloat(aMat[1]); 168 | // } 169 | // } 170 | 171 | // return android; 172 | // } 173 | 174 | var svgDrawer = (function() { 175 | 176 | var Drawing = function (el, htOption ,callback) { 177 | this._el = el; 178 | this._htOption = htOption; 179 | this._callback = callback; 180 | }; 181 | 182 | Drawing.prototype.draw = function (oQRCode) { 183 | var _htOption = this._htOption; 184 | var _el = this._el; 185 | var nCount = oQRCode.getModuleCount(); 186 | var nWidth = Math.floor(_htOption.width / nCount); 187 | var nHeight = Math.floor(_htOption.height / nCount); 188 | 189 | this.clear(); 190 | 191 | function makeSVG(tag, attrs) { 192 | var el = document.createElementNS('http://www.w3.org/2000/svg', tag); 193 | for (var k in attrs) 194 | if (attrs.hasOwnProperty(k)) el.setAttribute(k, attrs[k]); 195 | return el; 196 | } 197 | 198 | var svg = makeSVG("svg" , {'viewBox': '0 0 ' + String(nCount) + " " + String(nCount), 'width': '100%', 'height': '100%', 'fill': _htOption.colorLight}); 199 | svg.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xlink", "http://www.w3.org/1999/xlink"); 200 | _el.appendChild(svg); 201 | 202 | svg.appendChild(makeSVG("rect", {"fill": _htOption.colorLight, "width": "100%", "height": "100%"})); 203 | svg.appendChild(makeSVG("rect", {"fill": _htOption.colorDark, "width": "1", "height": "1", "id": "template"})); 204 | 205 | for (var row = 0; row < nCount; row++) { 206 | for (var col = 0; col < nCount; col++) { 207 | if (oQRCode.isDark(row, col)) { 208 | var child = makeSVG("use", {"x": String(col), "y": String(row)}); 209 | child.setAttributeNS("http://www.w3.org/1999/xlink", "href", "#template") 210 | svg.appendChild(child); 211 | } 212 | } 213 | } 214 | }; 215 | Drawing.prototype.clear = function () { 216 | while (this._el.hasChildNodes()) 217 | this._el.removeChild(this._el.lastChild); 218 | }; 219 | return Drawing; 220 | })(); 221 | 222 | /** 223 | * Get the type by string length 224 | * 225 | * @private 226 | * @param {String} sText 227 | * @param {Number} nCorrectLevel 228 | * @return {Number} type 229 | */ 230 | function _getTypeNumber(sText, nCorrectLevel) { 231 | var nType = 1; 232 | var length = _getUTF8Length(sText); 233 | 234 | for (var i = 0, len = QRCodeLimitLength.length; i <= len; i++) { 235 | var nLimit = 0; 236 | 237 | switch (nCorrectLevel) { 238 | case QRErrorCorrectLevel.L : 239 | nLimit = QRCodeLimitLength[i][0]; 240 | break; 241 | case QRErrorCorrectLevel.M : 242 | nLimit = QRCodeLimitLength[i][1]; 243 | break; 244 | case QRErrorCorrectLevel.Q : 245 | nLimit = QRCodeLimitLength[i][2]; 246 | break; 247 | case QRErrorCorrectLevel.H : 248 | nLimit = QRCodeLimitLength[i][3]; 249 | break; 250 | } 251 | 252 | if (length <= nLimit) { 253 | break; 254 | } else { 255 | nType++; 256 | } 257 | } 258 | 259 | if (nType > QRCodeLimitLength.length) { 260 | throw new Error("Too long data"); 261 | } 262 | 263 | return nType; 264 | } 265 | 266 | function _getUTF8Length(sText) { 267 | var replacedText = encodeURI(sText).toString().replace(/\%[0-9a-fA-F]{2}/g, 'a'); 268 | return replacedText.length + (replacedText.length != sText ? 3 : 0); 269 | } 270 | 271 | /** 272 | * @class QRCode 273 | * @constructor 274 | * @example 275 | * new QRCode(document.getElementById("test"), "http://jindo.dev.naver.com/collie"); 276 | * 277 | * @example 278 | * var oQRCode = new QRCode("test", { 279 | * text : "http://naver.com", 280 | * width : 128, 281 | * height : 128 282 | * }); 283 | * 284 | * oQRCode.clear(); // Clear the QRCode. 285 | * oQRCode.makeCode("http://map.naver.com"); // Re-create the QRCode. 286 | * 287 | * @param {HTMLElement|String} el target element or 'id' attribute of element. 288 | * @param {Object|String} vOption 289 | * @param {String} vOption.text QRCode link data 290 | * @param {Number} [vOption.width=256] 291 | * @param {Number} [vOption.height=256] 292 | * @param {String} [vOption.colorDark="#000000"] 293 | * @param {String} [vOption.colorLight="#ffffff"] 294 | * @param {QRCode.CorrectLevel} [vOption.correctLevel=QRCode.CorrectLevel.H] [L|M|Q|H] 295 | */ 296 | QRCode = function (vOption,fn ) { 297 | this._htOption = { 298 | width : 256, 299 | height : 256, 300 | typeNumber : 4, 301 | colorDark : "#000000", 302 | colorLight : "#ffffff", 303 | correctLevel : QRErrorCorrectLevel.H 304 | }; 305 | 306 | if (typeof vOption === 'string') { 307 | vOption = { 308 | text : vOption 309 | }; 310 | } 311 | 312 | // Overwrites options 313 | if (vOption) { 314 | for (var i in vOption) { 315 | this._htOption[i] = vOption[i]; 316 | } 317 | } 318 | 319 | this._oQRCode = null; 320 | if (this._htOption.text) { 321 | this.makeCode(this._htOption.text); 322 | } 323 | }; 324 | 325 | /** 326 | * Make the QRCode 327 | * 328 | * @param {String} sText link data 329 | */ 330 | QRCode.prototype.makeCode = function (sText) { 331 | this._oQRCode = new QRCodeModel(_getTypeNumber(sText, this._htOption.correctLevel), this._htOption.correctLevel); 332 | this._oQRCode.addData(sText); 333 | this._oQRCode.make(); 334 | }; 335 | 336 | /** 337 | * Make the Image from Canvas element 338 | * - It occurs automatically 339 | * - Android below 3 doesn't support Data-URI spec. 340 | * 341 | * @private 342 | */ 343 | QRCode.prototype.makeImage = function () { 344 | if (typeof this._oDrawing.makeImage == "function" && (!this._android || this._android >= 3)) { 345 | this._oDrawing.makeImage(); 346 | } 347 | }; 348 | 349 | /** 350 | * Clear the QRCode 351 | */ 352 | QRCode.prototype.clear = function () { 353 | this._oDrawing.clear(); 354 | }; 355 | 356 | /** 357 | * @name QRCode.CorrectLevel 358 | */ 359 | QRCode.CorrectLevel = QRErrorCorrectLevel; 360 | 361 | 362 | export default QRCode; -------------------------------------------------------------------------------- /miniprogram/pages/checkqr/checkqr.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrlist/qrlist.js 2 | Page({ 3 | 4 | /** 5 | * 页面的初始数据 6 | */ 7 | data: { 8 | list: [], 9 | total: null, 10 | limit: 10, //每页数量 11 | pageid: 1, 12 | datatype: 0, 13 | ifloading: false 14 | }, 15 | getall() { 16 | this.setData({ 17 | datatype: 0 18 | }) 19 | this.firstgetdatalist(); 20 | }, 21 | getpublish() { 22 | this.setData({ 23 | datatype: 1 24 | }) 25 | this.firstgetdatalist(); 26 | }, 27 | getwait() { 28 | this.setData({ 29 | datatype: 2 30 | }) 31 | this.firstgetdatalist(); 32 | }, 33 | qrpublish(e) { 34 | var id = e.currentTarget.dataset.qrid; 35 | var qrpublish = !e.currentTarget.dataset.publish; 36 | wx.cloud.callFunction({ 37 | // 需调用的云函数名 38 | name: 'publishQR', 39 | // 传给云函数的参数 40 | data: { 41 | qr_id: id, 42 | publish: qrpublish 43 | }, 44 | // 成功回调 45 | complete: (res) => { 46 | for (let i = 0; i < this.data.list.length; i++) { 47 | if (this.data.list[i]._id == id) { 48 | var publish = `list[${i}].publish`; 49 | this.setData({ 50 | [publish]: qrpublish 51 | }) 52 | break; 53 | } 54 | } 55 | } 56 | }) 57 | 58 | }, 59 | firstgetdatalist() { 60 | this.setData({ 61 | ifloading: true 62 | }) 63 | wx.cloud.callFunction({ 64 | // 需调用的云函数名 65 | name: 'getQRElementList', 66 | // 传给云函数的参数 67 | data: { 68 | limit: this.data.limit, 69 | page_index: 0, 70 | datatype: this.data.datatype, 71 | self: false 72 | }, 73 | // 成功回调 74 | complete: (res) => { 75 | var list = res.result.data.list; 76 | for (let i = 0; i < list.length; i++) { 77 | list[i].select = false; 78 | } 79 | var total = Math.ceil(res.result.data.total / this.data.limit); 80 | this.setData({ 81 | total: total, 82 | list: list, 83 | ifloading: false 84 | }) 85 | } 86 | }) 87 | }, 88 | getdatalist(pageid) { 89 | this.setData({ 90 | ifloading: true 91 | }) 92 | wx.cloud.callFunction({ 93 | // 需调用的云函数名 94 | name: 'getQRElementList', 95 | // 传给云函数的参数 96 | data: { 97 | limit: this.data.limit, 98 | page_index: pageid - 1, 99 | datatype: this.data.datatype, 100 | self: false 101 | }, 102 | // 成功回调 103 | complete: (res) => { 104 | var list = res.result.data.list; 105 | for (let i = 0; i < list.length; i++) { 106 | list[i].select = false; 107 | } 108 | var total = Math.ceil(res.result.data.total / this.data.limit); 109 | this.setData({ 110 | total: total, 111 | list: list, 112 | ifloading: false 113 | }) 114 | } 115 | }) 116 | }, 117 | prepage() { 118 | if (this.data.pageid <= this.data.total && this.data.pageid > 1) { 119 | this.setData({ 120 | pageid: this.data.pageid - 1 121 | }) 122 | this.getdatalist(this.data.pageid) 123 | } 124 | }, 125 | nextpage() { 126 | if (this.data.pageid < this.data.total) { 127 | this.setData({ 128 | pageid: this.data.pageid + 1 129 | }) 130 | this.getdatalist(this.data.pageid) 131 | } 132 | } 133 | }) -------------------------------------------------------------------------------- /miniprogram/pages/checkqr/checkqr.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "icon":"../../components/icon/icon", 7 | "btn":"../../components/btn/btn", 8 | "cell":"../../components/cell/cell", 9 | "popbox":"../../components/popbox/popbox", 10 | "avatar":"../../components/avatar/avatar", 11 | "missbox":"../../components/missbox/missbox", 12 | "contain":"../../components/contain/contain" 13 | }, 14 | "navigationStyle": "custom" 15 | } -------------------------------------------------------------------------------- /miniprogram/pages/checkqr/checkqr.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 全部 6 | 已上架 7 | 未上架 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | {{item.element_name}} 16 | 17 | 18 | {{item._author_name}} 19 | 20 | 21 | {{item.publish?"下架":"上架"}} 22 | 23 | 24 | 25 | 26 | cover 27 | 28 | 29 | 30 | one 31 | 32 | 33 | 34 | eye 35 | 36 | 37 | 38 | col2 39 | 40 | 41 | 42 | col3 43 | 44 | 45 | 46 | col4 47 | 48 | 49 | 50 | row2 51 | 52 | 53 | 54 | row3 55 | 56 | 57 | 58 | row4 59 | 60 | 61 | 62 | tian 63 | 64 | 65 | 66 | po7 67 | 68 | 69 | 70 | re7 71 | 72 | 73 | 74 | 75 | 76 | 77 | -------------------------------------------------------------------------------- /miniprogram/pages/checkqr/checkqr.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/qrlist/qrlist.wxss */ 2 | .opt{ 3 | display: flex; 4 | align-items: center; 5 | justify-content: center; 6 | } 7 | 8 | .list { 9 | padding: 0 32rpx; 10 | } 11 | 12 | .item { 13 | position: relative; 14 | width: 100%; 15 | display: inline-block; 16 | overflow: hidden; 17 | box-sizing: border-box; 18 | border-radius: 32rpx; 19 | margin: 16rpx 0; 20 | } 21 | 22 | .item-hd { 23 | padding: 20rpx 32rpx; 24 | border-bottom: solid 4rpx #000; 25 | display: flex; 26 | justify-content: space-between; 27 | align-items: center; 28 | } 29 | 30 | .item-hd-tit { 31 | font-weight: bold; 32 | font-size: 48rpx; 33 | } 34 | 35 | .item-hd-user { 36 | display: flex; 37 | align-items: center; 38 | } 39 | 40 | .user-name { 41 | margin-left: 20rpx; 42 | } 43 | 44 | .item-bd { 45 | padding: 32rpx; 46 | display: flex; 47 | flex-wrap: wrap; 48 | } 49 | 50 | .img-item { 51 | width: 100rpx; 52 | text-align: center; 53 | margin: 10rpx; 54 | } 55 | 56 | .img-item image { 57 | width: 100rpx; 58 | height: 100rpx; 59 | } -------------------------------------------------------------------------------- /miniprogram/pages/designrule/designrule.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/index/index.js 2 | Page({ 3 | 4 | /** 5 | * 页面的初始数据 6 | */ 7 | data: { 8 | 9 | }, 10 | goupload() { 11 | wx.navigateTo({ 12 | url: '/pages/upload/upload' 13 | }) 14 | } 15 | }) -------------------------------------------------------------------------------- /miniprogram/pages/designrule/designrule.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "icon":"../../components/icon/icon", 7 | "btn":"../../components/btn/btn", 8 | "popbox":"../../components/popbox/popbox", 9 | "cell":"../../components/cell/cell", 10 | "contain":"../../components/contain/contain" 11 | }, 12 | "navigationStyle": "custom" 13 | } -------------------------------------------------------------------------------- /miniprogram/pages/designrule/designrule.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 设计指引 6 | 亲爱的用户: 7 | ٩(๑❛ᴗ❛๑)۶,欢迎使用艺术二维码生成器。现在让我来告诉你如何设计对应的素材吧~ 8 | 我们常见认知的二维码是黑白两色的,但其实它是可以彩色的。 9 | 10 | 11 | ヾ(◍°∇°◍)ノ゙上面两个二维码是同一个哦~ 12 | 我们可以将黑白二维码拆分成以下11个基础元素: 13 | 14 | ヾ(✿゚▽゚)ノ提取基础的元素 15 | 将它们都放在网格中,我们发现它之间是有比例的。 16 | 17 | 18 | 关于二维码的原理,在这里便不再多说。有兴趣可以去查阅相关资料。回到这里,现在我们在黑色区域进行设计。 19 | 20 | 21 | (▼へ▼メ)一定要按照比例设计导出图片哦~ 22 | 23 | 24 | 建议最小码点尺寸为:50 * 50px,分辨率:300 25 | 26 | 注意:设计时要保证设计面覆盖在码点中心即9分之一圆心上。 27 | 28 | 29 | 30 | 两个码点也是这样的道理。 31 | 32 | 33 | 34 | 最后导出小图片: 35 | 36 | 37 | o(▼皿▼メ;)o按比例导出素材,命名随意 38 | 将图片上传对对应的示例图中,最后取个名字上传就可以成功啦~ 39 | 40 | (╬◣д◢)必须上传封面图、码眼、单元素图片哦 41 | 是不是很简单,快去尝试一下吧,制作自己的专属艺术二维码。最后在我的界面中,选中你刚才上传的素材包,就可以生成漂亮的艺术二维码啦~ 42 | 合作与建议:可以添加微信“mengmeng-na”与我联系哦~ 43 | 现在去制作 44 | 45 | -------------------------------------------------------------------------------- /miniprogram/pages/designrule/designrule.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/designrule/designrule.wxss */ 2 | .rule-box { 3 | background: #fff; 4 | border: 4rpx solid #000000; 5 | box-shadow: var(--box-shadow); 6 | border-radius: 40rpx; 7 | font-size: 24rpx; 8 | margin: 32rpx; 9 | padding: 32rpx; 10 | text-align: center; 11 | height: 70%; 12 | box-sizing: border-box; 13 | overflow: scroll; 14 | } 15 | .h1{ 16 | font-size: 40rpx; 17 | font-weight: bold; 18 | margin-bottom: 32rpx; 19 | } 20 | .tit { 21 | font-size: 30rpx; 22 | margin-bottom: 30rpx; 23 | text-align: left; 24 | } 25 | 26 | .txt { 27 | line-height: 40rpx; 28 | margin-bottom: 10rpx; 29 | text-indent: 2em; 30 | text-align: left; 31 | } 32 | 33 | .tip { 34 | font-size: 20rpx; 35 | color: var(--tip-1); 36 | line-height: 40rpx; 37 | text-align: center; 38 | } 39 | 40 | .img-short { 41 | width: 200rpx; 42 | height: 200rpx; 43 | } 44 | 45 | .img-long { 46 | width: 400rpx; 47 | } -------------------------------------------------------------------------------- /miniprogram/pages/imgmade/imgmade.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrlist/qrlist.js 2 | import qrcode from '../../js/artqrcoed.js'; 3 | import common from '../../js/common.js'; 4 | 5 | Page({ 6 | 7 | /** 8 | * 页面的初始数据 9 | */ 10 | data: { 11 | styleInfo: null, 12 | imginfo: null, 13 | qrinfo: { 14 | canvasid: 'qrcode', 15 | size: '', 16 | text: '', 17 | img: '' 18 | }, 19 | ifmadeqr: false, 20 | pbqr: false, 21 | pbtip: false, 22 | tip: "", 23 | checkqrimg: false 24 | }, 25 | addlikenum(id) { 26 | wx.cloud.callFunction({ 27 | // 需调用的云函数名 28 | name: 'reportQRLike', 29 | // 传给云函数的参数 30 | data: { 31 | qr_id: id 32 | }, 33 | // 成功回调 34 | complete: (res) => { 35 | console.log("add 1") 36 | } 37 | }) 38 | }, 39 | saveimg() { 40 | var that = this; 41 | wx.canvasToTempFilePath({ 42 | x: 0, 43 | y: 0, 44 | width: that.data.qrinfo.size, 45 | height: that.data.qrinfo.size, 46 | canvasId: that.data.qrinfo.canvasid, 47 | success: function (data) { 48 | wx.saveImageToPhotosAlbum({ 49 | filePath: data.tempFilePath, 50 | success: (res) => { 51 | console.log("保存成功") 52 | }, 53 | fail: (err) => {} 54 | }) 55 | } 56 | }) 57 | }, 58 | getsize() { 59 | return new Promise((resolve, reject) => { 60 | var that = this; 61 | var query = wx.createSelectorQuery(); 62 | query.select('.qrcode').boundingClientRect(function (rect) { 63 | var qrsize = 'qrinfo.size' 64 | that.setData({ 65 | [qrsize]: rect.height 66 | }) 67 | resolve(); 68 | }).exec(); 69 | }) 70 | }, 71 | async madeImg() { 72 | var that = this; 73 | if (this.data.qrinfo.img == '') { 74 | this.setData({ 75 | tip: '(▼へ▼メ)请上传黑白二维码吖~', 76 | pbtip: true 77 | }) 78 | return 79 | } 80 | if (this.data.styleInfo == null) { 81 | this.setData({ 82 | tip: 'o(▼皿▼メ;)o请选择二维码风格吖~', 83 | pbtip: true 84 | }) 85 | return 86 | } 87 | 88 | this.setData({ 89 | pbimg: false, 90 | pbqr: true 91 | }) 92 | await this.manageimgs(); 93 | this.getsize().then(() => { 94 | this.addlikenum(this.data.styleInfo._id); 95 | qrcode.getqrcode(this.data.qrinfo, this.data.imginfo).then(() => { 96 | that.setData({ 97 | ifmadeqr: true 98 | }) 99 | }); 100 | }); 101 | }, 102 | uploadimg() { 103 | var that = this; 104 | wx.chooseImage({ 105 | count: 1, 106 | sizeType: ['compressed'], 107 | sourceType: ['album', 'camera'], 108 | success: function (res) { 109 | that.setData({ 110 | pbtip: true, 111 | checkqrimg: true, 112 | tip: "正在检验二维码中٩(๑❛ᴗ❛๑)۶" 113 | }) 114 | var imgurl = res.tempFilePaths[0]; 115 | // 图片转base64 116 | common.urlTobase64(imgurl).then(data => { 117 | // 上传单个图片 118 | common.uploadSingleImg(data).then(imgfileId => { 119 | // 扫码识别 s 120 | wx.cloud.callFunction({ 121 | // 需调用的云函数名 122 | name: 'decode', 123 | // 传给云函数的参数 124 | data: { 125 | fileid: imgfileId 126 | }, 127 | // 成功回调 128 | complete: (res) => { 129 | var qrdata = res.result; 130 | if (qrdata.length > 0) { 131 | var qrimg = `qrinfo.img` 132 | var qrtext = `qrinfo.text` 133 | var text = qrdata[0].data; 134 | that.setData({ 135 | [qrimg]: imgurl, 136 | [qrtext]: text 137 | }) 138 | wx.setStorage({ 139 | key: "qrimg", 140 | data: imgurl 141 | }) 142 | wx.setStorage({ 143 | key: "qrtxt", 144 | data: text 145 | }) 146 | that.setData({ 147 | pbtip: false, 148 | checkqrimg: false, 149 | tip: "٩(๑❛ᴗ❛๑)۶" 150 | }) 151 | } else { 152 | var qrimg = `qrinfo.img` 153 | 154 | that.setData({ 155 | pbtip: true, 156 | checkqrimg: false, 157 | tip: "我怀疑你上传的是假的二维码(╥╯^╰╥),请重新上传一个真的好不?", 158 | [qrimg]:'' 159 | }) 160 | } 161 | } 162 | }) 163 | // 扫码识别 e 164 | }); 165 | }) 166 | } 167 | }) 168 | }, 169 | goqrlist() { 170 | wx.navigateTo({ 171 | url: '/pages/qrlist/qrlist?pagefrom=imgmade' 172 | }) 173 | }, 174 | close() { 175 | this.setData({ 176 | pbqr: false, 177 | pbtip: false, 178 | ifmadeqr: false 179 | }) 180 | }, 181 | async manageimgs() { 182 | var info = this.data.styleInfo; 183 | var imgs = { 184 | eye: info.eye, 185 | one: info.one, 186 | tian: info.tian, 187 | col2: info.col2, 188 | col3: info.col3, 189 | col4: info.col4, 190 | row2: info.row2, 191 | row3: info.row3, 192 | row4: info.row4, 193 | re7: info.re7, 194 | po7: info.po7, 195 | } 196 | for (const key in imgs) { 197 | if (imgs.hasOwnProperty(key)) { 198 | const element = imgs[key]; 199 | if (element) { 200 | await wx.cloud.downloadFile({ 201 | fileID: element 202 | }).then(res => { 203 | imgs[key] = res.tempFilePath; 204 | }).catch(error => {}) 205 | } 206 | 207 | } 208 | } 209 | this.setData({ 210 | imginfo: imgs 211 | }) 212 | }, 213 | /** 214 | * 生命周期函数--监听页面加载 215 | */ 216 | onLoad: function (options) { 217 | var that = this; 218 | if (options.info) { 219 | var info = JSON.parse(options.info) 220 | this.setData({ 221 | styleInfo: info 222 | }) 223 | wx.getStorage({ 224 | key: 'qrimg', 225 | success(res) { 226 | var img = `qrinfo.img` 227 | that.setData({ 228 | [img]: res.data 229 | }) 230 | } 231 | }) 232 | wx.getStorage({ 233 | key: 'qrtxt', 234 | success(res) { 235 | var text = `qrinfo.text` 236 | that.setData({ 237 | [text]: res.data 238 | }) 239 | } 240 | }) 241 | } 242 | } 243 | }) -------------------------------------------------------------------------------- /miniprogram/pages/imgmade/imgmade.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "cell":"../../components/cell/cell", 7 | "icon":"../../components/icon/icon", 8 | "btn":"../../components/btn/btn", 9 | "missbox":"../../components/missbox/missbox", 10 | "popbox":"../../components/popbox/popbox", 11 | "contain":"../../components/contain/contain" 12 | }, 13 | "navigationStyle": "custom" 14 | } -------------------------------------------------------------------------------- /miniprogram/pages/imgmade/imgmade.wxml: -------------------------------------------------------------------------------- 1 | 美化二维码 2 | 3 | 一、上传二维码: 4 | 5 | 6 | 7 | 8 | 二、选择风格: 9 | 10 | 11 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 生成以后请用手机扫描验证是否能识别 23 | 生成 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 保存 33 | 34 | 35 | 36 | 37 | 38 | {{tip}} 39 | -------------------------------------------------------------------------------- /miniprogram/pages/imgmade/imgmade.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/txtmade/txtmad.wxss */ 2 | .tit { 3 | font-size: 36rpx; 4 | font-weight: bold; 5 | color: #fff; 6 | margin: 32rpx; 7 | display: flex; 8 | justify-content: space-between; 9 | } 10 | 11 | .input { 12 | border-radius: 10rpx; 13 | border: 4rpx solid #000000; 14 | box-sizing: border-box; 15 | box-shadow: var(--box-shadow); 16 | background: #fff; 17 | font-size: 32rpx; 18 | font-weight: bold; 19 | border-radius: 32rpx; 20 | margin-bottom: 50rpx; 21 | height: 200rpx; 22 | margin: 0 32rpx; 23 | box-sizing: border-box; 24 | text-align: left; 25 | padding: 20rpx; 26 | } 27 | 28 | content { 29 | text-align: center; 30 | } 31 | 32 | .item-qr { 33 | width: 330rpx; 34 | box-sizing: border-box; 35 | text-align: center; 36 | margin: 0 auto; 37 | margin-bottom: 30rpx; 38 | } 39 | 40 | .item { 41 | width: 330rpx; 42 | box-sizing: border-box; 43 | text-align: center; 44 | margin: 0 auto; 45 | margin-bottom: 30rpx; 46 | } 47 | 48 | .icon-add { 49 | margin: 150rpx 0; 50 | } 51 | 52 | .upload-img { 53 | width: 200rpx; 54 | height: 200rpx; 55 | margin: 0 auto; 56 | display: flex; 57 | justify-content: center; 58 | align-items: center; 59 | } 60 | 61 | .upload-img image { 62 | width: 100%; 63 | height: 100%; 64 | } 65 | 66 | 67 | 68 | .qrcode { 69 | margin: 30rpx auto; 70 | display: block; 71 | } 72 | 73 | .opt { 74 | text-align: center; 75 | } 76 | 77 | .missbox { 78 | position: absolute; 79 | width: 70%; 80 | left: 0; 81 | right: 0; 82 | top: 0; 83 | bottom: 0; 84 | height: 90%; 85 | background: #fff; 86 | z-index: 9; 87 | margin: auto; 88 | } 89 | .tip{ 90 | margin:0 32rpx; 91 | color:var(--tip-1); 92 | font-size: var(--size-tip-1); 93 | } 94 | .tip-key{ 95 | color: black; 96 | } -------------------------------------------------------------------------------- /miniprogram/pages/index/index.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/index/index.js 2 | Page({ 3 | 4 | /** 5 | * 页面的初始数据 6 | */ 7 | data: { 8 | openid:null 9 | }, 10 | gotxtmade() { 11 | wx.navigateTo({ 12 | url: '/pages/txtmade/txtmade' 13 | }) 14 | }, 15 | goimgmade() { 16 | wx.navigateTo({ 17 | url: '/pages/imgmade/imgmade' 18 | }) 19 | }, 20 | goqrlist() { 21 | wx.navigateTo({ 22 | url: '/pages/qrlist/qrlist' 23 | }) 24 | }, 25 | gomylist() { 26 | wx.navigateTo({ 27 | url: '/pages/myqrlist/myqrlist' 28 | }) 29 | }, 30 | gocheck() { 31 | wx.navigateTo({ 32 | url: '/pages/checkqr/checkqr' 33 | }) 34 | }, 35 | /** 36 | * 生命周期函数--监听页面加载 37 | */ 38 | onLoad: function (options) { 39 | var that=this; 40 | wx.removeStorage({ 41 | key: 'qrimg', 42 | success(res) {} 43 | }) 44 | wx.removeStorage({ 45 | key: 'qrtxt', 46 | success(res) {} 47 | }) 48 | 49 | wx.cloud.callFunction({ 50 | // 需调用的云函数名 51 | name: 'login', 52 | // 成功回调 53 | complete: (res) => { 54 | this.setData({ 55 | openid:res.result.openid 56 | }) 57 | } 58 | }) 59 | } 60 | }) -------------------------------------------------------------------------------- /miniprogram/pages/index/index.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "btn":"../../components/btn/btn", 4 | "icon":"../../components/icon/icon" 5 | }, 6 | "navigationStyle": "custom" 7 | } -------------------------------------------------------------------------------- /miniprogram/pages/index/index.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 二维码生成 9 | 10 | 11 | 12 | 13 | 14 | 二维码美化 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 社区 23 | 24 | 25 | 26 | 27 | 28 | 我的 29 | 30 | 31 | 32 | 33 | 34 | 审核 35 | 36 | 37 | 38 | -------------------------------------------------------------------------------- /miniprogram/pages/index/index.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/index/index.wxss */ 2 | /* 标题 */ 3 | .tit{ 4 | font-weight: 900; 5 | font-size: 40rpx; 6 | color: #fff; 7 | } 8 | .content { 9 | position: fixed; 10 | height: 100%; 11 | width: 100%; 12 | top: 0; 13 | bottom: 0; 14 | margin: auto; 15 | text-align: center; 16 | } 17 | 18 | .content image { 19 | margin-top: 200rpx; 20 | width: 450rpx; 21 | height: 340rpx; 22 | } 23 | 24 | .method { 25 | display: flex; 26 | justify-content: center; 27 | } 28 | .method-default { 29 | margin-top: 20rpx; 30 | display: flex; 31 | justify-content: center; 32 | color: #fff; 33 | } 34 | 35 | .method-item { 36 | font-weight: bold; 37 | height: 180rpx; 38 | padding-top: 30rpx; 39 | width: 150rpx; 40 | } 41 | .method-item-txt{ 42 | font-size: 30rpx; 43 | line-height: 30rpx; 44 | font-weight: bold; 45 | } -------------------------------------------------------------------------------- /miniprogram/pages/myqrlist/myqrlist.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrlist/qrlist.js 2 | Page({ 3 | 4 | /** 5 | * 页面的初始数据 6 | */ 7 | data: { 8 | ifsetting: false, 9 | list: [], 10 | total: null, 11 | limit: 4, //每页数量 12 | pageid: 1, 13 | deletelist: [], 14 | misstxt: "数据加载中", 15 | misstype: 'loading', 16 | ifgetinfo: false, 17 | userInfo: { 18 | avatarUrl: '', 19 | nickName: '点击获取信息' 20 | }, 21 | pbtip: false, 22 | tip: 'ヾ(✿゚▽゚)ノ' 23 | }, 24 | close() { 25 | this.setData({ 26 | pbtip: false, 27 | tip: 'ヾ(✿゚▽゚)ノ' 28 | }) 29 | }, 30 | goqrcode(e) { 31 | var data = JSON.stringify(e.currentTarget.dataset.info) 32 | wx.navigateTo({ 33 | url: `/pages/qrcode/qrcode?info=${data}&pagefrom=myqrlist` 34 | }) 35 | }, 36 | delete() { 37 | wx.cloud.callFunction({ 38 | // 需调用的云函数名 39 | name: 'deleteUserQR', 40 | // 传给云函数的参数 41 | data: { 42 | qr_id_array: this.data.deletelist 43 | }, 44 | // 成功回调 45 | complete: (res) => { 46 | this.setData({ 47 | ifsetting: false 48 | }) 49 | this.firstgetdatalist(); 50 | } 51 | }) 52 | }, 53 | firstgetdatalist() { 54 | wx.cloud.callFunction({ 55 | // 需调用的云函数名 56 | name: 'getQRElementList', 57 | // 传给云函数的参数 58 | data: { 59 | limit: this.data.limit, 60 | page_index: 0, 61 | self: true 62 | }, 63 | // 成功回调 64 | complete: (res) => { 65 | var list = res.result.data.list; 66 | for (let i = 0; i < list.length; i++) { 67 | list[i].select = false; 68 | } 69 | var total = Math.ceil(res.result.data.total / this.data.limit); 70 | this.setData({ 71 | total: total, 72 | list: list, 73 | misstxt: list.length == 0 ? '暂无数据' : '数据加载中', 74 | misstype: list.length == 0 ? 'nodata' : 'loading', 75 | }) 76 | } 77 | }) 78 | }, 79 | getdatalist(pageid) { 80 | wx.cloud.callFunction({ 81 | // 需调用的云函数名 82 | name: 'getQRElementList', 83 | // 传给云函数的参数 84 | data: { 85 | limit: this.data.limit, 86 | page_index: pageid - 1, 87 | self: true 88 | }, 89 | // 成功回调 90 | complete: (res) => { 91 | var list = res.result.data.list; 92 | for (let i = 0; i < list.length; i++) { 93 | list[i].select = false; 94 | } 95 | var total = Math.ceil(res.result.data.total / this.data.limit); 96 | this.setData({ 97 | total: total, 98 | list: list, 99 | }) 100 | } 101 | }) 102 | }, 103 | prepage() { 104 | if (this.data.pageid <= this.data.total && this.data.pageid > 1) { 105 | this.setData({ 106 | pageid: this.data.pageid - 1 107 | }) 108 | this.getdatalist(this.data.pageid) 109 | } 110 | }, 111 | nextpage() { 112 | if (this.data.pageid < this.data.total) { 113 | this.setData({ 114 | pageid: this.data.pageid + 1 115 | }) 116 | this.getdatalist(this.data.pageid) 117 | } 118 | }, 119 | goupload() { 120 | if (!this.data.ifgetinfo) { 121 | this.getUserProfile().then(() => { 122 | wx.navigateTo({ 123 | url: '/pages/upload/upload' 124 | }) 125 | }); 126 | } else { 127 | wx.navigateTo({ 128 | url: '/pages/upload/upload' 129 | }) 130 | } 131 | }, 132 | cancleSetting() { 133 | this.setData({ 134 | ifsetting: false 135 | }) 136 | }, 137 | doSetting() { 138 | this.setData({ 139 | ifsetting: true 140 | }) 141 | }, 142 | select(e) { 143 | var id = e.currentTarget.dataset.id; 144 | for (let i = 0; i < this.data.list.length; i++) { 145 | if (this.data.list[i]._id == id) { 146 | var selectid = `list[${i}].select`; 147 | this.setData({ 148 | [selectid]: !this.data.list[i].select 149 | }) 150 | break; 151 | } 152 | } 153 | for (let i = 0; i < this.data.deletelist.length; i++) { 154 | if (this.data.deletelist[i] == id) { 155 | this.data.deletelist.splice(i, 1); 156 | this.setData({ 157 | deletelist: this.data.deletelist 158 | }) 159 | } 160 | break; 161 | } 162 | this.data.deletelist.push(id); 163 | this.setData({ 164 | deletelist: this.data.deletelist 165 | }) 166 | }, 167 | /** 168 | * 生命周期函数--监听页面加载 169 | */ 170 | onLoad: function (options) { 171 | var that = this; 172 | wx.getStorage({ 173 | key: 'userInfo', 174 | success: (e) => { 175 | var info = JSON.parse(e.data); 176 | that.setData({ 177 | ifgetinfo: true, 178 | userInfo: info 179 | }) 180 | }, 181 | fail: (e) => { 182 | that.setData({ 183 | ifgetinfo: false 184 | }) 185 | } 186 | }) 187 | this.firstgetdatalist(); 188 | }, 189 | getUserProfile(e) { 190 | var that = this; 191 | return new Promise((resolve, reject) => { 192 | // 推荐使用wx.getUserProfile获取用户信息,开发者每次通过该接口获取用户个人信息均需用户确认,开发者妥善保管用户快速填写的头像昵称,避免重复弹窗 193 | wx.getUserProfile({ 194 | desc: '展示用户信息', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写 195 | success: (res) => { 196 | this.setData({ 197 | userInfo: res.userInfo, 198 | ifgetinfo: true, 199 | }) 200 | var info = JSON.stringify(res.userInfo); 201 | wx.setStorage({ 202 | key: "userInfo", 203 | data: info 204 | }), 205 | resolve(); 206 | }, 207 | fail: (e) => { 208 | that.setData({ 209 | pbtip: true, 210 | tip: "(╬◣д◢)不授权无法上传素材哦!" 211 | }) 212 | reject(e); 213 | } 214 | }) 215 | }) 216 | } 217 | }) -------------------------------------------------------------------------------- /miniprogram/pages/myqrlist/myqrlist.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "icon":"../../components/icon/icon", 7 | "btn":"../../components/btn/btn", 8 | "popbox":"../../components/popbox/popbox", 9 | "avatar":"../../components/avatar/avatar", 10 | "missbox":"../../components/missbox/missbox", 11 | "contain":"../../components/contain/contain" 12 | }, 13 | "navigationStyle": "custom" 14 | } -------------------------------------------------------------------------------- /miniprogram/pages/myqrlist/myqrlist.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | {{userInfo.nickName}} 8 | 9 | 10 | 11 | 12 | 13 | 14 | 取消 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 29 | 30 | 31 | 32 | 33 | 34 | {{tip}} 35 | -------------------------------------------------------------------------------- /miniprogram/pages/myqrlist/myqrlist.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/qrlist/qrlist.wxss */ 2 | button{ 3 | background: transparent; 4 | display: block; 5 | width:80rpx; 6 | height: 150rpx; 7 | display: flex; 8 | align-items: center; 9 | } 10 | button:not([size='mini']){ 11 | width:100rpx !important; 12 | padding: 0 !important; 13 | } 14 | .opt{ 15 | display: flex; 16 | justify-content: space-between; 17 | align-items: center; 18 | padding: 0 32rpx; 19 | } 20 | .user{ 21 | text-align: center; 22 | margin-right: 40rpx; 23 | } 24 | .user-name{ 25 | font-weight: bold; 26 | color: #fff; 27 | line-height: 50rpx; 28 | font-size: 36rpx; 29 | } 30 | 31 | .setting { 32 | display: flex; 33 | align-items: center; 34 | } 35 | 36 | .tit { 37 | font-weight: bold; 38 | font-size: 36rpx; 39 | color: #fff; 40 | } 41 | 42 | .list { 43 | padding: 15rpx; 44 | } 45 | 46 | .item { 47 | position: relative; 48 | width: 330rpx; 49 | display: inline-block; 50 | overflow: hidden; 51 | margin: 15rpx; 52 | border-radius: 32rpx; 53 | } 54 | 55 | .select { 56 | position: absolute; 57 | width: 100%; 58 | height: 100%; 59 | z-index: 1; 60 | } 61 | 62 | .select-icon { 63 | position: absolute; 64 | top: 20rpx; 65 | bottom: 20rpx; 66 | } 67 | 68 | .mask { 69 | position: absolute; 70 | width: 100%; 71 | height: 100%; 72 | background: rgba(0, 0, 0, .5); 73 | left: 0; 74 | top: 0; 75 | } -------------------------------------------------------------------------------- /miniprogram/pages/qrcode/qrcode.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrcode/qrcode.js 2 | import qrcode from '../../js/artqrcoed.js'; 3 | import common from '../../js/common.js'; 4 | Page({ 5 | 6 | /** 7 | * 页面的初始数据 8 | */ 9 | data: { 10 | styleInfo: null, 11 | imginfo: null, 12 | qrinfo: { 13 | canvasid: 'qrcode', 14 | size: '', 15 | text: '', 16 | img: '' 17 | }, 18 | pbtxt: false, 19 | pbimg: false, 20 | pbqr: false, 21 | ifmadeqr: false, 22 | checkqrimg: false, 23 | pbtip: false 24 | }, 25 | saveimg() { 26 | var that = this; 27 | wx.canvasToTempFilePath({ 28 | x: 0, 29 | y: 0, 30 | width: that.data.qrinfo.size, 31 | height: that.data.qrinfo.size, 32 | canvasId: that.data.qrinfo.canvasid, 33 | success: function (data) { 34 | wx.saveImageToPhotosAlbum({ 35 | filePath: data.tempFilePath, 36 | success: (res) => { 37 | console.log("保存成功") 38 | }, 39 | fail: (err) => {} 40 | }) 41 | } 42 | }) 43 | }, 44 | uploadimg() { 45 | var that = this; 46 | wx.chooseImage({ 47 | count: 1, 48 | sizeType: ['compressed'], 49 | sourceType: ['album', 'camera'], 50 | success: function (res) { 51 | that.setData({ 52 | pbtip: true, 53 | checkqrimg: true, 54 | tip: "正在检验二维码中٩(๑❛ᴗ❛๑)۶" 55 | }) 56 | var imgurl = res.tempFilePaths[0]; 57 | // 图片转base64 58 | common.urlTobase64(imgurl).then(data => { 59 | // 上传单个图片 60 | common.uploadSingleImg(data).then(imgfileId => { 61 | // 扫码识别 s 62 | wx.cloud.callFunction({ 63 | // 需调用的云函数名 64 | name: 'decode', 65 | // 传给云函数的参数 66 | data: { 67 | fileid: imgfileId 68 | }, 69 | // 成功回调 70 | complete: (res) => { 71 | var qrdata = res.result; 72 | if (qrdata.length > 0) { 73 | var qrimg = `qrinfo.img` 74 | var qrtext = `qrinfo.text` 75 | var text = qrdata[0].data; 76 | that.setData({ 77 | [qrimg]: imgurl, 78 | [qrtext]: text 79 | }) 80 | wx.setStorage({ 81 | key: "qrimg", 82 | data: imgurl 83 | }) 84 | wx.setStorage({ 85 | key: "qrtxt", 86 | data: text 87 | }) 88 | that.setData({ 89 | pbtip: false, 90 | checkqrimg: false, 91 | tip: "٩(๑❛ᴗ❛๑)۶" 92 | }) 93 | } else { 94 | that.setData({ 95 | pbimg: false, 96 | pbtip: true, 97 | checkqrimg: false, 98 | tip: "我怀疑你上传的是假的二维码(╥╯^╰╥),请重新上传一个真的好不?" 99 | }) 100 | } 101 | } 102 | }) 103 | // 扫码识别 e 104 | }); 105 | }) 106 | } 107 | }) 108 | }, 109 | gettxt(e) { 110 | var txt = `qrinfo.text`; 111 | this.setData({ 112 | [txt]: e.detail.value 113 | }) 114 | }, 115 | showpbtxt() { 116 | var qrtext = `qrinfo.text` 117 | this.setData({ 118 | [qrtext]: '', 119 | pbtxt: true 120 | }) 121 | }, 122 | showpbqr() { 123 | this.setData({ 124 | pbqr: true 125 | }) 126 | }, 127 | showpbimg() { 128 | var qrimg = `qrinfo.img` 129 | this.setData({ 130 | [qrimg]: '', 131 | pbimg: true, 132 | }) 133 | 134 | }, 135 | madeTxt() { 136 | var that = this; 137 | this.setData({ 138 | pbtxt: false, 139 | pbqr: true, 140 | }) 141 | this.getsize().then(() => { 142 | this.addlikenum(this.data.styleInfo._id); 143 | qrcode.getqrcode(this.data.qrinfo, this.data.imginfo).then(() => { 144 | that.setData({ 145 | ifmadeqr: true 146 | }) 147 | }); 148 | }); 149 | }, 150 | madeImg() { 151 | var that = this; 152 | // 先鉴黄 153 | wx.cloud.callFunction({ 154 | // 需调用的云函数名 155 | name: 'checkeText', 156 | // 传给云函数的参数 157 | data: { 158 | txt:that.qrinfo.text 159 | }, 160 | // 成功回调 161 | complete: (res) => { 162 | 163 | } 164 | }) 165 | console.log("输入文字") 166 | return ; 167 | this.setData({ 168 | pbimg: false, 169 | pbqr: true 170 | }) 171 | this.getsize().then(() => { 172 | this.addlikenum(this.data.styleInfo._id); 173 | qrcode.getqrcode(this.data.qrinfo, this.data.imginfo).then(() => { 174 | that.setData({ 175 | ifmadeqr: true 176 | }) 177 | }); 178 | }); 179 | }, 180 | addlikenum(id) { 181 | wx.cloud.callFunction({ 182 | // 需调用的云函数名 183 | name: 'reportQRLike', 184 | // 传给云函数的参数 185 | data: { 186 | qr_id: id 187 | }, 188 | // 成功回调 189 | complete: (res) => { 190 | console.log("add 1") 191 | } 192 | }) 193 | }, 194 | close() { 195 | this.setData({ 196 | pbqr: false, 197 | pbimg: false, 198 | pbtxt: false, 199 | ifmadeqr: false, 200 | pbtip: false 201 | }) 202 | }, 203 | getsize() { 204 | return new Promise((resolve, reject) => { 205 | var that = this; 206 | var query = wx.createSelectorQuery(); 207 | query.select('.qrcode').boundingClientRect(function (rect) { 208 | var qrsize = 'qrinfo.size' 209 | that.setData({ 210 | [qrsize]: rect.height 211 | }) 212 | resolve(); 213 | }).exec(); 214 | }) 215 | }, 216 | /** 217 | * 生命周期函数--监听页面加载 218 | */ 219 | onLoad: function (options) { 220 | var info = JSON.parse(options.info); 221 | var imgs = { 222 | eye: info.eye, 223 | one: info.one, 224 | tian: info.tian, 225 | col2: info.col2, 226 | col3: info.col3, 227 | col4: info.col4, 228 | row2: info.row2, 229 | row3: info.row3, 230 | row4: info.row4, 231 | re7: info.re7, 232 | po7: info.po7, 233 | } 234 | for (const key in imgs) { 235 | if (imgs.hasOwnProperty(key)) { 236 | const element = imgs[key]; 237 | if (element) { 238 | wx.cloud.downloadFile({ 239 | fileID: element 240 | }).then(res => { 241 | imgs[key] = res.tempFilePath; 242 | }).catch(error => {}) 243 | } 244 | } 245 | } 246 | this.setData({ 247 | styleInfo: info, 248 | imginfo: imgs, 249 | }) 250 | } 251 | }) -------------------------------------------------------------------------------- /miniprogram/pages/qrcode/qrcode.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "icon":"../../components/icon/icon", 7 | "btn":"../../components/btn/btn", 8 | "missbox":"../../components/missbox/missbox", 9 | "popbox":"../../components/popbox/popbox", 10 | "contain":"../../components/contain/contain" 11 | }, 12 | "navigationStyle": "custom" 13 | } -------------------------------------------------------------------------------- /miniprogram/pages/qrcode/qrcode.wxml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 6 | 7 | 8 | 9 | 10 | 11 | 二维码生成 12 | 13 | 14 | 15 | 16 | 17 | 二维码美化 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 保存 31 | 32 | 33 | 34 | 35 | 36 | 请输入文字内容:文明使用语句,已经做了敏感词处理 37 | 38 | 39 | 生成二维码 40 | 41 | 42 | 43 | 44 | 45 | 请上传黑白二维码: 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 美化二维码 54 | 55 | 56 | 57 | 58 | 59 | {{tip}} 60 | -------------------------------------------------------------------------------- /miniprogram/pages/qrcode/qrcode.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/qrcode/qrcode.wxss */ 2 | .qrcode { 3 | margin: 30rpx auto; 4 | display: block; 5 | } 6 | 7 | .item { 8 | margin: 70rpx auto; 9 | text-align: center; 10 | } 11 | 12 | .popbox { 13 | text-align: center; 14 | } 15 | 16 | .tit { 17 | font-size: 36rpx; 18 | font-weight: bold; 19 | text-align: left; 20 | margin-bottom: 40rpx; 21 | } 22 | 23 | .opt { 24 | text-align: center; 25 | } 26 | 27 | .add-box { 28 | margin: 20rpx; 29 | } 30 | 31 | .img { 32 | width: 250rpx; 33 | height: 250rpx; 34 | margin: 0 auto; 35 | } 36 | 37 | .img image { 38 | width: 100%; 39 | height: 100%; 40 | } 41 | 42 | .input { 43 | border-radius: 10rpx; 44 | border: 4rpx solid #000000; 45 | box-sizing: border-box; 46 | box-shadow: var(--box-shadow); 47 | background: #fff; 48 | font-size: 32rpx; 49 | font-weight: bold; 50 | border-radius: 32rpx; 51 | margin-bottom: 50rpx; 52 | height: 200rpx; 53 | width: 100%; 54 | box-sizing: border-box; 55 | text-align: left; 56 | padding: 20rpx; 57 | } 58 | 59 | .missbox { 60 | position: absolute; 61 | width: 70%; 62 | left: 0; 63 | right: 0; 64 | top: 0; 65 | bottom: 0; 66 | height: 90%; 67 | background: #fff; 68 | z-index: 9; 69 | margin: auto; 70 | } 71 | 72 | .method { 73 | margin-top: 20rpx; 74 | display: flex; 75 | justify-content: center; 76 | } 77 | 78 | .method-item { 79 | font-weight: bold; 80 | height: 180rpx; 81 | padding-top: 30rpx; 82 | width: 150rpx; 83 | } 84 | 85 | .method-item-txt { 86 | font-size: 30rpx; 87 | line-height: 23rpx; 88 | font-weight: bold; 89 | } -------------------------------------------------------------------------------- /miniprogram/pages/qrlist/qrlist.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrlist/qrlist.js 2 | Page({ 3 | 4 | /** 5 | * 页面的初始数据 6 | */ 7 | data: { 8 | list: [], 9 | total: null, 10 | limit: 6, //每页数量 11 | pageid: 1, 12 | misstype:'loading', 13 | misstxt:'数据加载中٩(๑❛ᴗ❛๑)۶~', 14 | pagefrom:'index', 15 | }, 16 | gomylist() { 17 | wx.navigateTo({ 18 | url: '/pages/myqrlist/myqrlist' 19 | }) 20 | }, 21 | goqrcode(e) { 22 | var data = JSON.stringify(e.currentTarget.dataset.info) 23 | if(this.data.pagefrom=='index'){ 24 | wx.navigateTo({ 25 | url: `/pages/qrcode/qrcode?info=${data}` 26 | }) 27 | }else{ 28 | wx.navigateTo({ 29 | url: `/pages/${this.data.pagefrom}/${this.data.pagefrom}?info=${data}` 30 | }) 31 | } 32 | }, 33 | firstgetdatalist() { 34 | wx.cloud.callFunction({ 35 | // 需调用的云函数名 36 | name: 'getQRElementList', 37 | // 传给云函数的参数 38 | data: { 39 | limit: this.data.limit, 40 | page_index: this.data.pageid - 1, 41 | self: false, 42 | datatype:1 43 | }, 44 | // 成功回调 45 | complete: (res) => { 46 | var list = res.result.data.list; 47 | var total = Math.ceil(res.result.data.total / this.data.limit); 48 | this.setData({ 49 | total: total, 50 | list: list, 51 | misstype:list.length>0?'loading':'nodata', 52 | misstxt:list.length>0?'好看的模板在路上٩(๑❛ᴗ❛๑)۶':'数据跑哪里了呢?(╥╯^╰╥)', 53 | }) 54 | } 55 | }) 56 | }, 57 | getdatalist(pageid) { 58 | wx.cloud.callFunction({ 59 | // 需调用的云函数名 60 | name: 'getQRElementList', 61 | // 传给云函数的参数 62 | data: { 63 | limit: this.data.limit, 64 | page_index: pageid - 1, 65 | self: false, 66 | datatype:1 67 | }, 68 | // 成功回调 69 | complete: (res) => { 70 | var list = res.result.data.list; 71 | var total = Math.ceil(res.result.data.total / this.data.limit); 72 | this.setData({ 73 | total: total, 74 | list: list, 75 | misstype:list.length>0?'loading':'nodata', 76 | misstxt:list.length>0?'好看的模板在路上٩(๑❛ᴗ❛๑)۶':'数据跑哪里了呢?(╥╯^╰╥)', 77 | }) 78 | } 79 | }) 80 | }, 81 | prepage() { 82 | if (this.data.pageid <= this.data.total&&this.data.pageid>1) { 83 | this.setData({ 84 | pageid: this.data.pageid - 1 85 | }) 86 | this.getdatalist(this.data.pageid) 87 | } 88 | }, 89 | nextpage(){ 90 | if(this.data.pageid 2 | 3 | 4 | 5 | 6 | 7 | 9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /miniprogram/pages/qrlist/qrlist.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/qrlist/qrlist.wxss */ 2 | .opt { 3 | display: flex; 4 | justify-content: flex-start; 5 | align-items: center; 6 | width: 100%; 7 | padding-left: 30rpx; 8 | box-sizing: border-box; 9 | } 10 | .list{ 11 | padding: 15rpx; 12 | } 13 | .item{ 14 | margin: 15rpx; 15 | display: inline-block; 16 | } -------------------------------------------------------------------------------- /miniprogram/pages/txtmade/txtmade.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/qrlist/qrlist.js 2 | import qrcode from '../../js/artqrcoed.js' 3 | import common from '../../js/common.js'; 4 | 5 | Page({ 6 | 7 | /** 8 | * 页面的初始数据 9 | */ 10 | data: { 11 | styleInfo: null, 12 | imginfo: null, 13 | qrinfo: { 14 | canvasid: 'qrcode', 15 | size: '', 16 | text: '', 17 | img: '' 18 | }, 19 | ifmadeqr: false, 20 | pbtip: false, 21 | tip: "", 22 | pbqr:false, 23 | }, 24 | addlikenum(id) { 25 | wx.cloud.callFunction({ 26 | // 需调用的云函数名 27 | name: 'reportQRLike', 28 | // 传给云函数的参数 29 | data: { 30 | qr_id: id 31 | }, 32 | // 成功回调 33 | complete: (res) => { 34 | console.log("add 1") 35 | } 36 | }) 37 | }, 38 | saveimg() { 39 | var that = this; 40 | wx.canvasToTempFilePath({ 41 | x: 0, 42 | y: 0, 43 | width: that.data.qrinfo.size, 44 | height: that.data.qrinfo.size, 45 | canvasId: that.data.qrinfo.canvasid, 46 | success: function (data) { 47 | wx.saveImageToPhotosAlbum({ 48 | filePath: data.tempFilePath, 49 | success: (res) => { 50 | console.log("保存成功") 51 | }, 52 | fail: (err) => {} 53 | }) 54 | } 55 | }) 56 | }, 57 | getsize() { 58 | return new Promise((resolve, reject) => { 59 | var that = this; 60 | var query = wx.createSelectorQuery(); 61 | query.select('.qrcode').boundingClientRect(function (rect) { 62 | var qrsize = 'qrinfo.size' 63 | that.setData({ 64 | [qrsize]: rect.height 65 | }) 66 | resolve(); 67 | }).exec(); 68 | }) 69 | }, 70 | async madeTxt() { 71 | if (this.data.qrinfo.text == '') { 72 | this.setData({ 73 | tip: '(▼へ▼メ)请输入文字吖~', 74 | pbtip: true 75 | }); 76 | return; 77 | } 78 | 79 | if (this.data.styleInfo == null) { 80 | this.setData({ 81 | tip: 'o(▼皿▼メ;)o选择二维码风格吖~', 82 | pbtip: true 83 | }); 84 | return; 85 | } 86 | 87 | try { 88 | const res = await common.checkText(this.data.qrinfo.text); 89 | if (res === 'pass') { 90 | this.setData({ 91 | pbimg: false, 92 | pbqr: true 93 | }); 94 | 95 | await this.manageimgs(); 96 | await this.getsize(); 97 | this.addlikenum(this.data.styleInfo._id); 98 | await qrcode.getqrcode(this.data.qrinfo, this.data.imginfo); 99 | 100 | this.setData({ 101 | ifmadeqr: true 102 | }); 103 | } else { 104 | this.setData({ 105 | tip: '(▼へ▼メ)文明有礼貌,不要乱发敏感词!~', 106 | pbtip: true 107 | }); 108 | } 109 | } catch (error) { 110 | console.error(error); 111 | } 112 | } 113 | , 114 | gettxt(e) { 115 | var txt = `qrinfo.text`; 116 | this.setData({ 117 | [txt]: e.detail.value 118 | }) 119 | wx.setStorage({ 120 | key: "qrtxt", 121 | data: e.detail.value 122 | }) 123 | }, 124 | close() { 125 | this.setData({ 126 | pbqr:false, 127 | pbtip: false, 128 | ifmadeqr: false 129 | }) 130 | }, 131 | async manageimgs() { 132 | var info = this.data.styleInfo; 133 | var imgs = { 134 | eye: info.eye, 135 | one: info.one, 136 | tian: info.tian, 137 | col2: info.col2, 138 | col3: info.col3, 139 | col4: info.col4, 140 | row2: info.row2, 141 | row3: info.row3, 142 | row4: info.row4, 143 | re7: info.re7, 144 | po7: info.po7, 145 | } 146 | for (const key in imgs) { 147 | if (imgs.hasOwnProperty(key)) { 148 | const element = imgs[key]; 149 | if (element) { 150 | await wx.cloud.downloadFile({ 151 | fileID: element 152 | }).then(res => { 153 | imgs[key] = res.tempFilePath; 154 | }).catch(error => {}) 155 | } 156 | 157 | } 158 | } 159 | this.setData({ 160 | imginfo: imgs 161 | }) 162 | }, 163 | goqrlist() { 164 | wx.navigateTo({ 165 | url: '/pages/qrlist/qrlist?pagefrom=txtmade' 166 | }) 167 | }, 168 | /** 169 | * 生命周期函数--监听页面加载 170 | */ 171 | onLoad: function (options) { 172 | var that = this; 173 | if (options.info) { 174 | var info = JSON.parse(options.info) 175 | this.setData({ 176 | styleInfo: info 177 | }) 178 | wx.getStorage({ 179 | key: 'qrtxt', 180 | success(res) { 181 | var txt = `qrinfo.text` 182 | var data=res.data; 183 | that.setData({ 184 | [txt]:data 185 | }) 186 | } 187 | }) 188 | } 189 | } 190 | }) -------------------------------------------------------------------------------- /miniprogram/pages/txtmade/txtmade.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "cell":"../../components/cell/cell", 7 | "icon":"../../components/icon/icon", 8 | "btn":"../../components/btn/btn", 9 | "missbox":"../../components/missbox/missbox", 10 | "popbox":"../../components/popbox/popbox", 11 | "contain":"../../components/contain/contain" 12 | }, 13 | "navigationStyle": "custom" 14 | } -------------------------------------------------------------------------------- /miniprogram/pages/txtmade/txtmade.wxml: -------------------------------------------------------------------------------- 1 | 生成二维码 2 | 3 | 一、输入文明用语内容: 4 | 5 | 二、选择风格: 6 | 7 | 8 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 生成以后请用手机扫描验证是否能识别 20 | 生成 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 保存 30 | 31 | 32 | 33 | 34 | {{tip}} 35 | -------------------------------------------------------------------------------- /miniprogram/pages/txtmade/txtmade.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/txtmade/txtmad.wxss */ 2 | .tit { 3 | font-size: 36rpx; 4 | font-weight: bold; 5 | color: #fff; 6 | margin: 32rpx; 7 | display: flex; 8 | justify-content: space-between; 9 | } 10 | 11 | .input { 12 | border-radius: 10rpx; 13 | border: 4rpx solid #000000; 14 | box-sizing: border-box; 15 | box-shadow: var(--box-shadow); 16 | background: #fff; 17 | font-size: 32rpx; 18 | font-weight: bold; 19 | border-radius: 32rpx; 20 | margin-bottom: 50rpx; 21 | height: 200rpx; 22 | margin: 0 32rpx; 23 | box-sizing: border-box; 24 | text-align: left; 25 | padding: 20rpx; 26 | } 27 | 28 | content { 29 | text-align: center; 30 | } 31 | 32 | .item-qr { 33 | width: 330rpx; 34 | box-sizing: border-box; 35 | text-align: center; 36 | margin: 0 auto; 37 | margin-bottom: 30rpx; 38 | } 39 | 40 | .item { 41 | width: 330rpx; 42 | box-sizing: border-box; 43 | text-align: center; 44 | margin: 0 auto; 45 | margin-bottom: 30rpx; 46 | } 47 | 48 | .icon-add { 49 | margin: 150rpx 0; 50 | } 51 | .qrcode { 52 | margin: 30rpx auto; 53 | display: block; 54 | } 55 | 56 | .opt { 57 | text-align: center; 58 | } 59 | 60 | .missbox { 61 | position: absolute; 62 | width: 70%; 63 | left: 0; 64 | right: 0; 65 | top: 0; 66 | bottom: 0; 67 | height: 90%; 68 | background: #fff; 69 | z-index: 9; 70 | margin: auto; 71 | } 72 | .tip{ 73 | margin:0 32rpx; 74 | color:var(--tip-1); 75 | font-size: var(--size-tip-1); 76 | } -------------------------------------------------------------------------------- /miniprogram/pages/upload/upload.js: -------------------------------------------------------------------------------- 1 | // miniprogram/pages/upload/upload.js 2 | import common from '../../js/common.js'; 3 | 4 | Page({ 5 | 6 | /** 7 | * 页面的初始数据 8 | */ 9 | data: { 10 | list: [{ 11 | name: "cover", 12 | temporary: "", 13 | fileId: "", 14 | url: '../../images/demo.png', 15 | }, { 16 | name: "eye", 17 | temporary: "", 18 | fileId: "", 19 | url: '../../images/upload/eye.png', 20 | }, { 21 | name: "one", 22 | temporary: "", 23 | fileId: "", 24 | url: '../../images/upload/one.png', 25 | }, { 26 | name: "col2", 27 | temporary: "", 28 | fileId: "", 29 | url: '../../images/upload/col2.png', 30 | }, { 31 | name: "col3", 32 | temporary: "", 33 | fileId: "", 34 | url: '../../images/upload/col3.png', 35 | }, { 36 | name: "col4", 37 | temporary: "", 38 | fileId: "", 39 | url: '../../images/upload/col4.png', 40 | }, { 41 | name: "po7", 42 | temporary: "", 43 | fileId: "", 44 | url: '../../images/upload/po7.png', 45 | }, { 46 | name: "re7", 47 | temporary: "", 48 | fileId: "", 49 | url: '../../images/upload/re7.png', 50 | }, { 51 | name: "row2", 52 | temporary: "", 53 | fileId: "", 54 | url: '../../images/upload/row2.png', 55 | }, { 56 | name: "row3", 57 | temporary: "", 58 | fileId: "", 59 | url: '../../images/upload/row3.png', 60 | }, { 61 | name: "row4", 62 | temporary: "", 63 | fileId: "", 64 | url: '../../images/upload/row4.png', 65 | }, { 66 | name: "tian", 67 | temporary: "", 68 | fileId: "", 69 | url: '../../images/upload/tian.png', 70 | }], 71 | pbupload: false, 72 | stylename: null, 73 | pbtip: false, 74 | tip: "", 75 | isuploaded: false, 76 | ifgetinfo: false, 77 | userInfo: { 78 | avatarUrl: '', 79 | nickName: '点击获取信息' 80 | }, 81 | }, 82 | gettxt(e) { 83 | this.setData({ 84 | stylename: e.detail.value 85 | }) 86 | }, 87 | close(e) { 88 | this.setData({ 89 | pbupload: false, 90 | pbrule: false, 91 | pbtip: false 92 | }) 93 | }, 94 | upload() { 95 | var that = this; 96 | var data = { 97 | cover: that.data.list[0].fileId, //封面 98 | eye: that.data.list[1].fileId, //必填 99 | one: that.data.list[2].fileId, //必填 100 | col2: that.data.list[3].fileId, 101 | col3: that.data.list[4].fileId, 102 | col4: that.data.list[5].fileId, 103 | po7: that.data.list[6].fileId, 104 | re7: that.data.list[7].fileId, 105 | row2: that.data.list[8].fileId, 106 | row3: that.data.list[9].fileId, 107 | row4: that.data.list[10].fileId, 108 | tian: that.data.list[11].fileId, 109 | element_name: that.data.stylename, //必填,素材包名称 110 | _author_avatar: that.data.userInfo.avatarUrl, 111 | _author_name: that.data.userInfo.nickName //必填,用户名称 112 | } 113 | this.setData({ 114 | pbupload: false, 115 | isuploaded: false, 116 | pbtip: true, 117 | }) 118 | wx.cloud.callFunction({ 119 | // 需调用的云函数名 120 | name: 'uploadQRElement', 121 | // 传给云函数的参数 122 | data: data, 123 | // 成功回调 124 | complete: (res) => { 125 | that.setData({ 126 | isuploaded: true, 127 | tip: `٩(๑>◡<๑)۶ :${res.result.msg},你可以继续上传素材哟~`, 128 | list: [{ 129 | name: "cover", 130 | temporary: "", 131 | fileId: "", 132 | url: '../../images/demo.png', 133 | }, { 134 | name: "eye", 135 | temporary: "", 136 | fileId: "", 137 | url: '../../images/upload/eye.png', 138 | }, { 139 | name: "one", 140 | temporary: "", 141 | fileId: "", 142 | url: '../../images/upload/one.png', 143 | }, { 144 | name: "col2", 145 | temporary: "", 146 | fileId: "", 147 | url: '../../images/upload/col2.png', 148 | }, { 149 | name: "col3", 150 | temporary: "", 151 | fileId: "", 152 | url: '../../images/upload/col3.png', 153 | }, { 154 | name: "col4", 155 | temporary: "", 156 | fileId: "", 157 | url: '../../images/upload/col4.png', 158 | }, { 159 | name: "po7", 160 | temporary: "", 161 | fileId: "", 162 | url: '../../images/upload/po7.png', 163 | }, { 164 | name: "re7", 165 | temporary: "", 166 | fileId: "", 167 | url: '../../images/upload/re7.png', 168 | }, { 169 | name: "row2", 170 | temporary: "", 171 | fileId: "", 172 | url: '../../images/upload/row2.png', 173 | }, { 174 | name: "row3", 175 | temporary: "", 176 | fileId: "", 177 | url: '../../images/upload/row3.png', 178 | }, { 179 | name: "row4", 180 | temporary: "", 181 | fileId: "", 182 | url: '../../images/upload/row4.png', 183 | }, { 184 | name: "tian", 185 | temporary: "", 186 | fileId: "", 187 | url: '../../images/upload/tian.png', 188 | }], 189 | }) 190 | } 191 | }) 192 | 193 | }, 194 | check() { 195 | if (this.data.list[0].fileId == "" || this.data.list[1].fileId == "" || this.data.list[2].fileId == "") { 196 | this.setData({ 197 | tip: '(▼へ▼メ)至少上传前三张示意图哦~,不明白可点击右上角查看设计指引哦~', 198 | pbtip: true, 199 | isuploaded: true 200 | }) 201 | return; 202 | } 203 | this.setData({ 204 | pbupload: true, 205 | isuploaded: false 206 | }) 207 | }, 208 | showpbupload() { 209 | var that = this; 210 | if (!this.data.ifgetinfo) { 211 | this.getUserProfile().then(() => { 212 | this.check() 213 | }).catch(() => { 214 | that.setData({ 215 | pbtip: true, 216 | tip: '(╬◣д◢)不授权无法上传素材哦!', 217 | isuploaded: true, 218 | ifgetinfo: false 219 | }) 220 | }); 221 | } else { 222 | this.check() 223 | } 224 | }, 225 | showpbrule() { 226 | wx.navigateTo({ 227 | url: '/pages/designrule/designrule' 228 | }) 229 | }, 230 | // 选择单张图片 231 | chooseSingleImg(e) { 232 | var that = this; 233 | var name = e.currentTarget.dataset.name; 234 | wx.chooseImage({ 235 | count: 1, 236 | sizeType: ['compressed'], 237 | sourceType: ['album', 'camera'], 238 | success: function (res) { 239 | for (let i = 0; i < that.data.list.length; i++) { 240 | if (that.data.list[i].name == name) { 241 | // 转成base64 242 | common.urlTobase64(res.tempFilePaths[0]).then(data => { 243 | // 上传图片 244 | common.uploadSingleImg(data).then(imgfileId => { 245 | // 上传成功后 246 | var temporary = `list[${i}].temporary`; 247 | var fileId = `list[${i}].fileId`; 248 | that.setData({ 249 | [temporary]: res.tempFilePaths[0], 250 | [fileId]: imgfileId 251 | }) 252 | }); 253 | }) 254 | break; 255 | } 256 | } 257 | } 258 | }) 259 | }, 260 | /** 261 | * 生命周期函数--监听页面加载 262 | */ 263 | onLoad: function (options) { 264 | var that = this; 265 | wx.getStorage({ 266 | key: 'userInfo', 267 | success: (e) => { 268 | var info = JSON.parse(e.data); 269 | that.setData({ 270 | userInfo: info, 271 | ifgetinfo:true 272 | }) 273 | }, 274 | fail: (e) => { 275 | that.setData({ 276 | pbtip: true, 277 | tip: '٩(๑>◡<๑)۶ 请点击头像授权资料哦~', 278 | isuploaded: true, 279 | ifgetinfo: false 280 | }) 281 | } 282 | }) 283 | }, 284 | getUserProfile(e) { 285 | return new Promise((resolve, reject) => { 286 | // 推荐使用wx.getUserProfile获取用户信息,开发者每次通过该接口获取用户个人信息均需用户确认,开发者妥善保管用户快速填写的头像昵称,避免重复弹窗 287 | wx.getUserProfile({ 288 | desc: '展示用户信息', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写 289 | success: (res) => { 290 | this.setData({ 291 | userInfo: res.userInfo, 292 | ifgetinfo: true, 293 | }) 294 | var info = JSON.stringify(res.userInfo); 295 | wx.setStorage({ 296 | key: "userInfo", 297 | data: info 298 | }), 299 | resolve(); 300 | }, 301 | fail: (e) => { 302 | this.setData({ 303 | ifgetinfo: false 304 | }) 305 | reject(e); 306 | } 307 | }) 308 | }) 309 | } 310 | }) -------------------------------------------------------------------------------- /miniprogram/pages/upload/upload.json: -------------------------------------------------------------------------------- 1 | { 2 | "usingComponents": { 3 | "navbar":"../../components/navbar/navbar", 4 | "styleitem":"../../components/styleitem/styleitem", 5 | "page":"../../components/page/page", 6 | "icon":"../../components/icon/icon", 7 | "btn":"../../components/btn/btn", 8 | "avatar":"../../components/avatar/avatar", 9 | "missbox":"../../components/missbox/missbox", 10 | "popbox":"../../components/popbox/popbox", 11 | "cell":"../../components/cell/cell", 12 | "contain":"../../components/contain/contain" 13 | }, 14 | "navigationStyle": "custom" 15 | } -------------------------------------------------------------------------------- /miniprogram/pages/upload/upload.wxml: -------------------------------------------------------------------------------- 1 | 自定义素材 2 | 3 | 4 | 5 | 6 | {{userInfo.nickName}} 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 下一步 20 | 21 | 22 | 23 | 24 | 标题: 25 | 27 | 28 | 您将上传以下图片素材: 29 | 30 | 31 | 32 | 33 | 34 | ヾ(✿゚▽゚)ノ好看的风格,则有机会在社区中展示哦~ 35 | 36 | 上传素材包 37 | 38 | 39 | 40 | 41 | 42 | {{tip}} 43 | 44 | 45 | -------------------------------------------------------------------------------- /miniprogram/pages/upload/upload.wxss: -------------------------------------------------------------------------------- 1 | /* miniprogram/pages/upload/upload.wxss */ 2 | .opt{ 3 | display: flex; 4 | align-items: center; 5 | justify-content: space-between; 6 | margin: 0 20rpx; 7 | margin-left: 30rpx; 8 | margin-bottom: 30rpx; 9 | } 10 | .user{ 11 | text-align: center; 12 | margin-right: 40rpx; 13 | display: flex; 14 | align-items: center; 15 | } 16 | .user-name{ 17 | font-weight: bold; 18 | color: #fff; 19 | line-height: 50rpx; 20 | font-size: 36rpx; 21 | margin-left: 20rpx; 22 | } 23 | .list{ 24 | padding: 15rpx; 25 | width: 750rpx; 26 | box-sizing: border-box; 27 | display: flex; 28 | flex-wrap: wrap; 29 | justify-content: center; 30 | } 31 | .item{ 32 | width: 210rpx; 33 | padding-left: 15rpx; 34 | padding-right: 15rpx; 35 | display: inline-block; 36 | margin-bottom: 25rpx; 37 | } 38 | .item-name{ 39 | text-align: center; 40 | font-size: 36rpx; 41 | color: #fff; 42 | } 43 | .img{ 44 | width: 175rpx; 45 | height: 175rpx; 46 | margin: 15rpx; 47 | box-sizing: border-box; 48 | } 49 | .img image{ 50 | width: 100%; 51 | height: 100%; 52 | } 53 | 54 | .input{ 55 | background: #FFFFFF; 56 | border: 4rpx solid #000000; 57 | box-shadow: 4rpx 4rpx 0rpx #000; 58 | height: 80rpx; 59 | border-radius: 32rpx; 60 | padding-left: 20rpx; 61 | font-size: 36rpx; 62 | font-weight: bold; 63 | } 64 | .txt{ 65 | font-size: 36rpx; 66 | margin: 20rpx 0; 67 | } 68 | .img-box{ 69 | width:100%; 70 | height: 500rpx; 71 | overflow: scroll; 72 | 73 | } 74 | .img-item{ 75 | display: inline-block; 76 | width: 120rpx; 77 | height: 120rpx; 78 | padding: 20rpx; 79 | background: #FFFFFF; 80 | border: 4rpx solid #000000; 81 | box-shadow: 4rpx 4rpx 0rpx #000; 82 | box-sizing: border-box; 83 | margin: 10rpx; 84 | } 85 | .img-item image{ 86 | width: 100%; 87 | height: 100%; 88 | } 89 | .popbox{ 90 | height: 600rpx; 91 | overflow: scroll; 92 | } -------------------------------------------------------------------------------- /miniprogram/sitemap.json: -------------------------------------------------------------------------------- 1 | { 2 | "desc": "关于本文件的更多信息,请参考文档 https://developers.weixin.qq.com/miniprogram/dev/framework/sitemap.html", 3 | "rules": [{ 4 | "action": "allow", 5 | "page": "*" 6 | }] 7 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "qrcode", 3 | "lockfileVersion": 2, 4 | "requires": true, 5 | "packages": { 6 | "": { 7 | "dependencies": { 8 | "qrcode-reader": "^1.0.4", 9 | "weapp-qrcode": "^1.0.0" 10 | } 11 | }, 12 | "node_modules/extend": { 13 | "version": "3.0.2", 14 | "resolved": "http://r.tnpm.oa.com/extend/-/extend-3.0.2.tgz", 15 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 16 | "license": "MIT" 17 | }, 18 | "node_modules/qrcode-reader": { 19 | "version": "1.0.4", 20 | "resolved": "http://r.tnpm.oa.com/qrcode-reader/-/qrcode-reader-1.0.4.tgz", 21 | "integrity": "sha512-rRjALGNh9zVqvweg1j5OKIQKNsw3bLC+7qwlnead5K/9cb1cEIAGkwikt/09U0K+2IDWGD9CC6SP7tHAjUeqvQ==", 22 | "license": "Apache-2.0" 23 | }, 24 | "node_modules/weapp-qrcode": { 25 | "version": "1.0.0", 26 | "resolved": "http://r.tnpm.oa.com/weapp-qrcode/-/weapp-qrcode-1.0.0.tgz", 27 | "integrity": "sha512-4sa3W0rGDVJ9QaeZpAKlAuUxVyjhDwiUqHyGK/jJMsRMXnhb4yO8qWU/pZruMo+iT5J6CraS67lDMFb1VY+RaA==", 28 | "license": "MIT", 29 | "dependencies": { 30 | "extend": "^3.0.2" 31 | } 32 | } 33 | }, 34 | "dependencies": { 35 | "extend": { 36 | "version": "3.0.2", 37 | "resolved": "http://r.tnpm.oa.com/extend/-/extend-3.0.2.tgz", 38 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" 39 | }, 40 | "qrcode-reader": { 41 | "version": "1.0.4", 42 | "resolved": "http://r.tnpm.oa.com/qrcode-reader/-/qrcode-reader-1.0.4.tgz", 43 | "integrity": "sha512-rRjALGNh9zVqvweg1j5OKIQKNsw3bLC+7qwlnead5K/9cb1cEIAGkwikt/09U0K+2IDWGD9CC6SP7tHAjUeqvQ==" 44 | }, 45 | "weapp-qrcode": { 46 | "version": "1.0.0", 47 | "resolved": "http://r.tnpm.oa.com/weapp-qrcode/-/weapp-qrcode-1.0.0.tgz", 48 | "integrity": "sha512-4sa3W0rGDVJ9QaeZpAKlAuUxVyjhDwiUqHyGK/jJMsRMXnhb4yO8qWU/pZruMo+iT5J6CraS67lDMFb1VY+RaA==", 49 | "requires": { 50 | "extend": "^3.0.2" 51 | } 52 | } 53 | } 54 | } 55 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "dependencies": { 3 | "qrcode-reader": "^1.0.4", 4 | "weapp-qrcode": "^1.0.0" 5 | } 6 | } 7 | -------------------------------------------------------------------------------- /project.config.json: -------------------------------------------------------------------------------- 1 | { 2 | "miniprogramRoot": "miniprogram/", 3 | "cloudfunctionRoot": "cloudfunctions/", 4 | "setting": { 5 | "urlCheck": true, 6 | "es6": true, 7 | "enhance": true, 8 | "postcss": true, 9 | "preloadBackgroundData": false, 10 | "minified": true, 11 | "newFeature": true, 12 | "coverView": true, 13 | "nodeModules": true, 14 | "autoAudits": false, 15 | "showShadowRootInWxmlPanel": true, 16 | "scopeDataCheck": false, 17 | "uglifyFileName": false, 18 | "checkInvalidKey": true, 19 | "checkSiteMap": true, 20 | "uploadWithSourceMap": true, 21 | "compileHotReLoad": false, 22 | "useMultiFrameRuntime": true, 23 | "useApiHook": true, 24 | "useApiHostProcess": true, 25 | "babelSetting": { 26 | "ignore": [], 27 | "disablePlugins": [], 28 | "outputPath": "" 29 | }, 30 | "enableEngineNative": false, 31 | "useIsolateContext": true, 32 | "useCompilerModule": true, 33 | "userConfirmedUseCompilerModuleSwitch": false, 34 | "userConfirmedBundleSwitch": false, 35 | "packNpmManually": false, 36 | "packNpmRelationList": [], 37 | "minifyWXSS": true, 38 | "condition": false 39 | }, 40 | "appid": "wxdb5a9d708acf35ee", 41 | "projectname": "qrcode", 42 | "libVersion": "2.16.1", 43 | "cloudfunctionTemplateRoot": "cloudfunctionTemplate/", 44 | "condition": { 45 | "search": { 46 | "list": [] 47 | }, 48 | "conversation": { 49 | "list": [] 50 | }, 51 | "plugin": { 52 | "list": [] 53 | }, 54 | "game": { 55 | "list": [] 56 | }, 57 | "miniprogram": { 58 | "list": [ 59 | { 60 | "id": -1, 61 | "name": "db guide", 62 | "pathName": "pages/databaseGuide/databaseGuide" 63 | } 64 | ] 65 | } 66 | }, 67 | "compileType": "miniprogram", 68 | "srcMiniprogramRoot": "miniprogram/", 69 | "packOptions": { 70 | "ignore": [], 71 | "include": [] 72 | }, 73 | "editorSetting": { 74 | "tabIndent": "insertSpaces", 75 | "tabSize": 2 76 | } 77 | } -------------------------------------------------------------------------------- /project.private.config.json: -------------------------------------------------------------------------------- 1 | { 2 | "setting": {}, 3 | "condition": { 4 | "miniprogram": { 5 | "list": [ 6 | { 7 | "name": "db guide", 8 | "pathName": "pages/databaseGuide/databaseGuide", 9 | "query": "" 10 | }, 11 | { 12 | "name": "pages/qrcode/qrcode", 13 | "pathName": "pages/qrcode/qrcode", 14 | "query": "", 15 | "scene": null 16 | }, 17 | { 18 | "name": "pages/index/index", 19 | "pathName": "pages/index/index", 20 | "query": "", 21 | "scene": null 22 | }, 23 | { 24 | "name": "pages/uploadqrImg/uploadqrImg", 25 | "pathName": "pages/uploadqrImg/uploadqrImg", 26 | "query": "", 27 | "scene": null 28 | }, 29 | { 30 | "name": "pages/components/components", 31 | "pathName": "pages/components/components", 32 | "query": "", 33 | "scene": null 34 | }, 35 | { 36 | "name": "pages/qrlist/qrlist", 37 | "pathName": "pages/qrlist/qrlist", 38 | "query": "", 39 | "scene": null 40 | }, 41 | { 42 | "name": "pages/myqrlist/myqrlist", 43 | "pathName": "pages/myqrlist/myqrlist", 44 | "query": "", 45 | "scene": null 46 | }, 47 | { 48 | "name": "pages/upload/upload", 49 | "pathName": "pages/upload/upload", 50 | "query": "", 51 | "scene": null 52 | }, 53 | { 54 | "name": "pages/txtmade/txtmad", 55 | "pathName": "pages/txtmade/txtmad", 56 | "query": "", 57 | "scene": null 58 | }, 59 | { 60 | "name": "pages/txtmade/txtmade", 61 | "pathName": "pages/txtmade/txtmade", 62 | "query": "", 63 | "scene": null 64 | }, 65 | { 66 | "name": "pages/imgmade/imgmade", 67 | "pathName": "pages/imgmade/imgmade", 68 | "query": "", 69 | "scene": null 70 | }, 71 | { 72 | "name": "pages/designrule/designrule", 73 | "pathName": "pages/designrule/designrule", 74 | "query": "", 75 | "scene": null 76 | }, 77 | { 78 | "name": "pages/checkqr/checkqr", 79 | "pathName": "pages/checkqr/checkqr", 80 | "query": "", 81 | "scene": null 82 | } 83 | ] 84 | } 85 | }, 86 | "description": "项目私有配置文件。此文件中的内容将覆盖 project.config.json 中的相同字段。项目的改动优先同步到此文件中。详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html" 87 | } -------------------------------------------------------------------------------- /readme/cover.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/cover.png -------------------------------------------------------------------------------- /readme/toolcode.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/toolcode.jpg -------------------------------------------------------------------------------- /readme/上传.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/上传.gif -------------------------------------------------------------------------------- /readme/上传指引.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/上传指引.gif -------------------------------------------------------------------------------- /readme/图片生成.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/图片生成.gif -------------------------------------------------------------------------------- /readme/我的生成.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/我的生成.gif -------------------------------------------------------------------------------- /readme/我的素材.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/我的素材.gif -------------------------------------------------------------------------------- /readme/文字生成.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/文字生成.gif -------------------------------------------------------------------------------- /readme/流程.mp4: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/流程.mp4 -------------------------------------------------------------------------------- /readme/社区.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/社区.gif -------------------------------------------------------------------------------- /readme/艺术例子.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/艺术例子.png -------------------------------------------------------------------------------- /readme/首页.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/首页.gif -------------------------------------------------------------------------------- /readme/黑白例子.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WeDaHub/incubator-qrcode/3031ac57ba174b410ade990e16d234edb7848180/readme/黑白例子.png --------------------------------------------------------------------------------