OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include <stddef.h> | 5 #include <stddef.h> |
6 #include <stdint.h> | 6 #include <stdint.h> |
7 #include <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "cc/output/gl_renderer.h" | 10 #include "cc/output/gl_renderer.h" |
11 #include "cc/quads/draw_quad.h" | 11 #include "cc/quads/draw_quad.h" |
12 #include "cc/quads/picture_draw_quad.h" | 12 #include "cc/quads/picture_draw_quad.h" |
13 #include "cc/quads/texture_draw_quad.h" | 13 #include "cc/quads/texture_draw_quad.h" |
14 #include "cc/resources/video_resource_updater.h" | 14 #include "cc/resources/video_resource_updater.h" |
15 #include "cc/test/fake_raster_source.h" | 15 #include "cc/test/fake_raster_source.h" |
16 #include "cc/test/fake_recording_source.h" | 16 #include "cc/test/fake_recording_source.h" |
17 #include "cc/test/pixel_test.h" | 17 #include "cc/test/pixel_test.h" |
18 #include "gpu/command_buffer/client/gles2_interface.h" | 18 #include "gpu/command_buffer/client/gles2_interface.h" |
| 19 #include "media/base/video_color_space.h" |
19 #include "media/base/video_frame.h" | 20 #include "media/base/video_frame.h" |
20 #include "third_party/skia/include/core/SkColorPriv.h" | 21 #include "third_party/skia/include/core/SkColorPriv.h" |
21 #include "third_party/skia/include/core/SkImageFilter.h" | 22 #include "third_party/skia/include/core/SkImageFilter.h" |
22 #include "third_party/skia/include/core/SkMatrix.h" | 23 #include "third_party/skia/include/core/SkMatrix.h" |
23 #include "third_party/skia/include/core/SkRefCnt.h" | 24 #include "third_party/skia/include/core/SkRefCnt.h" |
24 #include "third_party/skia/include/core/SkSurface.h" | 25 #include "third_party/skia/include/core/SkSurface.h" |
25 #include "third_party/skia/include/effects/SkColorFilterImageFilter.h" | 26 #include "third_party/skia/include/effects/SkColorFilterImageFilter.h" |
26 #include "third_party/skia/include/effects/SkColorMatrixFilter.h" | 27 #include "third_party/skia/include/effects/SkColorMatrixFilter.h" |
27 #include "ui/gfx/geometry/rect_conversions.h" | 28 #include "ui/gfx/geometry/rect_conversions.h" |
28 | 29 |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
199 ResourceProvider* resource_provider) { | 200 ResourceProvider* resource_provider) { |
200 const bool with_alpha = (video_frame->format() == media::PIXEL_FORMAT_YV12A); | 201 const bool with_alpha = (video_frame->format() == media::PIXEL_FORMAT_YV12A); |
201 YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::REC_601; | 202 YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::REC_601; |
202 int video_frame_color_space; | 203 int video_frame_color_space; |
203 if (video_frame->metadata()->GetInteger( | 204 if (video_frame->metadata()->GetInteger( |
204 media::VideoFrameMetadata::COLOR_SPACE, &video_frame_color_space) && | 205 media::VideoFrameMetadata::COLOR_SPACE, &video_frame_color_space) && |
205 video_frame_color_space == media::COLOR_SPACE_JPEG) { | 206 video_frame_color_space == media::COLOR_SPACE_JPEG) { |
206 color_space = YUVVideoDrawQuad::JPEG; | 207 color_space = YUVVideoDrawQuad::JPEG; |
207 } | 208 } |
208 | 209 |
| 210 media::VideoColorSpace video_color_space(video_frame.get()); |
| 211 |
209 const gfx::Rect opaque_rect(0, 0, 0, 0); | 212 const gfx::Rect opaque_rect(0, 0, 0, 0); |
210 | 213 |
211 if (with_alpha) { | 214 if (with_alpha) { |
212 memset(video_frame->data(media::VideoFrame::kAPlane), alpha_value, | 215 memset(video_frame->data(media::VideoFrame::kAPlane), alpha_value, |
213 video_frame->stride(media::VideoFrame::kAPlane) * | 216 video_frame->stride(media::VideoFrame::kAPlane) * |
214 video_frame->rows(media::VideoFrame::kAPlane)); | 217 video_frame->rows(media::VideoFrame::kAPlane)); |
215 } | 218 } |
216 | 219 |
217 VideoFrameExternalResources resources = | 220 VideoFrameExternalResources resources = |
218 video_resource_updater->CreateExternalResourcesFromVideoFrame( | 221 video_resource_updater->CreateExternalResourcesFromVideoFrame( |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
264 gfx::RectF uv_tex_coord_rect(tex_coord_rect.x() * uv_tex_size.width(), | 267 gfx::RectF uv_tex_coord_rect(tex_coord_rect.x() * uv_tex_size.width(), |
265 tex_coord_rect.y() * uv_tex_size.height(), | 268 tex_coord_rect.y() * uv_tex_size.height(), |
266 tex_coord_rect.width() * uv_tex_size.width(), | 269 tex_coord_rect.width() * uv_tex_size.width(), |
267 tex_coord_rect.height() * uv_tex_size.height()); | 270 tex_coord_rect.height() * uv_tex_size.height()); |
268 | 271 |
269 YUVVideoDrawQuad* yuv_quad = | 272 YUVVideoDrawQuad* yuv_quad = |
270 render_pass->CreateAndAppendDrawQuad<YUVVideoDrawQuad>(); | 273 render_pass->CreateAndAppendDrawQuad<YUVVideoDrawQuad>(); |
271 yuv_quad->SetNew(shared_state, rect, opaque_rect, visible_rect, | 274 yuv_quad->SetNew(shared_state, rect, opaque_rect, visible_rect, |
272 ya_tex_coord_rect, uv_tex_coord_rect, ya_tex_size, | 275 ya_tex_coord_rect, uv_tex_coord_rect, ya_tex_size, |
273 uv_tex_size, y_resource, u_resource, v_resource, a_resource, | 276 uv_tex_size, y_resource, u_resource, v_resource, a_resource, |
274 color_space, 0.0f, 1.0f); | 277 color_space, video_color_space, 0.0f, 1.0f); |
275 } | 278 } |
276 | 279 |
277 // Upshift video frame to 10 bit. | 280 // Upshift video frame to 10 bit. |
278 scoped_refptr<media::VideoFrame> CreateHighbitVideoFrame( | 281 scoped_refptr<media::VideoFrame> CreateHighbitVideoFrame( |
279 media::VideoFrame* video_frame) { | 282 media::VideoFrame* video_frame) { |
280 media::VideoPixelFormat format; | 283 media::VideoPixelFormat format; |
281 switch (video_frame->format()) { | 284 switch (video_frame->format()) { |
282 case media::PIXEL_FORMAT_I420: | 285 case media::PIXEL_FORMAT_I420: |
283 case media::PIXEL_FORMAT_YV12: | 286 case media::PIXEL_FORMAT_YV12: |
284 format = media::PIXEL_FORMAT_YUV420P10; | 287 format = media::PIXEL_FORMAT_YUV420P10; |
(...skipping 182 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
467 memset(video_frame->data(media::VideoFrame::kVPlane), v, | 470 memset(video_frame->data(media::VideoFrame::kVPlane), v, |
468 video_frame->stride(media::VideoFrame::kVPlane) * | 471 video_frame->stride(media::VideoFrame::kVPlane) * |
469 video_frame->rows(media::VideoFrame::kVPlane)); | 472 video_frame->rows(media::VideoFrame::kVPlane)); |
470 | 473 |
471 uint8_t alpha_value = is_transparent ? 0 : 128; | 474 uint8_t alpha_value = is_transparent ? 0 : 128; |
472 CreateTestYUVVideoDrawQuad_FromVideoFrame( | 475 CreateTestYUVVideoDrawQuad_FromVideoFrame( |
473 shared_state, video_frame, alpha_value, tex_coord_rect, render_pass, | 476 shared_state, video_frame, alpha_value, tex_coord_rect, render_pass, |
474 video_resource_updater, rect, visible_rect, resource_provider); | 477 video_resource_updater, rect, visible_rect, resource_provider); |
475 } | 478 } |
476 | 479 |
477 void CreateTestYUVVideoDrawQuad_NV12(const SharedQuadState* shared_state, | 480 void CreateTestYUVVideoDrawQuad_NV12( |
478 media::ColorSpace video_frame_color_space, | 481 const SharedQuadState* shared_state, |
479 const gfx::RectF& tex_coord_rect, | 482 media::ColorSpace video_frame_color_space, |
480 uint8_t y, | 483 const media::VideoColorSpace& video_color_space, |
481 uint8_t u, | 484 const gfx::RectF& tex_coord_rect, |
482 uint8_t v, | 485 uint8_t y, |
483 RenderPass* render_pass, | 486 uint8_t u, |
484 const gfx::Rect& rect, | 487 uint8_t v, |
485 const gfx::Rect& visible_rect, | 488 RenderPass* render_pass, |
486 ResourceProvider* resource_provider) { | 489 const gfx::Rect& rect, |
| 490 const gfx::Rect& visible_rect, |
| 491 ResourceProvider* resource_provider) { |
487 YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::REC_601; | 492 YUVVideoDrawQuad::ColorSpace color_space = YUVVideoDrawQuad::REC_601; |
488 if (video_frame_color_space == media::COLOR_SPACE_JPEG) { | 493 if (video_frame_color_space == media::COLOR_SPACE_JPEG) { |
489 color_space = YUVVideoDrawQuad::JPEG; | 494 color_space = YUVVideoDrawQuad::JPEG; |
490 } | 495 } |
491 | 496 |
492 const gfx::Rect opaque_rect(0, 0, 0, 0); | 497 const gfx::Rect opaque_rect(0, 0, 0, 0); |
493 const gfx::Size ya_tex_size = rect.size(); | 498 const gfx::Size ya_tex_size = rect.size(); |
494 const gfx::Size uv_tex_size = media::VideoFrame::PlaneSize( | 499 const gfx::Size uv_tex_size = media::VideoFrame::PlaneSize( |
495 media::PIXEL_FORMAT_NV12, media::VideoFrame::kUVPlane, rect.size()); | 500 media::PIXEL_FORMAT_NV12, media::VideoFrame::kUVPlane, rect.size()); |
496 | 501 |
(...skipping 21 matching lines...) Expand all Loading... |
518 gfx::RectF uv_tex_coord_rect(tex_coord_rect.x() * uv_tex_size.width(), | 523 gfx::RectF uv_tex_coord_rect(tex_coord_rect.x() * uv_tex_size.width(), |
519 tex_coord_rect.y() * uv_tex_size.height(), | 524 tex_coord_rect.y() * uv_tex_size.height(), |
520 tex_coord_rect.width() * uv_tex_size.width(), | 525 tex_coord_rect.width() * uv_tex_size.width(), |
521 tex_coord_rect.height() * uv_tex_size.height()); | 526 tex_coord_rect.height() * uv_tex_size.height()); |
522 | 527 |
523 YUVVideoDrawQuad* yuv_quad = | 528 YUVVideoDrawQuad* yuv_quad = |
524 render_pass->CreateAndAppendDrawQuad<YUVVideoDrawQuad>(); | 529 render_pass->CreateAndAppendDrawQuad<YUVVideoDrawQuad>(); |
525 yuv_quad->SetNew(shared_state, rect, opaque_rect, visible_rect, | 530 yuv_quad->SetNew(shared_state, rect, opaque_rect, visible_rect, |
526 ya_tex_coord_rect, uv_tex_coord_rect, ya_tex_size, | 531 ya_tex_coord_rect, uv_tex_coord_rect, ya_tex_size, |
527 uv_tex_size, y_resource, u_resource, v_resource, a_resource, | 532 uv_tex_size, y_resource, u_resource, v_resource, a_resource, |
528 color_space, 0.0f, 1.0f); | 533 color_space, video_color_space, 0.0f, 1.0f); |
529 } | 534 } |
530 | 535 |
531 typedef ::testing::Types<GLRenderer, | 536 typedef ::testing::Types<GLRenderer, |
532 SoftwareRenderer, | 537 SoftwareRenderer, |
533 GLRendererWithExpandedViewport, | 538 GLRendererWithExpandedViewport, |
534 SoftwareRendererWithExpandedViewport> RendererTypes; | 539 SoftwareRendererWithExpandedViewport> RendererTypes; |
535 TYPED_TEST_CASE(RendererPixelTest, RendererTypes); | 540 TYPED_TEST_CASE(RendererPixelTest, RendererTypes); |
536 | 541 |
537 template <typename RendererType> | 542 template <typename RendererType> |
538 class SoftwareRendererPixelTest : public RendererPixelTest<RendererType> {}; | 543 class SoftwareRendererPixelTest : public RendererPixelTest<RendererType> {}; |
(...skipping 678 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1217 gfx::Rect rect(this->device_viewport_size_); | 1222 gfx::Rect rect(this->device_viewport_size_); |
1218 | 1223 |
1219 RenderPassId id(1, 1); | 1224 RenderPassId id(1, 1); |
1220 std::unique_ptr<RenderPass> pass = CreateTestRootRenderPass(id, rect); | 1225 std::unique_ptr<RenderPass> pass = CreateTestRootRenderPass(id, rect); |
1221 | 1226 |
1222 SharedQuadState* shared_state = | 1227 SharedQuadState* shared_state = |
1223 CreateTestSharedQuadState(gfx::Transform(), rect, pass.get()); | 1228 CreateTestSharedQuadState(gfx::Transform(), rect, pass.get()); |
1224 | 1229 |
1225 // YUV of (149,43,21) should be green (0,255,0) in RGB. | 1230 // YUV of (149,43,21) should be green (0,255,0) in RGB. |
1226 CreateTestYUVVideoDrawQuad_NV12( | 1231 CreateTestYUVVideoDrawQuad_NV12( |
1227 shared_state, media::COLOR_SPACE_JPEG, gfx::RectF(0.0f, 0.0f, 1.0f, 1.0f), | 1232 shared_state, media::COLOR_SPACE_JPEG, |
1228 149, 43, 21, pass.get(), rect, rect, resource_provider_.get()); | 1233 media::VideoColorSpace(media::COLOR_SPACE_JPEG), |
| 1234 gfx::RectF(0.0f, 0.0f, 1.0f, 1.0f), 149, 43, 21, pass.get(), rect, rect, |
| 1235 resource_provider_.get()); |
1229 | 1236 |
1230 RenderPassList pass_list; | 1237 RenderPassList pass_list; |
1231 pass_list.push_back(std::move(pass)); | 1238 pass_list.push_back(std::move(pass)); |
1232 | 1239 |
1233 EXPECT_TRUE(this->RunPixelTest(&pass_list, | 1240 EXPECT_TRUE(this->RunPixelTest(&pass_list, |
1234 base::FilePath(FILE_PATH_LITERAL("green.png")), | 1241 base::FilePath(FILE_PATH_LITERAL("green.png")), |
1235 FuzzyPixelOffByOneComparator(true))); | 1242 FuzzyPixelOffByOneComparator(true))); |
1236 } | 1243 } |
1237 | 1244 |
1238 // Test that a YUV video doesn't bleed outside of its tex coords when the | 1245 // Test that a YUV video doesn't bleed outside of its tex coords when the |
(...skipping 1935 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3174 | 3181 |
3175 EXPECT_TRUE(this->RunPixelTest( | 3182 EXPECT_TRUE(this->RunPixelTest( |
3176 &pass_list, base::FilePath(FILE_PATH_LITERAL("spiral.png")), | 3183 &pass_list, base::FilePath(FILE_PATH_LITERAL("spiral.png")), |
3177 FuzzyPixelOffByOneComparator(true))); | 3184 FuzzyPixelOffByOneComparator(true))); |
3178 } | 3185 } |
3179 | 3186 |
3180 #endif // !defined(OS_ANDROID) | 3187 #endif // !defined(OS_ANDROID) |
3181 | 3188 |
3182 } // namespace | 3189 } // namespace |
3183 } // namespace cc | 3190 } // namespace cc |
OLD | NEW |