Skip to content
Advertisement

Is there a way to edit an image before saving it to the database?

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:

  • Cropping libraries (lots of them, but most had rectangle or circle as options for shapes and no clear way to customize the shape).
  • Ways to add a pre-saved mask to the alpha channel of the image (couldn’t really figure out a way that would work).
  • The HTML tag canvas (still trying this approach).

I’m willing to try almost anything as long as it doesn’t involve major changes to the Qt application.

Advertisement

Answer

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.

  1. Create a canvas
  2. Draw a rounded-rectangle mask (see these wonderful answers 1 and 2)
    • Use ctx.clip() after drawing a custom path.
    • Or use ctx.globalCompositeOperation = 'source-in' after drawing a mask image
  3. Draw the actual image with the desired width/height and stretch/fill behavior
  4. Export the resulting image using canvas.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>
User contributions licensed under: CC BY-SA
2 People found this is helpful
Advertisement