neko-ui 2.15.0 → 2.15.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/es/avatar/group.js +2 -2
  2. package/es/avatar/index.js +2 -2
  3. package/es/back-top/index.js +2 -2
  4. package/es/basic-config/index.d.ts +1 -0
  5. package/es/basic-config/index.js +2 -2
  6. package/es/button/index.js +2 -2
  7. package/es/button/style.js +2 -2
  8. package/es/capture-screen/index.js +10 -10
  9. package/es/carousel/index.js +2 -2
  10. package/es/checkbox/index.js +2 -2
  11. package/es/code/copy-icon.js +2 -2
  12. package/es/code/index.js +3 -3
  13. package/es/code/worker.js +2 -2
  14. package/es/color-palette/index.js +2 -2
  15. package/es/color-picker/index.js +2 -2
  16. package/es/cron/begin-interval.js +2 -2
  17. package/es/cron/day.js +2 -2
  18. package/es/cron/hour.js +2 -2
  19. package/es/cron/index.js +2 -2
  20. package/es/cron/item.js +2 -2
  21. package/es/cron/minute.js +2 -2
  22. package/es/cron/month.js +2 -2
  23. package/es/cron/period.js +2 -2
  24. package/es/cron/second.js +2 -2
  25. package/es/cron/some.js +2 -2
  26. package/es/cron/week.js +2 -2
  27. package/es/cron/year.js +2 -2
  28. package/es/date-picker/date.js +2 -2
  29. package/es/date-picker/index.js +3 -3
  30. package/es/date-picker/month.js +2 -2
  31. package/es/date-picker/panel.js +2 -2
  32. package/es/date-picker/time.js +2 -2
  33. package/es/date-picker/year.js +2 -2
  34. package/es/dropdown/index.js +2 -2
  35. package/es/empty/index.js +2 -2
  36. package/es/from-schema/index.js +2 -2
  37. package/es/get-options/index.js +2 -2
  38. package/es/glass-panel/index.js +2 -2
  39. package/es/highlight-text/index.js +2 -2
  40. package/es/icon/index.js +2 -2
  41. package/es/img/index.js +2 -2
  42. package/es/img/lazy.js +2 -2
  43. package/es/index.d.ts +1 -7
  44. package/es/index.js +2 -2
  45. package/es/input/index.js +2 -2
  46. package/es/input-number/index.js +2 -2
  47. package/es/marquee/index.d.ts +5 -0
  48. package/es/marquee/index.js +2 -2
  49. package/es/md/index.js +2 -2
  50. package/es/md/worker.js +2 -2
  51. package/es/menu/index.js +2 -2
  52. package/es/modal/hooks.js +2 -2
  53. package/es/modal/index.js +2 -2
  54. package/es/modal/posi.js +2 -2
  55. package/es/modal/store.js +2 -2
  56. package/es/notification/notification.js +2 -2
  57. package/es/notification/queque.js +2 -2
  58. package/es/pagination/index.js +2 -2
  59. package/es/popover/index.js +2 -2
  60. package/es/provider/index.js +2 -2
  61. package/es/qrcode/index.d.ts +1 -0
  62. package/es/qrcode/index.js +4 -4
  63. package/es/qrcode/qrcode.js +61 -61
  64. package/es/radio/index.js +2 -2
  65. package/es/segmented/index.js +2 -2
  66. package/es/select/index.js +3 -3
  67. package/es/skeleton/index.js +2 -2
  68. package/es/spin/index.js +2 -2
  69. package/es/switch/index.js +2 -2
  70. package/es/table/index.js +3 -3
  71. package/es/tabs/index.js +2 -2
  72. package/es/tag/index.js +2 -2
  73. package/es/theme/index.js +3 -3
  74. package/es/tree/index.js +2 -2
  75. package/es/tree/type.d.ts +1 -0
  76. package/es/tree/type.js +1 -1
  77. package/es/typography/index.js +2 -2
  78. package/es/utils/index.js +2 -2
  79. package/lib/avatar/group.js +2 -2
  80. package/lib/avatar/index.js +2 -2
  81. package/lib/back-top/index.js +2 -2
  82. package/lib/basic-config/index.d.ts +1 -0
  83. package/lib/basic-config/index.js +2 -2
  84. package/lib/button/index.js +2 -2
  85. package/lib/button/style.js +2 -2
  86. package/lib/capture-screen/index.js +10 -10
  87. package/lib/carousel/index.js +2 -2
  88. package/lib/checkbox/index.js +2 -2
  89. package/lib/code/copy-icon.js +2 -2
  90. package/lib/code/index.js +3 -3
  91. package/lib/code/worker.js +2 -2
  92. package/lib/color-palette/index.js +2 -2
  93. package/lib/color-picker/index.js +2 -2
  94. package/lib/cron/begin-interval.js +2 -2
  95. package/lib/cron/day.js +2 -2
  96. package/lib/cron/hour.js +2 -2
  97. package/lib/cron/index.js +2 -2
  98. package/lib/cron/item.js +2 -2
  99. package/lib/cron/minute.js +2 -2
  100. package/lib/cron/month.js +2 -2
  101. package/lib/cron/period.js +2 -2
  102. package/lib/cron/second.js +2 -2
  103. package/lib/cron/some.js +2 -2
  104. package/lib/cron/week.js +2 -2
  105. package/lib/cron/year.js +2 -2
  106. package/lib/date-picker/date.js +2 -2
  107. package/lib/date-picker/dayjs.js +1 -1
  108. package/lib/date-picker/index.js +3 -3
  109. package/lib/date-picker/month.js +2 -2
  110. package/lib/date-picker/panel.js +2 -2
  111. package/lib/date-picker/time.js +2 -2
  112. package/lib/date-picker/year.js +2 -2
  113. package/lib/dropdown/index.js +2 -2
  114. package/lib/empty/index.js +2 -2
  115. package/lib/from-schema/index.js +2 -2
  116. package/lib/get-options/index.js +2 -2
  117. package/lib/glass-panel/index.js +2 -2
  118. package/lib/highlight-text/index.js +2 -2
  119. package/lib/icon/index.js +2 -2
  120. package/lib/img/index.js +2 -2
  121. package/lib/img/lazy.js +2 -2
  122. package/lib/index.d.ts +1 -7
  123. package/lib/index.js +2 -2
  124. package/lib/input/index.js +2 -2
  125. package/lib/input-number/index.js +2 -2
  126. package/lib/marquee/index.d.ts +5 -0
  127. package/lib/marquee/index.js +2 -2
  128. package/lib/md/index.js +2 -2
  129. package/lib/md/worker.js +2 -2
  130. package/lib/menu/index.js +2 -2
  131. package/lib/modal/hooks.js +2 -2
  132. package/lib/modal/index.js +2 -2
  133. package/lib/modal/posi.js +2 -2
  134. package/lib/modal/store.js +2 -2
  135. package/lib/notification/notification.js +2 -2
  136. package/lib/notification/queque.js +2 -2
  137. package/lib/pagination/index.js +2 -2
  138. package/lib/popover/index.js +2 -2
  139. package/lib/provider/index.js +2 -2
  140. package/lib/qrcode/index.d.ts +1 -0
  141. package/lib/qrcode/index.js +4 -4
  142. package/lib/qrcode/qrcode.js +61 -61
  143. package/lib/radio/index.js +2 -2
  144. package/lib/segmented/index.js +2 -2
  145. package/lib/select/index.js +3 -3
  146. package/lib/skeleton/index.js +2 -2
  147. package/lib/spin/index.js +2 -2
  148. package/lib/switch/index.js +2 -2
  149. package/lib/table/index.js +3 -3
  150. package/lib/tabs/index.js +2 -2
  151. package/lib/tag/index.js +2 -2
  152. package/lib/theme/index.js +3 -3
  153. package/lib/tree/index.js +2 -2
  154. package/lib/tree/type.d.ts +1 -0
  155. package/lib/tree/type.js +1 -1
  156. package/lib/typography/index.js +2 -2
  157. package/lib/utils/index.js +2 -2
  158. package/package.json +8 -17
  159. package/es/collapse/index.d.ts +0 -16
  160. package/es/collapse/index.js +0 -2
  161. package/lib/collapse/index.d.ts +0 -16
  162. package/lib/collapse/index.js +0 -2
  163. package/umd/app-resource.json +0 -1
  164. package/umd/index.js +0 -5053
  165. package/umd/site.webmanifest +0 -1
@@ -9,8 +9,8 @@ var ECC_CODEWORDS_PER_BLOCK=[[-1,7,10,15,20,26,18,20,24,30,18,20,24,26,30,22,24,
9
9
  [-1,13,22,18,26,18,24,18,22,20,24,28,26,24,20,30,24,28,28,26,30,28,30,30,30,30,28,30,30,30,30,30,30,30,30,30,30,30,30,30,30],// Quartile
10
10
  [-1,17,28,22,16,22,28,26,26,24,28,24,28,22,24,24,30,28,28,26,28,30,24,30,30,30,30,30,30,30,30,30,30,30,30,30,30,30,30,30,30]// High
11
11
  ];var NUM_ERROR_CORRECTION_BLOCKS=[[-1,1,1,1,1,1,2,2,2,2,4,4,4,4,4,6,6,6,6,7,8,8,9,9,10,12,12,12,13,14,15,16,17,18,19,19,20,21,22,24,25],[-1,1,1,1,2,2,4,4,4,5,5,5,8,9,9,10,10,11,13,14,16,17,17,18,20,21,23,25,26,28,29,31,33,35,37,38,40,43,45,47,49],[-1,1,1,2,2,4,4,6,6,8,8,8,10,12,16,12,17,16,18,21,20,23,23,25,27,29,34,34,35,38,40,43,45,48,51,53,56,59,62,65,68],[-1,1,1,2,4,4,4,5,6,8,8,11,11,16,16,18,16,19,21,25,25,25,34,30,32,35,37,40,42,45,48,51,54,57,60,63,66,70,74,77,81]];// 返回在给定版本的QR码中可以存储的数据位数,已排除所有功能模块。这包括余数位,因此可能不是8的倍数。结果范围在[208, 29648]之间。这可以实现为一个40项的查找表。
12
- function getNumRawDataModules(ver){if(ver<QrCode.VERSION.MIN||ver>QrCode.VERSION.MAX){throw new RangeError("Version number out of range")}var result=(16*ver+128)*ver+64;if(ver>=2){var numAlign=Math.floor(ver/7)+2;result-=(25*numAlign-10)*numAlign-55;if(ver>=7)result-=36}assert(208<=result&&result<=29648);return result}// 返回指定版本号和纠错级别的 QR 码包含的 8 位数据码字数量(即非纠错码字),余位被舍弃。这个无状态的纯函数可以实现为一个 (40*4) 大小的查找表。
13
- function getNumDataCodewords(ver,ecl){return Math.floor(getNumRawDataModules(ver)/8)-ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver]*NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver]}/**
12
+ function getNumRawDataModules(ver){if(ver<QrCode.VERSION.MIN||ver>QrCode.VERSION.MAX){throw new RangeError("Version number out of range");}var result=(16*ver+128)*ver+64;if(ver>=2){var numAlign=Math.floor(ver/7)+2;result-=(25*numAlign-10)*numAlign-55;if(ver>=7)result-=36;}assert(208<=result&&result<=29648);return result;}// 返回指定版本号和纠错级别的 QR 码包含的 8 位数据码字数量(即非纠错码字),余位被舍弃。这个无状态的纯函数可以实现为一个 (40*4) 大小的查找表。
13
+ function getNumDataCodewords(ver,ecl){return Math.floor(getNumRawDataModules(ver)/8)-ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver]*NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver];}/**
14
14
  * 生成一个 QR 码
15
15
  * @description
16
16
  * 根据给定的数据段和编码参数生成 QR 码。输出时会自动选择给定范围内尽可能小的 QR 码版本
@@ -21,32 +21,32 @@ function getNumDataCodewords(ver,ecl){return Math.floor(getNumRawDataModules(ver
21
21
  * @param {-1 | IntRange<0, 8>} [mask=-1] - 掩码模式(默认为 -1,表示自动选择)
22
22
  * @param {boolean} [boostEcl=true] - 在数据仍然适合当前版本号的情况下提高纠错级别(默认为 true)。
23
23
  * @returns {QrCode} 返回生成的 QR 码。
24
- */function encodeSegments(segs,ecl){var minVersion=arguments.length>2&&arguments[2]!==undefined?arguments[2]:1;var maxVersion=arguments.length>3&&arguments[3]!==undefined?arguments[3]:40;var mask=arguments.length>4&&arguments[4]!==undefined?arguments[4]:-1;var boostEcl=arguments.length>5&&arguments[5]!==undefined?arguments[5]:true;if(!(QrCode.VERSION.MIN<=minVersion&&minVersion<=maxVersion&&maxVersion<=QrCode.VERSION.MAX)||mask<-1||mask>7){throw new RangeError("Invalid value")}// 查找要使用的最小版本号
24
+ */function encodeSegments(segs,ecl){var minVersion=arguments.length>2&&arguments[2]!==undefined?arguments[2]:1;var maxVersion=arguments.length>3&&arguments[3]!==undefined?arguments[3]:40;var mask=arguments.length>4&&arguments[4]!==undefined?arguments[4]:-1;var boostEcl=arguments.length>5&&arguments[5]!==undefined?arguments[5]:true;if(!(QrCode.VERSION.MIN<=minVersion&&minVersion<=maxVersion&&maxVersion<=QrCode.VERSION.MAX)||mask<-1||mask>7){throw new RangeError("Invalid value");}// 查找要使用的最小版本号
25
25
  var version,dataUsedBits,_ecl=ecl;for(version=minVersion;;version++){var _dataCapacityBits=getNumDataCodewords(version,_ecl)*8,// 可用的数据位数
26
26
  usedBits=getTotalBits(segs,version);// 找到合适的版本号
27
- if(usedBits<=_dataCapacityBits){dataUsedBits=usedBits;break}if(version>=maxVersion){// 范围内的所有版本都无法容纳给定数据
28
- throw new RangeError("Data too long")}}// 提高纠错级别; 从低到高
29
- if(boostEcl){for(var _i=0,_arr=[Ecc.get("MEDIUM"),Ecc.get("QUARTILE"),Ecc.get("HIGH")];_i<_arr.length;_i++){var newEcl=_arr[_i];if(dataUsedBits<=getNumDataCodewords(version,newEcl)*8)_ecl=newEcl}}// 连接所有段以创建数据位字符串
30
- var bb=[];var _iterator=_createForOfIteratorHelper(segs),_step;try{for(_iterator.s();!(_step=_iterator.n()).done;){var seg=_step.value;appendBits(seg.mode.modeBits,4,bb);appendBits(seg.numChars,seg.mode.numCharCountBits(version),bb);var _iterator2=_createForOfIteratorHelper(seg.getData()),_step2;try{for(_iterator2.s();!(_step2=_iterator2.n()).done;){var b=_step2.value;bb.push(b)}}catch(err){_iterator2.e(err)}finally{_iterator2.f()}}}catch(err){_iterator.e(err)}finally{_iterator.f()}assert(bb.length===dataUsedBits);// 添加终止符并填充至字节边界(如果适用)
27
+ if(usedBits<=_dataCapacityBits){dataUsedBits=usedBits;break;}if(version>=maxVersion){// 范围内的所有版本都无法容纳给定数据
28
+ throw new RangeError("Data too long");}}// 提高纠错级别; 从低到高
29
+ if(boostEcl){for(var _i=0,_arr=[Ecc.get("MEDIUM"),Ecc.get("QUARTILE"),Ecc.get("HIGH")];_i<_arr.length;_i++){var newEcl=_arr[_i];if(dataUsedBits<=getNumDataCodewords(version,newEcl)*8)_ecl=newEcl;}}// 连接所有段以创建数据位字符串
30
+ var bb=[];var _iterator=_createForOfIteratorHelper(segs),_step;try{for(_iterator.s();!(_step=_iterator.n()).done;){var seg=_step.value;appendBits(seg.mode.modeBits,4,bb);appendBits(seg.numChars,seg.mode.numCharCountBits(version),bb);var _iterator2=_createForOfIteratorHelper(seg.getData()),_step2;try{for(_iterator2.s();!(_step2=_iterator2.n()).done;){var b=_step2.value;bb.push(b);}}catch(err){_iterator2.e(err)}finally{_iterator2.f()}}}catch(err){_iterator.e(err)}finally{_iterator.f()}assert(bb.length===dataUsedBits);// 添加终止符并填充至字节边界(如果适用)
31
31
  var dataCapacityBits=getNumDataCodewords(version,_ecl)*8;assert(bb.length<=dataCapacityBits);appendBits(0,Math.min(4,dataCapacityBits-bb.length),bb);appendBits(0,(8-bb.length%8)%8,bb);assert(bb.length%8===0);// 用交替字节填充直到达到数据容量
32
- for(var padByte=236;bb.length<dataCapacityBits;padByte^=236^17){appendBits(padByte,8,bb)}// 以大端序将位打包成字节
33
- var dataCodewords=[];while(dataCodewords.length*8<bb.length)dataCodewords.push(0);bb.forEach(function(b,i){return dataCodewords[i>>>3]|=b<<7-(i&7)});return new QrCode(version,_ecl,dataCodewords,mask)}// 返回表示给定字符串的UTF-8编码字节数组
32
+ for(var padByte=236;bb.length<dataCapacityBits;padByte^=236^17){appendBits(padByte,8,bb);}// 以大端序将位打包成字节
33
+ var dataCodewords=[];while(dataCodewords.length*8<bb.length)dataCodewords.push(0);bb.forEach(function(b,i){return dataCodewords[i>>>3]|=b<<7-(i&7)});return new QrCode(version,_ecl,dataCodewords,mask);}// 返回表示给定字符串的UTF-8编码字节数组
34
34
  function toUtf8ByteArray(str){// eslint-disable-next-line no-param-reassign
35
- str=encodeURI(str);var result=[];for(var i=0;i<str.length;i++){if(str.charAt(i)!=="%")result.push(str.charCodeAt(i));else{result.push(parseInt(str.substring(i+1,i+3),16));i+=2}}return result}// 返回一个新的可变段列表,用于表示给定的Unicode文本字符串。结果可能使用各种段模式并切换模式以优化位流的长度。
35
+ str=encodeURI(str);var result=[];for(var i=0;i<str.length;i++){if(str.charAt(i)!=="%")result.push(str.charCodeAt(i));else{result.push(parseInt(str.substring(i+1,i+3),16));i+=2;}}return result;}// 返回一个新的可变段列表,用于表示给定的Unicode文本字符串。结果可能使用各种段模式并切换模式以优化位流的长度。
36
36
  function makeSegments(text){// 自动选择最高效的段编码
37
- if(text==="")return[];else if(isNumeric(text))return[makeNumeric(text)];else if(isAlphanumeric(text))return[makeAlphanumeric(text)];return[makeBytes(toUtf8ByteArray(text))]}function reedSolomonComputeDivisor(degree){if(degree<1||degree>255)throw new RangeError("Degree out of range");// 多项式系数按从高到低的幂次存储,不包括始终为1的首项。
37
+ if(text==="")return[];else if(isNumeric(text))return[makeNumeric(text)];else if(isAlphanumeric(text))return[makeAlphanumeric(text)];return[makeBytes(toUtf8ByteArray(text))];}function reedSolomonComputeDivisor(degree){if(degree<1||degree>255)throw new RangeError("Degree out of range");// 多项式系数按从高到低的幂次存储,不包括始终为1的首项。
38
38
  // 例如多项式 x^3 + 255x^2 + 8x + 93 存储为uint8数组 [255, 8, 93]。
39
39
  var result=[];for(var i=0;i<degree-1;i++)result.push(0);result.push(1);// Start off with the monomial x^0
40
40
  // 计算多项式乘积 (x - r^0) * (x - r^1) * (x - r^2) * ... * (x - r^{degree-1}),
41
41
  // 并舍弃最高次项(该项始终为 1x^degree)。
42
42
  // 注意 r = 0x02,它是有限域 GF(2^8/0x11D) 的生成元。
43
43
  var root=1;for(var _i2=0;_i2<degree;_i2++){// 将当前结果乘以 (x - r^i)
44
- for(var j=0;j<result.length;j++){result[j]=reedSolomonMultiply(result[j],root);if(j+1<result.length)result[j]^=result[j+1]}root=reedSolomonMultiply(root,2)}return result}// 返回给定数据和除数多项式的里德-所罗门错误纠正码字。
44
+ for(var j=0;j<result.length;j++){result[j]=reedSolomonMultiply(result[j],root);if(j+1<result.length)result[j]^=result[j+1];}root=reedSolomonMultiply(root,2);}return result;}// 返回给定数据和除数多项式的里德-所罗门错误纠正码字。
45
45
  function reedSolomonComputeRemainder(data,divisor){var result=divisor.map(function(){return 0});var _iterator3=_createForOfIteratorHelper(data),_step3;try{var _loop=function _loop(){var b=_step3.value;// 多项式除法
46
- var factor=b^result.shift();result.push(0);divisor.forEach(function(coef,i){return result[i]^=reedSolomonMultiply(coef,factor)})};for(_iterator3.s();!(_step3=_iterator3.n()).done;){_loop()}}catch(err){_iterator3.e(err)}finally{_iterator3.f()}return result}// 返回两个给定域元素模GF(2^8/0x11D)的乘积。参数和结果
46
+ var factor=b^result.shift();result.push(0);divisor.forEach(function(coef,i){return result[i]^=reedSolomonMultiply(coef,factor)});};for(_iterator3.s();!(_step3=_iterator3.n()).done;){_loop()}}catch(err){_iterator3.e(err)}finally{_iterator3.f()}return result;}// 返回两个给定域元素模GF(2^8/0x11D)的乘积。参数和结果
47
47
  // 都是无符号8位整数。这可以实现为256*256个uint8条目的查找表。
