data:image/s3,"s3://crabby-images/9d63c/9d63ca270fad7d2d0fcf4eb416accc3783f5ee8e" alt="QR codes without distortion"
QR codes without distortion
Recently I came across a web page with a QR code. Unfortunately, the image was enlarged, causing distortion. However, there is a very simple trick to counter this.
Example
Below an example of such a QR code. I purposely saved it as a 50x50 pixel image and enlarged it on this page – so the bigger your screen, the better you'll see the distortion. If you would like to scan this QR code, especially with a device with a slightly inferior camera, you will have to have some patience or it may be that the scanning will not work at all. Makes sense, given that the image looks blurry.
data:image/s3,"s3://crabby-images/a3294/a3294bdedbaa5f4b697c853c5959d7bb33fd2bef" alt="Example of a scrambled QR code."
image-rendering
This problem is easily solved with the help of CSS. The property image-rendering
has the option to display an image pixalated. So, instead of just stretching the image, nearest-neighbor interpolation is used to keep the original pixelated style. Below you can see how this can be used.
1 2 3
.some-class { image-rendering: pixelated; }
As you can see below, after using this simple piece of CSS, the QR code is a lot brighter. Not only is it now easier to scan by (older) devices, it also looks a lot more professional.
data:image/s3,"s3://crabby-images/a3294/a3294bdedbaa5f4b697c853c5959d7bb33fd2bef" alt="Example of a QR code with image-rendering."
It's definitely the same image – feel free to open both in a new tab or check the source code of this page if you're suspicious.