1.第一种方法是用H5来实现的

  HTML:

 <label>
    <input style="opacity: 0;" type="file" accept="image/*" id="head_img_change"/>
    <img id="headimg" src="img/erma_search_goods_detail.png">
</label>

  JQ:

 $(function(){

     $("#head_img_change").change(function() {
      var $file = $(this);
      var fileObj = $file[0];
      var windowURL = window.URL || window.webkitURL;
      var dataURL;
      var $img = $("#headimg");
      if(fileObj && fileObj.files && fileObj.files[0]){
        dataURL = windowURL.createObjectURL(fileObj.files[0]);
        $img.attr('src',dataURL);
      }else{
        dataURL = $file.val();
        var imgObj = document.getElementById("headimg");
        // 1、在设置filter属性时,元素必须已经存在在DOM树中,动态创建的Node,也需要在设置属性前加入到DOM中,先设置属性再加入,无效;
        // 2、src属性需要像下面的方式添加,上面的两种方式添加,无效;
        imgObj.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
        imgObj.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = dataURL;
      }
    });   })

  说明:1)外部加个label是为了把让用户点击的时候在范围内的都会触发input

     2)H5  input file上传图片,调用API:<input type="file" accept="image/*;capture=camera">直接调用相机
                       <input type="file" accept="image/*" />调用相机、图片或者相册

       注:部分android机只能调用本地相册,相机调用不了或者只能调用相机,不能调用相册。

     3)此方法是网上的一种方法,做了兼容的,IE6以上都能正常运行。

2.第二种方法:MUI h5+

  不用引入mui.js或mui.min.js,直接在hbuilder这个IDE中新建移动app,然后在页面中直接调用方法就行了,当然,需要在manifest.json中先配置权限,然后真机调试才能看到效果。点击这里是拍照调用方法的文档

function getImage(){
var cameraObj = plus.camera.getCamera();
cameraObj.captureImage(function(path){
CompressImage(path)
}, function(e){
console.log('取消拍照');
}, {
filename:'_doc/pic/',
index:1
});
}
function CompressImage(path){
plus.zip.compressImage( {
src:path,
dst:path,
overwrite:true,
quality:60,
rotate:90
}, function(event){
var _src=event.target;
mui.confirm("是否保存该图片","温馨提示",["否","是"],function(e){
console.log(_src)
if(e.index){
plus.gallery.save(_src, function(evt){
$(".box").append('<img src="'+evt.file+'">');
mui.alert('保存成功'+evt.file); }, function(err){
mui.alert('保存失败: '+JSON.stringify(err)); });
}
}) console.log(event.size)
}, function(err){ });
}

说明:

  getImage()是点击拍照按钮之后触发的事件。CompressImage(path)是压缩图片的事件。

  拍照上传需要用到5+的api。plus.camera.getCamera()是获取到camera摄像头对象

  该对象有三个方法,其中一个是captureImage,它有三个参数,captureImage(successCB, errorCB, option)

    successCB:拍照操作成功的回调函数(必选)CameraSuccessCallback

    errorCB:拍照操作失败的回调函数(可选)CameraErrorCallback

    option:摄像头拍照参数(必选)CameraOption。

    option这个对象的属性:filename: 拍照或摄像文件保存的路径;

               index: 拍照或摄像默认使用的摄像头,1表示主摄像头(后),2表示辅摄像头(前) 

 

  compressImage是图片压缩的方法,属于5+里的zip接口。plus.zip.compressImage( options, successCB, errorCB),它也有三个参数,具体的参数信息可查看这里

  plus.gallery.save是保存文件到本地的方法,属于5+里的gallery接口,plus.gallery.save( path, successCB, errorCB )。它也有三个参数,具体的参数信息可查看这里 在上面的compressImage方法中,我加入了rotate:90的属性,是因为手持设备不同方向所拍摄的照片方向不同,照片的方向都会不同,但相册中会自动纠正,这一问题在ios和android中都存在。
 一般你只要竖直拍摄的照片,在页面上显示的时候就会自动旋转90度的样子。所以这里强制旋转90度,适用于大部分情况,但是如果拍摄的时候横着拍,或者180度倒着拍就不行了。
 可以考虑使用Exif.js来获取图片的拍照方向,然后设置旋转就能解决问题。  拍照完成了,上传的话,就可以用canvas把图片编码成base64,然后在后台解码base64就行了。也可以考虑使用5+api中的uploader来上传  这里有我自己总结的 5+ runtime 常用api,里面有详细的说明 第三种方法是通过form表单来实现:只需两步
第一步:html
<form action="" method="post" enctype="multipart/form-data">
<input type="file" onchange="uploadImg(this,'behindeImg')" class="comFileBtn" accept="image/*"/>
</form>
第二步:js 
//上传图片
//that是该input,imgName是图片要显示的src的位置
function uploadImg(that,imgName){
var reads= new FileReader();
var fileObj=that.files[0];
var imageType = /^image\//;
//是否是图片,如果input没加accept属性,这里也可以判断
if (!imageType.test(fileObj.type)) {
alert("请选择图片!");
return;
}
//读取完成
reads.readAsDataURL(fileObj);
reads.onload = function(e) {
//图片路径设置为读取的图片
$("#"+imgName).attr('src',e.target.result) ;
};
}

