Move WebRtcVideoRenderFrame from webrtcvideoengine2.cc to webrtcvideoframe.h
The purpose of this CL is to be able to reuse the class WebRtcVideoRenderFrame in webrtcvideoengine.cc. R=pbos@webrtc.org Review URL: https://webrtc-codereview.appspot.com/32799004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@7888 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
@ -574,134 +574,6 @@ std::vector<VideoCodec> WebRtcVideoEngine2::GetSupportedCodecs() const {
|
||||
return supported_codecs;
|
||||
}
|
||||
|
||||
// Thin map between VideoFrame and an existing webrtc::I420VideoFrame
|
||||
// to avoid having to copy the rendered VideoFrame prematurely.
|
||||
// This implementation is only safe to use in a const context and should never
|
||||
// be written to.
|
||||
class WebRtcVideoRenderFrame : public VideoFrame {
|
||||
public:
|
||||
explicit WebRtcVideoRenderFrame(const webrtc::I420VideoFrame* frame)
|
||||
: frame_(frame) {}
|
||||
|
||||
virtual bool InitToBlack(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
virtual bool Reset(uint32 fourcc,
|
||||
int w,
|
||||
int h,
|
||||
int dw,
|
||||
int dh,
|
||||
uint8* sample,
|
||||
size_t sample_size,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp,
|
||||
int rotation) OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
virtual size_t GetWidth() const OVERRIDE {
|
||||
return static_cast<size_t>(frame_->width());
|
||||
}
|
||||
virtual size_t GetHeight() const OVERRIDE {
|
||||
return static_cast<size_t>(frame_->height());
|
||||
}
|
||||
|
||||
virtual const uint8* GetYPlane() const OVERRIDE {
|
||||
return frame_->buffer(webrtc::kYPlane);
|
||||
}
|
||||
virtual const uint8* GetUPlane() const OVERRIDE {
|
||||
return frame_->buffer(webrtc::kUPlane);
|
||||
}
|
||||
virtual const uint8* GetVPlane() const OVERRIDE {
|
||||
return frame_->buffer(webrtc::kVPlane);
|
||||
}
|
||||
|
||||
virtual uint8* GetYPlane() OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
virtual uint8* GetUPlane() OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
virtual uint8* GetVPlane() OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
virtual int32 GetYPitch() const OVERRIDE {
|
||||
return frame_->stride(webrtc::kYPlane);
|
||||
}
|
||||
virtual int32 GetUPitch() const OVERRIDE {
|
||||
return frame_->stride(webrtc::kUPlane);
|
||||
}
|
||||
virtual int32 GetVPitch() const OVERRIDE {
|
||||
return frame_->stride(webrtc::kVPlane);
|
||||
}
|
||||
|
||||
virtual void* GetNativeHandle() const OVERRIDE { return NULL; }
|
||||
|
||||
virtual size_t GetPixelWidth() const OVERRIDE { return 1; }
|
||||
virtual size_t GetPixelHeight() const OVERRIDE { return 1; }
|
||||
|
||||
virtual int64_t GetElapsedTime() const OVERRIDE {
|
||||
// Convert millisecond render time to ns timestamp.
|
||||
return frame_->render_time_ms() * rtc::kNumNanosecsPerMillisec;
|
||||
}
|
||||
virtual int64_t GetTimeStamp() const OVERRIDE {
|
||||
// Convert 90K rtp timestamp to ns timestamp.
|
||||
return (frame_->timestamp() / 90) * rtc::kNumNanosecsPerMillisec;
|
||||
}
|
||||
virtual void SetElapsedTime(int64_t elapsed_time) OVERRIDE { UNIMPLEMENTED; }
|
||||
virtual void SetTimeStamp(int64_t time_stamp) OVERRIDE { UNIMPLEMENTED; }
|
||||
|
||||
virtual int GetRotation() const OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return ROTATION_0;
|
||||
}
|
||||
|
||||
virtual VideoFrame* Copy() const OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
virtual bool MakeExclusive() OVERRIDE {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
virtual size_t CopyToBuffer(uint8* buffer, size_t size) const {
|
||||
UNIMPLEMENTED;
|
||||
return 0;
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual VideoFrame* CreateEmptyFrame(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) const OVERRIDE {
|
||||
WebRtcVideoFrame* frame = new WebRtcVideoFrame();
|
||||
frame->InitToBlack(
|
||||
w, h, pixel_width, pixel_height, elapsed_time, time_stamp);
|
||||
return frame;
|
||||
}
|
||||
|
||||
private:
|
||||
const webrtc::I420VideoFrame* const frame_;
|
||||
};
|
||||
|
||||
WebRtcVideoChannel2::WebRtcVideoChannel2(
|
||||
WebRtcCallFactory* call_factory,
|
||||
WebRtcVoiceEngine* voice_engine,
|
||||
|
@ -33,6 +33,11 @@
|
||||
#include "talk/media/base/videocapturer.h"
|
||||
#include "talk/media/base/videocommon.h"
|
||||
#include "webrtc/base/logging.h"
|
||||
#include "webrtc/video_frame.h"
|
||||
|
||||
#define UNIMPLEMENTED \
|
||||
LOG(LS_ERROR) << "Call to unimplemented function " << __FUNCTION__; \
|
||||
ASSERT(false)
|
||||
|
||||
namespace cricket {
|
||||
|
||||
@ -354,4 +359,132 @@ void WebRtcVideoFrame::InitToEmptyBuffer(int w, int h, size_t pixel_width,
|
||||
elapsed_time, time_stamp, 0);
|
||||
}
|
||||
|
||||
WebRtcVideoRenderFrame::WebRtcVideoRenderFrame(
|
||||
const webrtc::I420VideoFrame* frame)
|
||||
: frame_(frame) {
|
||||
}
|
||||
|
||||
bool WebRtcVideoRenderFrame::InitToBlack(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
bool WebRtcVideoRenderFrame::Reset(uint32 fourcc,
|
||||
int w,
|
||||
int h,
|
||||
int dw,
|
||||
int dh,
|
||||
uint8* sample,
|
||||
size_t sample_size,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp,
|
||||
int rotation) {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
size_t WebRtcVideoRenderFrame::GetWidth() const {
|
||||
return static_cast<size_t>(frame_->width());
|
||||
}
|
||||
size_t WebRtcVideoRenderFrame::GetHeight() const {
|
||||
return static_cast<size_t>(frame_->height());
|
||||
}
|
||||
|
||||
const uint8* WebRtcVideoRenderFrame::GetYPlane() const {
|
||||
return frame_->buffer(webrtc::kYPlane);
|
||||
}
|
||||
const uint8* WebRtcVideoRenderFrame::GetUPlane() const {
|
||||
return frame_->buffer(webrtc::kUPlane);
|
||||
}
|
||||
const uint8* WebRtcVideoRenderFrame::GetVPlane() const {
|
||||
return frame_->buffer(webrtc::kVPlane);
|
||||
}
|
||||
|
||||
uint8* WebRtcVideoRenderFrame::GetYPlane() {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
uint8* WebRtcVideoRenderFrame::GetUPlane() {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
uint8* WebRtcVideoRenderFrame::GetVPlane() {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int32 WebRtcVideoRenderFrame::GetYPitch() const {
|
||||
return frame_->stride(webrtc::kYPlane);
|
||||
}
|
||||
int32 WebRtcVideoRenderFrame::GetUPitch() const {
|
||||
return frame_->stride(webrtc::kUPlane);
|
||||
}
|
||||
int32 WebRtcVideoRenderFrame::GetVPitch() const {
|
||||
return frame_->stride(webrtc::kVPlane);
|
||||
}
|
||||
|
||||
void* WebRtcVideoRenderFrame::GetNativeHandle() const {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
size_t WebRtcVideoRenderFrame::GetPixelWidth() const {
|
||||
return 1;
|
||||
}
|
||||
size_t WebRtcVideoRenderFrame::GetPixelHeight() const {
|
||||
return 1;
|
||||
}
|
||||
|
||||
int64_t WebRtcVideoRenderFrame::GetElapsedTime() const {
|
||||
// Convert millisecond render time to ns timestamp.
|
||||
return frame_->render_time_ms() * rtc::kNumNanosecsPerMillisec;
|
||||
}
|
||||
int64_t WebRtcVideoRenderFrame::GetTimeStamp() const {
|
||||
// Convert 90K rtp timestamp to ns timestamp.
|
||||
return (frame_->timestamp() / 90) * rtc::kNumNanosecsPerMillisec;
|
||||
}
|
||||
void WebRtcVideoRenderFrame::SetElapsedTime(int64_t elapsed_time) {
|
||||
UNIMPLEMENTED;
|
||||
}
|
||||
void WebRtcVideoRenderFrame::SetTimeStamp(int64_t time_stamp) {
|
||||
UNIMPLEMENTED;
|
||||
}
|
||||
|
||||
int WebRtcVideoRenderFrame::GetRotation() const {
|
||||
UNIMPLEMENTED;
|
||||
return ROTATION_0;
|
||||
}
|
||||
|
||||
VideoFrame* WebRtcVideoRenderFrame::Copy() const {
|
||||
UNIMPLEMENTED;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
bool WebRtcVideoRenderFrame::MakeExclusive() {
|
||||
UNIMPLEMENTED;
|
||||
return false;
|
||||
}
|
||||
|
||||
size_t WebRtcVideoRenderFrame::CopyToBuffer(uint8* buffer, size_t size) const {
|
||||
UNIMPLEMENTED;
|
||||
return 0;
|
||||
}
|
||||
|
||||
VideoFrame* WebRtcVideoRenderFrame::CreateEmptyFrame(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) const {
|
||||
WebRtcVideoFrame* frame = new WebRtcVideoFrame();
|
||||
frame->InitToBlack(w, h, pixel_width, pixel_height, elapsed_time, time_stamp);
|
||||
return frame;
|
||||
}
|
||||
|
||||
} // namespace cricket
|
||||
|
@ -35,6 +35,10 @@
|
||||
#include "webrtc/common_types.h"
|
||||
#include "webrtc/modules/interface/module_common_types.h"
|
||||
|
||||
namespace webrtc {
|
||||
class I420VideoFrame;
|
||||
};
|
||||
|
||||
namespace cricket {
|
||||
|
||||
struct CapturedFrame;
|
||||
@ -129,6 +133,67 @@ class WebRtcVideoFrame : public VideoFrame {
|
||||
int rotation_;
|
||||
};
|
||||
|
||||
// Thin map between VideoFrame and an existing webrtc::I420VideoFrame
|
||||
// to avoid having to copy the rendered VideoFrame prematurely.
|
||||
// This implementation is only safe to use in a const context and should never
|
||||
// be written to.
|
||||
class WebRtcVideoRenderFrame : public VideoFrame {
|
||||
public:
|
||||
explicit WebRtcVideoRenderFrame(const webrtc::I420VideoFrame* frame);
|
||||
|
||||
virtual bool InitToBlack(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) OVERRIDE;
|
||||
virtual bool Reset(uint32 fourcc,
|
||||
int w,
|
||||
int h,
|
||||
int dw,
|
||||
int dh,
|
||||
uint8* sample,
|
||||
size_t sample_size,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp,
|
||||
int rotation) OVERRIDE;
|
||||
virtual size_t GetWidth() const OVERRIDE;
|
||||
virtual size_t GetHeight() const OVERRIDE;
|
||||
virtual const uint8* GetYPlane() const OVERRIDE;
|
||||
virtual const uint8* GetUPlane() const OVERRIDE;
|
||||
virtual const uint8* GetVPlane() const OVERRIDE;
|
||||
virtual uint8* GetYPlane() OVERRIDE;
|
||||
virtual uint8* GetUPlane() OVERRIDE;
|
||||
virtual uint8* GetVPlane() OVERRIDE;
|
||||
virtual int32 GetYPitch() const OVERRIDE;
|
||||
virtual int32 GetUPitch() const OVERRIDE;
|
||||
virtual int32 GetVPitch() const OVERRIDE;
|
||||
virtual void* GetNativeHandle() const OVERRIDE;
|
||||
virtual size_t GetPixelWidth() const OVERRIDE;
|
||||
virtual size_t GetPixelHeight() const OVERRIDE;
|
||||
virtual int64_t GetElapsedTime() const OVERRIDE;
|
||||
virtual int64_t GetTimeStamp() const OVERRIDE;
|
||||
virtual void SetElapsedTime(int64_t elapsed_time) OVERRIDE;
|
||||
virtual void SetTimeStamp(int64_t time_stamp) OVERRIDE;
|
||||
virtual int GetRotation() const OVERRIDE;
|
||||
virtual VideoFrame* Copy() const OVERRIDE;
|
||||
virtual bool MakeExclusive() OVERRIDE;
|
||||
virtual size_t CopyToBuffer(uint8* buffer, size_t size) const OVERRIDE;
|
||||
|
||||
protected:
|
||||
virtual VideoFrame* CreateEmptyFrame(int w,
|
||||
int h,
|
||||
size_t pixel_width,
|
||||
size_t pixel_height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp) const OVERRIDE;
|
||||
|
||||
private:
|
||||
const webrtc::I420VideoFrame* const frame_;
|
||||
};
|
||||
|
||||
} // namespace cricket
|
||||
|
||||
#endif // TALK_MEDIA_WEBRTCVIDEOFRAME_H_
|
||||
|
Reference in New Issue
Block a user