上传图片转为base64格式预览并压缩图片(不兼容IE9以下浏览器,兼容移动端ios,android)
前些天公司要求在微信移动端做上传图片并预览的功能,要求能够调用摄像头拍照并立即预览。
在网上搜了一些方法,开始自己写了个简单的功能实现代码。结果发现移动端拍照出来的图片动不动就2M+,又因为要批量上传,为用户的流量和上传速度考虑,我决定做一下优化,看能不能在预览前就压缩一下图片尺寸。
结果又是一阵百度,发现一个靠谱的封装好的base64图片预览及压缩的方法。
直接上下载地址吧:
http://www.imwinlion.com/wp-content/uploads/2016/05/localresizeimg.rar
源码和用法都很简单,稍微看下源码就懂了,为了兼容移动端,请一定将/path/mobileBUGFix.mini.js加入到页面中。反正我是加了的,没加会有什么后果,大家有空可以测一下。
这个插件还是比较好用的,问题是我要批量上传,怎么搞?这个插件只能单个图片上传!
所以我后来改良了一下插件,在插件内部指向文件时,做了一个循环,话不多说,代码也很简单,直接上代码
/**
* 获得base64
* @param {Object} obj
* @param {Number} [obj.width] 图片需要压缩的宽度,高度会跟随调整
* @param {Number} [obj.quality=0.8] 压缩质量,不压缩为1
* @param {Function} [obj.before(this, blob, file)] 处理前函数,this指向的是input:file
* @param {Function} obj.success(obj) 处理后函数
* @example
*
*/
$.fn.localResizeIMG = function(obj) {
this.on('change', function() {
//批量预览压缩
var file,blob;
var _this=this;
if(this.files.length>1){
for(var i = 0, len=_this.files.length;i<len;i++){
file=_this.files[i];
if (window.createObjectURL!=undefined) { // basic
blob = window.createObjectURL(file) ;
} else if (window.URL!=undefined) { // mozilla(firefox)
blob = window.URL.createObjectURL(file) ;
} else if (window.webkitURL!=undefined) { // webkit or chrome
blob = window.webkitURL.createObjectURL(file) ;
}
if ($.isFunction(obj.before)) {
obj.before(_this, blob, file)
}
if(file.size/1024>300){
obj.quality=300/(file.size/1024)
}else{
obj.quality=1
}
_create(blob,obj.quality, file);
}
}else{
//单张预览压缩图片
file = this.files[0];
if (window.createObjectURL!=undefined) { // basic
blob = window.createObjectURL(file) ;
} else if (window.URL!=undefined) { // mozilla(firefox)
blob = window.URL.createObjectURL(file) ;
} else if (window.webkitURL!=undefined) { // webkit or chrome
blob = window.webkitURL.createObjectURL(file) ;
}
// 执行前函数
if ($.isFunction(obj.before)) {
obj.before(this, blob, file)
};
if(file.size/1024>300){
obj.quality=300/(file.size/1024)
}else{
obj.quality=1
}
_create(blob,obj.quality, file);
}
this.value = ''; // 清空临时数据
}); /**
* 生成base64
* @param blob 通过file获得的二进制
*/
function _create(blob,quality) {
console.log(quality);
var img = new Image();
img.src = blob;
img.onload = function() {
var that = this;
//生成比例
var w = that.width,
h = that.height,
quality = w / h;
w = obj.width || w;
h = w / quality; //生成canvas
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
$(canvas).attr({
width: w,
height: h
});
ctx.drawImage(that, 0, 0, w, h); /**
* 生成base64
* 兼容修复移动设备需要引入mobileBUGFix.js
*/
var base64 = canvas.toDataURL('image/png', quality || 0.8); // 修复IOS
if (navigator.userAgent.match(/iphone/i)) {
var mpImg = new MegaPixImage(img);
mpImg.render(canvas, {
maxWidth: w,
maxHeight: h,
quality: quality || 0.8
});
base64 = canvas.toDataURL('image/png', quality || 0.8);
} // 修复android
if (navigator.userAgent.match(/Android/i)) {
var encoder = new JPEGEncoder();
base64 = encoder.encode(ctx.getImageData(0, 0, w, h), parseFloat(quality).toFixed(1) * 100 || 80);
} // 生成结果
var result = {
base64: base64,
clearBase64: base64.substr(base64.indexOf(',') + 1)
}; // 执行后函数
obj.success(result);
};
}
}; // 例子
/*
$('input:file').localResizeIMG({
width: 100,
quality: 0.1,
//before: function (that, blob) {},
success: function (result) {
var img = new Image();
img.src = result.base64; $('body').append(img);
console.log(result);
}
});
*/
改良之后,我判断了input[type=files].files的长度,如果是批量上传的话,长度应该是大于1的,这个逻辑应该很好理解;然后循环每一个files,获取每个图片的size(图片大小),我这里的图片尺寸判断是写死了的300kb,如果这张图片>300kb,就压缩尺寸,如果相反,则按原尺寸预览。如果你用我改良后的代码,调用方法后的quality属性就不用赋值了。
with属性:你压缩后图片的宽度,不宜太小,我是设置的400,太小会失真。
before方法:开始压缩前执行函数
success方法:压缩成功后的回调函数,一般就是写预览代码,如果你要异步上传,这里也可以写ajax
说了这么多,再来说一下移动端的照相机调用,文件格式限制吧
很简单,一行搞定
<input id="images-multiple" class="weui-uploader__input" type="file" accept="image/*" multiple="multiple">
accept:接收文件的类型
multiple:可多选(android手机设置此项后,不能调用相机,只能从相册中选择;IOS手机体验还是很溜的)
id和calss自行制定就OK了。
目前的我页面在微信内跑,尚未发现问题,如有疑问欢迎探讨!!
提供一个GITHUB的类似解决方案:内容还没来得及看,有兴趣可以去看看
https://github.com/lyg945/localResizeIMG/tree/master/
上传图片转为base64格式预览并压缩图片(不兼容IE9以下浏览器,兼容移动端ios,android)的更多相关文章
- html5 图片上传,支持图片预览、压缩、及进度显示,兼容IE6+及标准浏览器
以前写过上传组件,见 打造 html5 文件上传组件,实现进度显示及拖拽上传,兼容IE6+及其它标准浏览器,对付一般的上传没有问题,不过如果是上传图片,且需要预览的话,就力有不逮了,趁着闲暇时间,给上 ...
- [javascript]——移动端 HTML5 图片上传预览和压缩
在开发移动端web网页中,我们不可避免的会遇到文件上传的功能,但由于手机图片尺寸太大,上传时间过长导致用户体验太差,就需要在上传前对图片进行一定的压缩. 在代码之前,有必要先了解我们即将使用到的几个A ...
- 使用jQuery在上传图片之前实现缩略图预览
使用jQuery在上传图片之前实现缩略图预览 jQuery代码 01 $("#uploadImage").on("change", function(){ 02 ...
- 【微信小程序云开发】1分钟学会实现上传、下载、预览、删除图片,并且以九宫格展示图片
大家好,我叫小秃僧 这篇文章是讲解云开发如何上传.下载.预览.删除图片,并且以九宫格展示图片的功能 @ 目录 1. 实现效果 2.JavaScript代码 3.wxml代码 4.wxss代码 1. 实 ...
- javascript实现 京东淘宝等商城的商品图片大图预览功能(图片放大器)
在京东和淘宝等购买东西的时候,我们会经常预览左侧商品展示图片,把鼠标放到原图,右侧就会有个大图显示出细节.本文将带领大家写一个这样简单的功能! 一.实现原理 当鼠标移入某一图片内部时,图片上部会出 ...
- input上传图片(file),预览图片的两种方法。blob与base64编码
上传图片时一般都需要预览,我一般用这两种方法来实现.base64编码可以直接上传到后台,后台解析下,得到的文件就会比较小了,省去了压缩图片这一步了. //获取对象input file 的图片地址,放进 ...
- JS实现图片base64转blob对象,压缩图片,预览图片,图片旋转到正确角度
base64转blob对象 /** 将base64转换为文件对象 * @param {String} base64 base64字符串 * */ var convertBase64ToBlob = f ...
- HTML5时代的纯前端上传图片预览及严格图片格式验证函数(转载)
原文地址:http://www.2cto.com/kf/201401/274752.html 一.要解决什么样的问题? 在写这个函数之前,有们童鞋在群里问如何纯前端严格验证图片格式.这在html5时代 ...
- html5 前端图片处理(预览、压缩、缩放)
现在手机图片是越来越大了,上传图片流量耗费巨大.同时预览也是一个问题,所以利用HTML5 file和canvas来解决这个问题. var upload = { _o: null,//对象id _aut ...
随机推荐
- Visual Studio Code 中编写 C++ 的工作流
1. 官网下载 Visual Studio Code ,安装.按提示安装 cpp 插件和 cmake 插件. 官网下载 CMake ,安装. 官网下载 Mingw ,安装. 安装 Mingw 时,注意 ...
- 初识Html:Html和CSS的关系
学习web前端开发基础技术需要掌握:HTML.CSS.JavaScript语言.下面我们就来了解下这三门技术都是用来实现什么的: 1. HTML是网页内容的载体.内容就是网页制作者放在页面上想要让用户 ...
- Docker存储驱动之AUFS简介
简介 AUFS是曾是Docker默认的首选存储驱动.它非常稳定.有很多真实场景的部署.很强的社区支持.它有以下主要优点: 极短的容器启动时间. 有效的存储利用率. 有效的内存利用率. 虽然如此,但由于 ...
- 初级:使用MD5对字符串进行加密操作
加密技术在企业数据安全中的应用: 大型企业管理软件的应用越来越广泛,企业数据平台涉及局域网.广域网. Internet等,在各类系统中保存的企业关键数据量也越来越大,许多数据需要保存数十年以上,甚至是 ...
- angular : ngModel 内部流程
angular 1.5 beta link NgModelController provides API for the ngModel directive. The controller conta ...
- Javascript学习十
认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...
- github学习(一)
初识github篇. 一.什么是github: GitHub 是一个面向开源及私有软件项目的托管平台,因为只支持 Git 作为唯一的版本库格式进行托管,故名 GitHub. g ...
- ANdrod Studio查看Sha1的方法
在用Studio做开发中,有时候根据业务需求,需要集成一些SDk,举个例子,百度的鹰眼定位,当然还有很多,在创建项目的时候需要输入sha1值,这个sha1值的获取有多种方式,我记得百度有个检测,就可以 ...
- 百度推送-sitemap-使用playframework框架实现-java
主动推送的目的是能够把我们高质量内容推送给百度,但是首先你得有一个属于你自己的网站,在百度站长进行验证通过之后,才有资格推送百度sitemap. 百度站长平台为未使用百度统计的站点提供三种验证方式:文 ...
- GCC命令
一. 常用编译命令选项 源程序test.c 1. 无选项编译链接用法:#gcc test.c作用:将test.c预处理.汇编.编译并链接形成可执行文件.这里未指定输出文件,默认输出为a.out. 2. ...