Cleanup: unify rotation to be enum based instead of int for degree.
Split from https://webrtc-codereview.appspot.com/37029004/ BUG=4145 R=pthatcher@webrtc.org, stefan@webrtc.org Review URL: https://webrtc-codereview.appspot.com/37129004 Cr-Commit-Position: refs/heads/master@{#8257} git-svn-id: http://webrtc.googlecode.com/svn/trunk@8257 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
		| @@ -98,6 +98,10 @@ bool CapturedFrame::GetDataSize(uint32* size) const { | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | webrtc::VideoFrameRotation CapturedFrame::GetRotation() const { | ||||||
|  |   return webrtc::ClockwiseRotationFromDegree(rotation); | ||||||
|  | } | ||||||
|  |  | ||||||
| ///////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////// | ||||||
| // Implementation of class VideoCapturer | // Implementation of class VideoCapturer | ||||||
| ///////////////////////////////////////////////////////////////////// | ///////////////////////////////////////////////////////////////////// | ||||||
|   | |||||||
| @@ -79,6 +79,10 @@ struct CapturedFrame { | |||||||
|   // fourcc. Return true if succeeded. |   // fourcc. Return true if succeeded. | ||||||
|   bool GetDataSize(uint32* size) const; |   bool GetDataSize(uint32* size) const; | ||||||
|  |  | ||||||
|  |   // TODO(guoweis): Change the type of |rotation| from int to | ||||||
|  |   // webrtc::VideoFrameRotation once chromium gets the code. | ||||||
|  |   webrtc::VideoFrameRotation GetRotation() const; | ||||||
|  |  | ||||||
|   // The width and height of the captured frame could be different from those |   // The width and height of the captured frame could be different from those | ||||||
|   // of VideoFormat. Once the first frame is captured, the width, height, |   // of VideoFormat. Once the first frame is captured, the width, height, | ||||||
|   // fourcc, pixel_width, and pixel_height should keep the same over frames. |   // fourcc, pixel_width, and pixel_height should keep the same over frames. | ||||||
| @@ -92,7 +96,11 @@ struct CapturedFrame { | |||||||
|   int64  time_stamp;    // timestamp of when the frame was captured, in unix |   int64  time_stamp;    // timestamp of when the frame was captured, in unix | ||||||
|                         // time with nanosecond units. |                         // time with nanosecond units. | ||||||
|   uint32 data_size;     // number of bytes of the frame data |   uint32 data_size;     // number of bytes of the frame data | ||||||
|  |  | ||||||
|  |   // TODO(guoweis): This can't be converted to VideoFrameRotation yet as it's | ||||||
|  |   // used by chrome now. | ||||||
|   int    rotation;      // rotation in degrees of the frame (0, 90, 180, 270) |   int    rotation;      // rotation in degrees of the frame (0, 90, 180, 270) | ||||||
|  |  | ||||||
|   void*  data;          // pointer to the frame data. This object allocates the |   void*  data;          // pointer to the frame data. This object allocates the | ||||||
|                         // memory or points to an existing memory. |                         // memory or points to an existing memory. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -30,17 +30,10 @@ | |||||||
|  |  | ||||||
| #include "webrtc/base/basictypes.h" | #include "webrtc/base/basictypes.h" | ||||||
| #include "webrtc/base/stream.h" | #include "webrtc/base/stream.h" | ||||||
|  | #include "webrtc/common_video/rotation.h"  // VideoFrameRotation. | ||||||
|  |  | ||||||
| namespace cricket { | namespace cricket { | ||||||
|  |  | ||||||
| // Simple rotation constants. |  | ||||||
| enum { |  | ||||||
|   ROTATION_0 = 0, |  | ||||||
|   ROTATION_90 = 90, |  | ||||||
|   ROTATION_180 = 180, |  | ||||||
|   ROTATION_270 = 270 |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| // Represents a YUV420 (a.k.a. I420) video frame. | // Represents a YUV420 (a.k.a. I420) video frame. | ||||||
| class VideoFrame { | class VideoFrame { | ||||||
|  public: |  public: | ||||||
| @@ -55,10 +48,18 @@ class VideoFrame { | |||||||
|   // |dw| is destination width; can be less than |w| if cropping is desired. |   // |dw| is destination width; can be less than |w| if cropping is desired. | ||||||
|   // |dh| is destination height, like |dw|, but must be a positive number. |   // |dh| is destination height, like |dw|, but must be a positive number. | ||||||
|   // Returns whether the function succeeded or failed. |   // Returns whether the function succeeded or failed. | ||||||
|   virtual bool Reset(uint32 fourcc, int w, int h, int dw, int dh, uint8 *sample, |   virtual bool Reset(uint32 fourcc, | ||||||
|                      size_t sample_size, size_t pixel_width, |                      int w, | ||||||
|                      size_t pixel_height, int64_t elapsed_time, |                      int h, | ||||||
|                      int64_t time_stamp, int rotation) = 0; |                      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, | ||||||
|  |                      webrtc::VideoFrameRotation rotation) = 0; | ||||||
|  |  | ||||||
|   // Basic accessors. |   // Basic accessors. | ||||||
|   virtual size_t GetWidth() const = 0; |   virtual size_t GetWidth() const = 0; | ||||||
| @@ -94,7 +95,7 @@ class VideoFrame { | |||||||
|   virtual void SetTimeStamp(int64_t time_stamp) = 0; |   virtual void SetTimeStamp(int64_t time_stamp) = 0; | ||||||
|  |  | ||||||
|   // Indicates the rotation angle in degrees. |   // Indicates the rotation angle in degrees. | ||||||
|   virtual int GetRotation() const = 0; |   virtual webrtc::VideoFrameRotation GetRotation() const = 0; | ||||||
|  |  | ||||||
|   // Make a shallow copy of the frame. The frame buffer itself is not copied. |   // 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 |   // Both the current and new VideoFrame will share a single reference-counted | ||||||
|   | |||||||
| @@ -42,6 +42,7 @@ | |||||||
| #include "webrtc/base/pathutils.h" | #include "webrtc/base/pathutils.h" | ||||||
| #include "webrtc/base/stream.h" | #include "webrtc/base/stream.h" | ||||||
| #include "webrtc/base/stringutils.h" | #include "webrtc/base/stringutils.h" | ||||||
|  | #include "webrtc/video_frame.h" | ||||||
|  |  | ||||||
| #if defined(_MSC_VER) | #if defined(_MSC_VER) | ||||||
| #define ALIGN16(var) __declspec(align(16)) var | #define ALIGN16(var) __declspec(align(16)) var | ||||||
| @@ -83,11 +84,16 @@ class VideoFrameTest : public testing::Test { | |||||||
|  |  | ||||||
|   bool LoadFrame(const std::string& filename, uint32 format, |   bool LoadFrame(const std::string& filename, uint32 format, | ||||||
|                  int32 width, int32 height, T* frame) { |                  int32 width, int32 height, T* frame) { | ||||||
|     return LoadFrame(filename, format, width, height, |     return LoadFrame(filename, format, width, height, width, abs(height), | ||||||
|                      width, abs(height), 0, frame); |                      webrtc::VideoFrameRotation_0, frame); | ||||||
|   } |   } | ||||||
|   bool LoadFrame(const std::string& filename, uint32 format, |   bool LoadFrame(const std::string& filename, | ||||||
|                  int32 width, int32 height, int dw, int dh, int rotation, |                  uint32 format, | ||||||
|  |                  int32 width, | ||||||
|  |                  int32 height, | ||||||
|  |                  int dw, | ||||||
|  |                  int dh, | ||||||
|  |                  webrtc::VideoFrameRotation rotation, | ||||||
|                  T* frame) { |                  T* frame) { | ||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms(LoadSample(filename)); |     rtc::scoped_ptr<rtc::MemoryStream> ms(LoadSample(filename)); | ||||||
|     return LoadFrame(ms.get(), format, width, height, dw, dh, rotation, frame); |     return LoadFrame(ms.get(), format, width, height, dw, dh, rotation, frame); | ||||||
| @@ -95,11 +101,16 @@ class VideoFrameTest : public testing::Test { | |||||||
|   // Load a video frame from a memory stream. |   // Load a video frame from a memory stream. | ||||||
|   bool LoadFrame(rtc::MemoryStream* ms, uint32 format, |   bool LoadFrame(rtc::MemoryStream* ms, uint32 format, | ||||||
|                  int32 width, int32 height, T* frame) { |                  int32 width, int32 height, T* frame) { | ||||||
|     return LoadFrame(ms, format, width, height, |     return LoadFrame(ms, format, width, height, width, abs(height), | ||||||
|                      width, abs(height), 0, frame); |                      webrtc::VideoFrameRotation_0, frame); | ||||||
|   } |   } | ||||||
|   bool LoadFrame(rtc::MemoryStream* ms, uint32 format, |   bool LoadFrame(rtc::MemoryStream* ms, | ||||||
|                  int32 width, int32 height, int dw, int dh, int rotation, |                  uint32 format, | ||||||
|  |                  int32 width, | ||||||
|  |                  int32 height, | ||||||
|  |                  int dw, | ||||||
|  |                  int dh, | ||||||
|  |                  webrtc::VideoFrameRotation rotation, | ||||||
|                  T* frame) { |                  T* frame) { | ||||||
|     if (!ms) { |     if (!ms) { | ||||||
|       return false; |       return false; | ||||||
| @@ -116,11 +127,17 @@ class VideoFrameTest : public testing::Test { | |||||||
|   // Load a frame from a raw buffer. |   // Load a frame from a raw buffer. | ||||||
|   bool LoadFrame(uint8* sample, size_t sample_size, uint32 format, |   bool LoadFrame(uint8* sample, size_t sample_size, uint32 format, | ||||||
|                  int32 width, int32 height, T* frame) { |                  int32 width, int32 height, T* frame) { | ||||||
|     return LoadFrame(sample, sample_size, format, width, height, |     return LoadFrame(sample, sample_size, format, width, height, width, | ||||||
|                      width, abs(height), 0, frame); |                      abs(height), webrtc::VideoFrameRotation_0, frame); | ||||||
|   } |   } | ||||||
|   bool LoadFrame(uint8* sample, size_t sample_size, uint32 format, |   bool LoadFrame(uint8* sample, | ||||||
|                  int32 width, int32 height, int dw, int dh, int rotation, |                  size_t sample_size, | ||||||
|  |                  uint32 format, | ||||||
|  |                  int32 width, | ||||||
|  |                  int32 height, | ||||||
|  |                  int dw, | ||||||
|  |                  int dh, | ||||||
|  |                  webrtc::VideoFrameRotation rotation, | ||||||
|                  T* frame) { |                  T* frame) { | ||||||
|     bool ret = false; |     bool ret = false; | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
| @@ -804,66 +821,62 @@ class VideoFrameTest : public testing::Test { | |||||||
|  |  | ||||||
|  |  | ||||||
| // Macro to help test different rotations | // Macro to help test different rotations | ||||||
| #define TEST_MIRROR(FOURCC, BPP)                                               \ | #define TEST_MIRROR(FOURCC, BPP)                                              \ | ||||||
| void Construct##FOURCC##Mirror() {                                             \ |   void Construct##FOURCC##Mirror() {                                          \ | ||||||
|     T frame1, frame2, frame3;                                                  \ |     T frame1, frame2, frame3;                                                 \ | ||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms(                         \ |     rtc::scoped_ptr<rtc::MemoryStream> ms(                                    \ | ||||||
|         CreateYuvSample(kWidth, kHeight, BPP));                                \ |         CreateYuvSample(kWidth, kHeight, BPP));                               \ | ||||||
|     ASSERT_TRUE(ms.get() != NULL);                                             \ |     ASSERT_TRUE(ms.get() != NULL);                                            \ | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_##FOURCC,                  \ |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_##FOURCC, kWidth,         \ | ||||||
|                           kWidth, -kHeight, kWidth, kHeight,                   \ |                           -kHeight, kWidth, kHeight,                          \ | ||||||
|                           cricket::ROTATION_180, &frame1));                    \ |                           webrtc::VideoFrameRotation_180, &frame1));          \ | ||||||
|     size_t data_size;                                                          \ |     size_t data_size;                                                         \ | ||||||
|     bool ret = ms->GetSize(&data_size);                                        \ |     bool ret = ms->GetSize(&data_size);                                       \ | ||||||
|     EXPECT_TRUE(ret);                                                          \ |     EXPECT_TRUE(ret);                                                         \ | ||||||
|     EXPECT_TRUE(frame2.Init(cricket::FOURCC_##FOURCC,                          \ |     EXPECT_TRUE(                                                              \ | ||||||
|                             kWidth, kHeight, kWidth, kHeight,                  \ |         frame2.Init(cricket::FOURCC_##FOURCC, kWidth, kHeight, kWidth,        \ | ||||||
|                             reinterpret_cast<uint8*>(ms->GetBuffer()),         \ |                     kHeight, reinterpret_cast<uint8*>(ms->GetBuffer()),       \ | ||||||
|                             data_size,                                         \ |                     data_size, 1, 1, 0, 0, webrtc::VideoFrameRotation_0));    \ | ||||||
|                             1, 1, 0, 0, 0));                                   \ |     int width_rotate = static_cast<int>(frame1.GetWidth());                   \ | ||||||
|     int width_rotate = static_cast<int>(frame1.GetWidth());                    \ |     int height_rotate = static_cast<int>(frame1.GetHeight());                 \ | ||||||
|     int height_rotate = static_cast<int>(frame1.GetHeight());                  \ |     EXPECT_TRUE(frame3.InitToBlack(width_rotate, height_rotate, 1, 1, 0, 0)); \ | ||||||
|     EXPECT_TRUE(frame3.InitToBlack(width_rotate, height_rotate, 1, 1, 0, 0));  \ |     libyuv::I420Mirror(                                                       \ | ||||||
|     libyuv::I420Mirror(frame2.GetYPlane(), frame2.GetYPitch(),                 \ |         frame2.GetYPlane(), frame2.GetYPitch(), frame2.GetUPlane(),           \ | ||||||
|                        frame2.GetUPlane(), frame2.GetUPitch(),                 \ |         frame2.GetUPitch(), frame2.GetVPlane(), frame2.GetVPitch(),           \ | ||||||
|                        frame2.GetVPlane(), frame2.GetVPitch(),                 \ |         frame3.GetYPlane(), frame3.GetYPitch(), frame3.GetUPlane(),           \ | ||||||
|                        frame3.GetYPlane(), frame3.GetYPitch(),                 \ |         frame3.GetUPitch(), frame3.GetVPlane(), frame3.GetVPitch(), kWidth,   \ | ||||||
|                        frame3.GetUPlane(), frame3.GetUPitch(),                 \ |         kHeight);                                                             \ | ||||||
|                        frame3.GetVPlane(), frame3.GetVPitch(),                 \ |     EXPECT_TRUE(IsEqual(frame1, frame3, 0));                                  \ | ||||||
|                        kWidth, kHeight);                                       \ |  | ||||||
|     EXPECT_TRUE(IsEqual(frame1, frame3, 0));                                   \ |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   TEST_MIRROR(I420, 420) |   TEST_MIRROR(I420, 420) | ||||||
|  |  | ||||||
| // Macro to help test different rotations | // Macro to help test different rotations | ||||||
| #define TEST_ROTATE(FOURCC, BPP, ROTATE)                                       \ | #define TEST_ROTATE(FOURCC, BPP, ROTATE)                                       \ | ||||||
| void Construct##FOURCC##Rotate##ROTATE() {                                     \ |   void Construct##FOURCC##Rotate##ROTATE() {                                   \ | ||||||
|     T frame1, frame2, frame3;                                                  \ |     T frame1, frame2, frame3;                                                  \ | ||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms(                         \ |     rtc::scoped_ptr<rtc::MemoryStream> ms(                                     \ | ||||||
|         CreateYuvSample(kWidth, kHeight, BPP));                                \ |         CreateYuvSample(kWidth, kHeight, BPP));                                \ | ||||||
|     ASSERT_TRUE(ms.get() != NULL);                                             \ |     ASSERT_TRUE(ms.get() != NULL);                                             \ | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_##FOURCC,                  \ |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_##FOURCC, kWidth, kHeight, \ | ||||||
|                           kWidth, kHeight, kWidth, kHeight,                    \ |                           kWidth, kHeight,                                     \ | ||||||
|                           cricket::ROTATION_##ROTATE, &frame1));               \ |                           webrtc::VideoFrameRotation_##ROTATE, &frame1));      \ | ||||||
|     size_t data_size;                                                          \ |     size_t data_size;                                                          \ | ||||||
|     bool ret = ms->GetSize(&data_size);                                        \ |     bool ret = ms->GetSize(&data_size);                                        \ | ||||||
|     EXPECT_TRUE(ret);                                                          \ |     EXPECT_TRUE(ret);                                                          \ | ||||||
|     EXPECT_TRUE(frame2.Init(cricket::FOURCC_##FOURCC,                          \ |     EXPECT_TRUE(                                                               \ | ||||||
|                             kWidth, kHeight, kWidth, kHeight,                  \ |         frame2.Init(cricket::FOURCC_##FOURCC, kWidth, kHeight, kWidth,         \ | ||||||
|                             reinterpret_cast<uint8*>(ms->GetBuffer()),         \ |                     kHeight, reinterpret_cast<uint8*>(ms->GetBuffer()),        \ | ||||||
|                             data_size,                                         \ |                     data_size, 1, 1, 0, 0, webrtc::VideoFrameRotation_0));     \ | ||||||
|                             1, 1, 0, 0, 0));                                   \ |  | ||||||
|     int width_rotate = static_cast<int>(frame1.GetWidth());                    \ |     int width_rotate = static_cast<int>(frame1.GetWidth());                    \ | ||||||
|     int height_rotate = static_cast<int>(frame1.GetHeight());                  \ |     int height_rotate = static_cast<int>(frame1.GetHeight());                  \ | ||||||
|     EXPECT_TRUE(frame3.InitToBlack(width_rotate, height_rotate, 1, 1, 0, 0));  \ |     EXPECT_TRUE(frame3.InitToBlack(width_rotate, height_rotate, 1, 1, 0, 0));  \ | ||||||
|     libyuv::I420Rotate(frame2.GetYPlane(), frame2.GetYPitch(),                 \ |     libyuv::I420Rotate(                                                        \ | ||||||
|                        frame2.GetUPlane(), frame2.GetUPitch(),                 \ |         frame2.GetYPlane(), frame2.GetYPitch(), frame2.GetUPlane(),            \ | ||||||
|                        frame2.GetVPlane(), frame2.GetVPitch(),                 \ |         frame2.GetUPitch(), frame2.GetVPlane(), frame2.GetVPitch(),            \ | ||||||
|                        frame3.GetYPlane(), frame3.GetYPitch(),                 \ |         frame3.GetYPlane(), frame3.GetYPitch(), frame3.GetUPlane(),            \ | ||||||
|                        frame3.GetUPlane(), frame3.GetUPitch(),                 \ |         frame3.GetUPitch(), frame3.GetVPlane(), frame3.GetVPitch(), kWidth,    \ | ||||||
|                        frame3.GetVPlane(), frame3.GetVPitch(),                 \ |         kHeight, libyuv::kRotate##ROTATE);                                     \ | ||||||
|                        kWidth, kHeight, libyuv::kRotate##ROTATE);              \ |  | ||||||
|     EXPECT_TRUE(IsEqual(frame1, frame3, 0));                                   \ |     EXPECT_TRUE(IsEqual(frame1, frame3, 0));                                   \ | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -899,9 +912,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_90, | ||||||
|                           cricket::ROTATION_90, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test constructing an image from a UYVY buffer rotated 180 degrees. |   // Test constructing an image from a UYVY buffer rotated 180 degrees. | ||||||
| @@ -910,9 +923,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_180, | ||||||
|                           cricket::ROTATION_180, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test constructing an image from a UYVY buffer rotated 270 degrees. |   // Test constructing an image from a UYVY buffer rotated 270 degrees. | ||||||
| @@ -921,9 +934,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_UYVY, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_UYVY, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_270, | ||||||
|                           cricket::ROTATION_270, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test constructing an image from a YUY2 buffer rotated 90 degrees. |   // Test constructing an image from a YUY2 buffer rotated 90 degrees. | ||||||
| @@ -932,9 +945,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_90, | ||||||
|                           cricket::ROTATION_90, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test constructing an image from a YUY2 buffer rotated 180 degrees. |   // Test constructing an image from a YUY2 buffer rotated 180 degrees. | ||||||
| @@ -943,9 +956,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_180, | ||||||
|                           cricket::ROTATION_180, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test constructing an image from a YUY2 buffer rotated 270 degrees. |   // Test constructing an image from a YUY2 buffer rotated 270 degrees. | ||||||
| @@ -954,9 +967,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     rtc::scoped_ptr<rtc::MemoryStream> ms( |     rtc::scoped_ptr<rtc::MemoryStream> ms( | ||||||
|         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); |         CreateYuv422Sample(cricket::FOURCC_YUY2, kWidth, kHeight)); | ||||||
|     ASSERT_TRUE(ms.get() != NULL); |     ASSERT_TRUE(ms.get() != NULL); | ||||||
|     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, |     EXPECT_TRUE(LoadFrame(ms.get(), cricket::FOURCC_YUY2, kWidth, kHeight, | ||||||
|                           kWidth, kHeight, kWidth, kHeight, |                           kWidth, kHeight, webrtc::VideoFrameRotation_270, | ||||||
|                           cricket::ROTATION_270, &frame2)); |                           &frame2)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Test 1 pixel edge case image I420 buffer. |   // Test 1 pixel edge case image I420 buffer. | ||||||
| @@ -964,9 +977,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     T frame; |     T frame; | ||||||
|     uint8 pixel[3] = { 1, 2, 3 }; |     uint8 pixel[3] = { 1, 2, 3 }; | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
|       EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 1, 1, 1, 1, |       EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 1, 1, 1, 1, pixel, | ||||||
|                              pixel, sizeof(pixel), |                              sizeof(pixel), 1, 1, 0, 0, | ||||||
|                              1, 1, 0, 0, 0)); |                              webrtc::VideoFrameRotation_0)); | ||||||
|     } |     } | ||||||
|     const uint8* y = pixel; |     const uint8* y = pixel; | ||||||
|     const uint8* u = y + 1; |     const uint8* u = y + 1; | ||||||
| @@ -981,9 +994,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     uint8 pixels5x5[5 * 5 + ((5 + 1) / 2 * (5 + 1) / 2) *  2]; |     uint8 pixels5x5[5 * 5 + ((5 + 1) / 2 * (5 + 1) / 2) *  2]; | ||||||
|     memset(pixels5x5, 1, 5 * 5 + ((5 + 1) / 2 * (5 + 1) / 2) *  2); |     memset(pixels5x5, 1, 5 * 5 + ((5 + 1) / 2 * (5 + 1) / 2) *  2); | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
|       EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 5, 5, 5, 5, |       EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 5, 5, 5, 5, pixels5x5, | ||||||
|                              pixels5x5, sizeof(pixels5x5), |                              sizeof(pixels5x5), 1, 1, 0, 0, | ||||||
|                              1, 1, 0, 0, 0)); |                              webrtc::VideoFrameRotation_0)); | ||||||
|     } |     } | ||||||
|     EXPECT_EQ(4u, frame.GetWidth()); |     EXPECT_EQ(4u, frame.GetWidth()); | ||||||
|     EXPECT_EQ(4u, frame.GetHeight()); |     EXPECT_EQ(4u, frame.GetHeight()); | ||||||
| @@ -997,9 +1010,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     T frame; |     T frame; | ||||||
|     uint8 pixel[4] = { 64, 128, 192, 255 }; |     uint8 pixel[4] = { 64, 128, 192, 255 }; | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
|       EXPECT_TRUE(frame.Init(cricket::FOURCC_ARGB, 1, 1, 1, 1, |       EXPECT_TRUE(frame.Init(cricket::FOURCC_ARGB, 1, 1, 1, 1, pixel, | ||||||
|                              pixel, sizeof(pixel), |                              sizeof(pixel), 1, 1, 0, 0, | ||||||
|                              1, 1, 0, 0, 0)); |                              webrtc::VideoFrameRotation_0)); | ||||||
|     } |     } | ||||||
|     // Convert back to ARGB. |     // Convert back to ARGB. | ||||||
|     size_t out_size = 4; |     size_t out_size = 4; | ||||||
| @@ -1034,9 +1047,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|                             255, 255, 255, 255 }; |                             255, 255, 255, 255 }; | ||||||
|  |  | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
|       EXPECT_TRUE(frame.Init(cricket::FOURCC_ARGB, 10, 1, 10, 1, |       EXPECT_TRUE(frame.Init(cricket::FOURCC_ARGB, 10, 1, 10, 1, pixel, | ||||||
|                              pixel, sizeof(pixel), |                              sizeof(pixel), 1, 1, 0, 0, | ||||||
|                              1, 1, 0, 0, 0)); |                              webrtc::VideoFrameRotation_0)); | ||||||
|     } |     } | ||||||
|     // Convert back to ARGB |     // Convert back to ARGB | ||||||
|     size_t out_size = 10 * 4; |     size_t out_size = 10 * 4; | ||||||
| @@ -1092,7 +1105,8 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     T frame1, frame2; |     T frame1, frame2; | ||||||
|     ASSERT_TRUE(LoadFrameNoRepeat(&frame1)); |     ASSERT_TRUE(LoadFrameNoRepeat(&frame1)); | ||||||
|     ASSERT_TRUE(LoadFrame(kImageFilename, cricket::FOURCC_I420, kWidth, kHeight, |     ASSERT_TRUE(LoadFrame(kImageFilename, cricket::FOURCC_I420, kWidth, kHeight, | ||||||
|                           kWidth, kHeight * 3 / 4, 0, &frame2)); |                           kWidth, kHeight * 3 / 4, webrtc::VideoFrameRotation_0, | ||||||
|  |                           &frame2)); | ||||||
|     EXPECT_TRUE(IsEqualWithCrop(frame2, frame1, 0, kHeight / 8, 0)); |     EXPECT_TRUE(IsEqualWithCrop(frame2, frame1, 0, kHeight / 8, 0)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -1410,10 +1424,10 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     EXPECT_TRUE(frame2.InitToBlack(kWidth, kHeight, 1, 1, 0, 0)); |     EXPECT_TRUE(frame2.InitToBlack(kWidth, kHeight, 1, 1, 0, 0)); | ||||||
|     EXPECT_TRUE(IsBlack(frame1)); |     EXPECT_TRUE(IsBlack(frame1)); | ||||||
|     EXPECT_TRUE(IsEqual(frame1, frame2, 0)); |     EXPECT_TRUE(IsEqual(frame1, frame2, 0)); | ||||||
|     EXPECT_TRUE(frame1.Reset(cricket::FOURCC_I420, |     EXPECT_TRUE(frame1.Reset(cricket::FOURCC_I420, kWidth, kHeight, kWidth, | ||||||
|                              kWidth, kHeight, kWidth, kHeight, |                              kHeight, reinterpret_cast<uint8*>(ms->GetBuffer()), | ||||||
|                              reinterpret_cast<uint8*>(ms->GetBuffer()), |                              data_size, 1, 1, 0, 0, | ||||||
|                              data_size, 1, 1, 0, 0, 0)); |                              webrtc::VideoFrameRotation_0)); | ||||||
|     EXPECT_FALSE(IsBlack(frame1)); |     EXPECT_FALSE(IsBlack(frame1)); | ||||||
|     EXPECT_FALSE(IsEqual(frame1, frame2, 0)); |     EXPECT_FALSE(IsEqual(frame1, frame2, 0)); | ||||||
|   } |   } | ||||||
| @@ -1866,10 +1880,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|                                       v, kWidth / 2, |                                       v, kWidth / 2, | ||||||
|                                       kWidth, kHeight)); |                                       kWidth, kHeight)); | ||||||
|     } |     } | ||||||
|     EXPECT_TRUE(frame2.Init(cricket::FOURCC_I422, |     EXPECT_TRUE(frame2.Init(cricket::FOURCC_I422, kWidth, kHeight, kWidth, | ||||||
|                             kWidth, kHeight, kWidth, kHeight, |                             kHeight, y, out_size, 1, 1, 0, 0, | ||||||
|                             y, |                             webrtc::VideoFrameRotation_0)); | ||||||
|                             out_size,  1, 1, 0, 0, cricket::ROTATION_0)); |  | ||||||
|     EXPECT_TRUE(IsEqual(frame1, frame2, 1)); |     EXPECT_TRUE(IsEqual(frame1, frame2, 1)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -2074,9 +2087,9 @@ void Construct##FOURCC##Rotate##ROTATE() {                                     \ | |||||||
|     memset(out.get(), 0xfb, out_size + 1);  // Fill buffer |     memset(out.get(), 0xfb, out_size + 1);  // Fill buffer | ||||||
|     uint8 pixel[3] = { 1, 2, 3 }; |     uint8 pixel[3] = { 1, 2, 3 }; | ||||||
|     T frame; |     T frame; | ||||||
|     EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 1, 1, 1, 1, |     EXPECT_TRUE(frame.Init(cricket::FOURCC_I420, 1, 1, 1, 1, pixel, | ||||||
|                            pixel, sizeof(pixel), |                            sizeof(pixel), 1, 1, 0, 0, | ||||||
|                            1, 1, 0, 0, 0)); |                            webrtc::VideoFrameRotation_0)); | ||||||
|     for (int i = 0; i < repeat_; ++i) { |     for (int i = 0; i < repeat_; ++i) { | ||||||
|       EXPECT_EQ(out_size, frame.CopyToBuffer(out.get(), out_size)); |       EXPECT_EQ(out_size, frame.CopyToBuffer(out.get(), out_size)); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -52,10 +52,18 @@ bool WebRtcTextureVideoFrame::InitToBlack( | |||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool WebRtcTextureVideoFrame::Reset( | bool WebRtcTextureVideoFrame::Reset(uint32 fourcc, | ||||||
|     uint32 fourcc, int w, int h, int dw, int dh, uint8* sample, |                                     int w, | ||||||
|     size_t sample_size, size_t pixel_width, size_t pixel_height, |                                     int h, | ||||||
|     int64_t elapsed_time, int64_t time_stamp, int rotation) { |                                     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, | ||||||
|  |                                     webrtc::VideoFrameRotation rotation) { | ||||||
|   UNIMPLEMENTED; |   UNIMPLEMENTED; | ||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -46,11 +46,18 @@ class WebRtcTextureVideoFrame : public VideoFrame { | |||||||
|   virtual bool InitToBlack(int w, int h, size_t pixel_width, |   virtual bool InitToBlack(int w, int h, size_t pixel_width, | ||||||
|                            size_t pixel_height, int64_t elapsed_time, |                            size_t pixel_height, int64_t elapsed_time, | ||||||
|                            int64_t time_stamp); |                            int64_t time_stamp); | ||||||
|   virtual bool Reset(uint32 fourcc, int w, int h, int dw, int dh, uint8* sample, |   virtual bool Reset(uint32 fourcc, | ||||||
|                      size_t sample_size, size_t pixel_width, |                      int w, | ||||||
|                      size_t pixel_height, int64_t elapsed_time, |                      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, |                      int64_t time_stamp, | ||||||
|                      int rotation); |                      webrtc::VideoFrameRotation rotation); | ||||||
|   virtual size_t GetWidth() const { return width_; } |   virtual size_t GetWidth() const { return width_; } | ||||||
|   virtual size_t GetHeight() const { return height_; } |   virtual size_t GetHeight() const { return height_; } | ||||||
|   virtual const uint8* GetYPlane() const; |   virtual const uint8* GetYPlane() const; | ||||||
| @@ -70,7 +77,9 @@ class WebRtcTextureVideoFrame : public VideoFrame { | |||||||
|     elapsed_time_ = elapsed_time; |     elapsed_time_ = elapsed_time; | ||||||
|   } |   } | ||||||
|   virtual void SetTimeStamp(int64_t time_stamp) { time_stamp_ = time_stamp; } |   virtual void SetTimeStamp(int64_t time_stamp) { time_stamp_ = time_stamp; } | ||||||
|   virtual int GetRotation() const { return 0; } |   virtual webrtc::VideoFrameRotation GetRotation() const { | ||||||
|  |     return webrtc::VideoFrameRotation_0; | ||||||
|  |   } | ||||||
|   virtual VideoFrame* Copy() const; |   virtual VideoFrame* Copy() const; | ||||||
|   virtual bool MakeExclusive(); |   virtual bool MakeExclusive(); | ||||||
|   virtual size_t CopyToBuffer(uint8* buffer, size_t size) const; |   virtual size_t CopyToBuffer(uint8* buffer, size_t size) const; | ||||||
|   | |||||||
| @@ -430,8 +430,8 @@ class WebRtcRenderAdapter : public webrtc::ExternalRenderer { | |||||||
|   int DeliverBufferFrame(unsigned char* buffer, size_t buffer_size, |   int DeliverBufferFrame(unsigned char* buffer, size_t buffer_size, | ||||||
|                          int64 time_stamp, int64 elapsed_time) { |                          int64 time_stamp, int64 elapsed_time) { | ||||||
|     WebRtcVideoFrame video_frame; |     WebRtcVideoFrame video_frame; | ||||||
|     video_frame.Alias(buffer, buffer_size, width_, height_, |     video_frame.Alias(buffer, buffer_size, width_, height_, 1, 1, elapsed_time, | ||||||
|                       1, 1, elapsed_time, time_stamp, 0); |                       time_stamp, webrtc::VideoFrameRotation_0); | ||||||
|  |  | ||||||
|     // Sanity check on decoded frame size. |     // Sanity check on decoded frame size. | ||||||
|     if (buffer_size != VideoFrame::SizeOf(width_, height_)) { |     if (buffer_size != VideoFrame::SizeOf(width_, height_)) { | ||||||
|   | |||||||
| @@ -115,10 +115,18 @@ WebRtcVideoFrame::WebRtcVideoFrame() | |||||||
|  |  | ||||||
| WebRtcVideoFrame::~WebRtcVideoFrame() {} | WebRtcVideoFrame::~WebRtcVideoFrame() {} | ||||||
|  |  | ||||||
| bool WebRtcVideoFrame::Init( | bool WebRtcVideoFrame::Init(uint32 format, | ||||||
|     uint32 format, int w, int h, int dw, int dh, uint8* sample, |                             int w, | ||||||
|     size_t sample_size, size_t pixel_width, size_t pixel_height, |                             int h, | ||||||
|     int64_t elapsed_time, int64_t time_stamp, int rotation) { |                             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, | ||||||
|  |                             webrtc::VideoFrameRotation rotation) { | ||||||
|   return Reset(format, w, h, dw, dh, sample, sample_size, pixel_width, |   return Reset(format, w, h, dw, dh, sample, sample_size, pixel_width, | ||||||
|                pixel_height, elapsed_time, time_stamp, rotation); |                pixel_height, elapsed_time, time_stamp, rotation); | ||||||
| } | } | ||||||
| @@ -127,24 +135,19 @@ bool WebRtcVideoFrame::Init(const CapturedFrame* frame, int dw, int dh) { | |||||||
|   return Reset(frame->fourcc, frame->width, frame->height, dw, dh, |   return Reset(frame->fourcc, frame->width, frame->height, dw, dh, | ||||||
|                static_cast<uint8*>(frame->data), frame->data_size, |                static_cast<uint8*>(frame->data), frame->data_size, | ||||||
|                frame->pixel_width, frame->pixel_height, frame->elapsed_time, |                frame->pixel_width, frame->pixel_height, frame->elapsed_time, | ||||||
|                frame->time_stamp, frame->rotation); |                frame->time_stamp, frame->GetRotation()); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool WebRtcVideoFrame::Alias(const CapturedFrame* frame, int dw, int dh) { | bool WebRtcVideoFrame::Alias(const CapturedFrame* frame, int dw, int dh) { | ||||||
|   if (CanonicalFourCC(frame->fourcc) != FOURCC_I420 || frame->rotation != 0 || |   if (CanonicalFourCC(frame->fourcc) != FOURCC_I420 || | ||||||
|  |       (frame->GetRotation() != webrtc::VideoFrameRotation_0) || | ||||||
|       frame->width != dw || frame->height != dh) { |       frame->width != dw || frame->height != dh) { | ||||||
|     // TODO(fbarchard): Enable aliasing of more formats. |     // TODO(fbarchard): Enable aliasing of more formats. | ||||||
|     return Init(frame, dw, dh); |     return Init(frame, dw, dh); | ||||||
|   } else { |   } else { | ||||||
|     Alias(static_cast<uint8*>(frame->data), |     Alias(static_cast<uint8*>(frame->data), frame->data_size, frame->width, | ||||||
|           frame->data_size, |           frame->height, frame->pixel_width, frame->pixel_height, | ||||||
|           frame->width, |           frame->elapsed_time, frame->time_stamp, frame->GetRotation()); | ||||||
|           frame->height, |  | ||||||
|           frame->pixel_width, |  | ||||||
|           frame->pixel_height, |  | ||||||
|           frame->elapsed_time, |  | ||||||
|           frame->time_stamp, |  | ||||||
|           frame->rotation); |  | ||||||
|     return true; |     return true; | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -156,10 +159,15 @@ bool WebRtcVideoFrame::InitToBlack(int w, int h, size_t pixel_width, | |||||||
|   return SetToBlack(); |   return SetToBlack(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void WebRtcVideoFrame::Alias( | void WebRtcVideoFrame::Alias(uint8* buffer, | ||||||
|     uint8* buffer, size_t buffer_size, int w, int h, size_t pixel_width, |                              size_t buffer_size, | ||||||
|     size_t pixel_height, int64_t elapsed_time, int64_t time_stamp, |                              int w, | ||||||
|     int rotation) { |                              int h, | ||||||
|  |                              size_t pixel_width, | ||||||
|  |                              size_t pixel_height, | ||||||
|  |                              int64_t elapsed_time, | ||||||
|  |                              int64_t time_stamp, | ||||||
|  |                              webrtc::VideoFrameRotation rotation) { | ||||||
|   rtc::scoped_refptr<RefCountedBuffer> video_buffer( |   rtc::scoped_refptr<RefCountedBuffer> video_buffer( | ||||||
|       new RefCountedBuffer()); |       new RefCountedBuffer()); | ||||||
|   video_buffer->Alias(buffer, buffer_size); |   video_buffer->Alias(buffer, buffer_size); | ||||||
| @@ -257,10 +265,15 @@ size_t WebRtcVideoFrame::ConvertToRgbBuffer(uint32 to_fourcc, uint8* buffer, | |||||||
|   return VideoFrame::ConvertToRgbBuffer(to_fourcc, buffer, size, stride_rgb); |   return VideoFrame::ConvertToRgbBuffer(to_fourcc, buffer, size, stride_rgb); | ||||||
| } | } | ||||||
|  |  | ||||||
| void WebRtcVideoFrame::Attach( | void WebRtcVideoFrame::Attach(RefCountedBuffer* video_buffer, | ||||||
|     RefCountedBuffer* video_buffer, size_t buffer_size, int w, int h, |                               size_t buffer_size, | ||||||
|     size_t pixel_width, size_t pixel_height, int64_t elapsed_time, |                               int w, | ||||||
|     int64_t time_stamp, int rotation) { |                               int h, | ||||||
|  |                               size_t pixel_width, | ||||||
|  |                               size_t pixel_height, | ||||||
|  |                               int64_t elapsed_time, | ||||||
|  |                               int64_t time_stamp, | ||||||
|  |                               webrtc::VideoFrameRotation rotation) { | ||||||
|   if (video_buffer_.get() == video_buffer) { |   if (video_buffer_.get() == video_buffer) { | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
| @@ -282,10 +295,18 @@ const webrtc::VideoFrame* WebRtcVideoFrame::frame() const { | |||||||
|   return video_buffer_->frame(); |   return video_buffer_->frame(); | ||||||
| } | } | ||||||
|  |  | ||||||
| bool WebRtcVideoFrame::Reset( | bool WebRtcVideoFrame::Reset(uint32 format, | ||||||
|     uint32 format, int w, int h, int dw, int dh, uint8* sample, |                              int w, | ||||||
|     size_t sample_size, size_t pixel_width, size_t pixel_height, |                              int h, | ||||||
|     int64_t elapsed_time, int64_t time_stamp, int rotation) { |                              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, | ||||||
|  |                              webrtc::VideoFrameRotation rotation) { | ||||||
|   if (!Validate(format, w, h, sample, sample_size)) { |   if (!Validate(format, w, h, sample, sample_size)) { | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
| @@ -313,7 +334,7 @@ bool WebRtcVideoFrame::Reset( | |||||||
|   // Since the libyuv::ConvertToI420 will handle the rotation, so the |   // Since the libyuv::ConvertToI420 will handle the rotation, so the | ||||||
|   // new frame's rotation should always be 0. |   // new frame's rotation should always be 0. | ||||||
|   Attach(video_buffer.get(), desired_size, new_width, new_height, pixel_width, |   Attach(video_buffer.get(), desired_size, new_width, new_height, pixel_width, | ||||||
|          pixel_height, elapsed_time, time_stamp, 0); |          pixel_height, elapsed_time, time_stamp, webrtc::VideoFrameRotation_0); | ||||||
|  |  | ||||||
|   int horiz_crop = ((w - dw) / 2) & ~1; |   int horiz_crop = ((w - dw) / 2) & ~1; | ||||||
|   // ARGB on Windows has negative height. |   // ARGB on Windows has negative height. | ||||||
| @@ -356,7 +377,7 @@ void WebRtcVideoFrame::InitToEmptyBuffer(int w, int h, size_t pixel_width, | |||||||
|   rtc::scoped_refptr<RefCountedBuffer> video_buffer( |   rtc::scoped_refptr<RefCountedBuffer> video_buffer( | ||||||
|       new RefCountedBuffer(buffer_size)); |       new RefCountedBuffer(buffer_size)); | ||||||
|   Attach(video_buffer.get(), buffer_size, w, h, pixel_width, pixel_height, |   Attach(video_buffer.get(), buffer_size, w, h, pixel_width, pixel_height, | ||||||
|          elapsed_time, time_stamp, 0); |          elapsed_time, time_stamp, webrtc::VideoFrameRotation_0); | ||||||
| } | } | ||||||
|  |  | ||||||
| WebRtcVideoRenderFrame::WebRtcVideoRenderFrame( | WebRtcVideoRenderFrame::WebRtcVideoRenderFrame( | ||||||
| @@ -386,7 +407,7 @@ bool WebRtcVideoRenderFrame::Reset(uint32 fourcc, | |||||||
|                                    size_t pixel_height, |                                    size_t pixel_height, | ||||||
|                                    int64_t elapsed_time, |                                    int64_t elapsed_time, | ||||||
|                                    int64_t time_stamp, |                                    int64_t time_stamp, | ||||||
|                                    int rotation) { |                                    webrtc::VideoFrameRotation rotation) { | ||||||
|   UNIMPLEMENTED; |   UNIMPLEMENTED; | ||||||
|   return false; |   return false; | ||||||
| } | } | ||||||
| @@ -455,9 +476,9 @@ void WebRtcVideoRenderFrame::SetTimeStamp(int64_t time_stamp) { | |||||||
|   UNIMPLEMENTED; |   UNIMPLEMENTED; | ||||||
| } | } | ||||||
|  |  | ||||||
| int WebRtcVideoRenderFrame::GetRotation() const { | webrtc::VideoFrameRotation WebRtcVideoRenderFrame::GetRotation() const { | ||||||
|   UNIMPLEMENTED; |   UNIMPLEMENTED; | ||||||
|   return ROTATION_0; |   return webrtc::VideoFrameRotation_0; | ||||||
| } | } | ||||||
|  |  | ||||||
| // TODO(magjed): Make this copy shallow instead of deep, BUG=1128. There is no | // TODO(magjed): Make this copy shallow instead of deep, BUG=1128. There is no | ||||||
|   | |||||||
| @@ -52,9 +52,18 @@ class WebRtcVideoFrame : public VideoFrame { | |||||||
|   // "h" can be negative indicating a vertically flipped image. |   // "h" can be negative indicating a vertically flipped image. | ||||||
|   // "dh" is destination height if cropping is desired and is always positive. |   // "dh" is destination height if cropping is desired and is always positive. | ||||||
|   // Returns "true" if successful. |   // Returns "true" if successful. | ||||||
|   bool Init(uint32 format, int w, int h, int dw, int dh, uint8* sample, |   bool Init(uint32 format, | ||||||
|             size_t sample_size, size_t pixel_width, size_t pixel_height, |             int w, | ||||||
|             int64_t elapsed_time, int64_t time_stamp, int rotation); |             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, | ||||||
|  |             webrtc::VideoFrameRotation rotation); | ||||||
|  |  | ||||||
|   bool Init(const CapturedFrame* frame, int dw, int dh); |   bool Init(const CapturedFrame* frame, int dw, int dh); | ||||||
|  |  | ||||||
| @@ -70,18 +79,32 @@ class WebRtcVideoFrame : public VideoFrame { | |||||||
|  |  | ||||||
|   // Aliases this WebRtcVideoFrame to a memory buffer. |buffer| must outlive |   // Aliases this WebRtcVideoFrame to a memory buffer. |buffer| must outlive | ||||||
|   // this WebRtcVideoFrame. |   // this WebRtcVideoFrame. | ||||||
|   void Alias(uint8* buffer, size_t buffer_size, int w, int h, |   void Alias(uint8* buffer, | ||||||
|              size_t pixel_width, size_t pixel_height, int64_t elapsed_time, |              size_t buffer_size, | ||||||
|              int64_t time_stamp, int rotation); |              int w, | ||||||
|  |              int h, | ||||||
|  |              size_t pixel_width, | ||||||
|  |              size_t pixel_height, | ||||||
|  |              int64_t elapsed_time, | ||||||
|  |              int64_t time_stamp, | ||||||
|  |              webrtc::VideoFrameRotation rotation); | ||||||
|  |  | ||||||
|   webrtc::VideoFrame* frame(); |   webrtc::VideoFrame* frame(); | ||||||
|   const webrtc::VideoFrame* frame() const; |   const webrtc::VideoFrame* frame() const; | ||||||
|  |  | ||||||
|   // From base class VideoFrame. |   // From base class VideoFrame. | ||||||
|   virtual bool Reset(uint32 format, int w, int h, int dw, int dh, uint8* sample, |   virtual bool Reset(uint32 format, | ||||||
|                      size_t sample_size, size_t pixel_width, |                      int w, | ||||||
|                      size_t pixel_height, int64_t elapsed_time, |                      int h, | ||||||
|                      int64_t time_stamp, int rotation); |                      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, | ||||||
|  |                      webrtc::VideoFrameRotation rotation); | ||||||
|  |  | ||||||
|   virtual size_t GetWidth() const; |   virtual size_t GetWidth() const; | ||||||
|   virtual size_t GetHeight() const; |   virtual size_t GetHeight() const; | ||||||
| @@ -105,7 +128,7 @@ class WebRtcVideoFrame : public VideoFrame { | |||||||
|   } |   } | ||||||
|   virtual void SetTimeStamp(int64_t time_stamp) { time_stamp_ = time_stamp; } |   virtual void SetTimeStamp(int64_t time_stamp) { time_stamp_ = time_stamp; } | ||||||
|  |  | ||||||
|   virtual int GetRotation() const { return rotation_; } |   virtual webrtc::VideoFrameRotation GetRotation() const { return rotation_; } | ||||||
|  |  | ||||||
|   virtual VideoFrame* Copy() const; |   virtual VideoFrame* Copy() const; | ||||||
|   virtual bool MakeExclusive(); |   virtual bool MakeExclusive(); | ||||||
| @@ -117,9 +140,15 @@ class WebRtcVideoFrame : public VideoFrame { | |||||||
|   class FrameBuffer; |   class FrameBuffer; | ||||||
|   typedef rtc::RefCountedObject<FrameBuffer> RefCountedBuffer; |   typedef rtc::RefCountedObject<FrameBuffer> RefCountedBuffer; | ||||||
|  |  | ||||||
|   void Attach(RefCountedBuffer* video_buffer, size_t buffer_size, int w, int h, |   void Attach(RefCountedBuffer* video_buffer, | ||||||
|               size_t pixel_width, size_t pixel_height, int64_t elapsed_time, |               size_t buffer_size, | ||||||
|               int64_t time_stamp, int rotation); |               int w, | ||||||
|  |               int h, | ||||||
|  |               size_t pixel_width, | ||||||
|  |               size_t pixel_height, | ||||||
|  |               int64_t elapsed_time, | ||||||
|  |               int64_t time_stamp, | ||||||
|  |               webrtc::VideoFrameRotation rotation); | ||||||
|  |  | ||||||
|   virtual VideoFrame* CreateEmptyFrame(int w, int h, size_t pixel_width, |   virtual VideoFrame* CreateEmptyFrame(int w, int h, size_t pixel_width, | ||||||
|                                        size_t pixel_height, |                                        size_t pixel_height, | ||||||
| @@ -131,7 +160,7 @@ class WebRtcVideoFrame : public VideoFrame { | |||||||
|   size_t pixel_height_; |   size_t pixel_height_; | ||||||
|   int64_t elapsed_time_; |   int64_t elapsed_time_; | ||||||
|   int64_t time_stamp_; |   int64_t time_stamp_; | ||||||
|   int rotation_; |   webrtc::VideoFrameRotation rotation_; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Thin map between VideoFrame and an existing webrtc::I420VideoFrame | // Thin map between VideoFrame and an existing webrtc::I420VideoFrame | ||||||
| @@ -160,7 +189,7 @@ class WebRtcVideoRenderFrame : public VideoFrame { | |||||||
|                      size_t pixel_height, |                      size_t pixel_height, | ||||||
|                      int64_t elapsed_time, |                      int64_t elapsed_time, | ||||||
|                      int64_t time_stamp, |                      int64_t time_stamp, | ||||||
|                      int rotation) OVERRIDE; |                      webrtc::VideoFrameRotation rotation) OVERRIDE; | ||||||
|   virtual size_t GetWidth() const OVERRIDE; |   virtual size_t GetWidth() const OVERRIDE; | ||||||
|   virtual size_t GetHeight() const OVERRIDE; |   virtual size_t GetHeight() const OVERRIDE; | ||||||
|   virtual const uint8* GetYPlane() const OVERRIDE; |   virtual const uint8* GetYPlane() const OVERRIDE; | ||||||
| @@ -179,7 +208,7 @@ class WebRtcVideoRenderFrame : public VideoFrame { | |||||||
|   virtual int64_t GetTimeStamp() const OVERRIDE; |   virtual int64_t GetTimeStamp() const OVERRIDE; | ||||||
|   virtual void SetElapsedTime(int64_t elapsed_time) OVERRIDE; |   virtual void SetElapsedTime(int64_t elapsed_time) OVERRIDE; | ||||||
|   virtual void SetTimeStamp(int64_t time_stamp) OVERRIDE; |   virtual void SetTimeStamp(int64_t time_stamp) OVERRIDE; | ||||||
|   virtual int GetRotation() const OVERRIDE; |   virtual webrtc::VideoFrameRotation GetRotation() const OVERRIDE; | ||||||
|   virtual VideoFrame* Copy() const OVERRIDE; |   virtual VideoFrame* Copy() const OVERRIDE; | ||||||
|   virtual bool MakeExclusive() OVERRIDE; |   virtual bool MakeExclusive() OVERRIDE; | ||||||
|   virtual size_t CopyToBuffer(uint8* buffer, size_t size) const OVERRIDE; |   virtual size_t CopyToBuffer(uint8* buffer, size_t size) const OVERRIDE; | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ class WebRtcVideoFrameTest : public VideoFrameTest<cricket::WebRtcVideoFrame> { | |||||||
|     captured_frame.pixel_height = 1; |     captured_frame.pixel_height = 1; | ||||||
|     captured_frame.elapsed_time = 1234; |     captured_frame.elapsed_time = 1234; | ||||||
|     captured_frame.time_stamp = 5678; |     captured_frame.time_stamp = 5678; | ||||||
|     captured_frame.rotation = 0; |     captured_frame.rotation = webrtc::VideoFrameRotation_0; | ||||||
|     captured_frame.width = frame_width; |     captured_frame.width = frame_width; | ||||||
|     captured_frame.height = frame_height; |     captured_frame.height = frame_height; | ||||||
|     captured_frame.data_size = (frame_width * frame_height) + |     captured_frame.data_size = (frame_width * frame_height) + | ||||||
| @@ -62,7 +62,7 @@ class WebRtcVideoFrameTest : public VideoFrameTest<cricket::WebRtcVideoFrame> { | |||||||
|     EXPECT_EQ(1u, frame.GetPixelHeight()); |     EXPECT_EQ(1u, frame.GetPixelHeight()); | ||||||
|     EXPECT_EQ(1234, frame.GetElapsedTime()); |     EXPECT_EQ(1234, frame.GetElapsedTime()); | ||||||
|     EXPECT_EQ(5678, frame.GetTimeStamp()); |     EXPECT_EQ(5678, frame.GetTimeStamp()); | ||||||
|     EXPECT_EQ(0, frame.GetRotation()); |     EXPECT_EQ(webrtc::VideoFrameRotation_0, frame.GetRotation()); | ||||||
|     // The size of the new frame should have been cropped to multiple of 4. |     // The size of the new frame should have been cropped to multiple of 4. | ||||||
|     EXPECT_EQ(static_cast<size_t>(cropped_width & ~3), frame.GetWidth()); |     EXPECT_EQ(static_cast<size_t>(cropped_width & ~3), frame.GetWidth()); | ||||||
|     EXPECT_EQ(static_cast<size_t>(cropped_height & ~3), frame.GetHeight()); |     EXPECT_EQ(static_cast<size_t>(cropped_height & ~3), frame.GetHeight()); | ||||||
| @@ -266,9 +266,9 @@ TEST_F(WebRtcVideoFrameTest, Alias) { | |||||||
|   const int64 time_stamp = INT64_C(0x7FFFFFFFFFFFFFF0); |   const int64 time_stamp = INT64_C(0x7FFFFFFFFFFFFFF0); | ||||||
|   frame1.SetTimeStamp(time_stamp); |   frame1.SetTimeStamp(time_stamp); | ||||||
|   EXPECT_EQ(time_stamp, frame1.GetTimeStamp()); |   EXPECT_EQ(time_stamp, frame1.GetTimeStamp()); | ||||||
|   frame2.Alias(frame1.frame()->Buffer(), frame1.frame()->Size(), |   frame2.Alias(frame1.frame()->Buffer(), frame1.frame()->Size(), kWidth, | ||||||
|                kWidth, kHeight, 1, 1, |                kHeight, 1, 1, frame1.GetElapsedTime(), frame1.GetTimeStamp(), | ||||||
|                frame1.GetElapsedTime(), frame1.GetTimeStamp(), 0); |                webrtc::VideoFrameRotation_0); | ||||||
|   EXPECT_TRUE(IsEqual(frame1, frame2, 0)); |   EXPECT_TRUE(IsEqual(frame1, frame2, 0)); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										33
									
								
								webrtc/common_video/rotation.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								webrtc/common_video/rotation.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | /* | ||||||
|  |  *  Copyright (c) 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. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #ifndef WEBRTC_COMMON_VIDEO_ROTATION_H_ | ||||||
|  | #define WEBRTC_COMMON_VIDEO_ROTATION_H_ | ||||||
|  |  | ||||||
|  | #include "webrtc/base/common.h" | ||||||
|  |  | ||||||
|  | namespace webrtc { | ||||||
|  |  | ||||||
|  | // enum for clockwise rotation. | ||||||
|  | enum VideoFrameRotation { | ||||||
|  |   VideoFrameRotation_0 = 0, | ||||||
|  |   VideoFrameRotation_90 = 90, | ||||||
|  |   VideoFrameRotation_180 = 180, | ||||||
|  |   VideoFrameRotation_270 = 270 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | inline VideoFrameRotation ClockwiseRotationFromDegree(int rotation) { | ||||||
|  |   ASSERT(rotation == 0 || rotation == 90 || rotation == 180 || rotation == 270); | ||||||
|  |   return static_cast<webrtc::VideoFrameRotation>(rotation); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | }  // namespace webrtc | ||||||
|  |  | ||||||
|  | #endif  // WEBRTC_COMMON_VIDEO_ROTATION_H_ | ||||||
		Reference in New Issue
	
	Block a user
	 guoweis@webrtc.org
					guoweis@webrtc.org