假设我有一个图像和一个画布。我使用画布API修改显示的图像。
我现在需要有2张图片的副本,原始副本和修改过的副本。
传达我想做的伪代码是:
NY-WM-3:dprsg jennifer.s$ python manage.py runserver
Performing system checks...
System check identified no issues (0 silenced).
May 06, 2019 - 14:04:00
Django version 2.1.2, using settings 'dprsg.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
[06/May/2019 14:04:08] "GET /register/ HTTP/1.1" 200 7108
我尝试搜索它,但找不到答案。
编辑:
通过“初始化”,我的意思是创建图像的深层副本。因此,原始图像没有线条,画布中的修改图像有线条,我现在需要2个独立的图像,一个带有线条,一个没有线条。
答案 0 :(得分:1)
您可以使用getImageData
method从绘制的画布中获取图像。
答案 1 :(得分:1)
如果要使用图像数据URL,请尝试以下代码段
let imageDataUrl = '';
let image = document.querySelector('img');
image.src = imageDataUrl;
let canvas;
image.addEventListener('load', () => {
canvas = document.querySelector('canvas');
canvas.width = image.width;
canvas.height = image.height;
let context = canvas.getContext('2d');
context.drawImage(image, 0, 0);
let margin = 10;
context.strokeRect(margin, margin, canvas.width - margin * 2, canvas.height - margin * 2);
console.log('new data url:', canvas.toDataURL());
});
<div>
<img src="https://www.google.com/logos/doodles/2019/us-teacher-appreciation-week-2019-begins-4994791740801024-l.png">
</div>
<div>
<canvas></canvas>
</div>