forked from rs/SDAVAssetExportSession
-
Notifications
You must be signed in to change notification settings - Fork 1
/
SDAVAssetExportSession.h
199 lines (169 loc) · 6.86 KB
/
SDAVAssetExportSession.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
//
// SDAVAssetExportSession.h
//
// This file is part of the SDAVAssetExportSession package.
//
// Created by Olivier Poitrey <[email protected]> on 13/03/13.
// Copyright 2013 Olivier Poitrey. All rights servered.
//
// For the full copyright and license information, please view the LICENSE
// file that was distributed with this source code.
//
#import <Foundation/Foundation.h>
#import <AVFoundation/AVFoundation.h>
@protocol SDAVAssetExportSessionDelegate;
/**
* An `SDAVAssetExportSession` object transcodes the contents of an AVAsset source object to create an output
* of the form described by specified video and audio settings. It implements most of the API of Apple provided
* `AVAssetExportSession` but with the capability to provide you own video and audio settings instead of the
* limited set of Apple provided presets.
*
* After you have initialized an export session with the asset that contains the source media, video and audio
* settings, and the output file type (outputFileType), you can start the export running by invoking
* `exportAsynchronouslyWithCompletionHandler:`. Because the export is performed asynchronously, this method
* returns immediately — you can observe progress to check on the progress.
*
* The completion handler you supply to `exportAsynchronouslyWithCompletionHandler:` is called whether the export
* fails, completes, or is cancelled. Upon completion, the status property indicates whether the export has
* completed successfully. If it has failed, the value of the error property supplies additional information
* about the reason for the failure.
*/
@interface SDAVAssetExportSession : NSObject
@property (nonatomic, weak) id<SDAVAssetExportSessionDelegate> delegate;
/**
* The asset with which the export session was initialized.
*/
@property (nonatomic, strong, readonly) AVAsset *asset;
/**
* Indicates whether video composition is enabled for export, and supplies the instructions for video composition.
*
* You can observe this property using key-value observing.
*/
@property (nonatomic, copy) AVVideoComposition *videoComposition;
/**
* Indicates whether non-default audio mixing is enabled for export, and supplies the parameters for audio mixing.
*/
@property (nonatomic, copy) AVAudioMix *audioMix;
/**
* The type of file to be written by the session.
*
* The value is a UTI string corresponding to the file type to use when writing the asset.
* For a list of constants specifying UTIs for standard file types, see `AV Foundation Constants Reference`.
*
* You can observe this property using key-value observing.
*/
@property (nonatomic, copy) NSString *outputFileType;
/**
* The URL of the export session’s output.
*
* You can observe this property using key-value observing.
*/
@property (nonatomic, copy) NSURL *outputURL;
/**
* The settings used for input video track.
*
* The dictionary’s keys are from <CoreVideo/CVPixelBuffer.h>.
*/
@property (nonatomic, copy) NSDictionary *videoInputSettings;
/**
* The settings used for encoding the video track.
*
* A value of nil specifies that appended output should not be re-encoded.
* The dictionary’s keys are from <AVFoundation/AVVideoSettings.h>.
*/
@property (nonatomic, copy) NSDictionary *videoSettings;
/**
* The settings used for encoding the audio track.
*
* A value of nil specifies that appended output should not be re-encoded.
* The dictionary’s keys are from <CoreVideo/CVPixelBuffer.h>.
*/
@property (nonatomic, copy) NSDictionary *audioSettings;
/**
* The time range to be exported from the source.
*
* The default time range of an export session is `kCMTimeZero` to `kCMTimePositiveInfinity`,
* meaning that (modulo a possible limit on file length) the full duration of the asset will be exported.
*
* You can observe this property using key-value observing.
*
*/
@property (nonatomic, assign) CMTimeRange timeRange;
/**
* Indicates whether the movie should be optimized for network use.
*
* You can observe this property using key-value observing.
*/
@property (nonatomic, assign) BOOL shouldOptimizeForNetworkUse;
/**
* The processing algorithm used to manage audio pitch for scaled audio edits.
*/
@property (nonatomic, copy) AVAudioTimePitchAlgorithm audioTimePitchAlgorithm;
/**
* The metadata to be written to the output file by the export session.
*/
@property (nonatomic, copy) NSArray *metadata;
/**
* Describes the error that occurred if the export status is `AVAssetExportSessionStatusFailed`
* or `AVAssetExportSessionStatusCancelled`.
*
* If there is no error to report, the value of this property is nil.
*/
@property (nonatomic, strong, readonly) NSError *error;
/**
* The progress of the export on a scale from 0 to 1.
*
*
* A value of 0 means the export has not yet begun, 1 means the export is complete.
*
* Unlike Apple provided `AVAssetExportSession`, this property can be observed using key-value observing.
*/
@property (nonatomic, assign, readonly) float progress;
/**
* The status of the export session.
*
* For possible values, see “AVAssetExportSessionStatus.”
*
* You can observe this property using key-value observing. (TODO)
*/
@property (nonatomic, assign, readonly) AVAssetExportSessionStatus status;
/**
* Returns an asset export session configured with a specified asset.
*
* @param asset The asset you want to export
* @return An asset export session initialized to export `asset`.
*/
+ (id)exportSessionWithAsset:(AVAsset *)asset;
/**
* Initializes an asset export session with a specified asset.
*
* @param asset The asset you want to export
* @return An asset export session initialized to export `asset`.
*/
- (id)initWithAsset:(AVAsset *)asset;
/**
* Starts the asynchronous execution of an export session.
*
* This method starts an asynchronous export operation and returns immediately. status signals the terminal
* state of the export session, and if a failure occurs, error describes the problem.
*
* If internal preparation for export fails, handler is invoked synchronously. The handler may also be called
* asynchronously, after the method returns, in the following cases:
*
* 1. If a failure occurs during the export, including failures of loading, re-encoding, or writing media data to the output.
* 2. If cancelExport is invoked.
* 3. After the export session succeeds, having completely written its output to the outputURL.
*
* @param handler A block that is invoked when writing is complete or in the event of writing failure.
*/
- (void)exportAsynchronouslyWithCompletionHandler:(void (^)(void))handler;
/**
* Cancels the execution of an export session.
*
* You can invoke this method when the export is running.
*/
- (void)cancelExport;
@end
@protocol SDAVAssetExportSessionDelegate <NSObject>
- (void)exportSession:(SDAVAssetExportSession *)exportSession renderFrame:(CVPixelBufferRef)pixelBuffer withPresentationTime:(CMTime)presentationTime toBuffer:(CVPixelBufferRef)renderBuffer;
@end