图像选择控制器:UIImagePickerController

功能:用于选取相册或相机等里面的照片。

@interface UIImagePickerController : UINavigationController

枚举:

//图片资源来源类型

typedef NS_ENUM(NSInteger, UIImagePickerControllerSourceType) {

UIImagePickerControllerSourceTypePhotoLibrary,          //图库

UIImagePickerControllerSourceTypeCamera,                 //相机

UIImagePickerControllerSourceTypeSavedPhotosAlbum   //相册

};

//摄像图像的质量

typedef NS_ENUM(NSInteger, UIImagePickerControllerQualityType) {

UIImagePickerControllerQualityTypeHigh = 0,          // 高质量

UIImagePickerControllerQualityTypeMedium = 1,      //中等质量,适合通过Wi-Fi传输

UIImagePickerControllerQualityTypeLow = 2,           // 最低的质量,适合通过蜂窝网络传输

UIImagePickerControllerQualityType640x480 = 3,             // VGA质量,640*480分辨率

UIImagePickerControllerQualityTypeIFrame1280x720 = 4,  // VGA质量1280*720分辨率

UIImagePickerControllerQualityTypeIFrame960x540 = 5    // VGA质量,960*540分辨率

};

//相机摄像模式

typedef NS_ENUM(NSInteger, UIImagePickerControllerCameraCaptureMode) {

UIImagePickerControllerCameraCaptureModePhoto,  //图片

UIImagePickerControllerCameraCaptureModeVideo   //录像

};

//摄像头位置

typedef NS_ENUM(NSInteger, UIImagePickerControllerCameraDevice) {

UIImagePickerControllerCameraDeviceRear,          //后摄像头

UIImagePickerControllerCameraDeviceFront          //前摄像头

};

//闪光灯状态模式

typedef NS_ENUM(NSInteger, UIImagePickerControllerCameraFlashMode) {

UIImagePickerControllerCameraFlashModeOff  = -1,   //关闭状态

UIImagePickerControllerCameraFlashModeAuto = 0,   //自动调节状态

UIImagePickerControllerCameraFlashModeOn   = 1    //开启状态

};

图片信息中字典的键:

UIKIT_EXTERN NSString *const UIImagePickerControllerMediaType;       //用户自定义的媒体类型

UIKIT_EXTERN NSString *const UIImagePickerControllerOriginalImage;   // 原始的图片

UIKIT_EXTERN NSString *const UIImagePickerControllerEditedImage;     // 编辑后的图片

UIKIT_EXTERN NSString *const UIImagePickerControllerCropRect;        // 裁剪尺寸

UIKIT_EXTERN NSString *const UIImagePickerControllerMediaURL;        // 媒体URL

UIKIT_EXTERN NSString *const UIImagePickerControllerReferenceURL;  // 原件URL

UIKIT_EXTERN NSString *const UIImagePickerControllerMediaMetadata  // 仅有效于拍摄图片时

属性:

//图像选取代理

@property(nonatomic,assign)  id <UINavigationControllerDelegate, UIImagePickerControllerDelegate> delegate;

//图片资源来源类型,默认来自图库

@property(nonatomic)UIImagePickerControllerSourceType     sourceType;

//媒体类型数组

@property(nonatomic,copy)NSArray  *mediaTypes;

//是否允许编辑图像,默认为NO

@property(nonatomic) BOOL   allowsEditing ;

@property(nonatomic)  BOOL    allowsImageEditing ;

//录像最大时长,默认为10分钟

@property(nonatomic)  NSTimeInterval   videoMaximumDuration;

//录像质量

@property(nonatomic)  UIImagePickerControllerQualityType  videoQuality ;

//是否显示相机控制界面,默认显示

@property(nonatomic) BOOL  showsCameraControls ;

//设置视图覆盖预览视图

@property(nonatomic,retain)    UIView    *cameraOverlayView  ;

//相机视图仿射类型

@property(nonatomic) CGAffineTransform   cameraViewTransform ;

//相机摄像模式,默认为拍摄图片

@property(nonatomic) UIImagePickerControllerCameraCaptureMode cameraCaptureMode ;

//摄像头选取,默认为后摄像头

@property(nonatomic) UIImagePickerControllerCameraDevice cameraDevice ;

//闪光灯状态模式

@property(nonatomic) UIImagePickerControllerCameraFlashMode   cameraFlashMode;

方法:

//资源来源类型是否可用

+ (BOOL)isSourceTypeAvailable:(UIImagePickerControllerSourceType)sourceType;

