|  | /* | 
|  | *  Copyright 2015 The WebRTC project authors. All Rights Reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #import <AVFoundation/AVFoundation.h> | 
|  | #import <Foundation/Foundation.h> | 
|  |  | 
|  | #import "RTCMacros.h" | 
|  |  | 
|  | NS_ASSUME_NONNULL_BEGIN | 
|  |  | 
|  | typedef NS_ENUM(NSInteger, RTCVideoRotation) { | 
|  | RTCVideoRotation_0 = 0, | 
|  | RTCVideoRotation_90 = 90, | 
|  | RTCVideoRotation_180 = 180, | 
|  | RTCVideoRotation_270 = 270, | 
|  | }; | 
|  |  | 
|  | @protocol RTC_OBJC_TYPE | 
|  | (RTCVideoFrameBuffer); | 
|  |  | 
|  | // RTCVideoFrame is an ObjectiveC version of webrtc::VideoFrame. | 
|  | RTC_OBJC_EXPORT | 
|  | @interface RTC_OBJC_TYPE (RTCVideoFrame) : NSObject | 
|  |  | 
|  | /** Width without rotation applied. */ | 
|  | @property(nonatomic, readonly) int width; | 
|  |  | 
|  | /** Height without rotation applied. */ | 
|  | @property(nonatomic, readonly) int height; | 
|  | @property(nonatomic, readonly) RTCVideoRotation rotation; | 
|  |  | 
|  | /** Timestamp in nanoseconds. */ | 
|  | @property(nonatomic, readonly) int64_t timeStampNs; | 
|  |  | 
|  | /** Timestamp 90 kHz. */ | 
|  | @property(nonatomic, assign) int32_t timeStamp; | 
|  |  | 
|  | @property(nonatomic, readonly) id<RTC_OBJC_TYPE(RTCVideoFrameBuffer)> buffer; | 
|  |  | 
|  | - (instancetype)init NS_UNAVAILABLE; | 
|  | - (instancetype)new NS_UNAVAILABLE; | 
|  |  | 
|  | /** Initialize an RTCVideoFrame from a pixel buffer, rotation, and timestamp. | 
|  | *  Deprecated - initialize with a RTCCVPixelBuffer instead | 
|  | */ | 
|  | - (instancetype)initWithPixelBuffer:(CVPixelBufferRef)pixelBuffer | 
|  | rotation:(RTCVideoRotation)rotation | 
|  | timeStampNs:(int64_t)timeStampNs | 
|  | DEPRECATED_MSG_ATTRIBUTE("use initWithBuffer instead"); | 
|  |  | 
|  | /** Initialize an RTCVideoFrame from a pixel buffer combined with cropping and | 
|  | *  scaling. Cropping will be applied first on the pixel buffer, followed by | 
|  | *  scaling to the final resolution of scaledWidth x scaledHeight. | 
|  | */ | 
|  | - (instancetype)initWithPixelBuffer:(CVPixelBufferRef)pixelBuffer | 
|  | scaledWidth:(int)scaledWidth | 
|  | scaledHeight:(int)scaledHeight | 
|  | cropWidth:(int)cropWidth | 
|  | cropHeight:(int)cropHeight | 
|  | cropX:(int)cropX | 
|  | cropY:(int)cropY | 
|  | rotation:(RTCVideoRotation)rotation | 
|  | timeStampNs:(int64_t)timeStampNs | 
|  | DEPRECATED_MSG_ATTRIBUTE("use initWithBuffer instead"); | 
|  |  | 
|  | /** Initialize an RTCVideoFrame from a frame buffer, rotation, and timestamp. | 
|  | */ | 
|  | - (instancetype)initWithBuffer:(id<RTC_OBJC_TYPE(RTCVideoFrameBuffer)>)frameBuffer | 
|  | rotation:(RTCVideoRotation)rotation | 
|  | timeStampNs:(int64_t)timeStampNs; | 
|  |  | 
|  | /** Return a frame that is guaranteed to be I420, i.e. it is possible to access | 
|  | *  the YUV data on it. | 
|  | */ | 
|  | - (RTC_OBJC_TYPE(RTCVideoFrame) *)newI420VideoFrame; | 
|  |  | 
|  | @end | 
|  |  | 
|  | NS_ASSUME_NONNULL_END |