Our images are being uploaded by the users on the web application (React) and being saved on the database by our API (Loopback).
The images will be used in our Qt application and they should have round corners. We have some processing limitations so we can't clip or mask the images on Qt.
We have some out of proportion images with dry corners breaking the layout right now and I need a way to crop them to the correct proportions with a border radius on all 4 corners. For our next application we should have two rounded corners and two squared ones but if this isn't possible I can try and change it.
What I have researched so far:
I'm willing to try almost anything as long as it doesn't involve major changes to the Qt application.
I would go with the canvas approach, since you would have full customization which is useful since you mention you'll be changing the requirements later.
ctx.clip()
after drawing a custom path.ctx.globalCompositeOperation = 'source-in'
after drawing a mask imagecanvas.toDataURL()
let width = 300;
let height = 500;
let radius = 50;
let canvas = document.querySelector('canvas'); // document.createElement('canvas');
let ctx = canvas.getContext('2d');
canvas.width = width;
canvas.height = height;
ctx.beginPath();
ctx.moveTo(radius, 0);
ctx.lineTo(width - radius, 0);
ctx.quadraticCurveTo(width, 0, width, radius);
ctx.lineTo(width, height - radius);
ctx.quadraticCurveTo(width, height, width - radius, height);
ctx.lineTo(radius, height);
ctx.quadraticCurveTo(0, height, 0, height - radius);
ctx.lineTo(0, radius);
ctx.quadraticCurveTo(0, 0, radius, 0);
ctx.closePath();
ctx.clip();
let imgUrl = ''
let image = new Image();
image.addEventListener('load', () => {
ctx.drawImage(image, 0, 0, width, height);
console.log(canvas.toDataURL());
});
image.src = imgUrl;
<canvas>