You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					122 lines
				
				5.4 KiB
			
		
		
			
		
	
	
					122 lines
				
				5.4 KiB
			| 
											10 months ago
										 | import EncodeHintType from '../core/EncodeHintType'; | ||
|  | import Encoder from '../core/qrcode/encoder/Encoder'; | ||
|  | import ErrorCorrectionLevel from '../core/qrcode/decoder/ErrorCorrectionLevel'; | ||
|  | import IllegalArgumentException from '../core/IllegalArgumentException'; | ||
|  | import IllegalStateException from '../core/IllegalStateException'; | ||
|  | /** | ||
|  |  * @deprecated Moving to @zxing/browser | ||
|  |  */ | ||
|  | class BrowserQRCodeSvgWriter { | ||
|  |     /** | ||
|  |      * Writes and renders a QRCode SVG element. | ||
|  |      * | ||
|  |      * @param contents | ||
|  |      * @param width | ||
|  |      * @param height | ||
|  |      * @param hints | ||
|  |      */ | ||
|  |     write(contents, width, height, hints = null) { | ||
|  |         if (contents.length === 0) { | ||
|  |             throw new IllegalArgumentException('Found empty contents'); | ||
|  |         } | ||
|  |         // if (format != BarcodeFormat.QR_CODE) {
 | ||
|  |         //   throw new IllegalArgumentException("Can only encode QR_CODE, but got " + format)
 | ||
|  |         // }
 | ||
|  |         if (width < 0 || height < 0) { | ||
|  |             throw new IllegalArgumentException('Requested dimensions are too small: ' + width + 'x' + height); | ||
|  |         } | ||
|  |         let errorCorrectionLevel = ErrorCorrectionLevel.L; | ||
|  |         let quietZone = BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE; | ||
|  |         if (hints !== null) { | ||
|  |             if (undefined !== hints.get(EncodeHintType.ERROR_CORRECTION)) { | ||
|  |                 errorCorrectionLevel = ErrorCorrectionLevel.fromString(hints.get(EncodeHintType.ERROR_CORRECTION).toString()); | ||
|  |             } | ||
|  |             if (undefined !== hints.get(EncodeHintType.MARGIN)) { | ||
|  |                 quietZone = Number.parseInt(hints.get(EncodeHintType.MARGIN).toString(), 10); | ||
|  |             } | ||
|  |         } | ||
|  |         const code = Encoder.encode(contents, errorCorrectionLevel, hints); | ||
|  |         return this.renderResult(code, width, height, quietZone); | ||
|  |     } | ||
|  |     /** | ||
|  |      * Renders the result and then appends it to the DOM. | ||
|  |      */ | ||
|  |     writeToDom(containerElement, contents, width, height, hints = null) { | ||
|  |         if (typeof containerElement === 'string') { | ||
|  |             containerElement = document.querySelector(containerElement); | ||
|  |         } | ||
|  |         const svgElement = this.write(contents, width, height, hints); | ||
|  |         if (containerElement) | ||
|  |             containerElement.appendChild(svgElement); | ||
|  |     } | ||
|  |     /** | ||
|  |      * Note that the input matrix uses 0 == white, 1 == black. | ||
|  |      * The output matrix uses 0 == black, 255 == white (i.e. an 8 bit greyscale bitmap). | ||
|  |      */ | ||
|  |     renderResult(code, width /*int*/, height /*int*/, quietZone /*int*/) { | ||
|  |         const input = code.getMatrix(); | ||
|  |         if (input === null) { | ||
|  |             throw new IllegalStateException(); | ||
|  |         } | ||
|  |         const inputWidth = input.getWidth(); | ||
|  |         const inputHeight = input.getHeight(); | ||
|  |         const qrWidth = inputWidth + (quietZone * 2); | ||
|  |         const qrHeight = inputHeight + (quietZone * 2); | ||
|  |         const outputWidth = Math.max(width, qrWidth); | ||
|  |         const outputHeight = Math.max(height, qrHeight); | ||
|  |         const multiple = Math.min(Math.floor(outputWidth / qrWidth), Math.floor(outputHeight / qrHeight)); | ||
|  |         // Padding includes both the quiet zone and the extra white pixels to accommodate the requested
 | ||
|  |         // dimensions. For example, if input is 25x25 the QR will be 33x33 including the quiet zone.
 | ||
|  |         // If the requested size is 200x160, the multiple will be 4, for a QR of 132x132. These will
 | ||
|  |         // handle all the padding from 100x100 (the actual QR) up to 200x160.
 | ||
|  |         const leftPadding = Math.floor((outputWidth - (inputWidth * multiple)) / 2); | ||
|  |         const topPadding = Math.floor((outputHeight - (inputHeight * multiple)) / 2); | ||
|  |         const svgElement = this.createSVGElement(outputWidth, outputHeight); | ||
|  |         for (let inputY = 0, outputY = topPadding; inputY < inputHeight; inputY++, outputY += multiple) { | ||
|  |             // Write the contents of this row of the barcode
 | ||
|  |             for (let inputX = 0, outputX = leftPadding; inputX < inputWidth; inputX++, outputX += multiple) { | ||
|  |                 if (input.get(inputX, inputY) === 1) { | ||
|  |                     const svgRectElement = this.createSvgRectElement(outputX, outputY, multiple, multiple); | ||
|  |                     svgElement.appendChild(svgRectElement); | ||
|  |                 } | ||
|  |             } | ||
|  |         } | ||
|  |         return svgElement; | ||
|  |     } | ||
|  |     /** | ||
|  |      * Creates a SVG element. | ||
|  |      * | ||
|  |      * @param w SVG's width attribute | ||
|  |      * @param h SVG's height attribute | ||
|  |      */ | ||
|  |     createSVGElement(w, h) { | ||
|  |         const svgElement = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'svg'); | ||
|  |         svgElement.setAttributeNS(null, 'height', w.toString()); | ||
|  |         svgElement.setAttributeNS(null, 'width', h.toString()); | ||
|  |         return svgElement; | ||
|  |     } | ||
|  |     /** | ||
|  |      * Creates a SVG rect element. | ||
|  |      * | ||
|  |      * @param x Element's x coordinate | ||
|  |      * @param y Element's y coordinate | ||
|  |      * @param w Element's width attribute | ||
|  |      * @param h Element's height attribute | ||
|  |      */ | ||
|  |     createSvgRectElement(x, y, w, h) { | ||
|  |         const rect = document.createElementNS(BrowserQRCodeSvgWriter.SVG_NS, 'rect'); | ||
|  |         rect.setAttributeNS(null, 'x', x.toString()); | ||
|  |         rect.setAttributeNS(null, 'y', y.toString()); | ||
|  |         rect.setAttributeNS(null, 'height', w.toString()); | ||
|  |         rect.setAttributeNS(null, 'width', h.toString()); | ||
|  |         rect.setAttributeNS(null, 'fill', '#000000'); | ||
|  |         return rect; | ||
|  |     } | ||
|  | } | ||
|  | BrowserQRCodeSvgWriter.QUIET_ZONE_SIZE = 4; | ||
|  | /** | ||
|  |  * SVG markup NameSpace | ||
|  |  */ | ||
|  | BrowserQRCodeSvgWriter.SVG_NS = 'http://www.w3.org/2000/svg'; | ||
|  | export { BrowserQRCodeSvgWriter }; | ||
|  | //# sourceMappingURL=BrowserQRCodeSvgWriter.js.map
 |