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

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: jpeg_color_range->has_jpeg_color_range Created 7 years 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
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 10 matching lines...) Expand all
21 return make_scoped_ptr(new YUVVideoDrawQuad); 21 return make_scoped_ptr(new YUVVideoDrawQuad);
22 } 22 }
23 23
24 void YUVVideoDrawQuad::SetNew(const SharedQuadState* shared_quad_state, 24 void YUVVideoDrawQuad::SetNew(const SharedQuadState* shared_quad_state,
25 gfx::Rect rect, 25 gfx::Rect rect,
26 gfx::Rect opaque_rect, 26 gfx::Rect opaque_rect,
27 gfx::SizeF tex_scale, 27 gfx::SizeF tex_scale,
28 unsigned y_plane_resource_id, 28 unsigned y_plane_resource_id,
29 unsigned u_plane_resource_id, 29 unsigned u_plane_resource_id,
30 unsigned v_plane_resource_id, 30 unsigned v_plane_resource_id,
31 unsigned a_plane_resource_id) { 31 unsigned a_plane_resource_id,
32 bool has_jpeg_color_range) {
32 gfx::Rect visible_rect = rect; 33 gfx::Rect visible_rect = rect;
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_scale = tex_scale; 37 this->tex_scale = tex_scale;
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->has_jpeg_color_range = has_jpeg_color_range;
41 } 43 }
42 44
43 void YUVVideoDrawQuad::SetAll(const SharedQuadState* shared_quad_state, 45 void YUVVideoDrawQuad::SetAll(const SharedQuadState* shared_quad_state,
44 gfx::Rect rect, 46 gfx::Rect rect,
45 gfx::Rect opaque_rect, 47 gfx::Rect opaque_rect,
46 gfx::Rect visible_rect, 48 gfx::Rect visible_rect,
47 bool needs_blending, 49 bool needs_blending,
48 gfx::SizeF tex_scale, 50 gfx::SizeF tex_scale,
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 bool has_jpeg_color_range) {
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_scale = tex_scale; 58 this->tex_scale = tex_scale;
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->has_jpeg_color_range = has_jpeg_color_range;
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_scale", MathUtil::AsValue(tex_scale).release()); 82 value->Set("tex_scale", MathUtil::AsValue(tex_scale).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

Powered by Google App Engine
This is Rietveld 408576698