前言:
  前几天, 写了一篇关于IOS手机上传照片颠倒的技术分析文章: IOS照片颠倒分析及PHP服务端的处理.   

  不过其思路是从服务器来进行处理的, 这种做法相当普遍.
  今天来讲述下, 如何从移动端/页面端, 来解决这个问题, 侧重于讲讲思路.
  

意义:
  但移动互联网有它独特的背景, 至今降耗电和省流量, 是很多移动端产品孜孜努力的方向.
  再者移动端手机的照片大小, 普遍较大, 因此直接往服务器传, 往往会消耗很多流量, 在弱网环境下, 用户等待的时间也长, 时常会失败, 体验非常不好. 因此移动端/页面端(webapp)进行图片的压缩/缩放, 就非常有意义了.
  同时, 既然已经做了图片的压缩和大小缩放, 何不一起把图片的旋转也一起搞定.

可行性分析:
  由于IOS照片图片颠倒, 是以为IOS的不作为, 不过其写入了Orientation信息到EXIF信息头中(jpeg和tiff文件).
  想要解决颠倒问题, 先要看, 能否在移动/页面端, 获取到EXIF信息.
  幸好, 我们拥有exif.js, 这个开源的js工具库, 帮我们铺好了路.
  这是资料链接: Exif.js 读取图像的元数据 http://code.ciaoca.com/javascript/exif-js/ .
  其对图片EXIF信息头的处理, 非常的简洁:
  *) html的相关代码:

<input type="file" accept="image/*" capture="camera" onchange="selectFileImage(this);">

  *) exif的使用代码片段:

function selectFileImage(file) {
  var Orientation = null;
  //获取照片方向角属性,用户旋转控制
  EXIF.getData(file, function() {
    EXIF.getAllTags(this);
    Orientation = EXIF.getTag(this, 'Orientation');
  });
}

  这边变量file为, input控件选择具体图片文件后得到的对象, Orientation即是旋转信息.
  Orientation的取值和含义:

旋转角度
参数
1
顺时针90°
6
逆时针90°
8
180°
3

颠倒和缩放:
  在页面端, 需要处理是的限制大小尺寸, 比如设置一个最大宽度值(限宽不限高), 同时又要解决图片旋转问题.
  其思路是借助canvas重绘来实现, 1). 先确定旋转方向, 2). 图片尺寸缩小调整 3). 确定canvas大小, 4). 绘制过程.

image = new Image();
image.onload = function() {
  var canvas = document.getElementById("myCanvas");
  var expectWidth, expectHeight;
  // *) 确定目标的宽和高
  if ( Orientation == 6 || Orientation == 8 ) {
    expectWidth = image.height;
    expectHeight = image.width;
  } else {
    expectWidth = image.width;
    expectHeight = image.height;
  }   // *) 最大宽度限制及缩小变化
  var MAX_WIDTH = 480;
  if ( expectWidth > MAX_WIDTH ) {
    expectHeight = expectHeight * MAX_WIDTH / expectWidth;
    expectWidth = MAX_WIDTH;
  }   if ( Orientation == 6 ) {
    // 顺时针90°
    ctx.save();
    ctx.translate(expectWidth/2, expectHeight/2);
    ctx.rotate(90 * Math.PI / 180.0);
    ctx.drawImage(image, -expectHeight/2, -expectWidth/2, expectHeight, expectWidth);
  } else if ( Orientation == 8 ) {
    // 逆时针90°
    ctx.save();
    ctx.translate(expectWidth/2, expectHeight/2);
    ctx.rotate(270 * Math.PI / 180.0);
    ctx.drawImage(image, -expectHeight/2, -expectWidth/2, expectHeight, expectWidth);
    ctx.restore();
  } else if ( Orientation == 3 ) {
    // 180°
    ctx.save();
    ctx.translate(expectWidth/2, expectHeight/2);
    ctx.rotate(Math.PI);
    ctx.drawImage(image, -expectWidth/2, -expectHeight/2, expectWidth, expectHeight);
    ctx.restore();
  } else {
    ctx.drawImage(image, 0, 0, expectWidth, expectHeight);
  }   // *) 获取旋转和压缩后的图片数据.
  var imagedata = canvas.toDataURL("image/png"); }

  整个流程相对, 还是比较简单的.

  这边讲讲canvas的drawImage, 如何去绘制旋转图片的思路的.
  1). 先把原点移至canvas的中点, translate
  2). 进行旋转操作, rorate
  3). 进行绘制, 此时canvas的绘制区域坐标范围为(-w/2, -h/2, w/2, h/2), 需要注意下.

图片上传:
  图片压缩和旋转后, 图片的数据上传, 又是怎么实现的呢?
  一种思路, 就是上文提到的:

var imageData = canvas.toDataURL("image/png");

  其本质的工作, 就是把图片的二进制数据, 转换为了base64编码后的数据, 这样就可以通过普通的Ajax来上传了, 也就实现了文件的异步上传工作.

php和nginx文章的相关列表:
  • nginx服务配置---php服务接入 
  • nginx+tomcat集群配置(1)---根目录设定和多后端分发配置 
  • nginx+tomcat集群配置(2)---静态和动态资源的分离
  • nginx+tomcat集群配置(3)---获取真实客户端IP
  • nginx+tomcat集群配置(4)--rewrite规则和多应用根目录设定思路

