/* * Copyright (c) 2004 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. */ #ifndef WEBRTC_MEDIA_BASE_VIDEOFRAME_H_ #define WEBRTC_MEDIA_BASE_VIDEOFRAME_H_ #include "webrtc/base/basictypes.h" #include "webrtc/base/stream.h" #include "webrtc/common_video/include/video_frame_buffer.h" #include "webrtc/common_video/rotation.h" namespace cricket { // Represents a YUV420 (a.k.a. I420) video frame. class VideoFrame { public: VideoFrame() {} virtual ~VideoFrame() {} // Basic accessors. // Note this is the width and height without rotation applied. virtual int width() const = 0; virtual int height() const = 0; // Returns the underlying video frame buffer. This function is ok to call // multiple times, but the returned object will refer to the same memory. virtual const rtc::scoped_refptr& video_frame_buffer() const = 0; // System monotonic clock, same timebase as rtc::TimeMicros(). virtual int64_t timestamp_us() const = 0; virtual void set_timestamp_us(int64_t time_us) = 0; // Deprecated methods, for backwards compatibility. // TODO(nisse): Delete when usage in Chrome and other applications // have been replaced. virtual int64_t GetTimeStamp() const { return rtc::kNumNanosecsPerMicrosec * timestamp_us(); } virtual void SetTimeStamp(int64_t time_ns) { set_timestamp_us(time_ns / rtc::kNumNanosecsPerMicrosec); } // Indicates the rotation angle in degrees. virtual webrtc::VideoRotation rotation() const = 0; // Make a shallow copy of the frame. The frame buffer itself is not copied. // Both the current and new VideoFrame will share a single reference-counted // frame buffer. virtual VideoFrame *Copy() const = 0; // Return a copy of frame which has its pending rotation applied. The // ownership of the returned frame is held by this frame. virtual const VideoFrame* GetCopyWithRotationApplied() const = 0; // Converts the I420 data to RGB of a certain type such as ARGB and ABGR. // Returns the frame's actual size, regardless of whether it was written or // not (like snprintf). Parameters size and stride_rgb are in units of bytes. // If there is insufficient space, nothing is written. virtual size_t ConvertToRgbBuffer(uint32_t to_fourcc, uint8_t* buffer, size_t size, int stride_rgb) const; // Tests if sample is valid. Returns true if valid. static bool Validate(uint32_t fourcc, int w, int h, const uint8_t* sample, size_t sample_size); protected: // Creates an empty frame. virtual VideoFrame* CreateEmptyFrame(int w, int h, int64_t timestamp_us) const = 0; virtual void set_rotation(webrtc::VideoRotation rotation) = 0; }; } // namespace cricket #endif // WEBRTC_MEDIA_BASE_VIDEOFRAME_H_