博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ios系统 竖屏拍照 canvas处理后 图片旋转(利用exif.js解决ios手机上传竖拍照片旋转90度问题)...
阅读量:5246 次
发布时间:2019-06-14

本文共 2155 字,大约阅读时间需要 7 分钟。

转:https://www.cnblogs.com/lovelgx/articles/8656615.html

 

---恢复内容开始---

问题:html5+canvas进行移动端手机照片上传时,发现ios手机上传竖拍照片会逆时针旋转90度,横拍照片无此问题;Android手机没这个问题。

解决方法:利用exif.js解决ios手机上传竖拍照片旋转90度问题

因此解决这个问题的思路是:获取到照片拍摄的方向角,对非横拍的ios照片进行角度旋转修正。

利用exif.js读取照片的拍摄信息,详见 http://code.ciaoca.com/javascript/exif-js/

这里主要用到Orientation属性。

Orientation属性说明如下:

 

exif.js 参考 

 主要代码参考如下:

 

---恢复内容结束---

通过上述参考代码,实践一个比较适用的代码

主要参考文章 

代码如下 :

  • 图片
  • function selectFileImage(fileObj) {    var file = fileObj.files['0'];    var agoimg=document.getElementById("ago"); //图片方向角 added by lzk var Orientation = null; if (file) { var rFilter = /^(image\/jpeg|image\/png)$/i; // 检查图片格式 if (!rFilter.test(file.type)) { wfy.alert("请选择jpeg、png格式的图片"); return; } // var URL = URL || webkitURL; //获取照片方向角属性,用户旋转控制 EXIF.getData(file, function() { EXIF.getAllTags(this); Orientation = EXIF.getTag(this, 'Orientation'); }); var oReader = new FileReader(); oReader.onload = function(e) { var image = new Image(); image.src = e.target.result; agoimg.src = e.target.result; agoimg.onload = function() { var expectWidth = this.naturalWidth; var expectHeight = this.naturalHeight; var calc = expectWidth / expectHeight; //比例参数 实现等比缩放 var canvas = document.getElementById('myCanvas'); var ctx = canvas.getContext("2d"); canvas.width = 1200;//此处可以随便设置 压缩后的宽度 canvas.height = (canvas.width)*calc; console.log('canvas数据'+canvas.width) var base64 = null; //修复ios Orientation ==6 只考虑一种情况 为做全面优化 if (Orientation == 6) { //alert('需要顺时针(向左)90度旋转'); ctx.save(); //保存状态 ctx.translate(canvas.width/2, canvas.height/2); //设置画布上的(0,0)位置,也就是旋转的中心点 ctx.rotate(90 * Math.PI / 180); //把画布旋转90度 // 执行Canvas的drawImage语句 ctx.drawImage(image, -(canvas.width/2), -(canvas.height/2), canvas.width, canvas.height); //把图片绘制在画布translate之前的中心点,这是关键点 ctx.restore(); //恢复状态 }else { ctx.drawImage(image, 0, 0, canvas.width, canvas.height); } base64 = canvas.toDataURL("image/jpeg", 0.92); $("#check_img").attr("src", base64); }; }; oReader.readAsDataURL(file); } //$('#uploadImage').imgloadsize(); }

    转载于:https://www.cnblogs.com/whatstone/p/11183646.html

    你可能感兴趣的文章
    [Kaggle] Sentiment Analysis on Movie Reviews
    查看>>
    价值观
    查看>>
    mongodb命令----批量更改文档字段名
    查看>>
    CentOS 简单命令
    查看>>
    使用 SharedPreferences 分类: Andro...
    查看>>
    TLA+(待续...)
    查看>>
    题解: [GXOI/GZOI2019]与或和
    查看>>
    MacOS copy图标shell脚本
    查看>>
    国外常见互联网盈利创新模式
    查看>>
    Oracle-05
    查看>>
    linux grep 搜索查找
    查看>>
    Not enough free disk space on disk '/boot'(转载)
    查看>>
    android 签名
    查看>>
    vue项目中使用百度统计
    查看>>
    android:scaleType属性
    查看>>
    SuperEPC
    查看>>
    mysql-5.7 innodb 的并行任务调度详解
    查看>>
    shell脚本
    查看>>
    Upload Image to .NET Core 2.1 API
    查看>>
    Js时间处理
    查看>>