'canvas to base 64 with angularx-codeqr
I am generating a QR code in Angular with this library: https://github.com/cordobo/angularx-qrcode
I want to get the data in base64 so I can then save that image to Firebase. I am trying the following:
components.ts
const canvas = document.createElement('canvas');
const myBase64 = canvas.toDataURL('parent');
console.log(myBase64);
components.html
<qrcode id="parent" [qrdata]="myAngularxQrCode" [width]="256" [errorCorrectionLevel]="'M'" ></qrcode>
This is what I get in the console (if I click on it, it's a blank image):

What I want to get is this (note the difference in base64):

Solution 1:[1]
EDIT
I came up with the following code and added it to the angularx-qrcode demo app. The code is based on this example. The element's type can be canvas, img and url.
# File: app.component.html
<div class="qrcodeImage">
<qrcode #parent
[elementType]="'canvas'"
[errorCorrectionLevel]="'M'"
[qrdata]="'My data'"
[width]="'256'"></qrcode>
</div>
<button (click)="saveAsImage(parent)">Download QR Code Image</button>
# File: app.component.ts
saveAsImage(parent: any) {
if (this.elementType === "canvas") {
// fetches base 64 data from canvas
parentElement = parent.qrcElement.nativeElement
.querySelector("canvas")
.toDataURL("image/png")
} else if (this.elementType === "img") {
// fetches base 64 data from image
parentElement = parent.qrcElement.nativeElement.querySelector("img").src
// use 'parentElement' for your firebase storage
} else {
alert("Set elementType to 'canvas', 'img' or 'url'.")
}
if (parentElement) {
// If you want to download the image, continue here
// converts base 64 encoded image to blobData
let blobData = this.convertBase64ToBlob(parentElement)
// saves as image
const blob = new Blob([blobData], { type: "image/png" })
const url = window.URL.createObjectURL(blob)
const link = document.createElement("a")
link.href = url
link.download = "Qrcode"
link.click()
}
}
// Only used if you plan to download the img
private convertBase64ToBlob(Base64Image: string) {
const parts = Base64Image.split(";base64,")
const imageType = parts[0].split(":")[1]
const decodedData = window.atob(parts[1])
const uInt8Array = new Uint8Array(decodedData.length)
for (let i = 0; i < decodedData.length; ++i) {
uInt8Array[i] = decodedData.charCodeAt(i)
}
return new Blob([uInt8Array], { type: imageType })
}
Old answer
I'm the author of angularx-qrcode. A feature to download (or get the Base64 encoded string) is not implemented in the lib itself, but there is an issue where we track solutions on how to download a qrcode
So instead of reading and downloading the Base64 encoded string like in this example, you could pass the string on to your function.
As similar issues are opened on a regular basis, I'm thinking about a sample implementation in the angularx-qrcode demo app
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 |


