我正在使用 phonegap 编写一个跨平台的移动应用程序,并且我有一个文件上传输入,用于上传单个图像的图像。
问题是大多数上传的图片都是用手机拍摄的,大小约为4MB。
我想大幅缩小这些图像,因为我根本不需要它们的高质量。
另外,我需要将它们转换为 base64 而不是真实图像文件。(我已经在使用 FileReader)
任何想法如何实现这一目标?也许使用画布或其他东西?
更新: 这是我到目前为止所拥有的:
function shrink() {
var self = this;
var reader = new FileReader(); // init a file reader
var file = $('#file-input').prop('files')[0]; // get file from input
reader.onloadend = function() {
// shrink image
var image = document.createElement('img');
image.src = reader.result;
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
ctx.drawImage(image, 0, 0, 300, 300);
var shrinked = canvas.toDataURL('image/jpeg');
console.log(shrinked);
};
reader.readAsDataURL(file); // convert file to base64*/
}
但我得到的只是黑色图像谢谢