2016-01-11 09:47:07 -08:00
|
|
|
/*
|
|
|
|
|
* 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.
|
|
|
|
|
*/
|
|
|
|
|
|
2016-04-04 14:10:43 -07:00
|
|
|
#import <AVFoundation/AVFoundation.h>
|
2016-01-11 09:47:07 -08:00
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
|
|
2016-04-27 01:54:20 -07:00
|
|
|
#import <WebRTC/RTCMacros.h>
|
2016-04-19 10:04:41 -07:00
|
|
|
|
2016-01-11 09:47:07 -08:00
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
|
|
2016-11-02 03:39:58 -07:00
|
|
|
// RTCVideoFrame is an ObjectiveC version of cricket::VideoFrame.
|
2016-04-19 10:04:41 -07:00
|
|
|
RTC_EXPORT
|
2016-01-11 09:47:07 -08:00
|
|
|
@interface RTCVideoFrame : NSObject
|
|
|
|
|
|
|
|
|
|
/** Width without rotation applied. */
|
|
|
|
|
@property(nonatomic, readonly) size_t width;
|
|
|
|
|
|
|
|
|
|
/** Height without rotation applied. */
|
|
|
|
|
@property(nonatomic, readonly) size_t height;
|
2016-08-10 07:58:29 -07:00
|
|
|
@property(nonatomic, readonly) int rotation;
|
2016-01-11 09:47:07 -08:00
|
|
|
@property(nonatomic, readonly) size_t chromaWidth;
|
|
|
|
|
@property(nonatomic, readonly) size_t chromaHeight;
|
|
|
|
|
// These can return NULL if the object is not backed by a buffer.
|
|
|
|
|
@property(nonatomic, readonly, nullable) const uint8_t *yPlane;
|
|
|
|
|
@property(nonatomic, readonly, nullable) const uint8_t *uPlane;
|
|
|
|
|
@property(nonatomic, readonly, nullable) const uint8_t *vPlane;
|
|
|
|
|
@property(nonatomic, readonly) int32_t yPitch;
|
|
|
|
|
@property(nonatomic, readonly) int32_t uPitch;
|
|
|
|
|
@property(nonatomic, readonly) int32_t vPitch;
|
|
|
|
|
|
2016-04-04 14:10:43 -07:00
|
|
|
/** Timestamp in nanoseconds. */
|
2016-08-10 07:58:29 -07:00
|
|
|
@property(nonatomic, readonly) int64_t timeStampNs;
|
2016-04-04 14:10:43 -07:00
|
|
|
|
|
|
|
|
/** The native handle should be a pixel buffer on iOS. */
|
|
|
|
|
@property(nonatomic, readonly) CVPixelBufferRef nativeHandle;
|
|
|
|
|
|
2016-03-08 16:04:46 -08:00
|
|
|
- (instancetype)init NS_UNAVAILABLE;
|
2016-01-11 09:47:07 -08:00
|
|
|
|
2016-04-04 14:10:43 -07:00
|
|
|
/** If the frame is backed by a CVPixelBuffer, creates a backing i420 frame.
|
|
|
|
|
* Calling the yuv plane properties will call this method if needed.
|
|
|
|
|
*/
|
|
|
|
|
- (void)convertBufferIfNeeded;
|
|
|
|
|
|
2016-01-11 09:47:07 -08:00
|
|
|
@end
|
|
|
|
|
|
|
|
|
|
NS_ASSUME_NONNULL_END
|