//返回资源来源类型中可用的媒体类型数组

+ (NSArray *)availableMediaTypesForSourceType:(UIImagePickerControllerSourceType)sourceType;

//摄像头是否可用

+ (BOOL)isCameraDeviceAvailable:(UIImagePickerControllerCameraDevice)cameraDevice                   ;

//闪光灯是否可用

+ (BOOL)isFlashAvailableForCameraDevice:(UIImagePickerControllerCameraDevice)cameraDevice ;

//返回可用的相机模式数组

+ (NSArray *)availableCaptureModesForCameraDevice (UIImagePickerControllerCameraDevice)

cameraDevice;

//照相

- (void)takePicture;

//开始录频

- (BOOL)startVideoCapture ;

//停止录频

- (void)stopVideoCapture ;

代理:

@protocol UIImagePickerControllerDelegate<NSObject>

@optional

//选取编辑过的图片

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingImage:(UIImage *)image editingInfo:(NSDictionary *)editingInfo ;

//选取原始图片

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info;

//取消选取

- (void)imagePickerControllerDidCancel:(UIImagePickerController *)picker;

@end

保存相关的函数:

// 保存图片到被保存的相册中

UIKIT_EXTERN void UIImageWriteToSavedPhotosAlbum(UIImage *image, id completionTarget, SEL completionSelector, void *contextInfo);

// - (void)image:(UIImage *)image didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo;

// 保存指定路径的录频到被保存的相册中

UIKIT_EXTERN BOOL UIVideoAtPathIsCompatibleWithSavedPhotosAlbum(NSString *videoPath) ;

// 保存录频到被保存的相册中

UIKIT_EXTERN void UISaveVideoAtPathToSavedPhotosAlbum(NSString *videoPath, id completionTarget, SEL completionSelector, void *contextInfo);

//- (void)video:(NSString *)videoPath didFinishSavingWithError:(NSError *)error contextInfo:(void *)contextInfo;

下面来举一个实例如下:从本地相册读取显示图片

1、设置故事板,往故事板的视图中拖入两个控件,一个是UIImageView,另一个是UIButton,分别命名为imageView、“相册”。

 

2、将imageView关联IBOutLet到控制器类中作为属性,给"相册"按钮关联IBAction事件,用来显示功能。还要让类实现图像选取器控制器协议和导航控制器协议

3、现在就是显示功能的实现和协议方法的实现了。

//按钮事件,打开相册(以模态窗口的形式显示相册)

- (IBAction)buttonClicked:(UIButton *)sender
{
//创建图片选取控制器
UIImagePickerController *imagePicker = [[UIImagePickerController alloc]init]; //图片资源来自相册
imagePicker.sourceType = UIImagePickerControllerSourceTypeSavedPhotosAlbum; //设置选取代理
imagePicker.delegate = self; //使用模态窗口显示相册
[self presentViewController:imagePicker animated:YES completion:nil];
} - (void)viewDidLoad {
[super viewDidLoad]; }

//实现协议方法,选取相册中的相片:

#pragma mark -<UIImagePickercontrollerDelegate>