48
48
  function reedSolomonMultiply(x,y){if(x>>>8!==0||y>>>8!==0)throw new RangeError("Byte out of range");// 俄罗斯农民乘法
49
- var z=0;for(var i=7;i>=0;i--){z=z<<1^(z>>>7)*285;z^=(y>>>i&1)*x}assert(z>>>8===0);return z}/*
49
+ var z=0;for(var i=7;i>=0;i--){z=z<<1^(z>>>7)*285;z^=(y>>>i&1)*x;}assert(z>>>8===0);return z;}/*
50
50
  * 由 Denso Wave 发明,并在 ISO/IEC 18004 标准中描述。
51
51
  * 此类的实例表示一个不可变的暗/亮单元方格网。
52
52
  * 该类遵循 QR 码模型 2 规范,支持所有版本(尺寸)从 1 到 40、4 种纠错等级以及 4 种字符编码模式。
@@ -57,89 +57,89 @@ errorCorrectionLevel,dataCodewords,msk){_classCallCheck(this,QrCode);// QR Code
57
57
  _defineProperty(this,"modules",[]);// 表示不受掩模影响的功能模块。构造函数完成后即被丢弃。
58
58
  _defineProperty(this,"isFunction",[]);// 掩码模式定义
59
59
  _defineProperty(this,"MASK_PATTERNS",[function(x,y){return(x+y)%2===0},function(_,y){return y%2===0},function(x){return x%3===0},function(x,y){return(x+y)%3===0},function(x,y){return(Math.floor(x/3)+Math.floor(y/2))%2===0},function(x,y){return x*y%2+x*y%3===0},function(x,y){return(x*y%2+x*y%3)%2===0},function(x,y){return((x+y)%2+x*y%3)%2===0}]);this.version=version;this.errorCorrectionLevel=errorCorrectionLevel;// 验证构造函数参数
60
- if(version<QrCode.VERSION.MIN||version>QrCode.VERSION.MAX){throw new RangeError("Version value out of range")}if(msk<-1||msk>7)throw new RangeError("Mask value out of range");// 初始化
60
+ if(version<QrCode.VERSION.MIN||version>QrCode.VERSION.MAX){throw new RangeError("Version value out of range");}if(msk<-1||msk>7)throw new RangeError("Mask value out of range");// 初始化
61
61
  this.size=version*4+17;// 创建模块数组
62
62
  // 初始化两个网格为 size*size 大小的布尔数组,初始值为 false 全为浅色
63
- var row=Array(this.size).fill(false);for(var i=0;i<this.size;i++){this.modules[i]=row.slice();this.isFunction[i]=row.slice()}// 计算错误纠正码(ECC),绘制模块
63
+ var row=Array(this.size).fill(false);for(var i=0;i<this.size;i++){this.modules[i]=row.slice();this.isFunction[i]=row.slice();}// 计算错误纠正码(ECC),绘制模块
64
64
  this.drawFunctionPatterns();// 构建 QR 码的主要流程
65
65
  var allCodewords=this.addEccAndInterleave(dataCodewords);this.drawCodewords(allCodewords);// 确定最终掩码
66
66
  this.mask=this.selectMask(msk);// 应用最终掩码并绘制格式位
67
67
  this.applyMask(this.mask);this.drawFormatBits(this.mask);// 构造完成, 丢弃
68
- this.isFunction=[]}/* -- 访问器方法 --*/// 返回给定坐标处模块(像素xy的颜色,浅色时为false,深色时为true);如果给定的坐标超出边界,则返回false(浅色)。
68
+ this.isFunction=[];}/* -- 访问器方法 --*/// 返回给定坐标处模块(像素xy的颜色,浅色时为false,深色时为true);如果给定的坐标超出边界,则返回false(浅色)。
69
69
  return _createClass(QrCode,[{key:"selectMask",value:// 选择最佳掩码
70
70
  function selectMask(msk){if(msk!==-1)return msk;var mask=0;var minPenalty=1000000000;for(var i=0;i<8;i++){// 自动选择最佳掩模
71
- this.applyMask(i);this.drawFormatBits(i);var penalty=this.getPenaltyScore();if(penalty<minPenalty){mask=i;minPenalty=penalty}// 撤销掩码
72
- this.applyMask(i)}assert(0<=mask&&mask<=7);return mask}},{key:"getModule",value:function getModule(x,y){return x>=0&&x<this.size&&y>=0&&y<this.size&&this.modules[y][x]}/* -- 构造函数的私有辅助方法:绘制功能模块 --*/// 读取该对象的版本字段,并绘制和标记所有功能模块。
71
+ this.applyMask(i);this.drawFormatBits(i);var penalty=this.getPenaltyScore();if(penalty<minPenalty){mask=i;minPenalty=penalty;}// 撤销掩码
72
+ this.applyMask(i);}assert(0<=mask&&mask<=7);return mask;}},{key:"getModule",value:function getModule(x,y){return x>=0&&x<this.size&&y>=0&&y<this.size&&this.modules[y][x];}/* -- 构造函数的私有辅助方法:绘制功能模块 --*/// 读取该对象的版本字段,并绘制和标记所有功能模块。
73
73
  },{key:"drawFunctionPatterns",value:function drawFunctionPatterns(){// 绘制水平和垂直定时图案
74
- for(var i=0;i<this.size;i++){var flag=i%2===0;this.setFunctionModule(6,i,flag);this.setFunctionModule(i,6,flag)}// 绘制 3 个定位图案(除了右下角的所有角落;会覆盖一些定时模块)
74
+ for(var i=0;i<this.size;i++){var flag=i%2===0;this.setFunctionModule(6,i,flag);this.setFunctionModule(i,6,flag);}// 绘制 3 个定位图案(除了右下角的所有角落;会覆盖一些定时模块)
75
75
  this.drawFinderPattern(3,3);var y=this.size-4;this.drawFinderPattern(y,3);this.drawFinderPattern(3,y);// 绘制多个对齐图案
76
76
  var alignPatPos=this.getAlignmentPatternPositions();var numAlign=alignPatPos.length;for(var _i3=0;_i3<numAlign;_i3++){for(var j=0;j<numAlign;j++){// 不在三个定位图案的角落处绘制
77
- if(!(_i3===0&&j===0||_i3===0&&j===numAlign-1||_i3===numAlign-1&&j===0)){this.drawAlignmentPattern(alignPatPos[_i3],alignPatPos[j])}}}// 绘制配置数据
77
+ if(!(_i3===0&&j===0||_i3===0&&j===numAlign-1||_i3===numAlign-1&&j===0)){this.drawAlignmentPattern(alignPatPos[_i3],alignPatPos[j]);}}}// 绘制配置数据
78
78
  this.drawFormatBits(0);// 临时掩码值;稍后在构造函数中会被覆盖
79
- this.drawVersion()}// 绘制格式位的两个副本(带有其自己的错误纠正码)
79
+ this.drawVersion();}// 绘制格式位的两个副本(带有其自己的错误纠正码)
80
80
  // 基于给定的掩码和该对象的错误纠正级别字段。
81
81
  },{key:"drawFormatBits",value:function drawFormatBits(mask){// 计算错误纠正码并打包位
82
82
  var data=this.errorCorrectionLevel.formatBits<<3|mask;// errCorrLvl 是 uint2 类型,mask 是 uint3 类型
83
83
  var rem=data;for(var i=0;i<10;i++)rem=rem<<1^(rem>>>9)*1335;var bits=(data<<10|rem)^21522;// uint15
84
84
  assert(bits>>>15===0);// 绘制第一个副本
85
- for(var _i4=0;_i4<=5;_i4++)this.setFunctionModule(8,_i4,getBit(bits,_i4));this.setFunctionModule(8,7,getBit(bits,6));this.setFunctionModule(8,8,getBit(bits,7));this.setFunctionModule(7,8,getBit(bits,8));for(var _i5=9;_i5<15;_i5++){this.setFunctionModule(14-_i5,8,getBit(bits,_i5))}// 绘制第二个副本
86
- for(var _i6=0;_i6<8;_i6++){this.setFunctionModule(this.size-1-_i6,8,getBit(bits,_i6))}for(var _i7=8;_i7<15;_i7++){this.setFunctionModule(8,this.size-15+_i7,getBit(bits,_i7))}this.setFunctionModule(8,this.size-8,true);// Always dark
85
+ for(var _i4=0;_i4<=5;_i4++)this.setFunctionModule(8,_i4,getBit(bits,_i4));this.setFunctionModule(8,7,getBit(bits,6));this.setFunctionModule(8,8,getBit(bits,7));this.setFunctionModule(7,8,getBit(bits,8));for(var _i5=9;_i5<15;_i5++){this.setFunctionModule(14-_i5,8,getBit(bits,_i5));}// 绘制第二个副本
86
+ for(var _i6=0;_i6<8;_i6++){this.setFunctionModule(this.size-1-_i6,8,getBit(bits,_i6));}for(var _i7=8;_i7<15;_i7++){this.setFunctionModule(8,this.size-15+_i7,getBit(bits,_i7));}this.setFunctionModule(8,this.size-8,true);// Always dark
87
87
  }// 如果7 <= version <= 40,则绘制版本位的两个副本(带有其自己的错误纠正码),
88
88
  // 基于该对象的版本字段。
89
89
  },{key:"drawVersion",value:function drawVersion(){if(this.version<7)return;// 计算错误纠正码并打包位
90
90
  var rem=this.version;// version 是 uint6 类型,范围在 [7, 40]
91
91
  for(var i=0;i<12;i++)rem=rem<<1^(rem>>>11)*7973;var bits=this.version<<12|rem;// uint18
92
92
  assert(bits>>>18===0);// 绘制两个副本
93
- for(var _i8=0;_i8<18;_i8++){var color=getBit(bits,_i8);var a=this.size-11+_i8%3;var b=Math.floor(_i8/3);this.setFunctionModule(a,b,color);this.setFunctionModule(b,a,color)}}// 绘制一个9*9的定位图案,包括边界分隔符,中心模块位于(x, y)。模块可以超出边界。
93
+ for(var _i8=0;_i8<18;_i8++){var color=getBit(bits,_i8);var a=this.size-11+_i8%3;var b=Math.floor(_i8/3);this.setFunctionModule(a,b,color);this.setFunctionModule(b,a,color);}}// 绘制一个9*9的定位图案,包括边界分隔符,中心模块位于(x, y)。模块可以超出边界。
94
94
  },{key:"drawFinderPattern",value:function drawFinderPattern(x,y){for(var dy=-4;dy<=4;dy++){for(var dx=-4;dx<=4;dx++){var dist=Math.max(Math.abs(dx),Math.abs(dy)),// Chebyshev/无穷范数
95
- xx=x+dx,yy=y+dy;if(0<=xx&&xx<this.size&&0<=yy&&yy<this.size){this.setFunctionModule(xx,yy,dist!==2&&dist!==4)}}}}// 绘制一个5*5的对齐图案,中心模块位于(x, y)。所有模块必须在边界内。
96
- },{key:"drawAlignmentPattern",value:function drawAlignmentPattern(x,y){for(var dy=-2;dy<=2;dy++){for(var dx=-2;dx<=2;dx++){this.setFunctionModule(x+dx,y+dy,Math.max(Math.abs(dx),Math.abs(dy))!==1)}}}// 设置模块的颜色并将其标记为功能模块。仅由构造函数使用。坐标必须在边界内。
97
- },{key:"setFunctionModule",value:function setFunctionModule(x,y,isDark){this.modules[y][x]=isDark;this.isFunction[y][x]=true}// 返回一个新的字节字符串,表示具有适当错误纠正码字的给定数据,基于该对象的版本和错误纠正级别。
98
- },{key:"addEccAndInterleave",value:function addEccAndInterleave(data){var ver=this.version,ecl=this.errorCorrectionLevel;if(data.length!==getNumDataCodewords(ver,ecl)){throw new RangeError("Invalid argument")}// 计算参数数值
95
+ xx=x+dx,yy=y+dy;if(0<=xx&&xx<this.size&&0<=yy&&yy<this.size){this.setFunctionModule(xx,yy,dist!==2&&dist!==4);}}}}// 绘制一个5*5的对齐图案,中心模块位于(x, y)。所有模块必须在边界内。
96
+ },{key:"drawAlignmentPattern",value:function drawAlignmentPattern(x,y){for(var dy=-2;dy<=2;dy++){for(var dx=-2;dx<=2;dx++){this.setFunctionModule(x+dx,y+dy,Math.max(Math.abs(dx),Math.abs(dy))!==1);}}}// 设置模块的颜色并将其标记为功能模块。仅由构造函数使用。坐标必须在边界内。
97
+ },{key:"setFunctionModule",value:function setFunctionModule(x,y,isDark){this.modules[y][x]=isDark;this.isFunction[y][x]=true;}// 返回一个新的字节字符串,表示具有适当错误纠正码字的给定数据,基于该对象的版本和错误纠正级别。
98
+ },{key:"addEccAndInterleave",value:function addEccAndInterleave(data){var ver=this.version,ecl=this.errorCorrectionLevel;if(data.length!==getNumDataCodewords(ver,ecl)){throw new RangeError("Invalid argument");}// 计算参数数值
99
99
  var numBlocks=NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver],blockEccLen=ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver],rawCodewords=Math.floor(getNumRawDataModules(ver)/8),numShortBlocks=numBlocks-rawCodewords%numBlocks,shortBlockLen=Math.floor(rawCodewords/numBlocks),blocks=[],// 将数据分割成块并为每个块附加ECC
