当前位置: 移动技术网 > IT编程>移动开发>IOS > iOS中UIImagePickerController图片选取器的用法小结

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

2019年07月24日  | 移动技术网IT编程  | 我要评论

有些事是不可以开玩笑的,谭江海个人资料,点柔唇

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]; 
}  

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网