移动端h5拍照压缩即时上传后台并预览
项目经理让迭代一个功能,实时预览并上传到后台的功能,听到这立马想起了几个第三方插件去实现,mui 和api cloude万万没想到的是这个app前面使用ios 和安卓原生写的,然后mui和api cloud里面都要配置文件,不能嵌入到app中,于是乎开始我的查询h5官方api之路。好在皇天不负有心人,终于让我弄出来了。
大致思路是这样的,首先用h5的input file 在拍照时或者选择手机相册后把获得的图片压缩成base64位(这样提高上传速度,不然会上传很久),然后调用接口传到后台,再从后台吧上传的图片拿下来显示到预览区就可以了。话不多说上代码:
html:
<div class="container">
<!--头像认证开始-->
<div class="top">
<div class="topUp">头像认证</div>
<div class="topDown">
<div class="left">
<div class="pics">
<img src="../images/example2.png" id="carImg"/>
</div>
</div>
<div class="right">
<div class="pics" style="float: right;"><img src="../images/example2.png" id="zmImg"/></div>
</div>
</div>
<div class="topUp">
<div class="left">车身照</div>
<div class="right">手持身份证拍照</div>
</div>
</div>
<!--头像认证结束-->
</div>
<!--拍照或者选择相册弹窗开始-->
<!--正面照开始-->
<div class="file" id="id1">
<div class="photograph">
<a href="javascript:;">
<form method="post" id="businessUpload1" enctype="multipart/form-data">
<input type="file" name="file" accept="image/gif,image/jpeg,image/jpg" capture="camera" id="txCramePic">相机拍照
<!--<input type="hidden" name="account" id="business-account1">
<input type="hidden" name="imgType" id="business-imgType1">-->
</form>
</a>
</div>
<div class="photo">
<a href="javascript:;">
<form method="post" id="businessUpload2" enctype="multipart/form-data">
<input type="file" name="file" accept="image/jpeg,image/jpg" id="txPic">选择相册
</form>
</a>
</div>
<button clsss="gb">取消</button>
</div>
<!--正面照结束-->
<!--身份证正面照开始-->
<div class="file" id="id2">
<div class="photograph">
<a href="javascript:;">
<form method="post" id="businessUpload3" enctype="multipart/form-data">
<input type="file" name="file" accept="image/gif,image/jpeg,image/jpg" capture="camera" id="sfzmCramePic">相机拍照
</form>
</a>
</div>
<div class="photo">
<a href="javascript:;">
<form method="post" id="businessUpload4" enctype="multipart/form-data">
<input type="file" name="file" accept="image/gif,image/jpeg,image/jpg" id="sfzmPic">选择相册
</form>
</a>
</div>
<button class="gb">取消</button>
</div>
<!--身份证正面照结束-->
<button class="gb">取消</button>
</div>
js:
var allowTypes = ['image/jpg', 'image/jpeg'];
// 10MB
var maxSize = 10 * 1024 * 1024;
var base64;
// 图片最大宽度
var maxWidth = 640;
///////////这里开始优化///////////
// 正面照开始
var zhengmianzhao;
$("#zmImg").on('touchend',function () {
$('#id1').show();
// 选择相机开始
// var faceUrl= 'faceUrl';
$('#txCramePic').on('change',function(event){
if(event==null)
return;
var files = event.target.files[0];
var file = files;
var fileName = files.name;
var reader = new FileReader();
// 如果类型不在允许的类型范围内
reader.onload = function (e) {
var img = new Image();
img.src = e.target.result;
img.onload = function(){
// 不要超出最大宽度
var w = Math.min(maxWidth, img.width);
// 高度按比例计算
var h = img.height * (w / img.width);
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
// 设置 canvas 的宽度和高度
canvas.width = w;
canvas.height = h;
ctx.drawImage(img, 0, 0, w, h);
base64 = canvas.toDataURL('image/jpeg');
//console.log(base64);
base64 = base64.substring(base64.indexOf("base64,")+7,base64.length-1);
$.ajax({
url :"",
beforeSend:function(){
$("#zmImg").attr("src","../images/loading.gif");
$('#id1').hide();
},
data:{
'account':account,
'imgType':'faceUrl',
'fileBase64':base64,
'fileName':fileName
},
type : 'post',
dataType : 'json',
success : function(data) {
$("#zmImg")[0].src = data.data.imgUrl;
window.zhengmianzhao = data.data.imgUrl;
},
error : function(data) {
alert("对不起,请重新上传");
$("#zmImg").attr("src","../images/example2.png");
}
});
};
//
};
reader.readAsDataURL(file);
});
// 选择相机结束
// 选择相册开始
$('#txPic').on('change',function(){
if(event==null)
return;
// 获取单张要上传的那个图片
var files = event.target.files[0];
var file = files;
var fileName = files.name;
// h5上传自定义方法
var reader = new FileReader();
// 如果类型不在允许的类型范围内
reader.onload = function (e) {
var img = new Image();
img.src = e.target.result;
img.onload = function(){
// 不要超出最大宽度
var w = Math.min(maxWidth, img.width);
// 高度按比例计算
var h = img.height * (w / img.width);
var canvas = document.createElement('canvas');
var ctx = canvas.getContext('2d');
// 设置 canvas 的宽度和高度
canvas.width = w;
canvas.height = h;
ctx.drawImage(img, 0, 0, w, h);
base64 = canvas.toDataURL('image/jpeg');
//console.log(base64);
base64 = base64.substring(base64.indexOf("base64,")+7,base64.length-1);
$.ajax({
url :"",
beforeSend:function(){
$("#zmImg").attr("src","../images/loading.gif");
$('#id1').hide();
},
data:{
'account':account,
'imgType':'faceUrl',
'fileBase64':base64,
'fileName':fileName
},
type : 'post',
dataType : 'json',
success : function(data) {
$("#zmImg")[0].src = data.data.imgUrl;
window.zhengmianzhao = data.data.imgUrl;
},
error : function(data) {
alert("对不起,请重新上传");
$("#zmImg").attr("src","../images/example2.png");
}
});
};
//
};
reader.readAsDataURL(file);
});
// 选择相册结束
});
//正面照结束
以上代码仅供参考,在这个程序员苦逼的年代里 我们需要抱团取暖
移动端h5拍照压缩即时上传后台并预览的更多相关文章
- java多图片上传--前端实现预览--图片压缩 、图片缩放,区域裁剪,水印,旋转,保持比例。
java多图片上传--前端实现预览 前端代码: https://pan.baidu.com/s/1cqKbmjBSXOhFX4HR1XGkyQ 解压后: java后台: <!--文件上传--&g ...
- jsp+springmvc实现文件上传、图片上传和及时预览图片
1.多文件上传:http://blog.csdn.net/a1314517love/article/details/24183273 2.单文件上传的简单示例:http://blog.csdn.net ...
- web 图片上传实现本地预览
在说上传之前先说说如何替换or美化浏览器自带的简陋上传按钮(自定义自己的上传按钮 如:img): 1.将自定义上传按钮上方添加 input file 框,实现input实现透明处理. 2.对自定义上传 ...
- [.ashx檔?泛型处理例程?]基础入门#2....FileUpload上传前,预览图片(两种作法--ashx与JavaScript)
原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/08/20/ashx_beginner_02_fileupload_picture_p ...
- Ajax上传图片以及上传之前先预览
手头上有几个小项目用到了easyUI,一开始决定使用easyUI就注定了项目整体上前后端分离,基本上所有的请求都采用Ajax来完成.在文件上传的时候用到了Ajax上传文件,以及图片在上传之前的预览效果 ...
- 关于confluence上传文件附件预览查看时出现乱码的问题解决办法
在confluence上传excel文件,预览时发现乱码问题主要是因为再上传文件的时候一般是Windows下的文件上传,而预览的时候,是linux下的环境,由于linux下没有微软字体,所以预览的时候 ...
- confluence上传文件附件预览乱码问题(linux服务器安装字体操作)
在confluence上传excel文件,预览时发现乱码问题主要是因为再上传文件的时候一般是Windows下的文件上传,而预览的时候,是linux下的环境,由于linux下没有微软字体,所以预览的时候 ...
- 项目分享五:H5图片压缩与上传
一.简介 图片的压缩与上传,是APP里一个很常用的功能.我们来年看 ChiTuStore 是怎样做的.相关文件 App/Module/User/UserInfo.html,App/Module/Use ...
- 图片上传前的预览(PHP)
1.先创建一个file表单域,我们需要用它来浏览本地文件.<form name="form1" id="form1" method="post& ...
随机推荐
- 开源API集成测试工具 Hitchhiker v0.2更新 - 压力测试
Hitchhiker 是一款开源的 Restful Api 集成测试工具,支持Schedule, 数据对比,压力测试,可以轻松部署到本地,和你的team成员一起管理Api. 详细介绍请看: http: ...
- Scala 运算符和集合转换操作示例
Scala是数据挖掘算法领域最有力的编程语言之一,语言本身是面向函数,这也符合了数据挖掘算法的常用场景:在原始数据集上应用一系列的变换,语言本身也对集合操作提供了众多强大的函数,本文将以List类型为 ...
- 使用OLAMISDK实现一个语音输入数字进行24点计算的iOS程序
前言 在目前的软件应用中,输入方式还是以文字输入方式为主,但是语音输入的方式目前应用的越来越广泛.这是一个利用 Olami SDK 编写的一个24点iOS程序,是通过语音进行输入. Olami SDK ...
- Shell一个文件并等待完成
Option Explicit Private Declare Function OpenProcess Lib "kernel32" _ (ByVal dwDesiredAcce ...
- RoportNG报表显示中文乱码和TestNG显示中文乱码实力解决办法
最近在进军测试自动化框架学习阶段,但无意间总是会伴随小问题的困扰,比如中文乱码,而导致显示总是不舒服,个人觉得,就一定要解决,似乎有点点强迫症.所以遇到RoportNG报表显示中文乱码和TestNG显 ...
- Android的快速开发框架 afinal
afinal 框架学习: http://www.oschina.net/p/afinal
- android 屏幕适配基础(1)
1. 概念定义 寸/英寸: 1寸=3.333333厘米:1英寸=2.54厘米(屏幕尺寸以英寸为单位) 像素 : 像素是组成图象的最基本单元要素:点. 一个像素有多大呢?主要取决于显示器的分辨 ...
- MongoDB快速入门
http://www.yiibai.com/mongodb/mongodb_quick_guide.html 创建数据库 MongoDB use DATABASE_NAME 用于创建数据库.该命令如果 ...
- vue.js实例对象+组件树
vue的实例对象 首先用js的new关键字实例化一个vue el: vue组件或对象装载在页面的位置,可通过id或class或标签名 template: 装载的内容.HTML代码/包含指令或者其他组件 ...
- OpenSCAD 建模:相框
下载地址:https://github.com/ZhangGaoxing/openscad-models/tree/master/PhotoFrame 代码: module bottom(){ dif ...