iOS中UIImagePickerController图片选取器的用法小结

 更新时间:2016年05月30日 09:24:40   作者:DavidHacker  
UIImagePickerController平时就是用来做应用中从相册中选取图片功能的,这里我们就来整理一下iOS中UIImagePickerController图片选取器的用法小结,需要的朋友可以参考下

UIImagePickerController用于管理可自定义的,系统支持的用于获取设备上图片和视频的用户界面。同时可以用于在App中选择存储的图片和视频。一个UIImagePickerController管理用户交互并且将这些交互结果传递给一个代理对象。该类不能被继承和修改,除了自定义cameraOverlayView外。

先简单讲解下UIImagePickerController的一些属性,再上代码。

一、常用属性

(1)sourceType 控制器展示的选择界面的类型,

包含三个枚举值

复制代码 代码如下:

enum {
   UIImagePickerControllerSourceTypePhotoLibrary,      //在图片库中选取图片或者视频
   UIImagePickerControllerSourceTypeCamera,            //用于拍摄照片或视频
   UIImagePickerControllerSourceTypeSavedPhotosAlbum   //在相册中选取图片或视频
};
typedef NSUInteger UIImagePickerControllerSourceType;

(2)mediaTypes

默认值是kUTTypeImage,意味着用户只能选择静态图片或者拍摄静态图片(相对于视频)

当mediaTypes设置为kUTTypeImage,kUTTypeMovie(设备支持的话)时,操作图片的同时,可以选择操作视频。

使用KUTTypeImage,KUTTypeMovie时,需导入#import <MobileCoreServices/MobileCoreServices.h>

(3)allowEditing

用户是否可以修改图片或视频,默认是NO

(3)cameraOverlayView

在默认图片选择界面的最前面显示。

二、基本用法

(1)使用isSourceTypeAvailable:来判断当前设备是否支持该SourceType

(2)若支持,使用availableMediaTypesForSourceType来检验当前SourceType下支持的mediaTypes

(3)若需要调整mediaTypes(默认是kUTTypeImage),调整

(4)展示界面,使用modal方式弹出。

(5)当用户操作完成(cancel或者选着了某张图片和某个视频),代理会触发方法,然后关闭界面并进行相关的处理。

三、其他两种sourceType详解

其他两种sourceType使用方式较为单一,下面详细讲解下当SourceType为UIImagePickerControllerSourceTypeCamera时的情况。

常见属性:

(1)videoQuality:用于设置视频的质量,默认值为UIImagePickerControllerQualityTypeMedium.

用于拍摄视频和选着视频,如果选择已经存在的视频,且该视频的质量高于设置的videoQuality,则视频会被转为低质量的

(如果存在的视频地狱videoQuality呢)

(2)videoMaximumDuration 最大的视频时间,默认为10分钟

(3)cameraViewTransform

‍这几个属性只在camera下可用

(4)cameraDevice

复制代码 代码如下:

enum {
   UIImagePickerControllerCameraDeviceRear,  //后置摄像头
   UIImagePickerControllerCameraDeviceFront  //前置摄像头
};
typedef NSUInteger UIImagePickerControllerCameraDevice;

(5)cameraCaptureMode

开启照相界面的时候选择的模式

复制代码 代码如下:

enum {
   UIImagePickerControllerCameraCaptureModePhoto,  //默认使用拍照模式
   UIImagePickerControllerCameraCaptureModeVideo   //默认使用摄像模式
};
typedef NSUInteger UIImagePickerControllerCameraCaptureMode;

(6)cameraFlashMode

闪光灯

复制代码 代码如下:

enum {
   UIImagePickerControllerCameraFlashModeOff  = -1,
   UIImagePickerControllerCameraFlashModeAuto = 0,
   UIImagePickerControllerCameraFlashModeOn   = 1
};

typedef NSInteger UIImagePickerControllerCameraFlashMode;


四、两个主要的委托方法实例
复制代码 代码如下:

// 用户选中图片之后的回调
- (void)imagePickerController: (UIImagePickerController *)picker didFinishPickingMediaWithInfo: (NSDictionary *)info 

    if (picker == picker_camera_)  
    { 
        //如果是 来自照相机的image,那么先保存 
        UIImage* original_image = [info objectForKey:@"UIImagePickerControllerOriginalImage"]; 
    }

