如何在移动浏览器中使用HTML5 Canvas实现图片压缩上传?

avatar
作者
猴君
阅读量:0
使用HTML5 Canvas,可以在移动浏览器上实现图片压缩和上传功能。

在移动浏览器上实现HTML5 Canvas图片压缩上传,可以通过以下步骤来完成:

如何在移动浏览器中使用HTML5 Canvas实现图片压缩上传?

1、获取本地图片并绘制到画布中:由于浏览器的保护机制,无法直接获取本地文件的图片路径,所以需要将本地图片编译成base64格式再上传,代码如下:

 var result = document.getElementById("/* 出错信息显示块 */"); var input = document.getElementById("/* 上传文件标签 */"); if(typeof FileReader === 'undefined'){     result.innerHTML = "<p class='warn'>抱歉,你的浏览器不支持 FileReader</p>";     input.setAttribute('disabled','disabled'); }else{     input.addEventListener('change',readFile,false); } function readFile(){     var file = this.files[0];     if(!/image\/\w+/.test(file.type)){         alert("请确保文件为图像类型");         return false;     }     var reader = new FileReader();     reader.readAsDataURL(file);     reader.onload = function(e){         // this.result 编译后的图像编码,可直接用src显示     } }

2、图像在canvas中的处理:使用canvas将Image对象等比缩放并写入到画布中,保存为base64格式的数据,代码如下:

 var c=document.getElementById("/* canvas标签的id */"); var cxt=c.getContext("2d"); var img=new Image(); img.src=/* 获取的图片编码地址 */; var width = img.width; var height = img.height; var dic = height / width; c.width = 200; //图片压缩的标准,这里是按照定宽200px计算 c.height = 200 * dic; cxt.clearRect(0,0,200,200*dic); cxt.drawImage(img,0,0,200,200*dic); var finalURL = c.toDataURL(); // 最终得到的 finalURL 即为压缩后的图片编码,可用来上传或者直接生成img标签

3、上传压缩后的图片:使用AJAX上传图像编码时,编码内的加号会被转成空格上传导致后台编译失败,需要在服务器端进行处理,代码如下:

 $.ajax({     url: '/upload',     type: 'POST',     data: { image: finalURL },     success: function(response) {         console.log(response);     },     error: function(error) {         console.log(error);     } });

4、注意事项:在本地调试时会有一个报错,原因为跨域问题,需要再服务端调试;canvas中的drawImage()方法具备图像剪裁功能,但将图像拉伸和剪裁同时写入的话,会优先执行剪裁的方法;关于对图片区域选择上传的方法尚在尝试阶段,后续会补上心得。

如何在移动浏览器中使用HTML5 Canvas实现图片压缩上传?

以下是相关问答FAQs:

1、问:为什么需要将图片转换为base64格式?

答:由于浏览器的保护机制,无法直接获取到本地文件的图片路径,所以需要将本地图片编译成base64格式再上传,这样可以保证图片数据的安全性和完整性。

2、问:如何设置canvas的宽度和高度来调整图片大小?

如何在移动浏览器中使用HTML5 Canvas实现图片压缩上传?

答:可以通过设置canvas的width和height属性来调整图片大小,将canvas的宽度设置为200像素,高度设置为200乘以原始图片的高宽比,然后使用drawImage()方法将图片绘制到canvas上,这样可以实现图片的等比缩放。

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!