当前位置:   article > 正文

微信小程序生成二维码_小程序二维码生成原理

小程序二维码生成原理

二维码又称二维条码,常见的二维码为QR Code,QR全称Quick Response(Quick Response,反映出这种二维码具有“超高速识读”的特点。“Quick Response Code”也就是“快速响应码”),是一个近几年来移动设备上超流行的一种编码方式,它比传统的Bar Code条形码能存更多的信息,也能表示更多的数据类型。

二维条码/二维码(2-dimensional bar code)是用某种特定的几何图形按一定规律在平面(二维方向上)分布的、黑白相间的、记录数据符号信息的图形;在代码编制上巧妙地利用构成计算机内部逻辑基础的“0”、“1”比特流的概念,使用若干个与二进制相对应的几何形体来表示文字数值信息,通过图象输入设备或光电扫描设备自动识读以实现信息自动处理:它具有条码技术的一些共性:每种码制有其特定的字符集;每个字符占有一定的宽度;具有一定的校验功能等。同时还具有对不同行的信息自动识别功能、及处理图形旋转变化点。 

发展历程

二维码原理

二维码的基本原理是利用二进制来存储信息的。通常由正方形矩阵像素点组成。下图就是一个常见的二维码形状。它一共由21行,21列的小矩形组成。矩阵中"黑色点"表示二进制"1", "白色点"表示二进制"0"。这些 1 和 0 排列组合就形成了二维码。

除了 1 和 0 的像素点之外,二维码还有三个像眼睛一样的大黑色块,叫做 定位点。这是二维码识别时用来对图像进行定位的,一定不能遮挡。否则将无法识别。

首先引入weapp-qrcode.js下载链接 点开链接,直接 ctrl + s 保存相对于位置即可

 

 wxml 

  1. <view id="container">
  2. <view class="ewm">
  3. <canvas style="width: 600rpx; height: 600rpx;" canvas-id="myQrcode"></canvas>
  4. </view>
  5. <input class="inpt" bindinput="ewmText" value="{{ text }}"></input>
  6. <button bindtap="searchFn" class="btn" type="primary">生成二维码</button>
  7. </view>

wxss

  1. .ewm{
  2. background-color: #e8e8e8;
  3. display: flex;
  4. justify-content: center;
  5. align-items: center;
  6. width: 680rpx;
  7. height: 680rpx;
  8. margin: 50rpx auto;
  9. }
  10. .inpt{
  11. border: 1rpx solid #e8e8e8;
  12. width: 620rpx;
  13. margin: 30rpx auto;
  14. padding: 30rpx;
  15. }
  16. .btn{
  17. width: 680rpx;
  18. }

js

  1. //index.js
  2. const app = getApp()
  3. let drawQrcode = require("../../utils/weapp-qrcode.js")
  4. Page({
  5. data: {
  6. text:"(๑′ᴗ‵๑)I Lᵒᵛᵉᵧₒᵤ❤",
  7. },
  8. onLoad() {
  9. this.ewmChange()
  10. },
  11. ewmChange(){
  12. let size = {}
  13. size.w = wx.getSystemInfoSync().windowWidth / 750 * 600
  14. size.h = size.w
  15. var that = this
  16. drawQrcode({
  17. width: size.w,
  18. height: size.h,
  19. canvasId: 'myQrcode',
  20. // ctx: wx.createCanvasContext('myQrcode'),
  21. text: that.data.text,
  22. // v1.0.0+版本支持在二维码上绘制图片
  23. })
  24. },
  25. ewmText(e){
  26. this.setData({
  27. text: e.detail.value
  28. })
  29. },
  30. searchFn(){
  31. this.ewmChange()
  32. }
  33. })

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号