Remove WebRtcTextureVideoFrame
WebRtcTextureVideoFrame is currently an empty shell that only provides a convenience constructor of I420VideoFrame with a texture buffer. This CL moves that constructor, and all unittests, of WebRtcTextureVideoFrame into the base class. Then it's possible to completely remove WebRtcTextureVideoFrame and all its files. BUG=1128 R=pbos@webrtc.org, perkj@webrtc.org Review URL: https://webrtc-codereview.appspot.com/48399004 Cr-Commit-Position: refs/heads/master@{#8638} git-svn-id: http://webrtc.googlecode.com/svn/trunk@8638 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
parent
c2008a0e8c
commit
1af1391b41
@ -463,8 +463,6 @@
|
||||
'media/webrtc/webrtcmediaengine.cc',
|
||||
'media/webrtc/webrtcpassthroughrender.cc',
|
||||
'media/webrtc/webrtcpassthroughrender.h',
|
||||
'media/webrtc/webrtctexturevideoframe.cc',
|
||||
'media/webrtc/webrtctexturevideoframe.h',
|
||||
'media/webrtc/webrtcvideocapturer.cc',
|
||||
'media/webrtc/webrtcvideocapturerfactory.h',
|
||||
'media/webrtc/webrtcvideocapturerfactory.cc',
|
||||
|
@ -1,46 +0,0 @@
|
||||
/*
|
||||
* libjingle
|
||||
* Copyright 2013 Google Inc.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* 3. The name of the author may not be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
|
||||
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include "talk/media/webrtc/webrtctexturevideoframe.h"
|
||||
|
||||
#include "webrtc/base/refcount.h"
|
||||
|
||||
namespace cricket {
|
||||
|
||||
WebRtcTextureVideoFrame::WebRtcTextureVideoFrame(webrtc::NativeHandle* handle,
|
||||
int width,
|
||||
int height,
|
||||
int64_t elapsed_time,
|
||||
int64_t time_stamp)
|
||||
: WebRtcVideoFrame(new rtc::RefCountedObject<webrtc::TextureBuffer>(handle,
|
||||
width,
|
||||
height),
|
||||
elapsed_time,
|
||||
time_stamp) {
|
||||
}
|
||||
|
||||
} // namespace cricket
|
@ -30,14 +30,10 @@
|
||||
|
||||
#include "talk/media/webrtc/webrtcvideoframe.h"
|
||||
|
||||
// TODO(magjed): Remove this when all external dependencies are updated.
|
||||
namespace cricket {
|
||||
|
||||
// A video frame backed by the texture via a native handle.
|
||||
class WebRtcTextureVideoFrame : public WebRtcVideoFrame {
|
||||
public:
|
||||
WebRtcTextureVideoFrame(webrtc::NativeHandle* handle, int width, int height,
|
||||
int64_t elapsed_time, int64_t time_stamp);
|
||||
};
|
||||
typedef WebRtcVideoFrame WebRtcTextureVideoFrame;
|
||||
|
||||
} // namespace cricket
|
||||
|
||||
|
@ -1,84 +0,0 @@
|
||||
/*
|
||||
* libjingle
|
||||
* Copyright 2013 Google Inc.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* 3. The name of the author may not be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
|
||||
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include "talk/media/webrtc/webrtctexturevideoframe.h"
|
||||
|
||||
#include "talk/media/base/videocommon.h"
|
||||
#include "webrtc/base/gunit.h"
|
||||
|
||||
class NativeHandleImpl : public webrtc::NativeHandle {
|
||||
public:
|
||||
NativeHandleImpl() : ref_count_(0) {}
|
||||
virtual ~NativeHandleImpl() {}
|
||||
virtual int32_t AddRef() { return ++ref_count_; }
|
||||
virtual int32_t Release() { return --ref_count_; }
|
||||
virtual void* GetHandle() { return NULL; }
|
||||
|
||||
int32_t ref_count() { return ref_count_; }
|
||||
private:
|
||||
int32_t ref_count_;
|
||||
};
|
||||
|
||||
TEST(WebRtcTextureVideoFrameTest, InitialValues) {
|
||||
NativeHandleImpl handle;
|
||||
cricket::WebRtcTextureVideoFrame frame(&handle, 640, 480, 100, 200);
|
||||
EXPECT_EQ(&handle, frame.GetNativeHandle());
|
||||
EXPECT_EQ(640u, frame.GetWidth());
|
||||
EXPECT_EQ(480u, frame.GetHeight());
|
||||
EXPECT_EQ(100, frame.GetElapsedTime());
|
||||
EXPECT_EQ(200, frame.GetTimeStamp());
|
||||
frame.SetElapsedTime(300);
|
||||
EXPECT_EQ(300, frame.GetElapsedTime());
|
||||
frame.SetTimeStamp(400);
|
||||
EXPECT_EQ(400, frame.GetTimeStamp());
|
||||
}
|
||||
|
||||
TEST(WebRtcTextureVideoFrameTest, CopyFrame) {
|
||||
NativeHandleImpl handle;
|
||||
cricket::WebRtcTextureVideoFrame frame1(&handle, 640, 480, 100, 200);
|
||||
cricket::VideoFrame* frame2 = frame1.Copy();
|
||||
EXPECT_EQ(frame1.GetNativeHandle(), frame2->GetNativeHandle());
|
||||
EXPECT_EQ(frame1.GetWidth(), frame2->GetWidth());
|
||||
EXPECT_EQ(frame1.GetHeight(), frame2->GetHeight());
|
||||
EXPECT_EQ(frame1.GetElapsedTime(), frame2->GetElapsedTime());
|
||||
EXPECT_EQ(frame1.GetTimeStamp(), frame2->GetTimeStamp());
|
||||
delete frame2;
|
||||
}
|
||||
|
||||
TEST(WebRtcTextureVideoFrameTest, RefCount) {
|
||||
NativeHandleImpl handle;
|
||||
EXPECT_EQ(0, handle.ref_count());
|
||||
cricket::WebRtcTextureVideoFrame* frame1 =
|
||||
new cricket::WebRtcTextureVideoFrame(&handle, 640, 480, 100, 200);
|
||||
EXPECT_EQ(1, handle.ref_count());
|
||||
cricket::VideoFrame* frame2 = frame1->Copy();
|
||||
EXPECT_EQ(2, handle.ref_count());
|
||||
delete frame2;
|
||||
EXPECT_EQ(1, handle.ref_count());
|
||||
delete frame1;
|
||||
EXPECT_EQ(0, handle.ref_count());
|
||||
}
|
@ -46,7 +46,6 @@
|
||||
#include "talk/media/webrtc/constants.h"
|
||||
#include "talk/media/webrtc/simulcast.h"
|
||||
#include "talk/media/webrtc/webrtcpassthroughrender.h"
|
||||
#include "talk/media/webrtc/webrtctexturevideoframe.h"
|
||||
#include "talk/media/webrtc/webrtcvideocapturer.h"
|
||||
#include "talk/media/webrtc/webrtcvideodecoderfactory.h"
|
||||
#include "talk/media/webrtc/webrtcvideoencoderfactory.h"
|
||||
|
@ -53,6 +53,22 @@ WebRtcVideoFrame::WebRtcVideoFrame(
|
||||
rotation_(webrtc::kVideoRotation_0) {
|
||||
}
|
||||
|
||||
WebRtcVideoFrame::WebRtcVideoFrame(webrtc::NativeHandle* handle,
|
||||
int width,
|
||||
int height,
|
||||
int64_t elapsed_time_ns,
|
||||
int64_t time_stamp_ns)
|
||||
: video_frame_buffer_(
|
||||
new rtc::RefCountedObject<webrtc::TextureBuffer>(handle,
|
||||
width,
|
||||
height)),
|
||||
pixel_width_(1),
|
||||
pixel_height_(1),
|
||||
elapsed_time_ns_(elapsed_time_ns),
|
||||
time_stamp_ns_(time_stamp_ns),
|
||||
rotation_(webrtc::kVideoRotation_0) {
|
||||
}
|
||||
|
||||
WebRtcVideoFrame::~WebRtcVideoFrame() {}
|
||||
|
||||
bool WebRtcVideoFrame::Init(uint32 format,
|
||||
|
@ -45,6 +45,11 @@ class WebRtcVideoFrame : public VideoFrame {
|
||||
WebRtcVideoFrame(const rtc::scoped_refptr<webrtc::VideoFrameBuffer>& buffer,
|
||||
int64_t elapsed_time_ns,
|
||||
int64_t time_stamp_ns);
|
||||
WebRtcVideoFrame(webrtc::NativeHandle* handle,
|
||||
int width,
|
||||
int height,
|
||||
int64_t elapsed_time_ns,
|
||||
int64_t time_stamp_ns);
|
||||
~WebRtcVideoFrame();
|
||||
|
||||
// Creates a frame from a raw sample with FourCC "format" and size "w" x "h".
|
||||
|
@ -30,6 +30,19 @@
|
||||
#include "talk/media/base/videoframe_unittest.h"
|
||||
#include "talk/media/webrtc/webrtcvideoframe.h"
|
||||
|
||||
class NativeHandleImpl : public webrtc::NativeHandle {
|
||||
public:
|
||||
NativeHandleImpl() : ref_count_(0) {}
|
||||
virtual ~NativeHandleImpl() {}
|
||||
virtual int32_t AddRef() { return ++ref_count_; }
|
||||
virtual int32_t Release() { return --ref_count_; }
|
||||
virtual void* GetHandle() { return NULL; }
|
||||
|
||||
int32_t ref_count() { return ref_count_; }
|
||||
private:
|
||||
int32_t ref_count_;
|
||||
};
|
||||
|
||||
class WebRtcVideoFrameTest : public VideoFrameTest<cricket::WebRtcVideoFrame> {
|
||||
public:
|
||||
WebRtcVideoFrameTest() {
|
||||
@ -304,3 +317,29 @@ TEST_F(WebRtcVideoFrameTest, InitRotated90ApplyRotation) {
|
||||
TEST_F(WebRtcVideoFrameTest, InitRotated90DontApplyRotation) {
|
||||
TestInit(640, 360, webrtc::kVideoRotation_90, false);
|
||||
}
|
||||
|
||||
TEST_F(WebRtcVideoFrameTest, TextureInitialValues) {
|
||||
NativeHandleImpl handle;
|
||||
cricket::WebRtcVideoFrame frame(&handle, 640, 480, 100, 200);
|
||||
EXPECT_EQ(&handle, frame.GetNativeHandle());
|
||||
EXPECT_EQ(640u, frame.GetWidth());
|
||||
EXPECT_EQ(480u, frame.GetHeight());
|
||||
EXPECT_EQ(100, frame.GetElapsedTime());
|
||||
EXPECT_EQ(200, frame.GetTimeStamp());
|
||||
frame.SetElapsedTime(300);
|
||||
EXPECT_EQ(300, frame.GetElapsedTime());
|
||||
frame.SetTimeStamp(400);
|
||||
EXPECT_EQ(400, frame.GetTimeStamp());
|
||||
}
|
||||
|
||||
TEST_F(WebRtcVideoFrameTest, CopyTextureFrame) {
|
||||
NativeHandleImpl handle;
|
||||
cricket::WebRtcVideoFrame frame1(&handle, 640, 480, 100, 200);
|
||||
cricket::VideoFrame* frame2 = frame1.Copy();
|
||||
EXPECT_EQ(frame1.GetNativeHandle(), frame2->GetNativeHandle());
|
||||
EXPECT_EQ(frame1.GetWidth(), frame2->GetWidth());
|
||||
EXPECT_EQ(frame1.GetHeight(), frame2->GetHeight());
|
||||
EXPECT_EQ(frame1.GetElapsedTime(), frame2->GetElapsedTime());
|
||||
EXPECT_EQ(frame1.GetTimeStamp(), frame2->GetTimeStamp());
|
||||
delete frame2;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user