AVCapturePhotoOutput 是一个静态照片,动态照片和其他摄影工作流程的拍摄输出。它为静态拍摄流程提供了最新接口;除了静态照片的基本拍摄之外,它还支持RAW格式拍摄,多个图像的包围拍摄,动态照片和宽色域颜色。可以输出各种格式和编解码器的拍摄照片,包括RAW格式DNG文件,HEVC格式HEIF文件和JPEG文件。
要使用AVCapturePhotoOutput
拍摄照片,需按步骤操作:
- 1、创建
AVCapturePhotoOutput
对象,使用其属性确定支持的拍摄设置并启用某些功能:例如,是否拍摄动态照片。 - 2、创建和配置
AVCapturePhotoSettings
对象以选择特定拍摄的功能和设置:例如,是否启用图像稳定或闪光灯。 - 3、通过将
AVCapturePhotoSettings
对象传递给-capturePhotoWithSettings:delegate:
方法以及实现AVCapturePhotoCaptureDelegate
协议的委托对象来拍照。然后,AVCapturePhotoOutput
在拍摄过程中会调用协议方法。
某些照片拍摄设置(如flashMode
属性)包含自动行为选项。对于此类设置,AVCapturePhotoOutput
确定是否在拍摄时使用该功能:在请求拍摄时不知道拍摄完成时是否启用该功能。当AVCapturePhotoOutput
使用有关已完成或正在进行的拍摄的信息调用AVCapturePhotoCaptureDelegate
方法时,它还提供AVCaptureResolvedPhotoSettings
对象,该对象详细说明已为该次拍摄设置了哪些自动功能。AVCaptureResolvedPhotoSettings
的uniqueID
与用于请求拍摄的AVCapturePhotoSettings
对象的uniqueID
值相匹配。
启用某些照片功能(拍摄动态照片和高分辨率照片)需要重新配置拍摄渲染管道。要选择这些功能,需要在调用AVCaptureSession
对象的-startRunning
方法之前设置highResolutionCaptureEnabled
,livePhotoCaptureEnabled
和livePhotoAutoTrimmingEnabled
属性。在AVCaptureSession
运行时更改这些属性会中断拍摄渲染管道:动态照片拍摄立即结束,未实现的照片请求中止,视频预览暂时冻结。
使用AVCapturePhotoOutput
会为AVCaptureSession
对象添加其他要求:
-
AVCaptureSession
不支持同时进行动态照片拍摄和电影文件输出。如果AVCaptureSession
包含AVCaptureMovieFileOutput
对象,则livePhotoCaptureSupported
属性将变为NO。作为替代方案,可以使用AVCaptureVideoDataOutput
类与动态照片拍摄相同的分辨率输出视频数据。 -
AVCaptureSession
不能同时包含AVCapturePhotoOutput
对象和AVCaptureStillImageOutput
对象。
AVCapturePhotoOutput
隐式支持宽色域彩色拍摄。如果AVCaptureDevice
对象的activeColorSpace
值为AVCaptureColorSpace_P3_D65
,则AVCapturePhotoOutput
将生成具有宽颜色信息的照片,除非AVCapturePhotoSettings
对象指定不支持宽颜色的输出格式。
1、创建AVCapturePhotoOutput
//初始化新的照片捕获输出对象
- (instancetype)init;
//创建一个新的照片捕获输出对象
+ (instancetype)new;
2、拍照
- (void)capturePhotoWithSettings:(AVCapturePhotoSettings *)settings
delegate:(id<AVCapturePhotoCaptureDelegate>)delegate;
使用指定的设置拍照:
- 参数
settings
:拍照设置,例如输出像素格式和闪光灯模式。此方法复制提供的AVCapturePhotoSettings
对象,因此将来对该对象的更改不会影响正在进行的拍摄。重复使用AVCapturePhotoSettings
实例进行多次拍摄是非法的。如果它的uniqueID
值与任何以前使用的设置对象的值匹配,则调用此方法会引发异常NSInvalidArgumentException
。 - 参数
delegate
: 委托对象,用于接收有关拍摄进度和结果的消息。随着照片从拍摄到处理再到完成图像的传递,AVCapturePhotoOutput
会调用委托方法。
此方法用于静态摄影的所有变体,包括单张拍摄,RAW格式拍摄、JPEG格式拍摄,多个图像的包围拍摄和动态照片拍摄。
调用此方法时,AVCapturePhotoOutput
将验证设置对象的属性以确保确定行为。例如,flashMode
设置必须指定AVCapturePhotoOutput
的supportedFlashModes
数组中存在的值。详情可查看AVCapturePhotoSettings
3、选择数据和文件格式
3.1、获取支持的文件类型
发送拍照请求时,可以单独指定拍照或编码图像数据的格式以及用于生成包含该数据的输出文件的容器格式。但是,每种文件类型仅支持一组特定的图像数据类型。
属性(NSArray<AVFileType> ) |
描述 |
---|---|
availablePhotoFileTypes |
AVCapturePhotoOutput 拍照时支持的文件类型列表。选择文件类型后,调用-supportedPhotoCodecTypesForFileType: 方法用于以压缩格式如HEVC和JPEG拍摄 或调用-supportedPhotoPixelFormatTypesForFileType: 方法用于以非压缩格式如TIFF拍摄,在创建AVCapturePhotoSettings 之前选择适当的数据格式。 |
availableRawPhotoFileTypes |
拍摄RAW照片时支持的文件类型列表。选择文件类型后,调用-supportedRawPhotoPixelFormatTypesForFileType: 方法在创建AVCapturePhotoSettings 之前选择适当的数据格式。 |
3.2、获取支持的像素格式类型
仅在将
AVCapturePhotoOutput
添加到包含视频源的AVCaptureSession
对象后才能读取此属性。如果AVCapturePhotoOutput
未连接到具有视频源的会话,则格式类型列表为nil。
只读属性 | 数据类型 | 描述 |
---|---|---|
availablePhotoPixelFormatTypes |
NSArray<NSNumber *> |
AVCapturePhotoOutput 拍照时支持的像素格式列表。要拍摄未压缩格式照片,例如420f,420v或BGRA,使用+ photoSettingsWithFormat: 创建AVCapturePhotoSettings 。在该初始化程序的格式字典中,传递密钥kCVPixelBufferPixelFormatTypeKey ,其值必须是此数组中列出的像素格式标识符之一。 |
availablePhotoCodecTypes |
NSArray<AVVideoCodecType *> |
拍照时支持的压缩编解码器列表。要拍摄压缩格式如JPEG照片,使用+ photoSettingsWithFormat: 创建AVCapturePhotoSettings 。在该初始化程序的格式字典中,传递密钥AVVideoCodecKey ,其值必须是此数组中列出的编解码器标识符之一。 |
availableRawPhotoPixelFormatTypes |
NSArray<NSNumber *> |
拍摄RAW照片时支持的像素格式列表。非所有设备都支持拍摄RAW图像,如果当前设备不支持拍摄RAW格式,则此列表为nil。要拍摄RAW格式照片,使用+photoSettingsWithRawPixelFormatType: 或+photoSettingsWithRawPixelFormatType:processedFormat: 来创建AVCapturePhotoSettings 。该初始化程序的rawPixelFormatType 参数的值必须是此数组中列出的Bayer RAW格式标识符之一。 |
3.3、指定文件类型后获取支持的像素格式类型
发送拍照请求时,可以单独指定拍照或编码图像数据的格式以及用于生成包含该数据的输出文件的容器格式。但是,每种文件类型仅支持一组特定的图像数据类型。
3.3.1、指定文件类型后获取支持的未压缩像素格式列表
- (NSArray<NSNumber *> *)supportedPhotoPixelFormatTypesForFileType:(AVFileType)fileType;
从availablePhotoFileTypes
数组中选择文件类型后,需要在创建AVCapturePhotoSettings
之前使用此方法查找兼容的图像数据格式。
- 参数
fileType
:要获取格式信息的文件类型。 - 返回值:支持在指定文件类型中进行编码的像素格式类型数组。
3.3.2、指定文件类型后获取支持的照片编解码器列表
- (NSArray<AVVideoCodecType> *)supportedPhotoCodecTypesForFileType:(AVFileType)fileType;
从availablePhotoFileTypes
数组中选择文件类型后,需要在创建AVCapturePhotoSettings
之前使用此方法查找兼容的图像数据编解码器。
- 参数
fileType
:要获取编解码器信息的文件类型,例如JFIF或HEIF。 - 返回值:支持在指定文件类型中进行编码的视频编解码器类型数组,如JPEG或HEVC。
3.3.3、指定文件类型后获取支持的的Bayer RAW像素格式列表
- (NSArray<NSNumber *> *)supportedRawPhotoPixelFormatTypesForFileType:(AVFileType)fileType;
从availableRawPhotoFileTypes
数组中选择文件类型后,需要在创建AVCapturePhotoSettings
之前使用此方法查找兼容的图像数据格式。
- 参数
fileType
:要获取格式信息的文件类型。 - 返回值:支持在指定文件类型中进行编码的像素格式类型数组。
4、确定可用设置
如果当前AVCaptureSession
的sessionPreset
属性或AVCaptureDevice
的activeFormat
属性发生更改,则以下属性的值可能会更改。
只读属性 | 数据类型 | 描述 |
---|---|---|
stillImageStabilizationSupported |
BOOL |
当前拍摄静态图像是否支持自动稳定。要使用图像稳定功能拍照,需要设置AVCapturePhotoSettings 的autoStillImageStabilizationEnabled 属性。自动稳定始终包括数字图像稳定,并且还可以包括基于当前设备的光学镜头稳定。如果设备不支持静态图像稳定,则设置autoStillImageStabilizationEnabled 属性无效,即AVCaptureResolvedPhotoSettings 的stillImageStabilizationEnabled 将始终为NO。 |
dualCameraFusionSupported |
BOOL |
当前拍摄是否支持在双摄像头设备上自动组合图像数据;在配备双摄像头的设备上,将两个摄像头的图像融合在一起,以产生更高质量的图像。要使用图像融合拍摄照片,需要设置AVCapturePhotoSettings 的autoDualCameraFusionEnabled 属性。如果设备不支持图像融合,则设置autoDualCameraFusionEnabled 属性不起作用,即AVCaptureResolvedPhotoSettings 的dualCameraFusionEnabled 将始终为NO。 |
maxBracketedCapturePhotoCount |
NSUInteger |
拍摄照片可以在单个包围捕获中支持的最大图像数;并非所有设备和拍摄格式都支持包围拍摄。如果当前设备或活动格式不支持括号拍摄,则此属性的值为零。要使用不同的拍摄设置对多个图像进行括号拍摄,需要创建一个AVCapturePhotoBracketSettings 实例,其中包含所需的设置和括号变体的组合。每次拍摄的最大照片数取决于要拍摄的图像的大小和格式。 |
lensStabilizationDuringBracketedCaptureSupported |
BOOL |
当前在括号内拍照期间是否支持镜头稳定。要在括号内拍摄的整个持续时间内使用光学图像稳定,需要设置AVCapturePhotoBracketSettings 的lensStabilizationEnabled 属性。 |
supportedFlashModes |
NSArray<NSNumber *> |
当前支持的闪光灯设置。要设置闪光灯模式,需要将AVCapturePhotoSettings 的flashMode 属性设置为此列表值之一。 |
5、监视可见场景
5.1、建议是否使用闪光灯
建议相机当前正在预览的场景是否使用闪光灯,该值会根据镜头可见的场景而变化:例如,iPhone自带相机中的闪光控件,向用户指示场景足够暗,可能需要启用闪光灯。
@property(nonatomic, readonly) BOOL isFlashScene;
如果AVCapturePhotoOutput
的supportedFlashModes
值为AVCaptureFlashModeOff
,则此属性的值始终为NO。
5.2、建议是否使用图像稳定
建议相机预览的场景是否使用图像稳定,该值会根据镜头可见的场景而变化:例如,iPhone自带相机中与图像稳定相关的控件,向用户指示场景足够暗,可能需要启用图像稳定功能。
@property(nonatomic, readonly) BOOL isStillImageStabilizationScene;
如果AVCapturePhotoOutput
的stillImageStabilizationSupported
值为NO,则此属性的值始终为NO。
5.3、设置对象
用于控制照片输出检测,处理自动闪光模式和稳定模式的照片设置对象。
@property(nonatomic, copy) AVCapturePhotoSettings *photoSettingsForSceneMonitoring;
设置此对象的flashMode
和autoStillImageStabilizationEnabled
属性会影响AVCapturePhotoOutput
的场景监视属性isFlashScene
和isStillImageStabilizationScene
的值。例如,如果将此对象的flashMode
属性设置为AVCaptureFlashModeOff
,则无论可见场景中的光照条件如何,照片输出的isFlashScene
属性都会为NO。如果将此照片设置对象的flashMode
属性设置为AVCaptureFlashModeAuto
或AVCaptureFlashModeOn
,则AVCapturePhotoOutput
的isFlashScene
属性将恢复为基于可见光级别返回YES或NO的默认行为。
注意:在亮度范围有一些重叠,这得益于静态图像稳定和闪光。如果此对象指示应监视静止图像稳定和闪光的场景,则静止图像稳定优先,并且
isFlashScene
属性在较低的整体亮度下变为YES。
默认值为AVCapturePhotoSettings
对象,具有以下设置:
-
flashMode
:取值AVCaptureFlashModeAuto
-
autoStillImageStabilizationEnabled
:取值YES
AVCapturePhotoOutput
会忽略此对象的所有其他属性。要在请求拍摄时控制其他照片设置,需要创建AVCapturePhotoSettings
以传递给-capturePhotoWithSettings:delegate:
方法。
6、配置高分辨率静态拍摄
一个布尔值,指定是否为拍摄高分辨率静态图像配置捕获管道。
@property(nonatomic, getter=isHighResolutionCaptureEnabled) BOOL highResolutionCaptureEnabled;
某些拍摄格式支持静态图像的输出,其分辨率高于用于实时预览和视频捕获的分辨率。在某些情况下,AVCaptureSession
需要以不同方式设置其内部渲染管道,以支持高分辨率静态图像捕获。
如果打算采用高分辨率静止图像,需要在调用AVCaptureSession
的 -startRunning
方法之前设置此属性。在AVCaptureSession
运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片拍摄将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。
在请求拍照之前,必须启用此选项,并将AVCapturePhotoSettings
的highResolutionPhotoEnabled
属性设置为YES。但是,启用此选项后,可以使用任何highResolutionPhotoEnabled
设置自由发出拍照请求。
7、拍摄动态照片配置
动态照片可以拍摄静止图像和以拍摄时刻为中心的短片,并在用户界面(如照片应用程序)中一起呈现。
7.1、是否支持 live Photo
//当前是否支持动态照片拍摄。
@property(nonatomic, readonly, getter=isLivePhotoCaptureSupported)
BOOL livePhotoCaptureSupported;
并非所有设备和捕获格式都支持动态照片拍摄。如果当前AVCaptureSession
的sessionPreset
属性或AVCaptureDevice
的activeFormat
属性发生更改,则此属性的值可能会更改。如果相机或格式更改导致此属性的值变为NO,则livePhotoCaptureEnabled
属性的值也将变为NO。
7.2、是否拍摄 live Photo
是否拍摄动态照片;在AVCapturePhotoSettings
的livePhotoMovieFileURL
属性为非nil、启动照片拍摄之前,必须启用此选项。启用此选项后,可以随时发起动态照片和静态照片的拍摄请求。
@property(nonatomic, getter=isLivePhotoCaptureEnabled)
BOOL livePhotoCaptureEnabled;
拍摄动态照片要求AVCaptureSession
以不同方式设置其内部渲染管道。如果打算完全拍摄动态照片,在调用AVCaptureSession
的 -startRunning
方法之前将此属性设置为YES。在AVCaptureSession
运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片捕获将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。
7.3、是否暂停 live Photo
//是否暂停但不禁用动态照片拍摄
@property(nonatomic, getter=isLivePhotoCaptureSuspended)
BOOL livePhotoCaptureSuspended;
使用此属性可以缩短当前正在进行的动态照片动画捕捉:例如,如果突然需要执行一些不希望在动态照片电影中显示的内容,例如拍摄快照的静态照片声音。
默认情况下,此属性的值为NO。当将值更改为YES时,正在进行的任何动态照片拍摄将被剪裁到当前时间。同样,当此属性的值从YES更改为NO时,后续的动态照片拍摄将不会包含任何比取消暂停的动态照片拍摄更早的示例。
如果livePhotoCaptureEnabled
属性的值为NO,则将此属性设置为YES会引发异常NSInvalidArgumentException
。
7.4、是否自动修剪 live Photo
是否自动修剪动态照片拍摄以避免过度移动;当livePhotoCaptureSupported
为YES时,此属性的值也默认为YES。
@property(nonatomic, getter=isLivePhotoAutoTrimmingEnabled)
BOOL livePhotoAutoTrimmingEnabled;
使用此选项可启用“相机”应用中的相同自动修剪行为。默认情况下,动态照片拍摄持续时间约为三秒:以拍摄请求的时间为中心。 但是,如果用户在拍摄期间升高或降低相机,iOS会实时分析电影捕捉并自动修剪实时照片的持续时间,以避免捕获过多的移动。
启用或禁用此功能要求AVCaptureSession
以不同方式设置其内部呈现管道。为获得最佳结果,在调用AVCaptureSession
的 -startRunning
方法之前更改此属性的值。会话运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片捕获将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。
7.5、 live Photo 的视频编解码器列表
当前可用于拍摄动态照片的视频编解码器列表。
@property(nonatomic, readonly) NSArray<AVVideoCodecType> *availableLivePhotoVideoCodecTypes;
默认情况下,动态照片拍摄使用H.264编解码器对动态照片的电影部分进行编码。要使用其他编解码器,将AVCapturePhotoSettings
的livePhotoVideoCodecType
属性设置为此数组中的某个值。
对数组进行排序,以便首先列出系统的默认(首选)视频编解码器。如果尚未将AVCapturePhotoOutput
添加到带有视频源的AVCaptureSession
,则无法使用任何编解码器。
8、配置深度数据捕获
深度数据捕获与照片图像一起传送的场景深度信息的每像素图,并且可选地嵌入图像文件输出中。深度数据可用于诸如应用深度敏感的照片滤镜效果(如iOS相机应用程序的肖像模式中所见)和执行计算机视觉任务等目的。
8.1、是否支持深度数据捕获
//当前是否支持深度数据捕获。
@property(nonatomic, readonly, getter=isDepthDataDeliverySupported)
BOOL depthDataDeliverySupported;
并非所有设备和捕获格式都支持深度捕获。如果当前AVCaptureSession
的sessionPreset
属性或AVCaptureDevice
的activeFormat
属性发生更改,则此属性的值可能会更改。如果摄像头或格式更改导致此属性的值变为NO,则depthDataDeliveryEnabled
属性的值也将变为NO。
8.2、是否配置深度数据捕获
@property(nonatomic, getter=isDepthDataDeliveryEnabled)
BOOL depthDataDeliveryEnabled;
捕获深度数据要求AVCaptureSession
以不同方式设置其内部渲染管道。如果打算捕获深度数据,在调用AVCaptureSession
的-startRunning
方法之前将此属性设置为YES。在会话运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片捕获将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。
在启动照片捕获之前,必须启用此选项,并将照片设置对象的depthDataDeliveryEnabled
属性设置为YES。启用此选项后,可以使用和不使用深度数据发出照片拍摄请求。
9、配置肖像效果
9.1、是否支持肖像效果遮罩
//当前是否支持肖像效果遮罩。
@property(nonatomic, readonly, getter=isPortraitEffectsMatteDeliverySupported)
BOOL portraitEffectsMatteDeliverySupported;
9.2、是否将生成肖像效果
@property(nonatomic, getter=isPortraitEffectsMatteDeliveryEnabled)
BOOL portraitEffectsMatteDeliveryEnabled;
10、配置双摄像头拍摄
10.1、是否支持同时使用两个摄像头进行拍照
//当前是否支持在双摄像头设备上同时使用两个摄像头进行拍照。
@property(nonatomic, readonly, getter=isDualCameraDualPhotoDeliverySupported)
BOOL dualCameraDualPhotoDeliverySupported;
并非所有设备和捕获格式都支持双摄像头捕获。如果当前AVCaptureSession
的sessionPreset
属性或AVCaptureDevice
的activeFormat
属性发生更改,则此属性的值可能会更改。如果相机或格式更改导致此属性的值变为NO,则dualCameraDualPhotoDeliveryEnabled
属性的值也将变为NO。
10.2、是否同时使用两个摄像头进行拍照
//是否配置在双摄像头设备上同时使用两个摄像头进行拍照。
@property(nonatomic, getter=isDualCameraDualPhotoDeliveryEnabled)
BOOL dualCameraDualPhotoDeliveryEnabled;
在支持的设备上启用此属性,允许捕获输出在单次捕获中从广角和长焦相机提供单独的图像。
双照片传送要求AVCaptureSession
以不同方式设置其内部渲染管道。如果打算使用双照片传送捕获,请在调用AVCaptureSession
的 -startRunning
方法之前将此属性设置为YES。在AVCaptureSession
运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片捕获将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。
在AVCapturePhotoSettings
对象的dualCameraDualPhotoDeliveryEnabled
属性设置为YES启动照片捕获之前,必须启用此选项。启用此选项后,可以在有和没有双照片传送的情况下发出照片拍摄请求。
10.3、是否支持传送相机校准数据
//当前是否支持传送相机校准数据。
@property(nonatomic, readonly, getter=isCameraCalibrationDataDeliverySupported)
BOOL cameraCalibrationDataDeliverySupported;
AVCameraCalibrationData
对象描述了设备摄像头的成像参数,对于在双摄像头设备上与双照片传送一起执行计算机视觉任务非常有用。仅当dualCameraDualPhotoDeliveryEnabled
属性为YES时,此属性的值才为YES。要启用摄像机校准传送,设置AVCapturePhotoSettings
的cameraCalibrationDataDeliveryEnabled
属性。
11、准备资源密集的拍摄
某些类型的照片拍摄:如括号内捕获和RAW捕获,需要AVCapturePhotoOutput
来分配额外的缓冲区或准备其他资源。为了防止拍照请求由于延迟资源分配而缓慢执行,可以使用一组设置对象AVCapturePhotoSettings
调用-setPreparedPhotoSettingsArray:completionHandler:
方法,该对象代表将要执行的拍摄类型:例如括号拍摄的设置,RAW拍摄 ,或使用静止图像稳定拍摄。
默认情况下,AVCapturePhotoOutput
准备足够的资源以使用默认设置AVCapturePhotoSettings
拍照。要回收所有可能的资源,使用空数组调用-setPreparedPhotoSettingsArray:completionHandler:
方法。
11.1、获取拍摄资源
//AVCapturePhotoOutput已准备好的一系列AVCapturePhotoSettings拍摄资源;
@property(nonatomic, readonly)
NSArray<AVCapturePhotoSettings *> *preparedPhotoSettingsArray;
11.2、设置拍摄资源
- (void)setPreparedPhotoSettingsArray:(NSArray<AVCapturePhotoSettings *> *)preparedPhotoSettingsArray
completionHandler:(void (^)(BOOL prepared, NSError *error))completionHandler;
告知拍照输出,以便为将来使用指定设置的拍照请求准备资源;该方法的两个参数:
- 参数
preparedPhotoSettingsArray
: 一组拍照设置对象,指示AVCapturePhotoOutput
应为其准备资源的拍摄类型。 - 参数
completionHandler
:在AVCapturePhotoOutput
完成准备资源后,在串行调度队列上调用的完成块。如果不希望在准备工作完成时收到通知,则为nil。
每次使用一组设置调用此方法时,AVCapturePhotoOutput
将评估需要分配的其他资源以及可回收的现有资源,并在完成准备(并可能需要回收)时调用completionHandler块资源。要提供有关打算使用哪些捕获功能的早期提示,甚至可以在AVCaptureSession
调用-startRunning
方法之前调用此方法。
照片捕获的准备始终是可选的。可以在不首先调用此方法的情况下调用-capturePhotoWithSettings:delegate:
方法;但是,由于捕获系统会在即时基础上分配其他资源,因此某些照片捕获可能会执行得很慢。
如果在AVCaptureSession
未运行时调用此方法,则不会立即调用completionHandler块。只有在AVCaptureSession
调用-startRunning
方法并且实际已准备好所需资源后,AVCapturePhotoOutput
才会调用完成处理程序。如果使用一组设置调用-setPreparedPhotoSettingsArray:completionHandler:
方法,然后再次调用它,则第一个调用的完成处理程序将立即触发,并准备好参数NO。
准备好的设置会在AVCaptureSession
启动/停止和已提交的配置更改之间保持不变,并参与AVCaptureSession
类定义的延迟工作行为。也就是说,如果调用AVCaptureSession
的-beginConfiguration
方法,更改AVCaptureSession
的输入/输出拓扑,然后调用此方法,AVCaptureSession
将推迟任何准备工作,直到调用-commitConfiguration
方法。此模式允许您以原子方式提交新配置,并准备在新配置中拍摄照片。
调用此方法并触发completionHandler
块后,preparedPhotoSettingsArray
属性将列出捕获系统已为其准备资源的照片设置。
12、获取格式化输出数据 iOS10.0 ~ iOS11.0
在
iOS11.0
及更高版本中,在捕获委托中实现-captureOutput:didFinishProcessingPhoto:error:
方法,并使用生成的AVCapturePhoto
对象的fileDataRepresentation
方法。
使用-capturePhotoWithSettings:delegate:
方法请求照片捕获后,照片捕获输出将结果作为一个或多个CMSampleBufferRef
对象传递给您的委托。要重新打包样本缓冲区的内容以作为JPEG文件输出,请使用此类方法。
12.1、获取JPEG格式的数据
+ (NSData *)JPEGPhotoDataRepresentationForJPEGSampleBuffer:(CMSampleBufferRef)JPEGSampleBuffer
previewPhotoSampleBuffer:(CMSampleBufferRef)previewPhotoSampleBuffer;
返回与指定样本缓冲区中捕获的照片对应的JPEG格式的数据;该方法的两个参数:
- 参数
JPEGSampleBuffer
:包含JPEG照片捕获结果的样本缓冲区,用于格式化输出。 - 参数
previewPhotoSampleBuffer
:包含照片捕获结果的预览分辨率版本的可选附加样本缓冲区,将作为缩略图添加到JPEG输出中。传递nil以跳过将预览图像添加到输出。 - 返回值:包含所请求的照片捕获结果的JPEG表示的数据对象,如果无法打包样本缓冲区以进行输出,则为nil。
12.2、
+ (NSData *)DNGPhotoDataRepresentationForRawSampleBuffer:(CMSampleBufferRef)rawSampleBuffer
previewPhotoSampleBuffer:(CMSampleBufferRef)previewPhotoSampleBuffer;
返回与指定样本缓冲区中捕获的RAW照片对应的数字负片DNG格式的数据;该方法的两个参数:
- 参数
rawSampleBuffer
:包含RAW照片捕获结果的样本缓冲区,用于格式化输出。 - 参数
previewPhotoSampleBuffer
:包含照片捕获结果的预览分辨率版本的可选附加样本缓冲区,将作为缩略图添加到DNG输出中。传递nil以跳过将预览图像添加到输出。 - 返回值:包含所请求的照片捕获结果的DNG表示的数据对象,如果无法打包样本缓冲区以进行输出,则为nil。
本文涉及到的更多信息请阅读:
点击阅读 AVCaptureDevice
点击阅读 AVCaptureSession
点击阅读 AVCapturePhotoOutput
点击阅读 AVCapturePhotoSettings
点击阅读 AVCaptureResolvedPhotoSettings
点击阅读 AVCapturePhoto