后记:
  应该说有幸吧, 通过这个简单的例子, 追踪定位, 到最后的问题解决, 其实学到了很多. 以前确实犹如井底之蛙, 以为很多问题, 只是一时疏忽而已, 在小的问题, 在背后也有大学问, 感谢每一天, 无论晴雨, 都是美好的一天.

个人站点&公众号:

    个人微信公众号: 小木的智慧屋

    个人游戏作品集站点(尚在建设中...): www.mmxfgame.com

IOS照片颠倒分析及移动/页面端的处理策略和思路的更多相关文章

  1. IOS照片颠倒分析及PHP服务端的处理

    前言: 因朋友的PHP小项目, 而去帮忙解决了一个小问题, 现在来总结概括一下. 也不知道大家在使用和开发的过程中有没有遇到类似的场景, IPhone手机上传照片后, 发现图片方向颠倒了, 甚至各种姿 ...

  2. iOS app内存分析套路

    iOS app内存分析套路 Xcode下查看app内存使用情况有2中方法: Navigator导航栏中的Debug navigator中的Memory Instruments 一.Debug navi ...

  3. 基于APNs最新HTTP/2接口实现iOS的高性能消息推送(服务端篇)

    1.前言 本文要分享的消息推送指的是当iOS端APP被关闭或者处于后台时,还能收到消息/信息/指令的能力. 这种在APP处于后台或关闭情况下的消息推送能力,通常在以下场景下非常有用: 1)IM即时通讯 ...

  4. 解决ios下的微信打开的页面背景音乐无法自动播放

    后面的项目发现,还有两个坑,需要注意下: ·本文的解决方案的核心是利用了 微信/易信 在ready的时候会有个 WeixinJSBridgeReady/YixinJSBridgeReady事件,通过监 ...

  5. iOS crash日志分析

    iOS crash日志分析 一. 寻找crash文件:手机崩溃后的ips或者crash文件(ips文件可以直接修改成crash文件,直接改后缀名就可以了),这里说下如何拿到crash文件 1. 把运行 ...

  6. iOS的内存分析和内存管理

    iOS的内存分析和内存管理 [内存管理]一直是iOS开发中的一个重点. 本文就带你从内存分析开始一步步了解内存的占用情况,从真实的情况中领悟真正项目开发过程中的内存的使用情况. 注:本文默认你熟悉 M ...

  7. iOS 崩溃日志分析(个人总结,最实用)

    iOS 崩溃日志分析(个人总结,最实用) 要分析奔溃日志需要三个文件:crash日志,symbolicatecrash分析工具,.dSYM符号集 0. 在桌面创建一个crash文件夹 1. 需要Xco ...

  8. 转: HTTP Live Streaming直播(iOS直播)技术分析与实现

    http://www.cnblogs.com/haibindev/archive/2013/01/30/2880764.html HTTP Live Streaming直播(iOS直播)技术分析与实现 ...

  9. amazeui页面分析之登录页面

    amazeui页面分析之登录页面 一.总结 1.tpl命名空间:tpl命名空间的样式都是从app.css里面来的,app.css用用来移动网站开发的样式 2.表单样式:am-form到am-form- ...

随机推荐

  1. C盘更改文件夹权限

    现象:点“安全”添加用户并允许所有权限后,点击“应用”,弹出“无法保存对xxxxx权限所在的更改.拒绝访问”对话框 解决方法:点击“安全”-->"高级"-->“所有者” ...

  2. Windows Server 2012 中80端口被PID为4的系统进程占用解决方法

    HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\HTTP 把"start" 的值改成4.

  3. Android studio 提示:Can't use Subversion command line client: svn Probably the path to Subversion executable is wrong. Fix it.

    1.参考来源:http://my.oschina.net/fyyy/blog/519353 按照下图,svn相关选项不要选.

  4. Android中的颜色设置

    1.在android中经常看到设置的颜色为八位的十六进制的颜色值,例如 public static final class color { public static final int lightb ...

  5. BroadCast Receiver的使用

    定义 广播接收器分为标准广播和有序广播,标准广播是异步执行的广播,有序广播是同步执行的,同一时刻只有一个广播接收器会收到广播,执行结束后,广播才会继续传递. 静态注册 在Androidmanifest ...

  6. nginx rewrite

    # nginx rewrite rule #Main menu rules.rewrite ^(.*?)/index.html$ $1/index.php?r=site/index break;rew ...

  7. HTML5和CSS3的一些新特性

    html5有哪些新特性.移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5? 新特性: 1. 拖拽释放(Drag and drop) 2. 语义化更好的内容标 ...

  8. Git忽略规则及.gitignore规则不生效的解决办法

    在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件).这个文件每一行保存了一个匹配的规则例如: # 此为注 ...

  9. HyperV采用硬盘拷贝的方式迁移虚拟机后的问题处理

    公司有一台RSA认证服务器,是在windows 2008 R2下的虚拟机,最近总是出现服务中断的情况,考虑到宿主机性能较差,于是想迁移到新的服务器中. 本想通过SCVMM来迁移,但因功能不可用,所以采 ...

  10. Android开源框架:Universal-Image-Loader解析(四)TaskProcess

    Universal-Image-Loader中,对Task的处理有两种方法:FIFO,LIFO 在core/assist下的deque包中,其主要是定义了LIFOLinkedBlockingDeque ...