// info dictionary keys
UIKIT_EXTERN NSString *const UIImagePickerControllerMediaType;      // an NSString (UTI, i.e. kUTTypeImage)
UIKIT_EXTERN NSString *const UIImagePickerControllerOriginalImage;  // a UIImage
UIKIT_EXTERN NSString *const UIImagePickerControllerEditedImage;    // a UIImage
UIKIT_EXTERN NSString *const UIImagePickerControllerCropRect;       // an NSValue (CGRect)
UIKIT_EXTERN NSString *const UIImagePickerControllerMediaURL;       // an NSURL
UIKIT_EXTERN NSString *const UIImagePickerControllerReferenceURL    NS_AVAILABLE_IOS(4_1);  // an NSURL that references an asset in the AssetsLibrary framework
UIKIT_EXTERN NSString *const UIImagePickerControllerMediaMetadata   NS_AVAILABLE_IOS(4_1);  // an NSDictionary containing metadata from a captured photo


    // 获得编辑过的图片 
    UIImage* image = [info objectForKey: @"UIImagePickerControllerEditedImage"]; 

    // 把图片转成NSData类型的数据来保存文件(存入到沙盒中) 
    NSData *imageData; 

    // 判断图片是不是png格式的文件 
    if (UIImagePNGRepresentation(image)) { 

        // 返回为png图像。 
        imageData = UIImagePNGRepresentation(image);

    }else { 

       // 返回为JPEG图像
        imageData = UIImageJPEGRepresentation(image, 1.0); 

    }

    // 路径拼接,写入-----
    NSString * imageSavePath = [[[HMTMySqliteDataHandle shareInstance]saveImagesPath] stringByAppendingPathComponent:@"自定义.自定义"];

    [imageData writeToFile:imageSavePath atomically:YES]; 

    // 关闭相册界面  
    [self dismissModalViewControllerAnimated:YES]; 
    [picker release]; 
}

// 用户选择取消 
- (void) imagePickerControllerDidCancel: (UIImagePickerController *)picker 

    // 关闭相册界面
    [self dismissModalViewControllerAnimated:YES]; 
    [picker release]; 
}  

相关文章

  • 谈谈XCode9的新变化

    谈谈XCode9的新变化

    这篇文章主要介绍了谈谈XCode9的新变化,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 谈谈iOS开发之JSON格式数据的生成与解析

    谈谈iOS开发之JSON格式数据的生成与解析

    JSON格式取代了xml给网络传输带来了很大的便利,本篇文章主要介绍了iOS开发:对象直接转化成JSON详解,具有一定的参考价值,有兴趣的可以了解一下。
    2017-01-01
  • 针对iOS10新增Api的详细研究

    针对iOS10新增Api的详细研究

    这篇文章主要针对iOS10新增Api进行详细研究,基于Api层面,着重看一些具体用法所做的笔记,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • iOS实现PDF文件浏览功能

    iOS实现PDF文件浏览功能

    这篇文章主要为大家详细介绍了iOS实现PDF文件浏览功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • iOS与Unity交互笔记之参数传递

    iOS与Unity交互笔记之参数传递

    这篇文章主要给大家介绍了关于iOS与Unity交互笔记之参数传递的相关资料,需要的朋友可以参考下
    2019-04-04
  • Objective-C方法的声明实现及调用方法

    Objective-C方法的声明实现及调用方法

    这篇文章主要介绍了Objective-C方法的声明实现及调用方法,包括五参数的方法和单个参数的方法,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧
    2024-02-02
  • iOS屏幕旋转与锁屏的示例代码

    iOS屏幕旋转与锁屏的示例代码

    这篇文章主要介绍了iOS屏幕旋转与锁屏的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • iOS中Sqlite和FMDB使用详解

    iOS中Sqlite和FMDB使用详解

    这篇文章主要为大家介绍了iOS中Sqlite和FMDB使用方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 全面解析iOS应用中自定义UITableViewCell的方法

    全面解析iOS应用中自定义UITableViewCell的方法

    这篇文章主要介绍了iOS应用开发中自定义UITableViewCell的方法,示例为传统的Obejective-C语言,需要的朋友可以参考下
    2016-04-04
  • iOS开发微信收款到账语音提醒功能思路详解

    iOS开发微信收款到账语音提醒功能思路详解

    这篇文章主要介绍了iOS开发微信收款到账语音提醒功能思路详解,需要的朋友可以参考下
    2017-09-09

最新评论