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

Side by Side Diff: cc/quads/yuv_video_draw_quad.cc

Issue 92703003: Support videos with JPEG color range in GPU YUV convert path. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@yuv_v2
Patch Set: Add missing 'f' to float literal to make VS happy Created 6 years, 7 months 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 unified diff | Download patch
« no previous file with comments | « cc/quads/yuv_video_draw_quad.h ('k') | cc/test/data/dark_grey.png » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "cc/quads/yuv_video_draw_quad.h" 5 #include "cc/quads/yuv_video_draw_quad.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/values.h" 8 #include "base/values.h"
9 #include "cc/base/math_util.h" 9 #include "cc/base/math_util.h"
10 10
(...skipping 11 matching lines...) Expand all
22 } 22 }
23 23
24 void YUVVideoDrawQuad::SetNew(const SharedQuadState* shared_quad_state, 24 void YUVVideoDrawQuad::SetNew(const SharedQuadState* shared_quad_state,
25 const gfx::Rect& rect, 25 const gfx::Rect& rect,
26 const gfx::Rect& opaque_rect, 26 const gfx::Rect& opaque_rect,
27 const gfx::Rect& visible_rect, 27 const gfx::Rect& visible_rect,
28 const gfx::RectF& tex_coord_rect, 28 const gfx::RectF& tex_coord_rect,
29 unsigned y_plane_resource_id, 29 unsigned y_plane_resource_id,
30 unsigned u_plane_resource_id, 30 unsigned u_plane_resource_id,
31 unsigned v_plane_resource_id, 31 unsigned v_plane_resource_id,
32 unsigned a_plane_resource_id) { 32 unsigned a_plane_resource_id,
33 ColorSpace color_space) {
33 bool needs_blending = false; 34 bool needs_blending = false;
34 DrawQuad::SetAll(shared_quad_state, DrawQuad::YUV_VIDEO_CONTENT, rect, 35 DrawQuad::SetAll(shared_quad_state, DrawQuad::YUV_VIDEO_CONTENT, rect,
35 opaque_rect, visible_rect, needs_blending); 36 opaque_rect, visible_rect, needs_blending);
36 this->tex_coord_rect = tex_coord_rect; 37 this->tex_coord_rect = tex_coord_rect;
37 this->y_plane_resource_id = y_plane_resource_id; 38 this->y_plane_resource_id = y_plane_resource_id;
38 this->u_plane_resource_id = u_plane_resource_id; 39 this->u_plane_resource_id = u_plane_resource_id;
39 this->v_plane_resource_id = v_plane_resource_id; 40 this->v_plane_resource_id = v_plane_resource_id;
40 this->a_plane_resource_id = a_plane_resource_id; 41 this->a_plane_resource_id = a_plane_resource_id;
42 this->color_space = color_space;
41 } 43 }
42 44
43 void YUVVideoDrawQuad::SetAll(const SharedQuadState* shared_quad_state, 45 void YUVVideoDrawQuad::SetAll(const SharedQuadState* shared_quad_state,
44 const gfx::Rect& rect, 46 const gfx::Rect& rect,
45 const gfx::Rect& opaque_rect, 47 const gfx::Rect& opaque_rect,
46 const gfx::Rect& visible_rect, 48 const gfx::Rect& visible_rect,
47 bool needs_blending, 49 bool needs_blending,
48 const gfx::RectF& tex_coord_rect, 50 const gfx::RectF& tex_coord_rect,
49 unsigned y_plane_resource_id, 51 unsigned y_plane_resource_id,
50 unsigned u_plane_resource_id, 52 unsigned u_plane_resource_id,
51 unsigned v_plane_resource_id, 53 unsigned v_plane_resource_id,
52 unsigned a_plane_resource_id) { 54 unsigned a_plane_resource_id,
55 ColorSpace color_space) {
53 DrawQuad::SetAll(shared_quad_state, DrawQuad::YUV_VIDEO_CONTENT, rect, 56 DrawQuad::SetAll(shared_quad_state, DrawQuad::YUV_VIDEO_CONTENT, rect,
54 opaque_rect, visible_rect, needs_blending); 57 opaque_rect, visible_rect, needs_blending);
55 this->tex_coord_rect = tex_coord_rect; 58 this->tex_coord_rect = tex_coord_rect;
56 this->y_plane_resource_id = y_plane_resource_id; 59 this->y_plane_resource_id = y_plane_resource_id;
57 this->u_plane_resource_id = u_plane_resource_id; 60 this->u_plane_resource_id = u_plane_resource_id;
58 this->v_plane_resource_id = v_plane_resource_id; 61 this->v_plane_resource_id = v_plane_resource_id;
59 this->a_plane_resource_id = a_plane_resource_id; 62 this->a_plane_resource_id = a_plane_resource_id;
63 this->color_space = color_space;
60 } 64 }
61 65
62 void YUVVideoDrawQuad::IterateResources( 66 void YUVVideoDrawQuad::IterateResources(
63 const ResourceIteratorCallback& callback) { 67 const ResourceIteratorCallback& callback) {
64 y_plane_resource_id = callback.Run(y_plane_resource_id); 68 y_plane_resource_id = callback.Run(y_plane_resource_id);
65 u_plane_resource_id = callback.Run(u_plane_resource_id); 69 u_plane_resource_id = callback.Run(u_plane_resource_id);
66 v_plane_resource_id = callback.Run(v_plane_resource_id); 70 v_plane_resource_id = callback.Run(v_plane_resource_id);
67 if (a_plane_resource_id) 71 if (a_plane_resource_id)
68 a_plane_resource_id = callback.Run(a_plane_resource_id); 72 a_plane_resource_id = callback.Run(a_plane_resource_id);
69 } 73 }
70 74
71 const YUVVideoDrawQuad* YUVVideoDrawQuad::MaterialCast( 75 const YUVVideoDrawQuad* YUVVideoDrawQuad::MaterialCast(
72 const DrawQuad* quad) { 76 const DrawQuad* quad) {
73 DCHECK(quad->material == DrawQuad::YUV_VIDEO_CONTENT); 77 DCHECK(quad->material == DrawQuad::YUV_VIDEO_CONTENT);
74 return static_cast<const YUVVideoDrawQuad*>(quad); 78 return static_cast<const YUVVideoDrawQuad*>(quad);
75 } 79 }
76 80
77 void YUVVideoDrawQuad::ExtendValue(base::DictionaryValue* value) const { 81 void YUVVideoDrawQuad::ExtendValue(base::DictionaryValue* value) const {
78 value->Set("tex_coord_rect", MathUtil::AsValue(tex_coord_rect).release()); 82 value->Set("tex_coord_rect", MathUtil::AsValue(tex_coord_rect).release());
79 value->SetInteger("y_plane_resource_id", y_plane_resource_id); 83 value->SetInteger("y_plane_resource_id", y_plane_resource_id);
80 value->SetInteger("u_plane_resource_id", u_plane_resource_id); 84 value->SetInteger("u_plane_resource_id", u_plane_resource_id);
81 value->SetInteger("v_plane_resource_id", v_plane_resource_id); 85 value->SetInteger("v_plane_resource_id", v_plane_resource_id);
82 value->SetInteger("a_plane_resource_id", a_plane_resource_id); 86 value->SetInteger("a_plane_resource_id", a_plane_resource_id);
83 } 87 }
84 88
85 } // namespace cc 89 } // namespace cc
OLDNEW
« no previous file with comments | « cc/quads/yuv_video_draw_quad.h ('k') | cc/test/data/dark_grey.png » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698