在 canvas 上保持图像的原始质量
Preserve original quality of image on canvas
我正在使用 fabric.js
。我正在 canvas 中上传多张图片。上传图片后。然后canvas被toDataURL()
转换成图像。我想将此转换后的图像粘贴到尺寸为 2000x2000
的 T 恤上。但是这张图片尺寸很小,当我尝试增加它的尺寸时,由于拉伸它变得模糊
我需要与用户上传的尺寸相同的图片,而不是缩小图片的放大版本。例如,如果用户上传了尺寸为 1500x1500
的图片,那么从 canvas 我只需要尺寸为 2000x2500
的图片,而不是 400x400
.
我看过 99Thsirts.com 网站,但我不知道如何处理护照尺寸的图像。
我只想要干净的上传自定义图像(不模糊),因为我正在实施自定义 T 恤。
var canvas = new fabric.Canvas('canvas');
document.getElementById('file').addEventListener("change", function (e) {
var file = e.target.files[0];
var reader = new FileReader();
reader.onload = function (f) {
var data = f.target.result;
var img = document.createElement('img');
img.src = data;
img.onload = function () {
if (img.width < 1000 || img.height < 1000)
{
alert("upload image should be greater then 1000px*1000px");
canvas.getActiveObject().remove();
}
};
fabric.Image.fromURL(data, function (img) {
var oImg = img.set({left: 50, top: 100,width:100, height:100, angle: 00}).scale(0.9);
canvas.add(oImg).renderAll();
var a = canvas.setActiveObject(oImg);
var dataURL = canvas.toDataURL({format: 'png', quality: 0.8});
console.log("aaaaaaaaaaa" + dataURL);
// console.log("Canvas Image " + dataURL);
// document.getElementById('txt').href = dataURL;
});
};
reader.readAsDataURL(file);
});
document.querySelector('#txt').onclick = function (e) {
e.preventDefault();
canvas.deactivateAll().renderAll();
document.querySelector('#preview').src = canvas.toDataURL();
}
canvas{
border: 1px solid black;
}
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
<input type="file" id="file">
<canvas id="canvas" width="400" height="400"></canvas>
<a href='' id='txt' target="_blank">Click Me!!</a>
<br />
<img id="preview" />
https://jsfiddle.net/varunPes/8gt6d7op/21/
请分享您的想法。
如果您将图像调整为 100x100 像素,那么您将得到一张 100x100 的图像。
加载图像时不要更改图像的宽度和高度。也没有理由使用图像加载函数和 imageFromURL 函数。
这么说,加载你的图片,将它缩放到 90px 的宽度(现在你做的是 100,缩放 0.9 所以是 90px),把它放在 canvas。
canvas 为 400px,当您导出它时,您将指定乘数 5 以获得 2000px canvas。
图像将被拉伸而不会失去其原始分辨率。当然,它不会超过其标准分辨率。
var canvas = new fabric.Canvas('canvas');
document.getElementById('file').addEventListener("change", function (e) {
var file = e.target.files[0];
var reader = new FileReader();
reader.onload = function (f) {
var data = f.target.result;
var img = document.createElement('img');
img.onload = function () {
if (img.width < 1000 || img.height < 1000)
{
alert("upload image should be greater then 1000px*1000px");
return;
}
var oImg = new fabric.Image(img);
var oImg = oImg.set({left: 50, top: 100, angle: 00}).scaleToWidth(90);
canvas.add(oImg);
canvas.setActiveObject(oImg);
};
img.src = data;
};
reader.readAsDataURL(file);
});
document.querySelector('#txt').onclick = function (e) {
e.preventDefault();
canvas.deactivateAll();
document.querySelector('#preview').src = canvas.toDataURL({multiplier: 5});
}
canvas{
border: 1px solid black;
}
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
<input type="file" id="file">
<canvas id="canvas" width="400" height="400"></canvas>
<a href='' id='txt' target="_blank">Export me 5x Bigger ( 400x5=2000)</a>
<br />
<img id="preview" />
我正在使用 fabric.js
。我正在 canvas 中上传多张图片。上传图片后。然后canvas被toDataURL()
转换成图像。我想将此转换后的图像粘贴到尺寸为 2000x2000
的 T 恤上。但是这张图片尺寸很小,当我尝试增加它的尺寸时,由于拉伸它变得模糊
我需要与用户上传的尺寸相同的图片,而不是缩小图片的放大版本。例如,如果用户上传了尺寸为 1500x1500
的图片,那么从 canvas 我只需要尺寸为 2000x2500
的图片,而不是 400x400
.
我看过 99Thsirts.com 网站,但我不知道如何处理护照尺寸的图像。
我只想要干净的上传自定义图像(不模糊),因为我正在实施自定义 T 恤。
var canvas = new fabric.Canvas('canvas');
document.getElementById('file').addEventListener("change", function (e) {
var file = e.target.files[0];
var reader = new FileReader();
reader.onload = function (f) {
var data = f.target.result;
var img = document.createElement('img');
img.src = data;
img.onload = function () {
if (img.width < 1000 || img.height < 1000)
{
alert("upload image should be greater then 1000px*1000px");
canvas.getActiveObject().remove();
}
};
fabric.Image.fromURL(data, function (img) {
var oImg = img.set({left: 50, top: 100,width:100, height:100, angle: 00}).scale(0.9);
canvas.add(oImg).renderAll();
var a = canvas.setActiveObject(oImg);
var dataURL = canvas.toDataURL({format: 'png', quality: 0.8});
console.log("aaaaaaaaaaa" + dataURL);
// console.log("Canvas Image " + dataURL);
// document.getElementById('txt').href = dataURL;
});
};
reader.readAsDataURL(file);
});
document.querySelector('#txt').onclick = function (e) {
e.preventDefault();
canvas.deactivateAll().renderAll();
document.querySelector('#preview').src = canvas.toDataURL();
}
canvas{
border: 1px solid black;
}
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
<input type="file" id="file">
<canvas id="canvas" width="400" height="400"></canvas>
<a href='' id='txt' target="_blank">Click Me!!</a>
<br />
<img id="preview" />
https://jsfiddle.net/varunPes/8gt6d7op/21/
请分享您的想法。
如果您将图像调整为 100x100 像素,那么您将得到一张 100x100 的图像。 加载图像时不要更改图像的宽度和高度。也没有理由使用图像加载函数和 imageFromURL 函数。
这么说,加载你的图片,将它缩放到 90px 的宽度(现在你做的是 100,缩放 0.9 所以是 90px),把它放在 canvas。
canvas 为 400px,当您导出它时,您将指定乘数 5 以获得 2000px canvas。 图像将被拉伸而不会失去其原始分辨率。当然,它不会超过其标准分辨率。
var canvas = new fabric.Canvas('canvas');
document.getElementById('file').addEventListener("change", function (e) {
var file = e.target.files[0];
var reader = new FileReader();
reader.onload = function (f) {
var data = f.target.result;
var img = document.createElement('img');
img.onload = function () {
if (img.width < 1000 || img.height < 1000)
{
alert("upload image should be greater then 1000px*1000px");
return;
}
var oImg = new fabric.Image(img);
var oImg = oImg.set({left: 50, top: 100, angle: 00}).scaleToWidth(90);
canvas.add(oImg);
canvas.setActiveObject(oImg);
};
img.src = data;
};
reader.readAsDataURL(file);
});
document.querySelector('#txt').onclick = function (e) {
e.preventDefault();
canvas.deactivateAll();
document.querySelector('#preview').src = canvas.toDataURL({multiplier: 5});
}
canvas{
border: 1px solid black;
}
<script src="https://rawgit.com/kangax/fabric.js/master/dist/fabric.min.js"></script>
<input type="file" id="file">
<canvas id="canvas" width="400" height="400"></canvas>
<a href='' id='txt' target="_blank">Export me 5x Bigger ( 400x5=2000)</a>
<br />
<img id="preview" />