iOS 手机照片上传服务器方向不对的原因以及解决方法
来源:互联网 发布:淘宝 门禁ic卡 编辑:程序博客网 时间:2024/05/17 20:35
苹果手机上传图片到服务器,发现图片方向不对,实践发现:
1:原因: 相机拍照后直接取出来的UIimage(用UIImagePickerControllerOriginalImage取出),它本身的imageOrientation属性是3,即UIImageOrientationRight。如果这个图片直接使用则没事,但是如果对它进行裁剪、缩放等操作后,它的这个imageOrientation属性会变成0。此时这张图片用在别的地方就会发生旋转。(手机竖着拍则为UIImageOrientationRight,手机横着拍为UIImageOrientationUp)
2: imageOrientation是只读的,不能直接修改其值。
解决方法:
1. 设置相机的一个属性allowsEditing为YES,设了这个值,你拍完照片后会在照片上出现一个框框,这就是对照片的裁剪编辑。在相机的代理方法中取照片的时候就别用UIImagePickerControllerOriginalImage来取了,要用UIImagePickerControllerEditedImage。用这个key取出来的照片,它的imageOrientation是0,所以之后的任何裁剪、缩放操作都不会造成旋转。
2.由于开发中经常要对原图进行裁剪和压缩,所以第一种方法就不可取了,于是用第二种方法
//调整图片方向
+ (UIImage *)fixOrientation:(UIImage *)srcImg {
if (srcImg.imageOrientation ==UIImageOrientationUp)return srcImg;
CGAffineTransform transform =CGAffineTransformIdentity;
switch (srcImg.imageOrientation) {
caseUIImageOrientationDown:
caseUIImageOrientationDownMirrored:
transform = CGAffineTransformTranslate(transform, srcImg.size.width, srcImg.size.height);
transform = CGAffineTransformRotate(transform,M_PI);
break;
caseUIImageOrientationLeft:
caseUIImageOrientationLeftMirrored:
transform = CGAffineTransformTranslate(transform, srcImg.size.width,0);
transform = CGAffineTransformRotate(transform,M_PI_2);
break;
caseUIImageOrientationRight:
caseUIImageOrientationRightMirrored:
transform = CGAffineTransformTranslate(transform,0, srcImg.size.height);
transform = CGAffineTransformRotate(transform, -M_PI_2);
break;
caseUIImageOrientationUp:
caseUIImageOrientationUpMirrored:
break;
}
switch (srcImg.imageOrientation) {
caseUIImageOrientationUpMirrored:
caseUIImageOrientationDownMirrored:
transform = CGAffineTransformTranslate(transform, srcImg.size.width,0);
transform = CGAffineTransformScale(transform, -1,1);
break;
caseUIImageOrientationLeftMirrored:
caseUIImageOrientationRightMirrored:
transform = CGAffineTransformTranslate(transform, srcImg.size.height,0);
transform = CGAffineTransformScale(transform, -1,1);
break;
caseUIImageOrientationUp:
caseUIImageOrientationDown:
caseUIImageOrientationLeft:
caseUIImageOrientationRight:
break;
}
CGContextRef ctx =CGBitmapContextCreate(NULL, srcImg.size.width, srcImg.size.height,
CGImageGetBitsPerComponent(srcImg.CGImage),0,
CGImageGetColorSpace(srcImg.CGImage),
CGImageGetBitmapInfo(srcImg.CGImage));
CGContextConcatCTM(ctx, transform);
switch (srcImg.imageOrientation) {
caseUIImageOrientationLeft:
caseUIImageOrientationLeftMirrored:
caseUIImageOrientationRight:
caseUIImageOrientationRightMirrored:
CGContextDrawImage(ctx,CGRectMake(0,0,srcImg.size.height,srcImg.size.width), srcImg.CGImage);
break;
default:
CGContextDrawImage(ctx,CGRectMake(0,0,srcImg.size.width,srcImg.size.height), srcImg.CGImage);
break;
}
CGImageRef cgimg =CGBitmapContextCreateImage(ctx);
UIImage *img = [UIImageimageWithCGImage:cgimg];
CGContextRelease(ctx);
CGImageRelease(cgimg);
return img;
}
- iOS 手机照片上传服务器方向不对的原因以及解决方法
- java解决手机等移动设备中照片上传至服务器方向不正确的问题
- iOS上传图片方向不对处理
- 手机拍照,浏览手机的文件夹,上传照片到服务器
- iOS 上传照片到服务器 获取相册和拍照功能的照片 照片压缩上传
- iOS中照片的方向
- iOS处理照片的方向
- iOS上传照片旋转90度解决方法
- H5调用手机的摄像头拍照上传以及手机相册选取照片
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 如何处理iOS中照片的方向
- 总结-HttpClient-RetryHandler重试
- PHP的几种排序算法的比较
- 启动浏览器步骤及其驱动
- 【hdu 1874】畅通工程续(注意重复路径的问题)
- 我的第一个Kotlin代码
- iOS 手机照片上传服务器方向不对的原因以及解决方法
- 嵌入式从业者应注意的问题
- CNN简介
- node.js 安装手册
- Linux防火墙iptables的策略
- Charles限流
- Spring AOP中的动态代理机制
- 同步监视器之同步代码块、同步方法
- 使用eclipse创建一个maven+springMVC工程