-(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
{
//NSLog(@"%@",info);
/*info:这个字典中放着图片的具体信息,通过这个字典的键可以获取图片*/
//取出图片
self.image = [info objectForKey:UIImagePickerControllerOriginalImage];//显示图片在图像视图中
[self.imageView setImage:self.image]; //关闭模态窗口
[picker dismissViewControllerAnimated:YES completion:nil];
}

4、演示结果:

开始运行截图:                                                    显示的本地相册截图:

   

选取某一图片截图:                                              点击"相册"返回,再选取某一图片截图:

   

iOS:图像选取器控制器控件UIImagePickerController的详解的更多相关文章

  1. iOS:提示框(警告框)控件UIAlertView的详解

    提示框(警告框)控件:UIAlertView   功能:当点击按钮或标签等时,弹出一个提示框,显示必要的提示,然后通过添加的按钮完成需要的功能.   类型:typedef NS_ENUM(NSInte ...

  2. 《手把手教你》系列技巧篇(三十八)-java+ selenium自动化测试-日历时间控件-下篇(详解教程)

    1.简介 理想很丰满现实很骨感,在应用selenium实现web自动化时,经常会遇到处理日期控件点击问题,手工很简单,可以一个个点击日期控件选择需要的日期,但自动化执行过程中,完全复制手工这样的操作就 ...

  3. iOS:UIPageViewController翻页控制器控件详细介绍

    翻页控制器控件:UIPageViewController 介绍: 1.它是为我们提供了一种类似翻书效果的一种控件.我们可以通过使用UIPageViewController控件,来完成类似图书一样的翻页 ...

  4. iOS:选择器控件UIPickerView的详解和演示

    选择器控件UIPickerView: 功能:它能够创建一个类似于密码锁式的单列或多列的选择菜单,用户可以通过它设置的代理来选择需要菜单中的任意的数据.例如创建日历.字体表(类型.大小.颜色).图库等. ...

  5. iOS:提示框(警告框)控件UIActionSheet的详解

    提示框(警告框)控件2:UIActionSheet 功能:当点击按钮或标签等时,弹出一个提示框,显示必要的提示,然后通过添加的按钮完成需要的功能.它与导航栏类似,它继承自UIView.   风格类型: ...

  6. iOS:下拉刷新控件UIRefreshControl的详解

    下拉刷新控件:UIRefreshControl 1.具体类信息: @interface UIRefreshControl : UIControl //继承控制类 - (instancetype)ini ...

  7. iOS:网页视图控件UIWebView的详解

    网页视图控件:UIWebView 功能:它是继承于UIView的,是一个内置的浏览器控件,以用来浏览从网络下载下来的网页或者本地上加载下来的文档. 枚举: //网页视图导航类型 typedef NS_ ...

  8. delphi控件属性大全-详解-简介

    http://blog.csdn.net/u011096030/article/details/18716713 button 组件: CAPTION 属性 :用于在按钮上显示文本内容 Cancel ...

  9. AnyCAD三维控件场景节点详解

    SceneNode是AnyCAD三维图形平台的AnyViz显示引擎的核心对象之一,只有放在场景管理器(SceneManager)里的节点才能被显示引擎所显示. 1.   节点分类 SceneNode是 ...

随机推荐

  1. 用webpy实现12306余票查询

    效果

  2. 前端读者 | 从一行代码里面学点JavaScript

    本文来自 @张小俊128:链接:http://www.html-js.com/article/A-day-to-learn-from-a-line-of-code-inside-the-JavaScr ...

  3. jquery中的jsonp和js中的jsonp还有配合php实现的jsonp。

    最近在做一个自己的网站,才知道一个前端需要学习的东西到底有多少. 来吧~步入正题,我的网站空间很小.所以在资源上,就有点吼不住了.跨域拿数据肯定是不可避免的了. 一.原生js: 我们知道他的原理,就是 ...

  4. 如何开启apache的PHP-FPM实例

    PHP-FPM 作为 FastCGI 进程管理器而广为熟知,它是PHPFastCGI 实现的改进,带有更为有用的功能,用于处理高负载的服务器和网站.下面列出其中一些功能: 新功能 拥有具有优雅(gra ...

  5. 开源地图编辑器 MarbleMap,支持Cocos2d-x坐标系

    由9秒社团开发并维护的MarbleMap是支持Cocos2d-x坐标系和as3坐标系的地图编辑器,功能完善高效.这里详细介绍一下它的使用方法! 一.功能简述 由9秒社团开发并维护的MarbleMap是 ...

  6. Ionic-wechat项目边开发边学(三):自定义样式,指令,服务

    摘要 上一篇文章主要介绍了一个ionic项目的标准目录结构,header标签的使用,以及页面之间的切换.这篇文章实现的功能有: 消息数据的获取, 消息列表的展示, 消息标为已读/未读, 主要涉及的到的 ...

  7. Android Theme.AppCompat.Light的解决方法

    styles.xml中<style name="AppBaseTheme" parent="Theme.AppCompat.Light">提示如下错 ...

  8. Queries for Number of Palindromes (区间DP)

    Queries for Number of Palindromes time limit per test 5 seconds memory limit per test 256 megabytes ...

  9. 线程间操作无效: 从不是创建控件“textBox2”的线程访问它

    如何:对 Windows 窗体控件进行线程安全调用 线程间操作无效: 从不是创建控件的线程访问它的三种方法 如果使用多线程处理来提高 Windows 窗体应用程序的性能,则你必须确保以线程安全的方式调 ...

  10. 认识C++中的bitset类型

    认识标准库bitset类型 位是用来保存一组项或者条件的yes/no(1或者0)信息的一种简洁方法,那么位集就是二进制位的有序集.C++中标准库提供的bitset类在我们程序中就很有效的简化了对于位集 ...