利用exif.js解决ios手机上传竖拍照片旋转90度问题
来源:互联网 发布:珠海网络传媒有限公司 编辑:程序博客网 时间:2024/04/28 20:43
html
<input style="border:0" type="file" id="upload1" accept="image/*" onchange="compress(this);">
//压缩图片
function compress(ele) {var self = ele;
var fileName = $(ele).attr("name");
var file = self.files[0];
var r = new FileReader();
r.readAsDataURL(file);
$(r).load(function () {
var fileStream = ele.result;//base64图片流
var URL = window.URL || window.webkitURL,
canvas = document.createElement('canvas'),
ctx = canvas.getContext('2d');
if (URL && file && ctx) {
var fileURL = URL.createObjectURL(file),
img = new Image();
img.src = fileURL;
img.onload = function () {
var orientation=null;
EXIF.getData(img, function () {
EXIF.getAllTags(this);
orientation = EXIF.getTag(this, "Orientation");// 获取方向角
var degree = 0, drawWidth = img.width, drawHeight = img.height, width, height;
//以下改变一下图片大小
var maxSide = Math.max(drawWidth, drawHeight);
var tarSize = 1024;
if (maxSide > tarSize) {
var minSide = Math.min(drawWidth, drawHeight);
minSide = minSide / maxSide * tarSize;
maxSide = tarSize;
if (drawWidth > drawHeight) {
drawWidth = maxSide;
drawHeight = minSide;
} else {
drawWidth = minSide;
drawHeight = maxSide;
}
}
canvas.width = width = drawWidth;
canvas.height = height = drawHeight;
switch (orientation) {//横屏竖屏转化
//横屏拍摄,此时home键在左侧
case 3:
degree = 180;
drawWidth = -width;
drawHeight = -height;
break;
//竖屏拍摄,此时home键在下方(正常拿手机的方向)
case 6:
canvas.width = height;
canvas.height = width;
degree = 90;
drawWidth = width;
drawHeight = -height;
break;
//竖屏拍摄,此时home键在上方
case 8:
canvas.width = height;
canvas.height = width;
degree = 270;
drawWidth = -width;
drawHeight = height;
break;
}
//使用canvas旋转校正
ctx.rotate(degree* Math.PI/180);
ctx.drawImage(img, 0, 0, drawWidth, drawHeight);
var base64 = canvas.toDataURL('image/jpeg',1);
var reader = new FileReader();
reader.readAsDataURL(ele.files[0]);
reader.onload = function(e){
$("."+ele.id).attr("src",e.target.result);
$("#"+ele.id+"z").val(base64);
};
canvas = null;
- img = null;
}
} else {
var reader = new FileReader();
reader.readAsDataURL(ele.files[0]);
reader.onload = function(e){
$("."+ele.id).attr("src",e.target.result);
$("#"+ele.id+"z").val(e.target.result);
};
}
});
}
或参照 http://www.jb51.net/article/78732.htm
阅读全文
1 0
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
- 利用exif.js插件解决ios手机上传竖拍照片旋转90度问题
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
- 基于java在服务端解决手机上传竖拍照片旋转90度问题
- Android手机拍照上传旋转90度问题
- 针对iphone手机拍照片旋转90度问题解决
- 移动端上传图片 支持图片预览、压缩、大图分片压缩、压缩后上传 解决了IOS竖屏拍照旋转90度的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题 .
- 解决android有的手机拍照后上传图片被旋转的问题
- android学习笔记----解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- 解决android有的手机拍照后上传图片被旋转的问题
- Kotlin语法基础
- Linux 下编译自己的 OpenJDK7 包括JVM和JDK API
- [python][库]os库使用方法
- Tkinter之Scrollbar篇
- leetcode 144. Binary Tree Preorder Traversal 二叉树前序遍历 + DFS
- 利用exif.js解决ios手机上传竖拍照片旋转90度问题
- java虚拟机——对象创建与访问概述
- 设计模式
- 黑客与画家
- CVE-2017-0037浅析-Internet Explorer类型混淆漏洞
- jvm系列(一):java类的加载机制
- Cocos2d-lua 初识shader之二:传值
- 关于新手入坑vue,页面跳转样式错位刷新又好了的情况
- ant 部署应用到远端服务器