用于设置图像质量/ dpi的参数
我有一个特定像素大小的图像。保存之前,我需要降低其质量(不更改其像素大小)。
我将图像发送到以下功能。如果我想将质量降低到87%-我该怎么做?
function defineNewImgFile(image) {
let imgBlob = base64ImageToBlob(image);
let newFile = new File([imgBlob], image, {
type: typeOfImg
});
return newFile;
}
//changes base64 format
let typeOfImg;
function base64ImageToBlob(str) {
let pos = str.indexOf(';base64,');
let type = str.substring(5, pos);
typeOfImg = type;
let b64 = str.substr(pos + 8);
let imageContent = atob(b64);
let buffer = new ArrayBuffer(imageContent.length);
let view = new Uint8Array(buffer);
for (let n = 0; n < imageContent.length; n++) {
view[n] = imageContent.charCodeAt(n);
}
let blob = new Blob([view], {
type: type
});
return blob;
}
答案 0 :(得分:0)
对于图像压缩,可以使用sharp
答案 1 :(得分:-2)
尝试一下:
JavaScript功能代码
var yourImg = document.getElementById('yourImgId');
if(yourImg && yourImg.style) {
yourImg.style.height = '100px';
yourImg.style.width = '200px';
}
前端代码:
<img src="src/to/your/img.jpg" id="yourImgId" alt="alt tags are key!"/>