OC之AVCapturePhotoOutput

AVCapturePhotoOutput 是一个静态照片,动态照片和其他摄影工作流程的拍摄输出。它为静态拍摄流程提供了最新接口;除了静态照片的基本拍摄之外,它还支持RAW格式拍摄,多个图像的包围拍摄,动态照片和宽色域颜色。可以输出各种格式和编解码器的拍摄照片,包括RAW格式DNG文件,HEVC格式HEIF文件和JPEG文件。

AVCapturePhotoOutput 拍照流程.png

要使用AVCapturePhotoOutput拍摄照片,需按步骤操作:

  • 1、创建AVCapturePhotoOutput对象,使用其属性确定支持的拍摄设置并启用某些功能:例如,是否拍摄动态照片。
  • 2、创建和配置AVCapturePhotoSettings对象以选择特定拍摄的功能和设置:例如,是否启用图像稳定或闪光灯。
  • 3、通过将AVCapturePhotoSettings对象传递给-capturePhotoWithSettings:delegate:方法以及实现AVCapturePhotoCaptureDelegate协议的委托对象来拍照。然后,AVCapturePhotoOutput在拍摄过程中会调用协议方法。

某些照片拍摄设置(如flashMode属性)包含自动行为选项。对于此类设置,AVCapturePhotoOutput确定是否在拍摄时使用该功能:在请求拍摄时不知道拍摄完成时是否启用该功能。当AVCapturePhotoOutput使用有关已完成或正在进行的拍摄的信息调用AVCapturePhotoCaptureDelegate方法时,它还提供AVCaptureResolvedPhotoSettings对象,该对象详细说明已为该次拍摄设置了哪些自动功能。AVCaptureResolvedPhotoSettingsuniqueID与用于请求拍摄的AVCapturePhotoSettings对象的uniqueID值相匹配。

启用某些照片功能(拍摄动态照片和高分辨率照片)需要重新配置拍摄渲染管道。要选择这些功能,需要在调用AVCaptureSession对象的-startRunning方法之前设置highResolutionCaptureEnabledlivePhotoCaptureEnabledlivePhotoAutoTrimmingEnabled属性。在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设置必须指定AVCapturePhotoOutputsupportedFlashModes数组中存在的值。详情可查看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、确定可用设置

如果当前AVCaptureSessionsessionPreset属性或AVCaptureDeviceactiveFormat属性发生更改,则以下属性的值可能会更改。

只读属性 数据类型 描述
stillImageStabilizationSupported BOOL 当前拍摄静态图像是否支持自动稳定。要使用图像稳定功能拍照,需要设置AVCapturePhotoSettingsautoStillImageStabilizationEnabled属性。自动稳定始终包括数字图像稳定,并且还可以包括基于当前设备的光学镜头稳定。如果设备不支持静态图像稳定,则设置autoStillImageStabilizationEnabled属性无效,即AVCaptureResolvedPhotoSettingsstillImageStabilizationEnabled将始终为NO。
dualCameraFusionSupported BOOL 当前拍摄是否支持在双摄像头设备上自动组合图像数据;在配备双摄像头的设备上,将两个摄像头的图像融合在一起,以产生更高质量的图像。要使用图像融合拍摄照片,需要设置AVCapturePhotoSettingsautoDualCameraFusionEnabled属性。如果设备不支持图像融合,则设置autoDualCameraFusionEnabled属性不起作用,即AVCaptureResolvedPhotoSettingsdualCameraFusionEnabled将始终为NO。
maxBracketedCapturePhotoCount NSUInteger 拍摄照片可以在单个包围捕获中支持的最大图像数;并非所有设备和拍摄格式都支持包围拍摄。如果当前设备或活动格式不支持括号拍摄,则此属性的值为零。要使用不同的拍摄设置对多个图像进行括号拍摄,需要创建一个AVCapturePhotoBracketSettings实例,其中包含所需的设置和括号变体的组合。每次拍摄的最大照片数取决于要拍摄的图像的大小和格式。
lensStabilizationDuringBracketedCaptureSupported BOOL 当前在括号内拍照期间是否支持镜头稳定。要在括号内拍摄的整个持续时间内使用光学图像稳定,需要设置AVCapturePhotoBracketSettingslensStabilizationEnabled属性。
supportedFlashModes NSArray<NSNumber *> 当前支持的闪光灯设置。要设置闪光灯模式,需要将AVCapturePhotoSettingsflashMode属性设置为此列表值之一。

5、监视可见场景

5.1、建议是否使用闪光灯

建议相机当前正在预览的场景是否使用闪光灯,该值会根据镜头可见的场景而变化:例如,iPhone自带相机中的闪光控件,向用户指示场景足够暗,可能需要启用闪光灯。

@property(nonatomic, readonly) BOOL isFlashScene;

如果AVCapturePhotoOutputsupportedFlashModes值为AVCaptureFlashModeOff,则此属性的值始终为NO。

5.2、建议是否使用图像稳定

建议相机预览的场景是否使用图像稳定,该值会根据镜头可见的场景而变化:例如,iPhone自带相机中与图像稳定相关的控件,向用户指示场景足够暗,可能需要启用图像稳定功能。

