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