有没有办法在将图像保存到数据库之前对其进行编辑?
Is there a way to edit an image before saving it to the database?
我们的图片由用户上传到 Web 应用程序 (React) 并由我们的 API (Loopback) 保存在数据库中。
这些图像将在我们的 Qt 应用程序中使用,它们应该有圆角。我们有一些处理限制,所以我们不能在 Qt 上剪辑或屏蔽图像。
我们现在有一些不成比例的图像,干角破坏了布局,我需要一种方法将它们裁剪成正确的比例,并在所有 4 个角上设置一个边框半径。对于我们的下一个应用程序,我们应该有两个圆角和两个方角,但如果这不可能,我可以尝试更改它。
目前我研究的内容:
- 裁剪库(很多,但大多数都有矩形或圆形作为形状选项,没有明确的自定义形状的方法)。
- 将预先保存的蒙版添加到图像的 Alpha 通道的方法(无法真正找到可行的方法)。
- HTML 标签 canvas(仍在尝试这种方法)。
只要不涉及对 Qt 应用程序的重大更改,我几乎愿意尝试任何事情。
我会选择 canvas 方法,因为您可以进行完全自定义,这很有用,因为您提到稍后会更改要求。
- 创建 canvas
- 画个rounded-rectangle面具(看这些精彩answers 1 and 2)
- 绘制自定义路径后使用
ctx.clip()
。
- 或者在绘制遮罩图像后使用
ctx.globalCompositeOperation = 'source-in'
- 使用所需的 width/height 和 stretch/fill 行为绘制实际图像
- 使用
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>
我们的图片由用户上传到 Web 应用程序 (React) 并由我们的 API (Loopback) 保存在数据库中。
这些图像将在我们的 Qt 应用程序中使用,它们应该有圆角。我们有一些处理限制,所以我们不能在 Qt 上剪辑或屏蔽图像。
我们现在有一些不成比例的图像,干角破坏了布局,我需要一种方法将它们裁剪成正确的比例,并在所有 4 个角上设置一个边框半径。对于我们的下一个应用程序,我们应该有两个圆角和两个方角,但如果这不可能,我可以尝试更改它。
目前我研究的内容:
- 裁剪库(很多,但大多数都有矩形或圆形作为形状选项,没有明确的自定义形状的方法)。
- 将预先保存的蒙版添加到图像的 Alpha 通道的方法(无法真正找到可行的方法)。
- HTML 标签 canvas(仍在尝试这种方法)。
只要不涉及对 Qt 应用程序的重大更改,我几乎愿意尝试任何事情。
我会选择 canvas 方法,因为您可以进行完全自定义,这很有用,因为您提到稍后会更改要求。
- 创建 canvas
- 画个rounded-rectangle面具(看这些精彩answers 1 and 2)
- 绘制自定义路径后使用
ctx.clip()
。 - 或者在绘制遮罩图像后使用
ctx.globalCompositeOperation = 'source-in'
- 绘制自定义路径后使用
- 使用所需的 width/height 和 stretch/fill 行为绘制实际图像
- 使用
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>