@property(nonatomic, readonly) BOOL isStillImageStabilizationScene;

如果AVCapturePhotoOutputstillImageStabilizationSupported值为NO,则此属性的值始终为NO。

5.3、设置对象

用于控制照片输出检测,处理自动闪光模式和稳定模式的照片设置对象。

@property(nonatomic, copy) AVCapturePhotoSettings *photoSettingsForSceneMonitoring;

设置此对象的flashModeautoStillImageStabilizationEnabled属性会影响AVCapturePhotoOutput的场景监视属性isFlashSceneisStillImageStabilizationScene的值。例如,如果将此对象的flashMode属性设置为AVCaptureFlashModeOff,则无论可见场景中的光照条件如何,照片输出的isFlashScene属性都会为NO。如果将此照片设置对象的flashMode属性设置为AVCaptureFlashModeAutoAVCaptureFlashModeOn,则AVCapturePhotoOutputisFlashScene属性将恢复为基于可见光级别返回YES或NO的默认行为。

注意:在亮度范围有一些重叠,这得益于静态图像稳定和闪光。如果此对象指示应监视静止图像稳定和闪光的场景,则静止图像稳定优先,并且isFlashScene属性在较低的整体亮度下变为YES。

默认值为AVCapturePhotoSettings对象,具有以下设置:

  • flashMode:取值AVCaptureFlashModeAuto
  • autoStillImageStabilizationEnabled:取值YES

AVCapturePhotoOutput会忽略此对象的所有其他属性。要在请求拍摄时控制其他照片设置,需要创建AVCapturePhotoSettings以传递给-capturePhotoWithSettings:delegate:方法。

6、配置高分辨率静态拍摄

一个布尔值,指定是否为拍摄高分辨率静态图像配置捕获管道。

@property(nonatomic, getter=isHighResolutionCaptureEnabled) BOOL highResolutionCaptureEnabled;

某些拍摄格式支持静态图像的输出,其分辨率高于用于实时预览和视频捕获的分辨率。在某些情况下,AVCaptureSession需要以不同方式设置其内部渲染管道,以支持高分辨率静态图像捕获。

如果打算采用高分辨率静止图像,需要在调用AVCaptureSession-startRunning方法之前设置此属性。在AVCaptureSession运行时更改此属性需要对捕获渲染管道进行冗长的重新配置:正在进行的动态照片拍摄将立即结束,未实现的照片请求将中止,视频预览将暂时冻结。

在请求拍照之前,必须启用此选项,并将AVCapturePhotoSettingshighResolutionPhotoEnabled属性设置为YES。但是,启用此选项后,可以使用任何highResolutionPhotoEnabled设置自由发出拍照请求。

7、拍摄动态照片配置

动态照片可以拍摄静止图像和以拍摄时刻为中心的短片,并在用户界面(如照片应用程序)中一起呈现。

7.1、是否支持 live Photo
//当前是否支持动态照片拍摄。
@property(nonatomic, readonly, getter=isLivePhotoCaptureSupported)
BOOL livePhotoCaptureSupported;

并非所有设备和捕获格式都支持动态照片拍摄。如果当前AVCaptureSessionsessionPreset属性或AVCaptureDeviceactiveFormat属性发生更改,则此属性的值可能会更改。如果相机或格式更改导致此属性的值变为NO,则livePhotoCaptureEnabled属性的值也将变为NO。

7.2、是否拍摄 live Photo

是否拍摄动态照片;在AVCapturePhotoSettingslivePhotoMovieFileURL属性为非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编解码器对动态照片的电影部分进行编码。要使用其他编解码器,将AVCapturePhotoSettingslivePhotoVideoCodecType属性设置为此数组中的某个值。

对数组进行排序,以便首先列出系统的默认(首选)视频编解码器。如果尚未将AVCapturePhotoOutput添加到带有视频源的AVCaptureSession,则无法使用任何编解码器。

8、配置深度数据捕获

深度数据捕获与照片图像一起传送的场景深度信息的每像素图,并且可选地嵌入图像文件输出中。深度数据可用于诸如应用深度敏感的照片滤镜效果(如iOS相机应用程序的肖像模式中所见)和执行计算机视觉任务等目的。

8.1、是否支持深度数据捕获
//当前是否支持深度数据捕获。
@property(nonatomic, readonly, getter=isDepthDataDeliverySupported)
BOOL depthDataDeliverySupported;

并非所有设备和捕获格式都支持深度捕获。如果当前AVCaptureSessionsessionPreset属性或AVCaptureDeviceactiveFormat属性发生更改,则此属性的值可能会更改。如果摄像头或格式更改导致此属性的值变为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;

并非所有设备和捕获格式都支持双摄像头捕获。如果当前AVCaptureSessionsessionPreset属性或AVCaptureDeviceactiveFormat属性发生更改,则此属性的值可能会更改。如果相机或格式更改导致此属性的值变为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。要启用摄像机校准传送,设置AVCapturePhotoSettingscameraCalibrationDataDeliveryEnabled属性。

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容