Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(89)

Unified Diff: media/renderers/skcanvas_video_renderer_unittest.cc

Issue 2428263004: 16 bpp video stream capture, render and createImageBitmap(video) using (CPU) shared memory buffers (Closed)
Patch Set: Split webrtc_depth_capture_browsertest. Thanks phoglund@, Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: media/renderers/skcanvas_video_renderer_unittest.cc
diff --git a/media/renderers/skcanvas_video_renderer_unittest.cc b/media/renderers/skcanvas_video_renderer_unittest.cc
index 3fe348e99f282a7792b0ace1718e1f6479d3f056..cf038d305ff17e4a61b45162886a3539dd7a55c0 100644
--- a/media/renderers/skcanvas_video_renderer_unittest.cc
+++ b/media/renderers/skcanvas_video_renderer_unittest.cc
@@ -5,6 +5,7 @@
#include <stdint.h>
#include "base/macros.h"
+#include "base/memory/aligned_memory.h"
#include "base/message_loop/message_loop.h"
#include "gpu/GLES2/gl2extchromium.h"
#include "gpu/command_buffer/client/gles2_interface_stub.h"
@@ -512,6 +513,50 @@ TEST_F(SkCanvasVideoRendererTest, HighBits) {
GetColorAt(target_canvas(), kWidth * 3 / 8, kHeight * 3 / 6));
}
+TEST_F(SkCanvasVideoRendererTest, Y16) {
+ SkBitmap bitmap;
+ bitmap.allocPixels(SkImageInfo::MakeN32(16, 16, kPremul_SkAlphaType));
+
+ // |offset_x| and |offset_y| define visible rect's offset to coded rect.
+ const int offset_x = 3;
+ const int offset_y = 5;
+ const int stride = bitmap.width() + offset_x;
+ const size_t byte_size = stride * (bitmap.height() + offset_y) * 2;
+ std::unique_ptr<unsigned char, base::AlignedFreeDeleter> memory(
+ static_cast<unsigned char*>(base::AlignedAlloc(
+ byte_size, media::VideoFrame::kFrameAddressAlignment)));
+
+ // In the visible rect, fill upper byte with [0-255] and lower with [255-0].
+ uint16_t* data = reinterpret_cast<uint16_t*>(memory.get());
+ for (int j = 0; j < bitmap.height(); j++) {
+ for (int i = 0; i < bitmap.width(); i++) {
+ const int value = i + j * bitmap.width();
+ data[(stride * (j + offset_y)) + i + offset_x] =
+ ((value & 0xFF) << 8) | (~value & 0xFF);
+ }
+ }
+ const gfx::Rect rect(offset_x, offset_y, bitmap.width(), bitmap.height());
+ scoped_refptr<media::VideoFrame> video_frame =
+ media::VideoFrame::WrapExternalData(
+ media::PIXEL_FORMAT_Y16,
+ gfx::Size(stride, offset_y + bitmap.height()), rect, rect.size(),
+ memory.get(), byte_size, cropped_frame()->timestamp());
+
+ SkCanvas canvas(bitmap);
+ SkPaint paint;
+ paint.setFilterQuality(kNone_SkFilterQuality);
+ renderer_.Paint(video_frame, &canvas,
+ gfx::RectF(bitmap.width(), bitmap.height()), paint,
+ VIDEO_ROTATION_0, Context3D());
+ SkAutoLockPixels lock(bitmap);
+ for (int j = 0; j < bitmap.height(); j++) {
+ for (int i = 0; i < bitmap.width(); i++) {
+ const int value = i + j * bitmap.width();
+ EXPECT_EQ(SkColorSetRGB(value, value, value), bitmap.getColor(i, j));
+ }
+ }
+}
+
namespace {
class TestGLES2Interface : public gpu::gles2::GLES2InterfaceStub {
public:

Powered by Google App Engine
This is Rietveld 408576698