这样,后台也可以通过读取表单数据来获取内容了

MUI 拍照或选取照片上传作为头像的更多相关文章

  1. 个人信息——头像更换(拍照或相册上传)~ 微信小程序

    微信小程序中 在用户信息中关于用户头像更换(拍照或相册上传)功能实现. 图像点击触发事件: <image src='{{personImage}}' bindtap='changeAvatar' ...

  2. Android实现批量照片上传至server,拍照或者从相冊选择

    近期因为项目需求,须要完毕批量照片上传,折腾了一段时间,最终完毕了,达到了例如以下效果 主界面主要有GridView组成和button组成,当按下一个格点时,会调用相机或者相冊,拍照或者选择相冊照片, ...

  3. Android图片上传(头像裁切+原图原样)

    下面简单铺一下代码: (一)头像裁切.上传服务器(代码) 这里上边的按钮是头像的点击事件,弹出底部的头像选择框,下边的按钮跳到下个页面,进行原图上传. ? 1 2 3 4 5 6 7 8 9 10 1 ...

  4. 用C#缩小照片上传到各种空间

    中秋到了,首先祝各位猿友节日快乐!!! 本博文的原名称是“跟我一起用C#压缩照片上传到各种空间”,评论上有人开骂,没办法我这人就是自信霸气,但是既然有人提出来我还是改掉吧,如果文章写得不好的地方欢迎大 ...

  5. css实现照片上传的加号框

    css实现照片上传的加号框    

  6. 升级IOS8游戏上传自定义头像功能失效的问题

    为了支持arm64,之前已经折腾了很久,昨晚打包准备提交苹果审核时,测试那边的同事反馈说游戏上传自定义头像功能不可用了. 游戏上传自定义功能的简介:卡牌游戏最初是<比武招亲>中有一个充VI ...

  7. 【NopCommerce 3.1】asp.net mvc 利用jQuery from.js上传用户头像

    纯代码不解释. 在CusotmerControllers中添加上传方法 /// <summary> /// ajax上传用户头像 /// </summary> /// < ...

  8. MUI 单图片压缩上传(拍照+系统相册): 选择立即上传

    1 html 部分 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...

  9. 微信调用照相拍照等 js 接口的权限配置 和 照片上传和下载实现

    直接上代码: 1. 前端调试代码: <html> <head> <meta http-equiv="Content-Type" content=&qu ...

随机推荐

  1. sheet制作返回按钮

    =HYPERLINK("#目录!A1","目录!A1") =HYPERLINK("#"&A2&"!A1" ...

  2. ResultSet集合查询字段名称(转载)

    转自:https://blog.csdn.net/song_litao/article/details/84751351 public List<String> getColumnName ...

  3. BugPhobia启程篇章:需求分析与功能定位

    0x01 :引言 If you weeped for the missing sunset, you would miss all the shining stars 我看着大巴缓缓的驶过街角,我躲在 ...

  4. 大三上学期安卓一边学一边开始做一个自己觉得可以的项目 广商小助手App 加油

    这项目构思好多 一个人一步一步来 一边做一边为后面应用铺设 广商小助手APP 设计出的软件登录场景 实现(算是可以) 界面大体出来了 界面点击方面也做了很多特效 上图其实点击各颜色后会出现各种图和反应 ...

  5. 5.1 四则运算单元测试j

    由于上个星期请假没上课,这个星期回来才知道作业,时间比较赶,个人能力又不足,作业质量不是很好 Calculator.java import java.util.Scanner; public clas ...

  6. QT应用在windows和Linux平台的发布指南

    环境:QT5.4 Windows下Qt应用的发布 Qt安装路径为:C:\Qt\Qt5.4.0\5.4\mingw491_32\bin 首先确保这个路径不在环境变量中,否则可能不成功. 执行" ...

  7. Java基础实践一:for关键字的实现原理

    Java源码: /** * Demo.java * com.yuanchuangyun.libra.web * * * ver date author * ────────────────────── ...

  8. Windows 通过命令行设置固定ip地址

    Winserver1709 之后 windows系统取消了GUI界面 设置ip地址 需要使用命令行界面进行 这里简单记录一下 打开win1709的虚拟机 进入命令行控制台 输入 ipconfig 查看 ...

  9. PHP hexdec() 函数

    hexdec() 函数把十六进制转换为十进制. 语法 hexdec(hex_string) 参数 描述 hex_string 必需.规定要转换的十六进制数. 说明 返回与 hex_string 参数所 ...

  10. linux中tomcat修改错误日志路径

    涉及文件 log4j.properties   (一般开发将该文件放在项目的缺省目录即源包下,在文件系统里,就是在项目的/src/java目录下,缺省的文件名是log4j.properties,这样项 ...