100
- rsDiv=reedSolomonComputeDivisor(blockEccLen);for(var i=0,k=0;i<numBlocks;i++){var dat=data.slice(k,k+shortBlockLen-blockEccLen+(i<numShortBlocks?0:1));var ecc=reedSolomonComputeRemainder(dat,rsDiv);k+=dat.length;if(i<numShortBlocks)dat.push(0);blocks.push(dat.concat(ecc))}// 将每个块的字节交错(而不是连接)成单个序列
100
+ rsDiv=reedSolomonComputeDivisor(blockEccLen);for(var i=0,k=0;i<numBlocks;i++){var dat=data.slice(k,k+shortBlockLen-blockEccLen+(i<numShortBlocks?0:1));var ecc=reedSolomonComputeRemainder(dat,rsDiv);k+=dat.length;if(i<numShortBlocks)dat.push(0);blocks.push(dat.concat(ecc));}// 将每个块的字节交错(而不是连接)成单个序列
101
101
  var result=[];var _loop2=function _loop2(_i9){blocks.forEach(function(block,j){// 跳过短块中的填充字节
102
- if(_i9!==shortBlockLen-blockEccLen||j>=numShortBlocks){result.push(block[_i9])}})};for(var _i9=0;_i9<blocks[0].length;_i9++){_loop2(_i9)}assert(result.length===rawCodewords);return result}// 将给定的8位码字序列(数据和错误纠正)绘制到此QR码的整个
102
+ if(_i9!==shortBlockLen-blockEccLen||j>=numShortBlocks){result.push(block[_i9]);}});};for(var _i9=0;_i9<blocks[0].length;_i9++){_loop2(_i9)}assert(result.length===rawCodewords);return result;}// 将给定的8位码字序列(数据和错误纠正)绘制到此QR码的整个
103
103
  // 数据区域上。在调用此方法之前需要标记功能模块。
104
- },{key:"drawCodewords",value:function drawCodewords(data){if(data.length!==Math.floor(getNumRawDataModules(this.version)/8)){throw new RangeError("Invalid argument")}var i=0;// 数据的位索引
104
+ },{key:"drawCodewords",value:function drawCodewords(data){if(data.length!==Math.floor(getNumRawDataModules(this.version)/8)){throw new RangeError("Invalid argument");}var i=0;// 数据的位索引
105
105
  var len=data.length*8;// 执行特殊的之字形扫描
106
106
  for(var right=this.size-1;right>=1;right-=2){// 每对列中右列的索引
107
107
  if(right===6)right=5;for(var vert=0;vert<this.size;vert++){// 垂直计数器
108
108
  for(var j=0;j<2;j++){var x=right-j,// 实际的x坐标
109
109
  y=(right+1&2)===0?this.size-1-vert:vert;// 实际的y坐标
110
- if(!this.isFunction[y][x]&&i<len){this.modules[y][x]=getBit(data[i>>>3],7-(i&7));i++}// 如果此QR码有任何剩余位(0到7位),它们被构造函数赋值为0/false/浅色,且此方法不会改变它们
111
- }}}assert(i===len)}},{key:"applyMask",value:// 使用给定的掩码模式对此QR码中的码字模块进行XOR运算。在掩码之前必须标记功能模块并绘制码字位。
112
- function applyMask(mask){if(mask<0||mask>7)throw new RangeError("Mask value out of range");var maskPattern=this.MASK_PATTERNS[mask];for(var y=0;y<this.size;y++){for(var x=0;x<this.size;x++){if(!this.isFunction[y][x]&&maskPattern(x,y)){this.modules[y][x]=!this.modules[y][x]}}}}// 计算并返回基于此 QR 码当前模块状态的惩罚分数。用于自动掩码选择算法,以找到产生最低分数的掩码模式。
110
+ if(!this.isFunction[y][x]&&i<len){this.modules[y][x]=getBit(data[i>>>3],7-(i&7));i++;}// 如果此QR码有任何剩余位(0到7位),它们被构造函数赋值为0/false/浅色,且此方法不会改变它们
111
+ }}}assert(i===len);}},{key:"applyMask",value:// 使用给定的掩码模式对此QR码中的码字模块进行XOR运算。在掩码之前必须标记功能模块并绘制码字位。
112
+ function applyMask(mask){if(mask<0||mask>7)throw new RangeError("Mask value out of range");var maskPattern=this.MASK_PATTERNS[mask];for(var y=0;y<this.size;y++){for(var x=0;x<this.size;x++){if(!this.isFunction[y][x]&&maskPattern(x,y)){this.modules[y][x]=!this.modules[y][x];}}}}// 计算并返回基于此 QR 码当前模块状态的惩罚分数。用于自动掩码选择算法,以找到产生最低分数的掩码模式。
113
113
  },{key:"getPenaltyScore",value:function getPenaltyScore(){var result=0;// 行中具有相同颜色的相邻模块,以及查找器类似的模式
114
- for(var y=0;y<this.size;y++){var runColor=false;var runX=0;var runHistory=[0,0,0,0,0,0,0];for(var x=0;x<this.size;x++){if(this.modules[y][x]===runColor){runX++;if(runX===5)result+=QrCode.PENALTY.N1;else if(runX>5)result++}else{this.finderPenaltyAddHistory(runX,runHistory);if(!runColor){result+=this.finderPenaltyCountPatterns(runHistory)*QrCode.PENALTY.N3}runColor=this.modules[y][x];runX=1}}result+=this.finderPenaltyTerminateAndCount(runColor,runX,runHistory)*QrCode.PENALTY.N3}// 列中具有相同颜色的相邻模块,以及查找器类似的模式
115
- for(var _x=0;_x<this.size;_x++){var _runColor=false;var runY=0;var _runHistory=[0,0,0,0,0,0,0];for(var _y=0;_y<this.size;_y++){if(this.modules[_y][_x]===_runColor){runY++;if(runY===5)result+=QrCode.PENALTY.N1;else if(runY>5)result++}else{this.finderPenaltyAddHistory(runY,_runHistory);if(!_runColor){result+=this.finderPenaltyCountPatterns(_runHistory)*QrCode.PENALTY.N3}_runColor=this.modules[_y][_x];runY=1}}result+=this.finderPenaltyTerminateAndCount(_runColor,runY,_runHistory)*QrCode.PENALTY.N3}// 2*2 块的模块具相同的颜色
116
- for(var _y2=0;_y2<this.size-1;_y2++){for(var _x2=0;_x2<this.size-1;_x2++){var color=this.modules[_y2][_x2];if(color===this.modules[_y2][_x2+1]&&color===this.modules[_y2+1][_x2]&&color===this.modules[_y2+1][_x2+1]){result+=QrCode.PENALTY.N2}}}// 暗模块和亮模块的平衡
117
- var dark=0;var _iterator4=_createForOfIteratorHelper(this.modules),_step4;try{for(_iterator4.s();!(_step4=_iterator4.n()).done;){var row=_step4.value;dark=row.reduce(function(sum,color){return sum+(color?1:0)},dark)}// 注意,size 是奇数,所以 dark/total !== 1/2
114
+ for(var y=0;y<this.size;y++){var runColor=false;var runX=0;var runHistory=[0,0,0,0,0,0,0];for(var x=0;x<this.size;x++){if(this.modules[y][x]===runColor){runX++;if(runX===5)result+=QrCode.PENALTY.N1;else if(runX>5)result++;}else{this.finderPenaltyAddHistory(runX,runHistory);if(!runColor){result+=this.finderPenaltyCountPatterns(runHistory)*QrCode.PENALTY.N3;}runColor=this.modules[y][x];runX=1;}}result+=this.finderPenaltyTerminateAndCount(runColor,runX,runHistory)*QrCode.PENALTY.N3;}// 列中具有相同颜色的相邻模块,以及查找器类似的模式
115
+ for(var _x=0;_x<this.size;_x++){var _runColor=false;var runY=0;var _runHistory=[0,0,0,0,0,0,0];for(var _y=0;_y<this.size;_y++){if(this.modules[_y][_x]===_runColor){runY++;if(runY===5)result+=QrCode.PENALTY.N1;else if(runY>5)result++;}else{this.finderPenaltyAddHistory(runY,_runHistory);if(!_runColor){result+=this.finderPenaltyCountPatterns(_runHistory)*QrCode.PENALTY.N3;}_runColor=this.modules[_y][_x];runY=1;}}result+=this.finderPenaltyTerminateAndCount(_runColor,runY,_runHistory)*QrCode.PENALTY.N3;}// 2*2 块的模块具相同的颜色
116
+ for(var _y2=0;_y2<this.size-1;_y2++){for(var _x2=0;_x2<this.size-1;_x2++){var color=this.modules[_y2][_x2];if(color===this.modules[_y2][_x2+1]&&color===this.modules[_y2+1][_x2]&&color===this.modules[_y2+1][_x2+1]){result+=QrCode.PENALTY.N2;}}}// 暗模块和亮模块的平衡
117
+ var dark=0;var _iterator4=_createForOfIteratorHelper(this.modules),_step4;try{for(_iterator4.s();!(_step4=_iterator4.n()).done;){var row=_step4.value;dark=row.reduce(function(sum,color){return sum+(color?1:0)},dark);}// 注意,size 是奇数,所以 dark/total !== 1/2
118
118
  }catch(err){_iterator4.e(err)}finally{_iterator4.f()}var total=this.size*this.size;// 计算最小的整数 k >= 0,使得 (45-5k)% <= dark/total <= (55+5k)%
119
119
  var k=Math.ceil(Math.abs(dark*20-total*10)/total)-1;assert(0<=k&&k<=9);result+=k*QrCode.PENALTY.N4;assert(0<=result&&result<=2568888);// 基于默认值的非紧密上限
120
- return result}// 返回一个升序的位置列表,表示此版本号的对齐模式位置。每个位置在 [0,177) 范围内,并用于行和列轴。这可以实现为 40 个可变长度整数列表的查找表。
121
- },{key:"getAlignmentPatternPositions",value:function getAlignmentPatternPositions(){if(this.version===1)return[];var numAlign=Math.floor(this.version/7)+2,step=Math.floor((this.version*8+numAlign*3+5)/(numAlign*4-4))*2,result=[6];for(var pos=this.size-7;result.length<numAlign;pos-=step){result.splice(1,0,pos)}return result}// 只能在添加了亮色运行后立即调用,并返回 0、1 或 2。这是 getPenaltyScore() 的辅助函数。
120
+ return result;}// 返回一个升序的位置列表,表示此版本号的对齐模式位置。每个位置在 [0,177) 范围内,并用于行和列轴。这可以实现为 40 个可变长度整数列表的查找表。
121
+ },{key:"getAlignmentPatternPositions",value:function getAlignmentPatternPositions(){if(this.version===1)return[];var numAlign=Math.floor(this.version/7)+2,step=Math.floor((this.version*8+numAlign*3+5)/(numAlign*4-4))*2,result=[6];for(var pos=this.size-7;result.length<numAlign;pos-=step){result.splice(1,0,pos);}return result;}// 只能在添加了亮色运行后立即调用,并返回 0、1 或 2。这是 getPenaltyScore() 的辅助函数。
122
122
  },{key:"finderPenaltyCountPatterns",value:function finderPenaltyCountPatterns(runHistory){var n=runHistory[1];assert(n<=this.size*3);// 提前验证 n 的有效性
123
123
  if(n<=0)return 0;var validScore=runHistory[2]===n&&runHistory[3]===n*3&&runHistory[4]===n&&runHistory[5]===n;if(!validScore)return 0;// 检查两端的延伸模式
124
- var score=0;if(runHistory[0]>=n*4&&runHistory[6]>=n)score++;if(runHistory[6]>=n*4&&runHistory[0]>=n)score++;return score}// 必须在行(或列)的模块结束时调用。这是 getPenaltyScore() 的辅助函数。
124
+ var score=0;if(runHistory[0]>=n*4&&runHistory[6]>=n)score++;if(runHistory[6]>=n*4&&runHistory[0]>=n)score++;return score;}// 必须在行(或列)的模块结束时调用。这是 getPenaltyScore() 的辅助函数。
125
125
  },{key:"finderPenaltyTerminateAndCount",value:function finderPenaltyTerminateAndCount(runColor,runLength,runHistory){if(runColor){// 终止暗色运行
126
126
  this.finderPenaltyAddHistory(runLength,runHistory);// eslint-disable-next-line no-param-reassign
127
- runLength=0}// eslint-disable-next-line no-param-reassign
127
+ runLength=0;}// eslint-disable-next-line no-param-reassign
128
128
  runLength+=this.size;// 添加亮色边框到最终运行
129
- this.finderPenaltyAddHistory(runLength,runHistory);return this.finderPenaltyCountPatterns(runHistory)}// 将给定值推到前面并丢弃最后一个值。这是 getPenaltyScore() 的辅助函数。
129
+ this.finderPenaltyAddHistory(runLength,runHistory);return this.finderPenaltyCountPatterns(runHistory);}// 将给定值推到前面并丢弃最后一个值。这是 getPenaltyScore() 的辅助函数。
130
130
  },{key:"finderPenaltyAddHistory",value:function finderPenaltyAddHistory(runLength,runHistory){// eslint-disable-next-line no-param-reassign
131
131
  if(runHistory[0]===0)runLength+=this.size;// 添加亮色边框到初始运行
132
- runHistory.pop();runHistory.unshift(runLength)}}])}();// 将给定数值的低位比特位追加到给定缓冲区。要求 0 <= len <= 31 且 0 <= val < 2^len。
132
+ runHistory.pop();runHistory.unshift(runLength);}}])}();// 将给定数值的低位比特位追加到给定缓冲区。要求 0 <= len <= 31 且 0 <= val < 2^len。
133
133
  // 支持的版本, QR码模型2标准
134
134
  _defineProperty(QrCode,"VERSION",{MIN:1,MAX:40});// 惩罚分数常量, 用于 getPenaltyScore(),在评估哪个掩码最佳时使用。
