html5前端压缩图片,html5 FileReader+Canvas 前端压缩图片(IE9及以下浏览器不支持)...

利用h5的FileReader属性读取图片文件,建立canvas画布,绘制图片

canvas{

display: none;

}

#show:checked ~ canvas{

display: block;

}

显示画布?

function change(self){

var press =function() {//上传图片

var Pic = document.getElementById('input_canvas').toDataURL("image/png"),

pics = Pic.replace(/^data:image\/(png|jpg);base64,/, "");//pics是要上传的值,去掉了前缀

//document.getElementsByTagName("img")[0].src=Pic;//测试部分

}

var getStyle =function(obj, attr) {//获取高度的兼容,

if (obj.currentStyle) {

return obj.currentStyle[attr];//IE

} else {

return getComputedStyle(obj, false)[attr];//chrome,firfox

}

}

var Cnv = document.getElementById('input_canvas');

var Cntx = Cnv.getContext('2d');//画布就绪

var imgs = new Image();//新建图片对象

var tmpFile = self.files[0];

var reader = new FileReader();//用户读取手机上的文件 ie9及以下浏览器不支持filereader

reader.readAsDataURL(tmpFile);//文件编码成Data URL

reader.onload = function (e) {//文件读取完成时执行

var url = e.target.result;//e.target.result读取文件编码

imgs.src = url;

imgs.onload = function () {

var m = imgs.width / imgs.height,

n = parseFloat(getStyle(imgs, 'height'));//获取图片高度

Cnv.height = 200; //该值影响缩放后图片的大小,此处设置图片高度为100px

Cnv.width = 200 * m;//宽度跟随高度变化

Cntx.drawImage(imgs, 0, 0, Cnv.width, Cnv.height);//画布绘制

press();//调用function上传图片

};

};

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值