国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS中UIImagePickerController圖片選取器的用法小結

2019-10-21 18:54:06
字體:
來源:轉載
供稿:網友
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];  
}   



注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 稻城县| 揭阳市| 建宁县| 利辛县| 南江县| 高密市| 杭锦后旗| 湖南省| 双桥区| 通道| 曲松县| 丹寨县| 揭阳市| 青阳县| 南涧| 乌兰察布市| 宜宾市| 锡林郭勒盟| 石泉县| 宁晋县| 五家渠市| 尖扎县| 仙桃市| 年辖:市辖区| 崇明县| 多伦县| 天柱县| 呼图壁县| 南城县| 黑河市| 翼城县| 原阳县| 北碚区| 富锦市| 新津县| 新巴尔虎右旗| 仁化县| 濮阳市| 民丰县| 黎城县| 民权县|