135
135
  _defineProperty(QrCode,"PENALTY",{N1:3,// 相同颜色的连续模块
136
136
  N2:3,// 2x2 块
137
137
  N3:40,// 查找器类似模式
138
138
  N4:10// 暗模块比例
139
- });function appendBits(val,len,bb){if(len<0||len>31||val>>>len!==0){throw new RangeError("Value out of range")}for(var i=len-1;i>=0;i--){// 逐位追加
140
- bb.push(val>>>i&1)}}// 返回x的第i位是否为1。
141
- function getBit(x,i){return(x>>>i&1)!==0}// 如果给定条件为false则抛出异常。
142
- function assert(cond){if(!cond)throw new Error("Assertion error")}/*
139
+ });function appendBits(val,len,bb){if(len<0||len>31||val>>>len!==0){throw new RangeError("Value out of range");}for(var i=len-1;i>=0;i--){// 逐位追加
140
+ bb.push(val>>>i&1);}}// 返回x的第i位是否为1。
141
+ function getBit(x,i){return(x>>>i&1)!==0;}// 如果给定条件为false则抛出异常。
142
+ function assert(cond){if(!cond)throw new Error("Assertion error");}/*
143
143
  * QR码符号中的 字符/二进制 数据段
144
144
  */var QrSegment=/*#__PURE__*/function(){// 使用给定的属性和数据创建一个新的QR码段。字符计数(numChars)必须与模式和位缓冲区长度一致,但不进行检查。给定的位缓冲区被克隆并存储。
145
145
  function QrSegment(// 此段的模式指示符。
@@ -150,25 +150,25 @@ bitData){_classCallCheck(this,QrSegment);this.mode=mode;this.numChars=numChars;t
150
150
  return _createClass(QrSegment,[{key:"getData",value:function getData(){return this.bitData.slice();// 进行防御性拷贝
151
151
  }}])}();var NUMERIC_REGEX=/^[0-9]*$/;var ALPHANUMERIC_REGEX=/^[A-Z0-9 $%*+./:-]*$/;// 字母数字模式中所有合法字符的集合,其中每个字符值映射到字符串中的索引。
152
152
  var ALPHANUMERIC_CHARSET="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:";// 是否可以用数字模式编码。当且仅当每个字符都在0到9的范围内时,字符串可编码。
153
- function isNumeric(text){return NUMERIC_REGEX.test(text)}/**
153
+ function isNumeric(text){return NUMERIC_REGEX.test(text);}/**
154
154
  * 是否可以用字母数字模式编码
155
155
  * @description 0到9、A到Z仅大写)、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。
156
156
  * @param {String} text 给定字符串
157
157
  * @returns {Boolean} boolean
158
- */function isAlphanumeric(text){return ALPHANUMERIC_REGEX.test(text)}// 返回一个表示以字节模式编码的给定二进制数据的段。所有输入字节数组都是可接受的。任何文本字符串都可以转换为UTF-8字节并编码为字节模式段。
159
- function makeBytes(data){var bb=[];var _iterator5=_createForOfIteratorHelper(data),_step5;try{for(_iterator5.s();!(_step5=_iterator5.n()).done;){var b=_step5.value;appendBits(b,8,bb)}}catch(err){_iterator5.e(err)}finally{_iterator5.f()}return new QrSegment(QrMode.get("BYTE"),data.length,bb)}// 计算并返回在给定版本下编码给定段所需的位数。如果某个段的字符数太多以至于无法适应其长度字段,则结果为无穷大。
158
+ */function isAlphanumeric(text){return ALPHANUMERIC_REGEX.test(text);}// 返回一个表示以字节模式编码的给定二进制数据的段。所有输入字节数组都是可接受的。任何文本字符串都可以转换为UTF-8字节并编码为字节模式段。
159
+ function makeBytes(data){var bb=[];var _iterator5=_createForOfIteratorHelper(data),_step5;try{for(_iterator5.s();!(_step5=_iterator5.n()).done;){var b=_step5.value;appendBits(b,8,bb);}}catch(err){_iterator5.e(err)}finally{_iterator5.f()}return new QrSegment(QrMode.get("BYTE"),data.length,bb);}// 计算并返回在给定版本下编码给定段所需的位数。如果某个段的字符数太多以至于无法适应其长度字段,则结果为无穷大。
160
160
  function getTotalBits(segs,version){var result=0;var _iterator6=_createForOfIteratorHelper(segs),_step6;try{for(_iterator6.s();!(_step6=_iterator6.n()).done;){var seg=_step6.value;var ccbits=seg.mode.numCharCountBits(version);if(seg.numChars>=1<<ccbits)return Infinity;// 段的长度不适合字段的位宽度
161
- result+=4+ccbits+seg.bitData.length}}catch(err){_iterator6.e(err)}finally{_iterator6.f()}return result}// 返回一个表示以数字模式编码的给定十进制数字字符串的段。
162
- function makeNumeric(digits){if(!isNumeric(digits)){throw new RangeError("String contains non-numeric characters")}var bb=[];for(var i=0;i<digits.length;){// 每次迭代最多消耗3个数字
163
- var n=Math.min(digits.length-i,3);appendBits(parseInt(digits.substring(i,i+n),10),n*3+1,bb);i+=n}return new QrSegment(QrMode.get("NUMERIC"),digits.length,bb)}// 返回一个表示以字母数字模式编码的给定文本字符串的段。允许的字符是:0到9、A到Z(仅大写)、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。
164
- function makeAlphanumeric(text){if(!isAlphanumeric(text)){throw new RangeError("String contains unencodable characters in alphanumeric mode")}var bb=[];var i;for(i=0;i+2<=text.length;i+=2){// 处理每组2个字符
165
- var temp=ALPHANUMERIC_CHARSET.indexOf(text.charAt(i))*45;temp+=ALPHANUMERIC_CHARSET.indexOf(text.charAt(i+1));appendBits(temp,11,bb)}// 剩下1个字符
166
- if(i<text.length){appendBits(ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)),6,bb)}return new QrSegment(QrMode.get("ALPHANUMERIC"),text.length,bb)}/*
161
+ result+=4+ccbits+seg.bitData.length;}}catch(err){_iterator6.e(err)}finally{_iterator6.f()}return result;}// 返回一个表示以数字模式编码的给定十进制数字字符串的段。
162
+ function makeNumeric(digits){if(!isNumeric(digits)){throw new RangeError("String contains non-numeric characters");}var bb=[];for(var i=0;i<digits.length;){// 每次迭代最多消耗3个数字
163
+ var n=Math.min(digits.length-i,3);appendBits(parseInt(digits.substring(i,i+n),10),n*3+1,bb);i+=n;}return new QrSegment(QrMode.get("NUMERIC"),digits.length,bb);}// 返回一个表示以字母数字模式编码的给定文本字符串的段。允许的字符是:0到9、A到Z(仅大写)、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。
164
+ function makeAlphanumeric(text){if(!isAlphanumeric(text)){throw new RangeError("String contains unencodable characters in alphanumeric mode");}var bb=[];var i;for(i=0;i+2<=text.length;i+=2){// 处理每组2个字符
165
+ var temp=ALPHANUMERIC_CHARSET.indexOf(text.charAt(i))*45;temp+=ALPHANUMERIC_CHARSET.indexOf(text.charAt(i+1));appendBits(temp,11,bb);}// 剩下1个字符
166
+ if(i<text.length){appendBits(ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)),6,bb);}return new QrSegment(QrMode.get("ALPHANUMERIC"),text.length,bb);}/*
167
167
  * QR码符号中的错误纠正级别
168
168
  */var Ecc=exports.Ecc=/*#__PURE__*/function(){function Ecc(// 在0到3范围内(无符号2位整数)。
169
169
  ordinal,// (包私有) 在0到3范围内(无符号2位整数)。
170
170
  formatBits){_classCallCheck(this,Ecc);this.ordinal=ordinal;this.formatBits=formatBits}return _createClass(Ecc,null,[{key:"get",value:// 获取指定级别的 ECC
171
- function get(level){return Ecc.LEVELS[level]}}])}();/*
171
+ function get(level){return Ecc.LEVELS[level];}}])}();/*
172
172
  * 描述如何解释段的数据位。不可变。
173
173
  */_Ecc=Ecc;_defineProperty(Ecc,"LEVELS",{LOW:new _Ecc(0,1),// 7% 错误容忍率
174
174
  MEDIUM:new _Ecc(1,0),// 15% 错误容忍率
@@ -177,5 +177,5 @@ HIGH:new _Ecc(3,2)// 30% 错误容忍率
177
177
  });var QrMode=/*#__PURE__*/function(){function QrMode(// 模式指示位,是一个uint4值(范围0到15)。
178
178
  modeBits,// 三个不同版本范围的字符计数位数。
179
179
  numBitsCharCount){_classCallCheck(this,QrMode);this.modeBits=modeBits;this.numBitsCharCount=numBitsCharCount}return _createClass(QrMode,[{key:"numCharCountBits",value:// 范围计算
180
- function numCharCountBits(version){return this.numBitsCharCount[Math.floor((version+7)/17)]}}],[{key:"get",value:function get(mode){return QrMode.modes[mode]}}])}();_QrMode=QrMode;_defineProperty(QrMode,"modes",{NUMERIC:new _QrMode(1,[10,12,14]),ALPHANUMERIC:new _QrMode(2,[9,11,13]),BYTE:new _QrMode(4,[8,16,16]),KANJI:new _QrMode(8,[8,10,12]),ECI:new _QrMode(7,[0,0,0])});
181
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ECC_CODEWORDS_PER_BLOCK","NUM_ERROR_CORRECTION_BLOCKS","getNumRawDataModules","ver","QrCode","VERSION","MIN","MAX","RangeError","result","numAlign","Math","floor","assert","getNumDataCodewords","ecl","ordinal","encodeSegments","segs","minVersion","arguments","length","undefined","maxVersion","mask","boostEcl","version","dataUsedBits","_ecl","dataCapacityBits","usedBits","getTotalBits","_i","_arr","Ecc","get","newEcl","bb","_iterator","_createForOfIteratorHelper","_step","s","n","done","seg","value","appendBits","mode","modeBits","numChars","numCharCountBits","_iterator2","getData","_step2","b","push","err","e","f","min","padByte","dataCodewords","forEach","i","toUtf8ByteArray","str","encodeURI","charAt","charCodeAt","parseInt","substring","makeSegments","text","isNumeric","makeNumeric","isAlphanumeric","makeAlphanumeric","makeBytes","reedSolomonComputeDivisor","degree","root","j","reedSolomonMultiply","reedSolomonComputeRemainder","data","divisor","map","_iterator3","_step3","_loop","factor","shift","coef","x","y","z","errorCorrectionLevel","msk","_classCallCheck","_defineProperty","_","size","row","Array","fill","modules","slice","isFunction","drawFunctionPatterns","allCodewords","addEccAndInterleave","drawCodewords","selectMask","applyMask","drawFormatBits","_createClass","key","minPenalty","penalty","getPenaltyScore","getModule","flag","setFunctionModule","drawFinderPattern","alignPatPos","getAlignmentPatternPositions","drawAlignmentPattern","drawVersion","formatBits","rem","bits","getBit","color","a","dy","dx","dist","max","abs","xx","yy","isDark","numBlocks","blockEccLen","rawCodewords","numShortBlocks","shortBlockLen","blocks","rsDiv","k","dat","ecc","concat","_loop2","_i9","block","len","right","vert","maskPattern","MASK_PATTERNS","runColor","runX","runHistory","PENALTY","N1","finderPenaltyAddHistory","finderPenaltyCountPatterns","N3","finderPenaltyTerminateAndCount","runY","N2","dark","_iterator4","_step4","reduce","sum","total","ceil","N4","step","pos","splice","validScore","score","runLength","pop","unshift","val","cond","Error","QrSegment","bitData","NUMERIC_REGEX","ALPHANUMERIC_REGEX","ALPHANUMERIC_CHARSET","test","_iterator5","_step5","QrMode","_iterator6","_step6","ccbits","Infinity","digits","temp","indexOf","exports","level","LEVELS","_Ecc","LOW","MEDIUM","QUARTILE","HIGH","numBitsCharCount","modes","_QrMode","NUMERIC","ALPHANUMERIC","BYTE","KANJI","ECI"],"sources":["components/qrcode/qrcode.ts"],"sourcesContent":["/*\n * QR Code generator library\n *\n * Copyright (c) Project Nayuki. (MIT License)\n * https://www.nayuki.io/page/qr-code-generator-library\n */\n\n// 注意索引0用于填充，并设置为一个非法值\nconst ECC_CODEWORDS_PER_BLOCK = [\n  [\n    -1, 7, 10, 15, 20, 26, 18, 20, 24, 30, 18, 20, 24, 26, 30, 22, 24, 28, 30, 28, 28, 28, 28, 30,\n    30, 26, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // Low\n  [\n    -1, 10, 16, 26, 18, 24, 16, 18, 22, 22, 26, 30, 22, 22, 24, 24, 28, 28, 26, 26, 26, 26, 28, 28,\n    28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,\n  ], // Medium\n  [\n    -1, 13, 22, 18, 26, 18, 24, 18, 22, 20, 24, 28, 26, 24, 20, 30, 24, 28, 28, 26, 30, 28, 30, 30,\n    30, 30, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // Quartile\n  [\n    -1, 17, 28, 22, 16, 22, 28, 26, 26, 24, 28, 24, 28, 22, 24, 24, 30, 28, 28, 26, 28, 30, 24, 30,\n    30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // High\n];\nconst NUM_ERROR_CORRECTION_BLOCKS = [\n  [\n    -1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 4, 4, 4, 4, 4, 6, 6, 6, 6, 7, 8, 8, 9, 9, 10, 12, 12, 12, 13, 14,\n    15, 16, 17, 18, 19, 19, 20, 21, 22, 24, 25,\n  ],\n  [\n    -1, 1, 1, 1, 2, 2, 4, 4, 4, 5, 5, 5, 8, 9, 9, 10, 10, 11, 13, 14, 16, 17, 17, 18, 20, 21, 23,\n    25, 26, 28, 29, 31, 33, 35, 37, 38, 40, 43, 45, 47, 49,\n  ],\n  [\n    -1, 1, 1, 2, 2, 4, 4, 6, 6, 8, 8, 8, 10, 12, 16, 12, 17, 16, 18, 21, 20, 23, 23, 25, 27, 29, 34,\n    34, 35, 38, 40, 43, 45, 48, 51, 53, 56, 59, 62, 65, 68,\n  ],\n  [\n    -1, 1, 1, 2, 4, 4, 4, 5, 6, 8, 8, 11, 11, 16, 16, 18, 16, 19, 21, 25, 25, 25, 34, 30, 32, 35,\n    37, 40, 42, 45, 48, 51, 54, 57, 60, 63, 66, 70, 74, 77, 81,\n  ],\n];\n\n// 返回在给定版本的QR码中可以存储的数据位数，已排除所有功能模块。这包括余数位，因此可能不是8的倍数。结果范围在[208, 29648]之间。这可以实现为一个40项的查找表。\nfunction getNumRawDataModules(ver: number): number {\n  if (ver < QrCode.VERSION.MIN || ver > QrCode.VERSION.MAX) {\n    throw new RangeError('Version number out of range');\n  }\n  let result = (16 * ver + 128) * ver + 64;\n\n  if (ver >= 2) {\n    const numAlign = Math.floor(ver / 7) + 2;\n\n    result -= (25 * numAlign - 10) * numAlign - 55;\n    if (ver >= 7) result -= 36;\n  }\n  assert(208 <= result && result <= 29648);\n  return result;\n}\n// 返回指定版本号和纠错级别的 QR 码包含的 8 位数据码字数量（即非纠错码字），余位被舍弃。这个无状态的纯函数可以实现为一个 (40*4) 大小的查找表。\nfunction getNumDataCodewords(ver: number, ecl: Ecc): number {\n  return (\n    Math.floor(getNumRawDataModules(ver) / 8) -\n    ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver] * NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver]\n  );\n}\n/**\n * 生成一个 QR 码\n * @description\n * 根据给定的数据段和编码参数生成 QR 码。输出时会自动选择给定范围内尽可能小的 QR 码版本\n * @param {Readonly<QrSegment[]>} segs - 要编码的 QR 数据段\n * @param {Ecc} ecl - 纠错级别\n * @param {IntRange<1, 41>} [minVersion=1] - 最小版本（默认为 1）\n * @param {IntRange<1, 41>} [maxVersion=40] - 最大版本（默认为 40）\n * @param {-1 | IntRange<0, 8>} [mask=-1] - 掩码模式（默认为 -1，表示自动选择）\n * @param {boolean} [boostEcl=true] - 在数据仍然适合当前版本号的情况下提高纠错级别（默认为 true）。\n * @returns {QrCode} 返回生成的 QR 码。\n */\nexport function encodeSegments(\n  segs: Readonly<QrSegment[]>,\n  ecl: Ecc,\n  minVersion: IntRange<1, 41> = 1,\n  maxVersion: IntRange<1, 41> = 40,\n  mask: -1 | IntRange<0, 8> = -1,\n  boostEcl: boolean = true,\n): QrCode {\n  if (\n    !(\n      QrCode.VERSION.MIN <= minVersion &&\n      minVersion <= maxVersion &&\n      maxVersion <= QrCode.VERSION.MAX\n    ) ||\n    mask < -1 ||\n    mask > 7\n  ) {\n    throw new RangeError('Invalid value');\n  }\n  // 查找要使用的最小版本号\n  let version: IntRange<1, 41>,\n    dataUsedBits: number,\n    _ecl = ecl;\n\n  for (version = minVersion; ; version++) {\n    const dataCapacityBits = getNumDataCodewords(version, _ecl) * 8, // 可用的数据位数\n      usedBits = getTotalBits(segs, version);\n\n    // 找到合适的版本号\n    if (usedBits <= dataCapacityBits) {\n      dataUsedBits = usedBits;\n      break;\n    }\n    if (version >= maxVersion) {\n      // 范围内的所有版本都无法容纳给定数据\n      throw new RangeError('Data too long');\n    }\n  }\n  // 提高纠错级别; 从低到高\n  if (boostEcl) {\n    for (const newEcl of [Ecc.get('MEDIUM'), Ecc.get('QUARTILE'), Ecc.get('HIGH')]) {\n      if (dataUsedBits <= getNumDataCodewords(version, newEcl) * 8) _ecl = newEcl;\n    }\n  }\n  // 连接所有段以创建数据位字符串\n  const bb: number[] = [];\n\n  for (const seg of segs) {\n    appendBits(seg.mode.modeBits, 4, bb);\n    appendBits(seg.numChars, seg.mode.numCharCountBits(version), bb);\n    for (const b of seg.getData()) bb.push(b);\n  }\n  assert(bb.length === dataUsedBits);\n  // 添加终止符并填充至字节边界(如果适用)\n  const dataCapacityBits: number = getNumDataCodewords(version, _ecl) * 8;\n\n  assert(bb.length <= dataCapacityBits);\n  appendBits(0, Math.min(4, dataCapacityBits - bb.length), bb);\n  appendBits(0, (8 - (bb.length % 8)) % 8, bb);\n  assert(bb.length % 8 === 0);\n  // 用交替字节填充直到达到数据容量\n  for (let padByte = 0xec; bb.length < dataCapacityBits; padByte ^= 0xec ^ 0x11) {\n    appendBits(padByte, 8, bb);\n  }\n  // 以大端序将位打包成字节\n  const dataCodewords: number[] = [];\n\n  while (dataCodewords.length * 8 < bb.length) dataCodewords.push(0);\n  bb.forEach((b, i) => (dataCodewords[i >>> 3] |= b << (7 - (i & 7))));\n  return new QrCode(version, _ecl, dataCodewords, mask);\n}\n\n// 返回表示给定字符串的UTF-8编码字节数组\nfunction toUtf8ByteArray(str: string): number[] {\n  // eslint-disable-next-line no-param-reassign\n  str = encodeURI(str);\n  const result: number[] = [];\n\n  for (let i = 0; i < str.length; i++) {\n    if (str.charAt(i) !== '%') result.push(str.charCodeAt(i));\n    else {\n      result.push(parseInt(str.substring(i + 1, i + 3), 16));\n      i += 2;\n    }\n  }\n  return result;\n}\n\n// 返回一个新的可变段列表,用于表示给定的Unicode文本字符串。结果可能使用各种段模式并切换模式以优化位流的长度。\nexport function makeSegments(text: string): QrSegment[] {\n  // 自动选择最高效的段编码\n  if (text === '') return [];\n  else if (isNumeric(text)) return [makeNumeric(text)];\n  else if (isAlphanumeric(text)) return [makeAlphanumeric(text)];\n  return [makeBytes(toUtf8ByteArray(text))];\n}\n\nfunction reedSolomonComputeDivisor(degree: number): number[] {\n  if (degree < 1 || degree > 255) throw new RangeError('Degree out of range');\n  // 多项式系数按从高到低的幂次存储,不包括始终为1的首项。\n  // 例如多项式 x^3 + 255x^2 + 8x + 93 存储为uint8数组 [255, 8, 93]。\n  const result: number[] = [];\n\n  for (let i = 0; i < degree - 1; i++) result.push(0);\n  result.push(1); // Start off with the monomial x^0\n\n  // 计算多项式乘积 (x - r^0) * (x - r^1) * (x - r^2) * ... * (x - r^{degree-1})，\n  // 并舍弃最高次项（该项始终为 1x^degree）。\n  // 注意 r = 0x02，它是有限域 GF(2^8/0x11D) 的生成元。\n  let root = 1;\n\n  for (let i = 0; i < degree; i++) {\n    // 将当前结果乘以 (x - r^i)\n    for (let j = 0; j < result.length; j++) {\n      result[j] = reedSolomonMultiply(result[j], root);\n      if (j + 1 < result.length) result[j] ^= result[j + 1];\n    }\n    root = reedSolomonMultiply(root, 0x02);\n  }\n  return result;\n}\n\n// 返回给定数据和除数多项式的里德-所罗门错误纠正码字。\nfunction reedSolomonComputeRemainder(\n  data: Readonly<number[]>,\n  divisor: Readonly<number[]>,\n): number[] {\n  const result = divisor.map(() => 0);\n\n  for (const b of data) {\n    // 多项式除法\n    const factor = b ^ (result.shift() as number);\n\n    result.push(0);\n    divisor.forEach((coef, i) => (result[i] ^= reedSolomonMultiply(coef, factor)));\n  }\n  return result;\n}\n\n// 返回两个给定域元素模GF(2^8/0x11D)的乘积。参数和结果\n// 都是无符号8位整数。这可以实现为256*256个uint8条目的查找表。\nfunction reedSolomonMultiply(x: number, y: number): number {\n  if (x >>> 8 !== 0 || y >>> 8 !== 0) throw new RangeError('Byte out of range');\n  // 俄罗斯农民乘法\n  let z: number = 0;\n\n  for (let i = 7; i >= 0; i--) {\n    z = (z << 1) ^ ((z >>> 7) * 0x11d);\n    z ^= ((y >>> i) & 1) * x;\n  }\n  assert(z >>> 8 === 0);\n  return z;\n}\n\n/*\n * 由 Denso Wave 发明，并在 ISO/IEC 18004 标准中描述。\n * 此类的实例表示一个不可变的暗/亮单元方格网。\n * 该类遵循 QR 码模型 2 规范，支持所有版本（尺寸）从 1 到 40、4 种纠错等级以及 4 种字符编码模式。\n */\nclass QrCode {\n  // QR Code 的模块（false 表示浅色，true 表示深色）。构造函数完成后不可更改。通过 getModule() 访问。\n  private readonly modules: boolean[][] = [];\n  // 表示不受掩模影响的功能模块。构造函数完成后即被丢弃。\n  private readonly isFunction: boolean[][] = [];\n  /**\n   * 获取 QR Code 的宽度和高度，以模块为单位。\n   * 宽度和高度范围为 21 至 177（包括边界）。宽度和高度的计算公式为：`version * 4 + 17`。\n   */\n  public readonly size: number;\n  /**\n   * 获取 QR Code 所使用的掩膜模式的索引值。掩膜模式索引值范围为 0 到 7（包括边界）。即使 QR Code 是通过自动掩膜（mask = -1）生成的，最终的掩膜值仍然是 0 到 7 之间的有效值。\n   */\n  public readonly mask: IntRange<0, 8>;\n  // 支持的版本, QR码模型2标准\n  public static readonly VERSION = {\n    MIN: 1,\n    MAX: 40,\n  } as const;\n  // 惩罚分数常量, 用于 getPenaltyScore()，在评估哪个掩码最佳时使用。\n  private static readonly PENALTY = {\n    N1: 3, // 相同颜色的连续模块\n    N2: 3, // 2x2 块\n    N3: 40, // 查找器类似模式\n    N4: 10, // 暗模块比例\n  } as const;\n  // 选择最佳掩码\n  private selectMask(msk: -1 | IntRange<0, 8>): IntRange<0, 8> {\n    if (msk !== -1) return msk;\n    let mask: IntRange<0, 8> = 0;\n    let minPenalty = 1000000000;\n\n    for (let i = 0; i < 8; i++) {\n      // 自动选择最佳掩模\n      this.applyMask(i);\n      this.drawFormatBits(i);\n      const penalty = this.getPenaltyScore();\n\n      if (penalty < minPenalty) {\n        mask = i as IntRange<0, 8>;\n        minPenalty = penalty;\n      }\n      // 撤销掩码\n      this.applyMask(i);\n    }\n    assert(0 <= mask && mask <= 7);\n    return mask;\n  }\n  // 使用给定的版本号、错误纠正级别、数据码字节和掩膜编号创建一个新的QR码。\n  public constructor(\n    // 此 QR Code 的版本号，范围为 1 到 40（含）;该值决定了二维码的尺寸。\n    public readonly version: IntRange<1, 41>,\n    // 错误纠正级别。\n    public readonly errorCorrectionLevel: Ecc,\n    dataCodewords: Readonly<number[]>,\n    msk: -1 | IntRange<0, 8>,\n  ) {\n    // 验证构造函数参数\n    if (version < QrCode.VERSION.MIN || version > QrCode.VERSION.MAX) {\n      throw new RangeError('Version value out of range');\n    }\n    if (msk < -1 || msk > 7) throw new RangeError('Mask value out of range');\n    // 初始化\n    this.size = version * 4 + 17;\n    // 创建模块数组\n    // 初始化两个网格为 size*size 大小的布尔数组，初始值为 false 全为浅色\n    const row = Array(this.size).fill(false);\n\n    for (let i = 0; i < this.size; i++) {\n      this.modules[i] = row.slice();\n      this.isFunction[i] = row.slice();\n    }\n    // 计算错误纠正码（ECC），绘制模块\n    this.drawFunctionPatterns();\n    // 构建 QR 码的主要流程\n    const allCodewords = this.addEccAndInterleave(dataCodewords);\n\n    this.drawCodewords(allCodewords);\n    // 确定最终掩码\n    this.mask = this.selectMask(msk);\n    // 应用最终掩码并绘制格式位\n    this.applyMask(this.mask);\n    this.drawFormatBits(this.mask);\n    // 构造完成, 丢弃\n    this.isFunction = [];\n  }\n\n  /* -- 访问器方法 --*/\n  // 返回给定坐标处模块（像素xy的颜色，浅色时为false，深色时为true);如果给定的坐标超出边界，则返回false（浅色）。\n  public getModule(x: number, y: number): boolean {\n    return x >= 0 && x < this.size && y >= 0 && y < this.size && this.modules[y][x];\n  }\n  /* -- 构造函数的私有辅助方法：绘制功能模块 --*/\n\n  // 读取该对象的版本字段，并绘制和标记所有功能模块。\n  private drawFunctionPatterns(): void {\n    // 绘制水平和垂直定时图案\n    for (let i = 0; i < this.size; i++) {\n      const flag = i % 2 === 0;\n\n      this.setFunctionModule(6, i, flag);\n      this.setFunctionModule(i, 6, flag);\n    }\n    // 绘制 3 个定位图案（除了右下角的所有角落；会覆盖一些定时模块）\n    this.drawFinderPattern(3, 3);\n    const y = this.size - 4;\n\n    this.drawFinderPattern(y, 3);\n    this.drawFinderPattern(3, y);\n    // 绘制多个对齐图案\n    const alignPatPos = this.getAlignmentPatternPositions();\n    const numAlign = alignPatPos.length;\n\n    for (let i = 0; i < numAlign; i++) {\n      for (let j = 0; j < numAlign; j++) {\n        // 不在三个定位图案的角落处绘制\n        if (\n          !(\n            (i === 0 && j === 0) ||\n            (i === 0 && j === numAlign - 1) ||\n            (i === numAlign - 1 && j === 0)\n          )\n        ) {\n          this.drawAlignmentPattern(alignPatPos[i], alignPatPos[j]);\n        }\n      }\n    }\n    // 绘制配置数据\n    this.drawFormatBits(0); // 临时掩码值；稍后在构造函数中会被覆盖\n    this.drawVersion();\n  }\n\n  // 绘制格式位的两个副本（带有其自己的错误纠正码）\n  // 基于给定的掩码和该对象的错误纠正级别字段。\n  private drawFormatBits(mask: number): void {\n    // 计算错误纠正码并打包位\n    const data: number = (this.errorCorrectionLevel.formatBits << 3) | mask; // errCorrLvl 是 uint2 类型，mask 是 uint3 类型\n    let rem: number = data;\n\n    for (let i = 0; i < 10; i++) rem = (rem << 1) ^ ((rem >>> 9) * 0x537);\n    const bits = ((data << 10) | rem) ^ 0x5412; // uint15\n\n    assert(bits >>> 15 === 0);\n    // 绘制第一个副本\n    for (let i = 0; i <= 5; i++) this.setFunctionModule(8, i, getBit(bits, i));\n    this.setFunctionModule(8, 7, getBit(bits, 6));\n    this.setFunctionModule(8, 8, getBit(bits, 7));\n    this.setFunctionModule(7, 8, getBit(bits, 8));\n    for (let i = 9; i < 15; i++) {\n      this.setFunctionModule(14 - i, 8, getBit(bits, i));\n    }\n    // 绘制第二个副本\n    for (let i = 0; i < 8; i++) {\n      this.setFunctionModule(this.size - 1 - i, 8, getBit(bits, i));\n    }\n    for (let i = 8; i < 15; i++) {\n      this.setFunctionModule(8, this.size - 15 + i, getBit(bits, i));\n    }\n    this.setFunctionModule(8, this.size - 8, true); // Always dark\n  }\n\n  // 如果7 <= version <= 40，则绘制版本位的两个副本（带有其自己的错误纠正码），\n  // 基于该对象的版本字段。\n  private drawVersion(): void {\n    if (this.version < 7) return;\n\n    // 计算错误纠正码并打包位\n    let rem: number = this.version; // version 是 uint6 类型，范围在 [7, 40]\n\n    for (let i = 0; i < 12; i++) rem = (rem << 1) ^ ((rem >>> 11) * 0x1f25);\n    const bits: number = (this.version << 12) | rem; // uint18\n\n    assert(bits >>> 18 === 0);\n    // 绘制两个副本\n    for (let i = 0; i < 18; i++) {\n      const color: boolean = getBit(bits, i);\n      const a: number = this.size - 11 + (i % 3);\n      const b: number = Math.floor(i / 3);\n\n      this.setFunctionModule(a, b, color);\n      this.setFunctionModule(b, a, color);\n    }\n  }\n  // 绘制一个9*9的定位图案，包括边界分隔符，中心模块位于(x, y)。模块可以超出边界。\n  private drawFinderPattern(x: number, y: number): void {\n    for (let dy = -4; dy <= 4; dy++) {\n      for (let dx = -4; dx <= 4; dx++) {\n        const dist = Math.max(Math.abs(dx), Math.abs(dy)), // Chebyshev/无穷范数\n          xx = x + dx,\n          yy = y + dy;\n\n        if (0 <= xx && xx < this.size && 0 <= yy && yy < this.size) {\n          this.setFunctionModule(xx, yy, dist !== 2 && dist !== 4);\n        }\n      }\n    }\n  }\n  // 绘制一个5*5的对齐图案，中心模块位于(x, y)。所有模块必须在边界内。\n  private drawAlignmentPattern(x: number, y: number): void {\n    for (let dy = -2; dy <= 2; dy++) {\n      for (let dx = -2; dx <= 2; dx++) {\n        this.setFunctionModule(x + dx, y + dy, Math.max(Math.abs(dx), Math.abs(dy)) !== 1);\n      }\n    }\n  }\n  // 设置模块的颜色并将其标记为功能模块。仅由构造函数使用。坐标必须在边界内。\n  private setFunctionModule(x: number, y: number, isDark: boolean): void {\n    this.modules[y][x] = isDark;\n    this.isFunction[y][x] = true;\n  }\n  // 返回一个新的字节字符串，表示具有适当错误纠正码字的给定数据，基于该对象的版本和错误纠正级别。\n  private addEccAndInterleave(data: Readonly<number[]>): number[] {\n    const ver = this.version,\n      ecl = this.errorCorrectionLevel;\n\n    if (data.length !== getNumDataCodewords(ver, ecl)) {\n      throw new RangeError('Invalid argument');\n    }\n    // 计算参数数值\n    const numBlocks = NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver],\n      blockEccLen = ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver],\n      rawCodewords = Math.floor(getNumRawDataModules(ver) / 8),\n      numShortBlocks = numBlocks - (rawCodewords % numBlocks),\n      shortBlockLen = Math.floor(rawCodewords / numBlocks),\n      blocks: number[][] = [], // 将数据分割成块并为每个块附加ECC\n      rsDiv = reedSolomonComputeDivisor(blockEccLen);\n\n    for (let i = 0, k = 0; i < numBlocks; i++) {\n      const dat = data.slice(k, k + shortBlockLen - blockEccLen + (i < numShortBlocks ? 0 : 1));\n      const ecc = reedSolomonComputeRemainder(dat, rsDiv);\n\n      k += dat.length;\n      if (i < numShortBlocks) dat.push(0);\n      blocks.push(dat.concat(ecc));\n    }\n    //  将每个块的字节交错(而不是连接)成单个序列\n    const result: number[] = [];\n\n    for (let i = 0; i < blocks[0].length; i++) {\n      blocks.forEach((block, j) => {\n        // 跳过短块中的填充字节\n        if (i !== shortBlockLen - blockEccLen || j >= numShortBlocks) {\n          result.push(block[i]);\n        }\n      });\n    }\n    assert(result.length === rawCodewords);\n    return result;\n  }\n  // 将给定的8位码字序列(数据和错误纠正)绘制到此QR码的整个\n  // 数据区域上。在调用此方法之前需要标记功能模块。\n  private drawCodewords(data: Readonly<number[]>): void {\n    if (data.length !== Math.floor(getNumRawDataModules(this.version) / 8)) {\n      throw new RangeError('Invalid argument');\n    }\n    let i = 0; // 数据的位索引\n    const len = data.length * 8;\n\n    // 执行特殊的之字形扫描\n    for (let right = this.size - 1; right >= 1; right -= 2) {\n      // 每对列中右列的索引\n      if (right === 6) right = 5;\n      for (let vert = 0; vert < this.size; vert++) {\n        // 垂直计数器\n        for (let j = 0; j < 2; j++) {\n          const x = right - j, // 实际的x坐标\n            y = ((right + 1) & 2) === 0 ? this.size - 1 - vert : vert; // 实际的y坐标\n\n          if (!this.isFunction[y][x] && i < len) {\n            this.modules[y][x] = getBit(data[i >>> 3], 7 - (i & 7));\n            i++;\n          }\n          // 如果此QR码有任何剩余位(0到7位)，它们被构造函数赋值为0/false/浅色，且此方法不会改变它们\n        }\n      }\n    }\n    assert(i === len);\n  }\n  // 掩码模式定义\n  private readonly MASK_PATTERNS: ((_: number, y: number) => boolean)[] = [\n    (x, y) => (x + y) % 2 === 0,\n    (_, y) => y % 2 === 0,\n    (x) => x % 3 === 0,\n    (x, y) => (x + y) % 3 === 0,\n    (x, y) => (Math.floor(x / 3) + Math.floor(y / 2)) % 2 === 0,\n    (x, y) => ((x * y) % 2) + ((x * y) % 3) === 0,\n    (x, y) => (((x * y) % 2) + ((x * y) % 3)) % 2 === 0,\n    (x, y) => (((x + y) % 2) + ((x * y) % 3)) % 2 === 0,\n  ] as const;\n  // 使用给定的掩码模式对此QR码中的码字模块进行XOR运算。在掩码之前必须标记功能模块并绘制码字位。\n  private applyMask(mask: number): void {\n    if (mask < 0 || mask > 7) throw new RangeError('Mask value out of range');\n    const maskPattern = this.MASK_PATTERNS[mask];\n\n    for (let y = 0; y < this.size; y++) {\n      for (let x = 0; x < this.size; x++) {\n        if (!this.isFunction[y][x] && maskPattern(x, y)) {\n          this.modules[y][x] = !this.modules[y][x];\n        }\n      }\n    }\n  }\n  // 计算并返回基于此 QR 码当前模块状态的惩罚分数。用于自动掩码选择算法，以找到产生最低分数的掩码模式。\n  private getPenaltyScore(): number {\n    let result: number = 0;\n\n    // 行中具有相同颜色的相邻模块，以及查找器类似的模式\n    for (let y = 0; y < this.size; y++) {\n      let runColor = false;\n      let runX = 0;\n      const runHistory = [0, 0, 0, 0, 0, 0, 0];\n\n      for (let x = 0; x < this.size; x++) {\n        if (this.modules[y][x] === runColor) {\n          runX++;\n          if (runX === 5) result += QrCode.PENALTY.N1;\n          else if (runX > 5) result++;\n        } else {\n          this.finderPenaltyAddHistory(runX, runHistory);\n          if (!runColor) {\n            result += this.finderPenaltyCountPatterns(runHistory) * QrCode.PENALTY.N3;\n          }\n          runColor = this.modules[y][x];\n          runX = 1;\n        }\n      }\n      result += this.finderPenaltyTerminateAndCount(runColor, runX, runHistory) * QrCode.PENALTY.N3;\n    }\n    // 列中具有相同颜色的相邻模块，以及查找器类似的模式\n    for (let x = 0; x < this.size; x++) {\n      let runColor = false;\n      let runY = 0;\n      const runHistory = [0, 0, 0, 0, 0, 0, 0];\n\n      for (let y = 0; y < this.size; y++) {\n        if (this.modules[y][x] === runColor) {\n          runY++;\n          if (runY === 5) result += QrCode.PENALTY.N1;\n          else if (runY > 5) result++;\n        } else {\n          this.finderPenaltyAddHistory(runY, runHistory);\n          if (!runColor) {\n            result += this.finderPenaltyCountPatterns(runHistory) * QrCode.PENALTY.N3;\n          }\n          runColor = this.modules[y][x];\n          runY = 1;\n        }\n      }\n      result += this.finderPenaltyTerminateAndCount(runColor, runY, runHistory) * QrCode.PENALTY.N3;\n    }\n    // 2*2 块的模块具相同的颜色\n    for (let y = 0; y < this.size - 1; y++) {\n      for (let x = 0; x < this.size - 1; x++) {\n        const color = this.modules[y][x];\n\n        if (\n          color === this.modules[y][x + 1] &&\n          color === this.modules[y + 1][x] &&\n          color === this.modules[y + 1][x + 1]\n        ) {\n          result += QrCode.PENALTY.N2;\n        }\n      }\n    }\n    // 暗模块和亮模块的平衡\n    let dark: number = 0;\n\n    for (const row of this.modules) {\n      dark = row.reduce((sum, color) => sum + (color ? 1 : 0), dark);\n    }\n    // 注意，size 是奇数，所以 dark/total !== 1/2\n    const total: number = this.size * this.size;\n    // 计算最小的整数 k >= 0，使得 (45-5k)% <= dark/total <= (55+5k)%\n    const k: number = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1;\n\n    assert(0 <= k && k <= 9);\n    result += k * QrCode.PENALTY.N4;\n    assert(0 <= result && result <= 2568888); // 基于默认值的非紧密上限\n    return result;\n  }\n  // 返回一个升序的位置列表，表示此版本号的对齐模式位置。每个位置在 [0,177) 范围内，并用于行和列轴。这可以实现为 40 个可变长度整数列表的查找表。\n  private getAlignmentPatternPositions(): number[] {\n    if (this.version === 1) return [];\n    const numAlign = Math.floor(this.version / 7) + 2,\n      step = Math.floor((this.version * 8 + numAlign * 3 + 5) / (numAlign * 4 - 4)) * 2,\n      result = [6];\n\n    for (let pos = this.size - 7; result.length < numAlign; pos -= step) {\n      result.splice(1, 0, pos);\n    }\n    return result;\n  }\n  // 只能在添加了亮色运行后立即调用，并返回 0、1 或 2。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyCountPatterns(runHistory: Readonly<number[]>): number {\n    const n = runHistory[1];\n\n    assert(n <= this.size * 3);\n    // 提前验证 n 的有效性\n    if (n <= 0) return 0;\n    const validScore =\n      runHistory[2] === n && runHistory[3] === n * 3 && runHistory[4] === n && runHistory[5] === n;\n\n    if (!validScore) return 0;\n    // 检查两端的延伸模式\n    let score = 0;\n\n    if (runHistory[0] >= n * 4 && runHistory[6] >= n) score++;\n    if (runHistory[6] >= n * 4 && runHistory[0] >= n) score++;\n    return score;\n  }\n  // 必须在行（或列）的模块结束时调用。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyTerminateAndCount(\n    runColor: boolean,\n    runLength: number,\n    runHistory: number[],\n  ): number {\n    if (runColor) {\n      // 终止暗色运行\n      this.finderPenaltyAddHistory(runLength, runHistory);\n      // eslint-disable-next-line no-param-reassign\n      runLength = 0;\n    }\n    // eslint-disable-next-line no-param-reassign\n    runLength += this.size; // 添加亮色边框到最终运行\n    this.finderPenaltyAddHistory(runLength, runHistory);\n    return this.finderPenaltyCountPatterns(runHistory);\n  }\n  // 将给定值推到前面并丢弃最后一个值。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyAddHistory(runLength: number, runHistory: number[]): void {\n    // eslint-disable-next-line no-param-reassign\n    if (runHistory[0] === 0) runLength += this.size; // 添加亮色边框到初始运行\n    runHistory.pop();\n    runHistory.unshift(runLength);\n  }\n}\n// 将给定数值的低位比特位追加到给定缓冲区。要求 0 <= len <= 31 且 0 <= val < 2^len。\nfunction appendBits(val: number, len: number, bb: number[]): void {\n  if (len < 0 || len > 31 || val >>> len !== 0) {\n    throw new RangeError('Value out of range');\n  }\n  for (let i = len - 1; i >= 0; i--) {\n    // 逐位追加\n    bb.push((val >>> i) & 1);\n  }\n}\n// 返回x的第i位是否为1。\nfunction getBit(x: number, i: number): boolean {\n  return ((x >>> i) & 1) !== 0;\n}\n// 如果给定条件为false则抛出异常。\nfunction assert(cond: boolean): void {\n  if (!cond) throw new Error('Assertion error');\n}\n/*\n * QR码符号中的 字符/二进制 数据段\n */\nclass QrSegment {\n  // 使用给定的属性和数据创建一个新的QR码段。字符计数（numChars）必须与模式和位缓冲区长度一致，但不进行检查。给定的位缓冲区被克隆并存储。\n  public constructor(\n    // 此段的模式指示符。\n    public readonly mode: QrMode,\n    // 此段未编码数据的长度。对于数字/字母数字/汉字模式，以字符为单位测量；对于字节模式，以字节为单位测量；对于ECI模式，为0; 始终为零或正数。不是数据的位长度。\n    public readonly numChars: number,\n    // 此段的数据位。通过getData()访问。\n    readonly bitData: number[],\n  ) {\n    if (numChars < 0) throw new RangeError('Invalid argument');\n    this.bitData = bitData.slice(); // 进行防御性拷贝\n  }\n  // 返回此段数据位的新副本。\n  public getData(): number[] {\n    return this.bitData.slice(); // 进行防御性拷贝\n  }\n}\nconst NUMERIC_REGEX: RegExp = /^[0-9]*$/;\nconst ALPHANUMERIC_REGEX: RegExp = /^[A-Z0-9 $%*+./:-]*$/;\n// 字母数字模式中所有合法字符的集合，其中每个字符值映射到字符串中的索引。\nconst ALPHANUMERIC_CHARSET: string = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:';\n\n// 是否可以用数字模式编码。当且仅当每个字符都在0到9的范围内时，字符串可编码。\nfunction isNumeric(text: string): boolean {\n  return NUMERIC_REGEX.test(text);\n}\n/**\n * 是否可以用字母数字模式编码\n * @description 0到9、A到Z仅大写）、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。\n * @param {String} text 给定字符串\n * @returns {Boolean} boolean\n */\nfunction isAlphanumeric(text: string): boolean {\n  return ALPHANUMERIC_REGEX.test(text);\n}\n// 返回一个表示以字节模式编码的给定二进制数据的段。所有输入字节数组都是可接受的。任何文本字符串都可以转换为UTF-8字节并编码为字节模式段。\nfunction makeBytes(data: Readonly<number[]>): QrSegment {\n  const bb: number[] = [];\n\n  for (const b of data) appendBits(b, 8, bb);\n  return new QrSegment(QrMode.get('BYTE'), data.length, bb);\n}\n// 计算并返回在给定版本下编码给定段所需的位数。如果某个段的字符数太多以至于无法适应其长度字段，则结果为无穷大。\nfunction getTotalBits(segs: Readonly<QrSegment[]>, version: number): number {\n  let result: number = 0;\n\n  for (const seg of segs) {\n    const ccbits: number = seg.mode.numCharCountBits(version);\n\n    if (seg.numChars >= 1 << ccbits) return Infinity; // 段的长度不适合字段的位宽度\n    result += 4 + ccbits + seg.bitData.length;\n  }\n  return result;\n}\n// 返回一个表示以数字模式编码的给定十进制数字字符串的段。\nfunction makeNumeric(digits: string): QrSegment {\n  if (!isNumeric(digits)) {\n    throw new RangeError('String contains non-numeric characters');\n  }\n  const bb: number[] = [];\n\n  for (let i = 0; i < digits.length; ) {\n    // 每次迭代最多消耗3个数字\n    const n: number = Math.min(digits.length - i, 3);\n\n    appendBits(parseInt(digits.substring(i, i + n), 10), n * 3 + 1, bb);\n    i += n;\n  }\n  return new QrSegment(QrMode.get('NUMERIC'), digits.length, bb);\n}\n// 返回一个表示以字母数字模式编码的给定文本字符串的段。允许的字符是：0到9、A到Z（仅大写）、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。\nfunction makeAlphanumeric(text: string): QrSegment {\n  if (!isAlphanumeric(text)) {\n    throw new RangeError('String contains unencodable characters in alphanumeric mode');\n  }\n  const bb: number[] = [];\n  let i: number;\n\n  for (i = 0; i + 2 <= text.length; i += 2) {\n    // 处理每组2个字符\n    let temp = ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)) * 45;\n\n    temp += ALPHANUMERIC_CHARSET.indexOf(text.charAt(i + 1));\n    appendBits(temp, 11, bb);\n  }\n  // 剩下1个字符\n  if (i < text.length) {\n    appendBits(ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)), 6, bb);\n  }\n  return new QrSegment(QrMode.get('ALPHANUMERIC'), text.length, bb);\n}\n/*\n * QR码符号中的错误纠正级别\n */\nexport class Ecc {\n  private constructor(\n    // 在0到3范围内（无符号2位整数）。\n    public readonly ordinal: IntRange<0, 4>,\n    // (包私有) 在0到3范围内（无符号2位整数）。\n    public readonly formatBits: IntRange<0, 4>,\n  ) {}\n  private static readonly LEVELS = {\n    LOW: new Ecc(0, 1), // 7% 错误容忍率\n    MEDIUM: new Ecc(1, 0), // 15% 错误容忍率\n    QUARTILE: new Ecc(2, 3), // 25% 错误容忍率\n    HIGH: new Ecc(3, 2), // 30% 错误容忍率\n  } as const;\n  // 获取指定级别的 ECC\n  public static get(level: keyof typeof Ecc.LEVELS): Ecc {\n    return Ecc.LEVELS[level];\n  }\n}\n/*\n * 描述如何解释段的数据位。不可变。\n */\nclass QrMode {\n  private constructor(\n    // 模式指示位，是一个uint4值（范围0到15）。\n    public readonly modeBits: IntRange<0, 16>,\n    // 三个不同版本范围的字符计数位数。\n    private readonly numBitsCharCount: readonly [number, number, number],\n  ) {}\n  private static readonly modes = {\n    NUMERIC: new QrMode(0x1, [10, 12, 14]),\n    ALPHANUMERIC: new QrMode(0x2, [9, 11, 13]),\n    BYTE: new QrMode(0x4, [8, 16, 16]),\n    KANJI: new QrMode(0x8, [8, 10, 12]),\n    ECI: new QrMode(0x7, [0, 0, 0]),\n  } as const;\n  public static get(mode: keyof typeof QrMode.modes) {\n    return QrMode.modes[mode];\n  }\n  // 范围计算\n  public numCharCountBits(version: number): number {\n    return this.numBitsCharCount[Math.floor((version + 7) / 17)];\n  }\n}\n\ntype Enumerate<N extends number, Acc extends number[] = []> = Acc['length'] extends N\n  ? Acc[number]\n  : Enumerate<N, [...Acc, Acc['length']]>;\n\nexport type IntRange<F extends number, T extends number> = Exclude<Enumerate<T>, Enumerate<F>>;\n"],"mappings":"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","ignoreList":[]}
180
+ function numCharCountBits(version){return this.numBitsCharCount[Math.floor((version+7)/17)];}}],[{key:"get",value:function get(mode){return QrMode.modes[mode];}}])}();_QrMode=QrMode;_defineProperty(QrMode,"modes",{NUMERIC:new _QrMode(1,[10,12,14]),ALPHANUMERIC:new _QrMode(2,[9,11,13]),BYTE:new _QrMode(4,[8,16,16]),KANJI:new _QrMode(8,[8,10,12]),ECI:new _QrMode(7,[0,0,0])});
181
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ECC_CODEWORDS_PER_BLOCK","NUM_ERROR_CORRECTION_BLOCKS","getNumRawDataModules","ver","QrCode","VERSION","MIN","MAX","RangeError","result","numAlign","Math","floor","assert","getNumDataCodewords","ecl","ordinal","encodeSegments","segs","minVersion","arguments","length","undefined","maxVersion","mask","boostEcl","version","dataUsedBits","_ecl","dataCapacityBits","usedBits","getTotalBits","_i","_arr","Ecc","get","newEcl","bb","_iterator","_createForOfIteratorHelper","_step","s","n","done","seg","value","appendBits","mode","modeBits","numChars","numCharCountBits","_iterator2","getData","_step2","b","push","err","e","f","min","padByte","dataCodewords","forEach","i","toUtf8ByteArray","str","encodeURI","charAt","charCodeAt","parseInt","substring","makeSegments","text","isNumeric","makeNumeric","isAlphanumeric","makeAlphanumeric","makeBytes","reedSolomonComputeDivisor","degree","root","j","reedSolomonMultiply","reedSolomonComputeRemainder","data","divisor","map","_iterator3","_step3","_loop","factor","shift","coef","x","y","z","errorCorrectionLevel","msk","_classCallCheck","_defineProperty","_","size","row","Array","fill","modules","slice","isFunction","drawFunctionPatterns","allCodewords","addEccAndInterleave","drawCodewords","selectMask","applyMask","drawFormatBits","_createClass","key","minPenalty","penalty","getPenaltyScore","getModule","flag","setFunctionModule","drawFinderPattern","alignPatPos","getAlignmentPatternPositions","drawAlignmentPattern","drawVersion","formatBits","rem","bits","getBit","color","a","dy","dx","dist","max","abs","xx","yy","isDark","numBlocks","blockEccLen","rawCodewords","numShortBlocks","shortBlockLen","blocks","rsDiv","k","dat","ecc","concat","_loop2","_i9","block","len","right","vert","maskPattern","MASK_PATTERNS","runColor","runX","runHistory","PENALTY","N1","finderPenaltyAddHistory","finderPenaltyCountPatterns","N3","finderPenaltyTerminateAndCount","runY","N2","dark","_iterator4","_step4","reduce","sum","total","ceil","N4","step","pos","splice","validScore","score","runLength","pop","unshift","val","cond","Error","QrSegment","bitData","NUMERIC_REGEX","ALPHANUMERIC_REGEX","ALPHANUMERIC_CHARSET","test","_iterator5","_step5","QrMode","_iterator6","_step6","ccbits","Infinity","digits","temp","indexOf","exports","level","LEVELS","_Ecc","LOW","MEDIUM","QUARTILE","HIGH","numBitsCharCount","modes","_QrMode","NUMERIC","ALPHANUMERIC","BYTE","KANJI","ECI"],"sources":["components/qrcode/qrcode.ts"],"sourcesContent":["/*\n * QR Code generator library\n *\n * Copyright (c) Project Nayuki. (MIT License)\n * https://www.nayuki.io/page/qr-code-generator-library\n */\n\n// 注意索引0用于填充，并设置为一个非法值\nconst ECC_CODEWORDS_PER_BLOCK = [\n  [\n    -1, 7, 10, 15, 20, 26, 18, 20, 24, 30, 18, 20, 24, 26, 30, 22, 24, 28, 30, 28, 28, 28, 28, 30,\n    30, 26, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // Low\n  [\n    -1, 10, 16, 26, 18, 24, 16, 18, 22, 22, 26, 30, 22, 22, 24, 24, 28, 28, 26, 26, 26, 26, 28, 28,\n    28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28,\n  ], // Medium\n  [\n    -1, 13, 22, 18, 26, 18, 24, 18, 22, 20, 24, 28, 26, 24, 20, 30, 24, 28, 28, 26, 30, 28, 30, 30,\n    30, 30, 28, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // Quartile\n  [\n    -1, 17, 28, 22, 16, 22, 28, 26, 26, 24, 28, 24, 28, 22, 24, 24, 30, 28, 28, 26, 28, 30, 24, 30,\n    30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30,\n  ], // High\n];\nconst NUM_ERROR_CORRECTION_BLOCKS = [\n  [\n    -1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 4, 4, 4, 4, 4, 6, 6, 6, 6, 7, 8, 8, 9, 9, 10, 12, 12, 12, 13, 14,\n    15, 16, 17, 18, 19, 19, 20, 21, 22, 24, 25,\n  ],\n  [\n    -1, 1, 1, 1, 2, 2, 4, 4, 4, 5, 5, 5, 8, 9, 9, 10, 10, 11, 13, 14, 16, 17, 17, 18, 20, 21, 23,\n    25, 26, 28, 29, 31, 33, 35, 37, 38, 40, 43, 45, 47, 49,\n  ],\n  [\n    -1, 1, 1, 2, 2, 4, 4, 6, 6, 8, 8, 8, 10, 12, 16, 12, 17, 16, 18, 21, 20, 23, 23, 25, 27, 29, 34,\n    34, 35, 38, 40, 43, 45, 48, 51, 53, 56, 59, 62, 65, 68,\n  ],\n  [\n    -1, 1, 1, 2, 4, 4, 4, 5, 6, 8, 8, 11, 11, 16, 16, 18, 16, 19, 21, 25, 25, 25, 34, 30, 32, 35,\n    37, 40, 42, 45, 48, 51, 54, 57, 60, 63, 66, 70, 74, 77, 81,\n  ],\n];\n\n// 返回在给定版本的QR码中可以存储的数据位数，已排除所有功能模块。这包括余数位，因此可能不是8的倍数。结果范围在[208, 29648]之间。这可以实现为一个40项的查找表。\nfunction getNumRawDataModules(ver: number): number {\n  if (ver < QrCode.VERSION.MIN || ver > QrCode.VERSION.MAX) {\n    throw new RangeError('Version number out of range');\n  }\n  let result = (16 * ver + 128) * ver + 64;\n\n  if (ver >= 2) {\n    const numAlign = Math.floor(ver / 7) + 2;\n\n    result -= (25 * numAlign - 10) * numAlign - 55;\n    if (ver >= 7) result -= 36;\n  }\n  assert(208 <= result && result <= 29648);\n  return result;\n}\n// 返回指定版本号和纠错级别的 QR 码包含的 8 位数据码字数量（即非纠错码字），余位被舍弃。这个无状态的纯函数可以实现为一个 (40*4) 大小的查找表。\nfunction getNumDataCodewords(ver: number, ecl: Ecc): number {\n  return (\n    Math.floor(getNumRawDataModules(ver) / 8) -\n    ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver] * NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver]\n  );\n}\n/**\n * 生成一个 QR 码\n * @description\n * 根据给定的数据段和编码参数生成 QR 码。输出时会自动选择给定范围内尽可能小的 QR 码版本\n * @param {Readonly<QrSegment[]>} segs - 要编码的 QR 数据段\n * @param {Ecc} ecl - 纠错级别\n * @param {IntRange<1, 41>} [minVersion=1] - 最小版本（默认为 1）\n * @param {IntRange<1, 41>} [maxVersion=40] - 最大版本（默认为 40）\n * @param {-1 | IntRange<0, 8>} [mask=-1] - 掩码模式（默认为 -1，表示自动选择）\n * @param {boolean} [boostEcl=true] - 在数据仍然适合当前版本号的情况下提高纠错级别（默认为 true）。\n * @returns {QrCode} 返回生成的 QR 码。\n */\nexport function encodeSegments(\n  segs: Readonly<QrSegment[]>,\n  ecl: Ecc,\n  minVersion: IntRange<1, 41> = 1,\n  maxVersion: IntRange<1, 41> = 40,\n  mask: -1 | IntRange<0, 8> = -1,\n  boostEcl: boolean = true,\n): QrCode {\n  if (\n    !(\n      QrCode.VERSION.MIN <= minVersion &&\n      minVersion <= maxVersion &&\n      maxVersion <= QrCode.VERSION.MAX\n    ) ||\n    mask < -1 ||\n    mask > 7\n  ) {\n    throw new RangeError('Invalid value');\n  }\n  // 查找要使用的最小版本号\n  let version: IntRange<1, 41>,\n    dataUsedBits: number,\n    _ecl = ecl;\n\n  for (version = minVersion; ; version++) {\n    const dataCapacityBits = getNumDataCodewords(version, _ecl) * 8, // 可用的数据位数\n      usedBits = getTotalBits(segs, version);\n\n    // 找到合适的版本号\n    if (usedBits <= dataCapacityBits) {\n      dataUsedBits = usedBits;\n      break;\n    }\n    if (version >= maxVersion) {\n      // 范围内的所有版本都无法容纳给定数据\n      throw new RangeError('Data too long');\n    }\n  }\n  // 提高纠错级别; 从低到高\n  if (boostEcl) {\n    for (const newEcl of [Ecc.get('MEDIUM'), Ecc.get('QUARTILE'), Ecc.get('HIGH')]) {\n      if (dataUsedBits <= getNumDataCodewords(version, newEcl) * 8) _ecl = newEcl;\n    }\n  }\n  // 连接所有段以创建数据位字符串\n  const bb: number[] = [];\n\n  for (const seg of segs) {\n    appendBits(seg.mode.modeBits, 4, bb);\n    appendBits(seg.numChars, seg.mode.numCharCountBits(version), bb);\n    for (const b of seg.getData()) bb.push(b);\n  }\n  assert(bb.length === dataUsedBits);\n  // 添加终止符并填充至字节边界(如果适用)\n  const dataCapacityBits: number = getNumDataCodewords(version, _ecl) * 8;\n\n  assert(bb.length <= dataCapacityBits);\n  appendBits(0, Math.min(4, dataCapacityBits - bb.length), bb);\n  appendBits(0, (8 - (bb.length % 8)) % 8, bb);\n  assert(bb.length % 8 === 0);\n  // 用交替字节填充直到达到数据容量\n  for (let padByte = 0xec; bb.length < dataCapacityBits; padByte ^= 0xec ^ 0x11) {\n    appendBits(padByte, 8, bb);\n  }\n  // 以大端序将位打包成字节\n  const dataCodewords: number[] = [];\n\n  while (dataCodewords.length * 8 < bb.length) dataCodewords.push(0);\n  bb.forEach((b, i) => (dataCodewords[i >>> 3] |= b << (7 - (i & 7))));\n  return new QrCode(version, _ecl, dataCodewords, mask);\n}\n\n// 返回表示给定字符串的UTF-8编码字节数组\nfunction toUtf8ByteArray(str: string): number[] {\n  // eslint-disable-next-line no-param-reassign\n  str = encodeURI(str);\n  const result: number[] = [];\n\n  for (let i = 0; i < str.length; i++) {\n    if (str.charAt(i) !== '%') result.push(str.charCodeAt(i));\n    else {\n      result.push(parseInt(str.substring(i + 1, i + 3), 16));\n      i += 2;\n    }\n  }\n  return result;\n}\n\n// 返回一个新的可变段列表,用于表示给定的Unicode文本字符串。结果可能使用各种段模式并切换模式以优化位流的长度。\nexport function makeSegments(text: string): QrSegment[] {\n  // 自动选择最高效的段编码\n  if (text === '') return [];\n  else if (isNumeric(text)) return [makeNumeric(text)];\n  else if (isAlphanumeric(text)) return [makeAlphanumeric(text)];\n  return [makeBytes(toUtf8ByteArray(text))];\n}\n\nfunction reedSolomonComputeDivisor(degree: number): number[] {\n  if (degree < 1 || degree > 255) throw new RangeError('Degree out of range');\n  // 多项式系数按从高到低的幂次存储,不包括始终为1的首项。\n  // 例如多项式 x^3 + 255x^2 + 8x + 93 存储为uint8数组 [255, 8, 93]。\n  const result: number[] = [];\n\n  for (let i = 0; i < degree - 1; i++) result.push(0);\n  result.push(1); // Start off with the monomial x^0\n\n  // 计算多项式乘积 (x - r^0) * (x - r^1) * (x - r^2) * ... * (x - r^{degree-1})，\n  // 并舍弃最高次项（该项始终为 1x^degree）。\n  // 注意 r = 0x02，它是有限域 GF(2^8/0x11D) 的生成元。\n  let root = 1;\n\n  for (let i = 0; i < degree; i++) {\n    // 将当前结果乘以 (x - r^i)\n    for (let j = 0; j < result.length; j++) {\n      result[j] = reedSolomonMultiply(result[j], root);\n      if (j + 1 < result.length) result[j] ^= result[j + 1];\n    }\n    root = reedSolomonMultiply(root, 0x02);\n  }\n  return result;\n}\n\n// 返回给定数据和除数多项式的里德-所罗门错误纠正码字。\nfunction reedSolomonComputeRemainder(\n  data: Readonly<number[]>,\n  divisor: Readonly<number[]>,\n): number[] {\n  const result = divisor.map(() => 0);\n\n  for (const b of data) {\n    // 多项式除法\n    const factor = b ^ (result.shift() as number);\n\n    result.push(0);\n    divisor.forEach((coef, i) => (result[i] ^= reedSolomonMultiply(coef, factor)));\n  }\n  return result;\n}\n\n// 返回两个给定域元素模GF(2^8/0x11D)的乘积。参数和结果\n// 都是无符号8位整数。这可以实现为256*256个uint8条目的查找表。\nfunction reedSolomonMultiply(x: number, y: number): number {\n  if (x >>> 8 !== 0 || y >>> 8 !== 0) throw new RangeError('Byte out of range');\n  // 俄罗斯农民乘法\n  let z: number = 0;\n\n  for (let i = 7; i >= 0; i--) {\n    z = (z << 1) ^ ((z >>> 7) * 0x11d);\n    z ^= ((y >>> i) & 1) * x;\n  }\n  assert(z >>> 8 === 0);\n  return z;\n}\n\n/*\n * 由 Denso Wave 发明，并在 ISO/IEC 18004 标准中描述。\n * 此类的实例表示一个不可变的暗/亮单元方格网。\n * 该类遵循 QR 码模型 2 规范，支持所有版本（尺寸）从 1 到 40、4 种纠错等级以及 4 种字符编码模式。\n */\nclass QrCode {\n  // QR Code 的模块（false 表示浅色，true 表示深色）。构造函数完成后不可更改。通过 getModule() 访问。\n  private readonly modules: boolean[][] = [];\n  // 表示不受掩模影响的功能模块。构造函数完成后即被丢弃。\n  private readonly isFunction: boolean[][] = [];\n  /**\n   * 获取 QR Code 的宽度和高度，以模块为单位。\n   * 宽度和高度范围为 21 至 177（包括边界）。宽度和高度的计算公式为：`version * 4 + 17`。\n   */\n  public readonly size: number;\n  /**\n   * 获取 QR Code 所使用的掩膜模式的索引值。掩膜模式索引值范围为 0 到 7（包括边界）。即使 QR Code 是通过自动掩膜（mask = -1）生成的，最终的掩膜值仍然是 0 到 7 之间的有效值。\n   */\n  public readonly mask: IntRange<0, 8>;\n  // 支持的版本, QR码模型2标准\n  public static readonly VERSION = {\n    MIN: 1,\n    MAX: 40,\n  } as const;\n  // 惩罚分数常量, 用于 getPenaltyScore()，在评估哪个掩码最佳时使用。\n  private static readonly PENALTY = {\n    N1: 3, // 相同颜色的连续模块\n    N2: 3, // 2x2 块\n    N3: 40, // 查找器类似模式\n    N4: 10, // 暗模块比例\n  } as const;\n  // 选择最佳掩码\n  private selectMask(msk: -1 | IntRange<0, 8>): IntRange<0, 8> {\n    if (msk !== -1) return msk;\n    let mask: IntRange<0, 8> = 0;\n    let minPenalty = 1000000000;\n\n    for (let i = 0; i < 8; i++) {\n      // 自动选择最佳掩模\n      this.applyMask(i);\n      this.drawFormatBits(i);\n      const penalty = this.getPenaltyScore();\n\n      if (penalty < minPenalty) {\n        mask = i as IntRange<0, 8>;\n        minPenalty = penalty;\n      }\n      // 撤销掩码\n      this.applyMask(i);\n    }\n    assert(0 <= mask && mask <= 7);\n    return mask;\n  }\n  // 使用给定的版本号、错误纠正级别、数据码字节和掩膜编号创建一个新的QR码。\n  public constructor(\n    // 此 QR Code 的版本号，范围为 1 到 40（含）;该值决定了二维码的尺寸。\n    public readonly version: IntRange<1, 41>,\n    // 错误纠正级别。\n    public readonly errorCorrectionLevel: Ecc,\n    dataCodewords: Readonly<number[]>,\n    msk: -1 | IntRange<0, 8>,\n  ) {\n    // 验证构造函数参数\n    if (version < QrCode.VERSION.MIN || version > QrCode.VERSION.MAX) {\n      throw new RangeError('Version value out of range');\n    }\n    if (msk < -1 || msk > 7) throw new RangeError('Mask value out of range');\n    // 初始化\n    this.size = version * 4 + 17;\n    // 创建模块数组\n    // 初始化两个网格为 size*size 大小的布尔数组，初始值为 false 全为浅色\n    const row = Array(this.size).fill(false);\n\n    for (let i = 0; i < this.size; i++) {\n      this.modules[i] = row.slice();\n      this.isFunction[i] = row.slice();\n    }\n    // 计算错误纠正码（ECC），绘制模块\n    this.drawFunctionPatterns();\n    // 构建 QR 码的主要流程\n    const allCodewords = this.addEccAndInterleave(dataCodewords);\n\n    this.drawCodewords(allCodewords);\n    // 确定最终掩码\n    this.mask = this.selectMask(msk);\n    // 应用最终掩码并绘制格式位\n    this.applyMask(this.mask);\n    this.drawFormatBits(this.mask);\n    // 构造完成, 丢弃\n    this.isFunction = [];\n  }\n\n  /* -- 访问器方法 --*/\n  // 返回给定坐标处模块（像素xy的颜色，浅色时为false，深色时为true);如果给定的坐标超出边界，则返回false（浅色）。\n  public getModule(x: number, y: number): boolean {\n    return x >= 0 && x < this.size && y >= 0 && y < this.size && this.modules[y][x];\n  }\n  /* -- 构造函数的私有辅助方法：绘制功能模块 --*/\n\n  // 读取该对象的版本字段，并绘制和标记所有功能模块。\n  private drawFunctionPatterns(): void {\n    // 绘制水平和垂直定时图案\n    for (let i = 0; i < this.size; i++) {\n      const flag = i % 2 === 0;\n\n      this.setFunctionModule(6, i, flag);\n      this.setFunctionModule(i, 6, flag);\n    }\n    // 绘制 3 个定位图案（除了右下角的所有角落；会覆盖一些定时模块）\n    this.drawFinderPattern(3, 3);\n    const y = this.size - 4;\n\n    this.drawFinderPattern(y, 3);\n    this.drawFinderPattern(3, y);\n    // 绘制多个对齐图案\n    const alignPatPos = this.getAlignmentPatternPositions();\n    const numAlign = alignPatPos.length;\n\n    for (let i = 0; i < numAlign; i++) {\n      for (let j = 0; j < numAlign; j++) {\n        // 不在三个定位图案的角落处绘制\n        if (\n          !(\n            (i === 0 && j === 0) ||\n            (i === 0 && j === numAlign - 1) ||\n            (i === numAlign - 1 && j === 0)\n          )\n        ) {\n          this.drawAlignmentPattern(alignPatPos[i], alignPatPos[j]);\n        }\n      }\n    }\n    // 绘制配置数据\n    this.drawFormatBits(0); // 临时掩码值；稍后在构造函数中会被覆盖\n    this.drawVersion();\n  }\n\n  // 绘制格式位的两个副本（带有其自己的错误纠正码）\n  // 基于给定的掩码和该对象的错误纠正级别字段。\n  private drawFormatBits(mask: number): void {\n    // 计算错误纠正码并打包位\n    const data: number = (this.errorCorrectionLevel.formatBits << 3) | mask; // errCorrLvl 是 uint2 类型，mask 是 uint3 类型\n    let rem: number = data;\n\n    for (let i = 0; i < 10; i++) rem = (rem << 1) ^ ((rem >>> 9) * 0x537);\n    const bits = ((data << 10) | rem) ^ 0x5412; // uint15\n\n    assert(bits >>> 15 === 0);\n    // 绘制第一个副本\n    for (let i = 0; i <= 5; i++) this.setFunctionModule(8, i, getBit(bits, i));\n    this.setFunctionModule(8, 7, getBit(bits, 6));\n    this.setFunctionModule(8, 8, getBit(bits, 7));\n    this.setFunctionModule(7, 8, getBit(bits, 8));\n    for (let i = 9; i < 15; i++) {\n      this.setFunctionModule(14 - i, 8, getBit(bits, i));\n    }\n    // 绘制第二个副本\n    for (let i = 0; i < 8; i++) {\n      this.setFunctionModule(this.size - 1 - i, 8, getBit(bits, i));\n    }\n    for (let i = 8; i < 15; i++) {\n      this.setFunctionModule(8, this.size - 15 + i, getBit(bits, i));\n    }\n    this.setFunctionModule(8, this.size - 8, true); // Always dark\n  }\n\n  // 如果7 <= version <= 40，则绘制版本位的两个副本（带有其自己的错误纠正码），\n  // 基于该对象的版本字段。\n  private drawVersion(): void {\n    if (this.version < 7) return;\n\n    // 计算错误纠正码并打包位\n    let rem: number = this.version; // version 是 uint6 类型，范围在 [7, 40]\n\n    for (let i = 0; i < 12; i++) rem = (rem << 1) ^ ((rem >>> 11) * 0x1f25);\n    const bits: number = (this.version << 12) | rem; // uint18\n\n    assert(bits >>> 18 === 0);\n    // 绘制两个副本\n    for (let i = 0; i < 18; i++) {\n      const color: boolean = getBit(bits, i);\n      const a: number = this.size - 11 + (i % 3);\n      const b: number = Math.floor(i / 3);\n\n      this.setFunctionModule(a, b, color);\n      this.setFunctionModule(b, a, color);\n    }\n  }\n  // 绘制一个9*9的定位图案，包括边界分隔符，中心模块位于(x, y)。模块可以超出边界。\n  private drawFinderPattern(x: number, y: number): void {\n    for (let dy = -4; dy <= 4; dy++) {\n      for (let dx = -4; dx <= 4; dx++) {\n        const dist = Math.max(Math.abs(dx), Math.abs(dy)), // Chebyshev/无穷范数\n          xx = x + dx,\n          yy = y + dy;\n\n        if (0 <= xx && xx < this.size && 0 <= yy && yy < this.size) {\n          this.setFunctionModule(xx, yy, dist !== 2 && dist !== 4);\n        }\n      }\n    }\n  }\n  // 绘制一个5*5的对齐图案，中心模块位于(x, y)。所有模块必须在边界内。\n  private drawAlignmentPattern(x: number, y: number): void {\n    for (let dy = -2; dy <= 2; dy++) {\n      for (let dx = -2; dx <= 2; dx++) {\n        this.setFunctionModule(x + dx, y + dy, Math.max(Math.abs(dx), Math.abs(dy)) !== 1);\n      }\n    }\n  }\n  // 设置模块的颜色并将其标记为功能模块。仅由构造函数使用。坐标必须在边界内。\n  private setFunctionModule(x: number, y: number, isDark: boolean): void {\n    this.modules[y][x] = isDark;\n    this.isFunction[y][x] = true;\n  }\n  // 返回一个新的字节字符串，表示具有适当错误纠正码字的给定数据，基于该对象的版本和错误纠正级别。\n  private addEccAndInterleave(data: Readonly<number[]>): number[] {\n    const ver = this.version,\n      ecl = this.errorCorrectionLevel;\n\n    if (data.length !== getNumDataCodewords(ver, ecl)) {\n      throw new RangeError('Invalid argument');\n    }\n    // 计算参数数值\n    const numBlocks = NUM_ERROR_CORRECTION_BLOCKS[ecl.ordinal][ver],\n      blockEccLen = ECC_CODEWORDS_PER_BLOCK[ecl.ordinal][ver],\n      rawCodewords = Math.floor(getNumRawDataModules(ver) / 8),\n      numShortBlocks = numBlocks - (rawCodewords % numBlocks),\n      shortBlockLen = Math.floor(rawCodewords / numBlocks),\n      blocks: number[][] = [], // 将数据分割成块并为每个块附加ECC\n      rsDiv = reedSolomonComputeDivisor(blockEccLen);\n\n    for (let i = 0, k = 0; i < numBlocks; i++) {\n      const dat = data.slice(k, k + shortBlockLen - blockEccLen + (i < numShortBlocks ? 0 : 1));\n      const ecc = reedSolomonComputeRemainder(dat, rsDiv);\n\n      k += dat.length;\n      if (i < numShortBlocks) dat.push(0);\n      blocks.push(dat.concat(ecc));\n    }\n    //  将每个块的字节交错(而不是连接)成单个序列\n    const result: number[] = [];\n\n    for (let i = 0; i < blocks[0].length; i++) {\n      blocks.forEach((block, j) => {\n        // 跳过短块中的填充字节\n        if (i !== shortBlockLen - blockEccLen || j >= numShortBlocks) {\n          result.push(block[i]);\n        }\n      });\n    }\n    assert(result.length === rawCodewords);\n    return result;\n  }\n  // 将给定的8位码字序列(数据和错误纠正)绘制到此QR码的整个\n  // 数据区域上。在调用此方法之前需要标记功能模块。\n  private drawCodewords(data: Readonly<number[]>): void {\n    if (data.length !== Math.floor(getNumRawDataModules(this.version) / 8)) {\n      throw new RangeError('Invalid argument');\n    }\n    let i = 0; // 数据的位索引\n    const len = data.length * 8;\n\n    // 执行特殊的之字形扫描\n    for (let right = this.size - 1; right >= 1; right -= 2) {\n      // 每对列中右列的索引\n      if (right === 6) right = 5;\n      for (let vert = 0; vert < this.size; vert++) {\n        // 垂直计数器\n        for (let j = 0; j < 2; j++) {\n          const x = right - j, // 实际的x坐标\n            y = ((right + 1) & 2) === 0 ? this.size - 1 - vert : vert; // 实际的y坐标\n\n          if (!this.isFunction[y][x] && i < len) {\n            this.modules[y][x] = getBit(data[i >>> 3], 7 - (i & 7));\n            i++;\n          }\n          // 如果此QR码有任何剩余位(0到7位)，它们被构造函数赋值为0/false/浅色，且此方法不会改变它们\n        }\n      }\n    }\n    assert(i === len);\n  }\n  // 掩码模式定义\n  private readonly MASK_PATTERNS: ((_: number, y: number) => boolean)[] = [\n    (x, y) => (x + y) % 2 === 0,\n    (_, y) => y % 2 === 0,\n    (x) => x % 3 === 0,\n    (x, y) => (x + y) % 3 === 0,\n    (x, y) => (Math.floor(x / 3) + Math.floor(y / 2)) % 2 === 0,\n    (x, y) => ((x * y) % 2) + ((x * y) % 3) === 0,\n    (x, y) => (((x * y) % 2) + ((x * y) % 3)) % 2 === 0,\n    (x, y) => (((x + y) % 2) + ((x * y) % 3)) % 2 === 0,\n  ] as const;\n  // 使用给定的掩码模式对此QR码中的码字模块进行XOR运算。在掩码之前必须标记功能模块并绘制码字位。\n  private applyMask(mask: number): void {\n    if (mask < 0 || mask > 7) throw new RangeError('Mask value out of range');\n    const maskPattern = this.MASK_PATTERNS[mask];\n\n    for (let y = 0; y < this.size; y++) {\n      for (let x = 0; x < this.size; x++) {\n        if (!this.isFunction[y][x] && maskPattern(x, y)) {\n          this.modules[y][x] = !this.modules[y][x];\n        }\n      }\n    }\n  }\n  // 计算并返回基于此 QR 码当前模块状态的惩罚分数。用于自动掩码选择算法，以找到产生最低分数的掩码模式。\n  private getPenaltyScore(): number {\n    let result: number = 0;\n\n    // 行中具有相同颜色的相邻模块，以及查找器类似的模式\n    for (let y = 0; y < this.size; y++) {\n      let runColor = false;\n      let runX = 0;\n      const runHistory = [0, 0, 0, 0, 0, 0, 0];\n\n      for (let x = 0; x < this.size; x++) {\n        if (this.modules[y][x] === runColor) {\n          runX++;\n          if (runX === 5) result += QrCode.PENALTY.N1;\n          else if (runX > 5) result++;\n        } else {\n          this.finderPenaltyAddHistory(runX, runHistory);\n          if (!runColor) {\n            result += this.finderPenaltyCountPatterns(runHistory) * QrCode.PENALTY.N3;\n          }\n          runColor = this.modules[y][x];\n          runX = 1;\n        }\n      }\n      result += this.finderPenaltyTerminateAndCount(runColor, runX, runHistory) * QrCode.PENALTY.N3;\n    }\n    // 列中具有相同颜色的相邻模块，以及查找器类似的模式\n    for (let x = 0; x < this.size; x++) {\n      let runColor = false;\n      let runY = 0;\n      const runHistory = [0, 0, 0, 0, 0, 0, 0];\n\n      for (let y = 0; y < this.size; y++) {\n        if (this.modules[y][x] === runColor) {\n          runY++;\n          if (runY === 5) result += QrCode.PENALTY.N1;\n          else if (runY > 5) result++;\n        } else {\n          this.finderPenaltyAddHistory(runY, runHistory);\n          if (!runColor) {\n            result += this.finderPenaltyCountPatterns(runHistory) * QrCode.PENALTY.N3;\n          }\n          runColor = this.modules[y][x];\n          runY = 1;\n        }\n      }\n      result += this.finderPenaltyTerminateAndCount(runColor, runY, runHistory) * QrCode.PENALTY.N3;\n    }\n    // 2*2 块的模块具相同的颜色\n    for (let y = 0; y < this.size - 1; y++) {\n      for (let x = 0; x < this.size - 1; x++) {\n        const color = this.modules[y][x];\n\n        if (\n          color === this.modules[y][x + 1] &&\n          color === this.modules[y + 1][x] &&\n          color === this.modules[y + 1][x + 1]\n        ) {\n          result += QrCode.PENALTY.N2;\n        }\n      }\n    }\n    // 暗模块和亮模块的平衡\n    let dark: number = 0;\n\n    for (const row of this.modules) {\n      dark = row.reduce((sum, color) => sum + (color ? 1 : 0), dark);\n    }\n    // 注意，size 是奇数，所以 dark/total !== 1/2\n    const total: number = this.size * this.size;\n    // 计算最小的整数 k >= 0，使得 (45-5k)% <= dark/total <= (55+5k)%\n    const k: number = Math.ceil(Math.abs(dark * 20 - total * 10) / total) - 1;\n\n    assert(0 <= k && k <= 9);\n    result += k * QrCode.PENALTY.N4;\n    assert(0 <= result && result <= 2568888); // 基于默认值的非紧密上限\n    return result;\n  }\n  // 返回一个升序的位置列表，表示此版本号的对齐模式位置。每个位置在 [0,177) 范围内，并用于行和列轴。这可以实现为 40 个可变长度整数列表的查找表。\n  private getAlignmentPatternPositions(): number[] {\n    if (this.version === 1) return [];\n    const numAlign = Math.floor(this.version / 7) + 2,\n      step = Math.floor((this.version * 8 + numAlign * 3 + 5) / (numAlign * 4 - 4)) * 2,\n      result = [6];\n\n    for (let pos = this.size - 7; result.length < numAlign; pos -= step) {\n      result.splice(1, 0, pos);\n    }\n    return result;\n  }\n  // 只能在添加了亮色运行后立即调用，并返回 0、1 或 2。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyCountPatterns(runHistory: Readonly<number[]>): number {\n    const n = runHistory[1];\n\n    assert(n <= this.size * 3);\n    // 提前验证 n 的有效性\n    if (n <= 0) return 0;\n    const validScore =\n      runHistory[2] === n && runHistory[3] === n * 3 && runHistory[4] === n && runHistory[5] === n;\n\n    if (!validScore) return 0;\n    // 检查两端的延伸模式\n    let score = 0;\n\n    if (runHistory[0] >= n * 4 && runHistory[6] >= n) score++;\n    if (runHistory[6] >= n * 4 && runHistory[0] >= n) score++;\n    return score;\n  }\n  // 必须在行（或列）的模块结束时调用。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyTerminateAndCount(\n    runColor: boolean,\n    runLength: number,\n    runHistory: number[],\n  ): number {\n    if (runColor) {\n      // 终止暗色运行\n      this.finderPenaltyAddHistory(runLength, runHistory);\n      // eslint-disable-next-line no-param-reassign\n      runLength = 0;\n    }\n    // eslint-disable-next-line no-param-reassign\n    runLength += this.size; // 添加亮色边框到最终运行\n    this.finderPenaltyAddHistory(runLength, runHistory);\n    return this.finderPenaltyCountPatterns(runHistory);\n  }\n  // 将给定值推到前面并丢弃最后一个值。这是 getPenaltyScore() 的辅助函数。\n  private finderPenaltyAddHistory(runLength: number, runHistory: number[]): void {\n    // eslint-disable-next-line no-param-reassign\n    if (runHistory[0] === 0) runLength += this.size; // 添加亮色边框到初始运行\n    runHistory.pop();\n    runHistory.unshift(runLength);\n  }\n}\n// 将给定数值的低位比特位追加到给定缓冲区。要求 0 <= len <= 31 且 0 <= val < 2^len。\nfunction appendBits(val: number, len: number, bb: number[]): void {\n  if (len < 0 || len > 31 || val >>> len !== 0) {\n    throw new RangeError('Value out of range');\n  }\n  for (let i = len - 1; i >= 0; i--) {\n    // 逐位追加\n    bb.push((val >>> i) & 1);\n  }\n}\n// 返回x的第i位是否为1。\nfunction getBit(x: number, i: number): boolean {\n  return ((x >>> i) & 1) !== 0;\n}\n// 如果给定条件为false则抛出异常。\nfunction assert(cond: boolean): void {\n  if (!cond) throw new Error('Assertion error');\n}\n/*\n * QR码符号中的 字符/二进制 数据段\n */\nclass QrSegment {\n  // 使用给定的属性和数据创建一个新的QR码段。字符计数（numChars）必须与模式和位缓冲区长度一致，但不进行检查。给定的位缓冲区被克隆并存储。\n  public constructor(\n    // 此段的模式指示符。\n    public readonly mode: QrMode,\n    // 此段未编码数据的长度。对于数字/字母数字/汉字模式，以字符为单位测量；对于字节模式，以字节为单位测量；对于ECI模式，为0; 始终为零或正数。不是数据的位长度。\n    public readonly numChars: number,\n    // 此段的数据位。通过getData()访问。\n    readonly bitData: number[],\n  ) {\n    if (numChars < 0) throw new RangeError('Invalid argument');\n    this.bitData = bitData.slice(); // 进行防御性拷贝\n  }\n  // 返回此段数据位的新副本。\n  public getData(): number[] {\n    return this.bitData.slice(); // 进行防御性拷贝\n  }\n}\nconst NUMERIC_REGEX: RegExp = /^[0-9]*$/;\nconst ALPHANUMERIC_REGEX: RegExp = /^[A-Z0-9 $%*+./:-]*$/;\n// 字母数字模式中所有合法字符的集合，其中每个字符值映射到字符串中的索引。\nconst ALPHANUMERIC_CHARSET: string = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ $%*+-./:';\n\n// 是否可以用数字模式编码。当且仅当每个字符都在0到9的范围内时，字符串可编码。\nfunction isNumeric(text: string): boolean {\n  return NUMERIC_REGEX.test(text);\n}\n/**\n * 是否可以用字母数字模式编码\n * @description 0到9、A到Z仅大写）、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。\n * @param {String} text 给定字符串\n * @returns {Boolean} boolean\n */\nfunction isAlphanumeric(text: string): boolean {\n  return ALPHANUMERIC_REGEX.test(text);\n}\n// 返回一个表示以字节模式编码的给定二进制数据的段。所有输入字节数组都是可接受的。任何文本字符串都可以转换为UTF-8字节并编码为字节模式段。\nfunction makeBytes(data: Readonly<number[]>): QrSegment {\n  const bb: number[] = [];\n\n  for (const b of data) appendBits(b, 8, bb);\n  return new QrSegment(QrMode.get('BYTE'), data.length, bb);\n}\n// 计算并返回在给定版本下编码给定段所需的位数。如果某个段的字符数太多以至于无法适应其长度字段，则结果为无穷大。\nfunction getTotalBits(segs: Readonly<QrSegment[]>, version: number): number {\n  let result: number = 0;\n\n  for (const seg of segs) {\n    const ccbits: number = seg.mode.numCharCountBits(version);\n\n    if (seg.numChars >= 1 << ccbits) return Infinity; // 段的长度不适合字段的位宽度\n    result += 4 + ccbits + seg.bitData.length;\n  }\n  return result;\n}\n// 返回一个表示以数字模式编码的给定十进制数字字符串的段。\nfunction makeNumeric(digits: string): QrSegment {\n  if (!isNumeric(digits)) {\n    throw new RangeError('String contains non-numeric characters');\n  }\n  const bb: number[] = [];\n\n  for (let i = 0; i < digits.length; ) {\n    // 每次迭代最多消耗3个数字\n    const n: number = Math.min(digits.length - i, 3);\n\n    appendBits(parseInt(digits.substring(i, i + n), 10), n * 3 + 1, bb);\n    i += n;\n  }\n  return new QrSegment(QrMode.get('NUMERIC'), digits.length, bb);\n}\n// 返回一个表示以字母数字模式编码的给定文本字符串的段。允许的字符是：0到9、A到Z（仅大写）、空格、美元符号、百分号、星号、加号、连字符、句点、斜杠、冒号。\nfunction makeAlphanumeric(text: string): QrSegment {\n  if (!isAlphanumeric(text)) {\n    throw new RangeError('String contains unencodable characters in alphanumeric mode');\n  }\n  const bb: number[] = [];\n  let i: number;\n\n  for (i = 0; i + 2 <= text.length; i += 2) {\n    // 处理每组2个字符\n    let temp = ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)) * 45;\n\n    temp += ALPHANUMERIC_CHARSET.indexOf(text.charAt(i + 1));\n    appendBits(temp, 11, bb);\n  }\n  // 剩下1个字符\n  if (i < text.length) {\n    appendBits(ALPHANUMERIC_CHARSET.indexOf(text.charAt(i)), 6, bb);\n  }\n  return new QrSegment(QrMode.get('ALPHANUMERIC'), text.length, bb);\n}\n/*\n * QR码符号中的错误纠正级别\n */\nexport class Ecc {\n  private constructor(\n    // 在0到3范围内（无符号2位整数）。\n    public readonly ordinal: IntRange<0, 4>,\n    // (包私有) 在0到3范围内（无符号2位整数）。\n    public readonly formatBits: IntRange<0, 4>,\n  ) {}\n  private static readonly LEVELS = {\n    LOW: new Ecc(0, 1), // 7% 错误容忍率\n    MEDIUM: new Ecc(1, 0), // 15% 错误容忍率\n    QUARTILE: new Ecc(2, 3), // 25% 错误容忍率\n    HIGH: new Ecc(3, 2), // 30% 错误容忍率\n  } as const;\n  // 获取指定级别的 ECC\n  public static get(level: keyof typeof Ecc.LEVELS): Ecc {\n    return Ecc.LEVELS[level];\n  }\n}\n/*\n * 描述如何解释段的数据位。不可变。\n */\nclass QrMode {\n  private constructor(\n    // 模式指示位，是一个uint4值（范围0到15）。\n    public readonly modeBits: IntRange<0, 16>,\n    // 三个不同版本范围的字符计数位数。\n    private readonly numBitsCharCount: readonly [number, number, number],\n  ) {}\n  private static readonly modes = {\n    NUMERIC: new QrMode(0x1, [10, 12, 14]),\n    ALPHANUMERIC: new QrMode(0x2, [9, 11, 13]),\n    BYTE: new QrMode(0x4, [8, 16, 16]),\n    KANJI: new QrMode(0x8, [8, 10, 12]),\n    ECI: new QrMode(0x7, [0, 0, 0]),\n  } as const;\n  public static get(mode: keyof typeof QrMode.modes) {\n    return QrMode.modes[mode];\n  }\n  // 范围计算\n  public numCharCountBits(version: number): number {\n    return this.numBitsCharCount[Math.floor((version + 7) / 17)];\n  }\n}\n\ntype Enumerate<N extends number, Acc extends number[] = []> = Acc['length'] extends N\n  ? Acc[number]\n  : Enumerate<N, [...Acc, Acc['length']]>;\n\nexport type IntRange<F extends number, T extends number> = Exclude<Enumerate<T>, Enumerate<F>>;\n"],"mappings":"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","ignoreList":[]}