qrcode源码修改,输出企业微信二维码

关键字: qrcode.js qrcode 企业微信二维码 二维码生成原理

简单修改qrcode.js源码,可以输出企业微信二维码。
关键在于修改各个点的间距,先来了解下二维码的生成原理

二维码生成原理

二维码基本结构

  • 位置探测图形、位置探测图形分隔符、定位图形:用于对二维码的定位,对每个QR码来说,位置都是固定存在的,只是大小规格会有所差异;

  • 校正图形:规格确定,校正图形的数量和位置也就确定了;

  • 格式信息:表示改二维码的纠错级别,分为L、M、Q、H;

  • 版本信息:即二维码的规格,QR码符号共有40种规格的矩阵(一般为黑白色),从21x21(版本1),到177x177(版本40),每一版本符号比前一版本 每边增加4个模块。

  • 数据和纠错码字:实际保存的二维码信息,和纠错码字(用于修正二维码损坏带来的错误)。

qrcode源码浅析

  • 根据上述二维码基本结构,可以来分析下部分图形的生成代码
  • 从函数makeImpl开始
  • 初始化码点矩阵
    this.moduleCount = 4 * this.typeNumber + 17
    this.modules = new Array(this.moduleCount)
    for (var r = 0; r < this.moduleCount; r++) {
      this.modules[r] = new Array(this.moduleCount)
      for (var o = 0; o < this.moduleCount; o++) {
        this.modules[r][o] = null
      }
    }
    

setupPositionProbePattern 函数用来标识位置探测图形
setupPositionAdjustPattern 函数用来标识校正图形

  • 其他复杂的过程可以略过
  • 最终码点的绘制是在draw函数中的fillRect
  e.prototype.draw = function (oQRCode) {
    var _oContext = this._oContext
    var _htOption = this._htOption
    ...
    ...
    _oContext.fillRect(
      nLeft,
      nTop,
      nWidth / 1.5,
      nHeight / 1.5
    )

实现企业微信名片的二维码

  • 如何实现企微名片的二维码样式呢?
  • 其实无非就是在标准二维码样式上,除三个位置探测图形和右下角的校正图形外,让码点与码点之间的距离稍微增大1.5倍
  • 关键就在上述几个函数中
  • 首先声明二维数组modulesPosition来存放三个位置探测图形和右下角的校正图形的位置信息
  • 在makeImpl函数中的初始化矩阵中,我们可以初始化
    this.modulesPosition = new Array(this.moduleCount)
    for (var r = 0; r < this.moduleCount; r++) {
      this.modulesPosition[r] = new Array(this.moduleCount)
      for (var o = 0; o < this.moduleCount; o++) {
        this.modulesPosition[r][o] = null
      }
    }
    
  • 在setupPositionProbePattern函数中内层循环中进行标识
    this.modulesCorner[row + r][col + c] = 'isPosition'
    
  • 同样在setupPositionAdjustPattern函数中内层循环中进行标识
  • 此处要注意因为校正图形只需要标识右下角那一个
    this.modulesCorner[pos[pos.length - 1] + r][pos[pos.length - 1] + c] = 'isPosition'
    
  • 最后只需要在e.prototype.draw中判断是否为豁免码点isPosition
  • 若为企微模式,则把码点间距拉长1.5倍即可
    _oContext.fillRect(
      nLeft,
      nTop,
      isPosition ? nWidth : nWidth / 1.5,
      isPosition ? nHeight : nHeight / 1.5
    )
    
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容