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
|
|
|
|
|
|
2017-02-21 04:19:46 -08:00
|
|
|
typedef NS_ENUM(NSInteger, RTCVideoRotation) {
|
|
|
|
|
RTCVideoRotation_0 = 0,
|
|
|
|
|
RTCVideoRotation_90 = 90,
|
|
|
|
|
RTCVideoRotation_180 = 180,
|
|
|
|
|
RTCVideoRotation_270 = 270,
|
|
|
|
|
};
|
|
|
|
|
|
2017-06-22 15:26:30 +02:00
|
|
|
@protocol RTCVideoFrameBuffer;
|
|
|
|
|
|
Reland of Delete all use of cricket::VideoFrame and cricket::WebRtcVideoFrame. (patchset #1 id:1 of https://codereview.webrtc.org/2471783002/ )
Reason for revert:
Relanding after known downstream breakages have been fixed.
Original issue's description:
> Revert of Delete all use of cricket::VideoFrame and cricket::WebRtcVideoFrame. (patchset #7 id:120001 of https://codereview.webrtc.org/2383093002/ )
>
> Reason for revert:
> Breaks chrome, see https://build.chromium.org/p/chromium.webrtc.fyi/builders/Mac%20Builder/builds/19019/steps/compile/logs/stdio
>
> Analysis: Chrome uses cricket::VideoFrame, without explicitly including webrtc/media/base/videoframe.h, and breaks when that file is no longer included by any other webrtc headers. Will reland after updating Chrome.
>
> Original issue's description:
> > Delete all use of cricket::VideoFrame and cricket::WebRtcVideoFrame.
> >
> > Replaced with webrtc::VideoFrame.
> >
> > TBR=mflodman@webrtc.org
> > BUG=webrtc:5682
> >
> > Committed: https://crrev.com/45c8b8940042bd2574c39920804ade8343cefdba
> > Cr-Commit-Position: refs/heads/master@{#14885}
>
> TBR=perkj@webrtc.org,pthatcher@webrtc.org,tkchin@webrtc.org,mflodman@webrtc.org,stefan@webrtc.org
> # Skipping CQ checks because original CL landed less than 1 days ago.
> NOPRESUBMIT=true
> NOTREECHECKS=true
> NOTRY=true
> BUG=webrtc:5682
>
> Committed: https://crrev.com/7341ab8e2505c9763d208e069bda269018357e7d
> Cr-Commit-Position: refs/heads/master@{#14886}
TBR=perkj@webrtc.org,pthatcher@webrtc.org,tkchin@webrtc.org,mflodman@webrtc.org,stefan@webrtc.org
# Not skipping CQ checks because original CL landed more than 1 days ago.
BUG=webrtc:5682
Review-Url: https://codereview.webrtc.org/2487633002
Cr-Commit-Position: refs/heads/master@{#15039}
2016-11-11 03:55:13 -08:00
|
|
|
// RTCVideoFrame is an ObjectiveC version of webrtc::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. */
|
2017-02-21 04:19:46 -08:00
|
|
|
@property(nonatomic, readonly) int width;
|
2016-01-11 09:47:07 -08:00
|
|
|
|
|
|
|
|
/** Height without rotation applied. */
|
2017-02-21 04:19:46 -08:00
|
|
|
@property(nonatomic, readonly) int height;
|
|
|
|
|
@property(nonatomic, readonly) RTCVideoRotation rotation;
|
|
|
|
|
/** Accessing YUV data should only be done for I420 frames, i.e. if nativeHandle
|
|
|
|
|
* is null. It is always possible to get such a frame by calling
|
|
|
|
|
* newI420VideoFrame.
|
|
|
|
|
*/
|
2017-06-22 15:26:30 +02:00
|
|
|
@property(nonatomic, readonly, nullable)
|
|
|
|
|
const uint8_t *dataY DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
|
|
|
|
@property(nonatomic, readonly, nullable)
|
|
|
|
|
const uint8_t *dataU DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
|
|
|
|
@property(nonatomic, readonly, nullable)
|
|
|
|
|
const uint8_t *dataV DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
|
|
|
|
@property(nonatomic, readonly) int strideY DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
|
|
|
|
@property(nonatomic, readonly) int strideU DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
|
|
|
|
@property(nonatomic, readonly) int strideV DEPRECATED_MSG_ATTRIBUTE("use [buffer toI420]");
|
2016-01-11 09:47:07 -08:00
|
|
|
|
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. */
|
2017-06-22 15:26:30 +02:00
|
|
|
@property(nonatomic, readonly)
|
|
|
|
|
CVPixelBufferRef nativeHandle DEPRECATED_MSG_ATTRIBUTE("use buffer instead");
|
|
|
|
|
|
|
|
|
|
@property(nonatomic, readonly) id<RTCVideoFrameBuffer> buffer;
|
2016-04-04 14:10:43 -07:00
|
|
|
|
2016-03-08 16:04:46 -08:00
|
|
|
- (instancetype)init NS_UNAVAILABLE;
|
2017-02-21 05:28:48 -08:00
|
|
|
- (instancetype)new NS_UNAVAILABLE;
|
|
|
|
|
|
|
|
|
|
/** Initialize an RTCVideoFrame from a pixel buffer, rotation, and timestamp.
|
2017-06-22 15:26:30 +02:00
|
|
|
* Deprecated - initialize with a RTCCVPixelBuffer instead
|
2017-02-21 05:28:48 -08:00
|
|
|
*/
|
|
|
|
|
- (instancetype)initWithPixelBuffer:(CVPixelBufferRef)pixelBuffer
|
|
|
|
|
rotation:(RTCVideoRotation)rotation
|
2017-06-22 15:26:30 +02:00
|
|
|
timeStampNs:(int64_t)timeStampNs
|
|
|
|
|
DEPRECATED_MSG_ATTRIBUTE("use initWithBuffer instead");
|
2017-02-21 05:28:48 -08:00
|
|
|
|
|
|
|
|
/** 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
|
2017-06-22 15:26:30 +02:00
|
|
|
timeStampNs:(int64_t)timeStampNs
|
|
|
|
|
DEPRECATED_MSG_ATTRIBUTE("use initWithBuffer instead");
|
|
|
|
|
|
|
|
|
|
/** Initialize an RTCVideoFrame from a frame buffer, rotation, and timestamp.
|
|
|
|
|
*/
|
|
|
|
|
- (instancetype)initWithBuffer:(id<RTCVideoFrameBuffer>)frameBuffer
|
|
|
|
|
rotation:(RTCVideoRotation)rotation
|
|
|
|
|
timeStampNs:(int64_t)timeStampNs;
|
2016-01-11 09:47:07 -08:00
|
|
|
|
2017-02-21 04:19:46 -08:00
|
|
|
/** Return a frame that is guaranteed to be I420, i.e. it is possible to access
|
|
|
|
|
* the YUV data on it.
|
2016-04-04 14:10:43 -07:00
|
|
|
*/
|
2017-02-21 04:19:46 -08:00
|
|
|
- (RTCVideoFrame *)newI420VideoFrame;
|
2016-04-04 14:10:43 -07:00
|
|
|
|
2016-01-11 09:47:07 -08:00
|
|
|
@end
|
|
|
|
|
|
|
|
|
|
NS_ASSUME_NONNULL_END
|