当前位置: 首页 > news >正文

从58做网站怎么做西宁市网站建设多少钱

从58做网站怎么做,西宁市网站建设多少钱,邢台市建设银行网站,网站首页布局设计教程通常QRCode由服务器生成,以图片格式发送到客户端,由客户端直接展示,也可以由客户端使用javascript或其他内置的SDK直接生成。 0、需求 QRCode生成过程中往往是先生成矩阵,然后使用矩阵生成图片,矩阵就是由01组成的一…

通常QRCode由服务器生成,以图片格式发送到客户端,由客户端直接展示,也可以由客户端使用javascript或其他内置的SDK直接生成。

0、需求

QRCode生成过程中往往是先生成矩阵,然后使用矩阵生成图片,矩阵就是由01组成的一维或二维数组。
例如,由ZXing生成的ByteMatrix就是一个由行列数据组成的二维数组。

//可以生成由01组成的一个矩阵字符串。
private string GetMatrixString(ByteMatrix matrix)
{return string.Join("", matrix.Array.Select(t => string.Join("", t)));
}

有时候,我们需要尽可能的减少网络传输,对QRCode进行缓存处理,或者减少QRCode矩阵生成的逻辑。
这时,我们完全可以将这个字符串发送给客户端,再由客户端生成图片,减少网络浏览传输或者方便客户端缓存QRCode。

下面方法可以对矩阵处理,生成QRCode图片。

function createQRCodeCanvas(matrix, size, padding) {size = size || 3;padding = padding === undefined ? 3 : padding;const width = Math.sqrt(matrix.length);const canvasWith = width * size + padding * 2;const canvas = document.createElement('canvas');canvas.width = canvasWith;canvas.height = canvasWith;const ctx = canvas.getContext('2d');ctx.fillStyle = "rgb(0,0,0)";for (let y = 0; y < width; y++) {for (let x = 0; x < width; x++) {const point = y * width + x;if (matrix[point] === 1) {ctx.fillRect(padding + x * size, padding + y * size, size, size);}}}return canvas.toDataURL();
}
1、矩阵压缩

由于矩阵完全由01组成,我们可以对矩阵进行处理,每8位作为一组,转换成一个字节。
往往矩阵的长度不会被8整除,所以我们在最后一位补1,标识矩阵结束,哪怕矩阵长度能被8整除,我们也补1。
下面代码生成压缩后的矩阵字节数组。

private byte[] GetMatrixBytes(ByteMatrix matrix)
{var qrData = matrix.Array;int idx = 7;int count = 0;byte[] result = new byte[(int)Math.Ceiling((decimal)(qrData.Length * qrData.Length + 1) / 8)];for (int i = 0; i < qrData.Length; i++){byte[] line = qrData[i];for (int j = 0; j < line.Length; j++){result[count++ >> 3] |= (byte)(line[j] << idx--);if (idx == -1) idx = 7;}}result[count >> 3] |= (byte)(1 << idx); //最后一位补1return result;
}

生成矩阵字节数组后,可以转换成base64发送到客户端,这样会大大减少传输的数据量。

2、矩阵还原

将上面的算法逆转即可。
例如,用csharp还原。

/// <summary>
/// 从字节数组还原矩阵字符串
/// </summary>
/// <param name="matrix"></param>
/// <returns></returns>
private byte[] GetMatrixBytes(byte[] matrix)
{byte[] bytes = new byte[matrix.Length * 8];int idx = 0;foreach (byte chr in matrix) for (int i = 7; i >= 0; i--) bytes[idx++] = (byte)((chr >> i) & 1);while (bytes[--idx] == 0) ;return bytes.Take(idx).ToArray();
}

用javascript还原

function getMatrix(raws) {const bytes = [];let idx = 0;for (let j = 0; j < raws.length; j++) {for (let i = 7; i >= 0; i--) bytes[idx++] = (raws[j] >> i) & 1;}while (bytes[--idx] === 0) ;return bytes.slice(0, idx);
}

矩阵还原出来后,就可以用文章最开始的方法将矩阵生成图片了。

3、总结

通过对矩阵的处理,进一步减少标识矩阵所用的字节数,从而减少网络传输的数据,并且更方便的缓存生成的QRCode。
客户端可以只缓存压缩后的矩阵,必要的时候还原并展示即可。

在这里插入图片描述

http://www.yayakq.cn/news/748748/

相关文章:

  • 网站源码如何优化企业网站的视频页如何做
  • 东莞市品牌网站建设报价备案网站服务内容
  • 设计师做私单网站企业如何做好网站的seo优化
  • c 网站开发培训百度上首页
  • 做企业网站有什么工作内容轻量级网站开发
  • 网站建设方案图文昌市建设局网站
  • 怎样用电脑和网訨自己做网站wordpress游客登录
  • 遵义营商环境建设局网站苏州网站制作及推广
  • 男女做恩爱视频网站设计师国外网站
  • 宣传 网站建设方案模板下载wordpress tdk设置
  • 创建网站的一般步骤wordpress 批注
  • 网页传奇游戏哪个好南宁网站怎么做seo
  • 做什么地方网站网站做的跟别人的一样可以吗
  • 如何查询网站空间大小成都市住房与城乡建设局官网
  • 视频网站如何做微信营销wordpress管理导航栏目
  • 网站编辑合适内向的人做吗如何优化购物网站建设
  • 网站建设方案范例施工企业施工生产计划
  • 网站标题优化 英文wordpress插件用户
  • 设置网站建设方案室内设计网站平面案例
  • 有可以免费建网站的吗表情包生成器在线制作gif
  • 导航网站模板如何提高网站的自然排名
  • 石景山网站建设做视频网站需要什么架构
  • 网站建设工作简介视频拍摄脚本
  • 网站建设应该学什么四省网站建设
  • 重庆忠县网站建设公司哪家好中国镇江网
  • 备案网站ip谷歌网站流量分析
  • 网站建设的需求分析免费的源码分享网站
  • 网站logo在哪里网站cms系统排名
  • 网站建设费用高开发一个平台
  • 做外贸怎么登陆外国网站国家住房和城乡建设厅网站首页