当前位置: 首页 > 编程笔记 >

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

黎震博
2023-03-14
本文向大家介绍iOS中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格式的html" target="_blank">文件      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];  }  

 类似资料:
  • 本文向大家介绍iOS提取APP中的图片资源的方法,包括了iOS提取APP中的图片资源的方法的使用技巧和注意事项,需要的朋友参考一下 最近在学习swift的过程中,准备通过模仿一个app来实战一下,于是我去下载了一个斗鱼直播,不是打广告.....因为模仿嘛,所以就需要获取其中的图片资源,本以为能很顺利的得到,没想到还是遇到了一个小麻烦,兴庆的是还是找到很好的办法来解决,下面就来记录下获取app中图片

  • 问题内容: 我正在尝试为用户提供照片库中图像的选择。因此,我用于选择。但是在文件系统中获取其初始URL会带来一个问题(我需要)。 我的代码。 imageURL 有点神秘。它描述了资产URL,但没有描述文件系统中的一个。它看起来像:。 根据该逻辑 路径 是其中是所述图像的名称。 然后,我访问我的Documents文件夹并尝试在其中找到带有路径的文件: /Users/Eugene/Library/De

  • 从相机camera或相册获取照片,并保存在沙盒中,显示在应用程序内,并可实现点击图片放大预览,缩小功能,带动画效果。 [Code4App.com]

  • 本文向大家介绍iOS中的UIKeyboard键盘视图使用方法小结,包括了iOS中的UIKeyboard键盘视图使用方法小结的使用技巧和注意事项,需要的朋友参考一下 一、键盘风格   UIKit框架支持8种风格键盘。 用法用例: 二、键盘外观 用法用例: 三、回车键 用法用例: 四、自动大写 用法用例: 五、自动更正 用法用例: 六、安全文本输入 开启安全输入主要是用于密码或一些私人数据的输入,此时

  • 这是一个图片选择器的演示,你可以在这里下载这个例子。 简介 这个 App 主要有这样几个交互: 当用户点击相机按钮时,让用户拍一张照片,然后显示出来。 当用户点击相册按钮时,让用户从相册中选出照片,然后显示出来。 当用户点击裁剪按钮时,让用户从相册中选出照片编辑,然后显示出来。 整体结构 ... override func viewDidLoad() { super.viewDidLoad

  • 本文向大家介绍iOS将相册中图片上传至服务器的方法,包括了iOS将相册中图片上传至服务器的方法的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了iOS图片上传至服务器的具体代码,供大家参考,具体内容如下 在使用app时,从相册中选取图片作为头像是很常用的操作,首先打开相册选择图片,然后将图片保存至本应用的document,最后将document中图片的路径保存至NSUserDefaults