1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- /*
- * 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
|