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 "cc/quads/draw_quad.h" | 5 #include "cc/quads/draw_quad.h" |
6 | 6 |
7 #include "base/debug/trace_event_argument.h" | |
8 #include "base/logging.h" | 7 #include "base/logging.h" |
9 #include "base/values.h" | 8 #include "base/values.h" |
10 #include "cc/base/math_util.h" | 9 #include "cc/base/math_util.h" |
11 #include "cc/debug/traced_value.h" | 10 #include "cc/debug/traced_value.h" |
12 #include "cc/quads/checkerboard_draw_quad.h" | 11 #include "cc/quads/checkerboard_draw_quad.h" |
13 #include "cc/quads/debug_border_draw_quad.h" | 12 #include "cc/quads/debug_border_draw_quad.h" |
14 #include "cc/quads/io_surface_draw_quad.h" | 13 #include "cc/quads/io_surface_draw_quad.h" |
15 #include "cc/quads/picture_draw_quad.h" | 14 #include "cc/quads/picture_draw_quad.h" |
16 #include "cc/quads/render_pass_draw_quad.h" | 15 #include "cc/quads/render_pass_draw_quad.h" |
17 #include "cc/quads/solid_color_draw_quad.h" | 16 #include "cc/quads/solid_color_draw_quad.h" |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
50 this->needs_blending = needs_blending; | 49 this->needs_blending = needs_blending; |
51 this->shared_quad_state = shared_quad_state; | 50 this->shared_quad_state = shared_quad_state; |
52 | 51 |
53 DCHECK(shared_quad_state); | 52 DCHECK(shared_quad_state); |
54 DCHECK(material != INVALID); | 53 DCHECK(material != INVALID); |
55 } | 54 } |
56 | 55 |
57 DrawQuad::~DrawQuad() { | 56 DrawQuad::~DrawQuad() { |
58 } | 57 } |
59 | 58 |
60 void DrawQuad::AsValueInto(base::debug::TracedValue* value) const { | 59 scoped_ptr<base::Value> DrawQuad::AsValue() const { |
| 60 scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); |
61 value->SetInteger("material", material); | 61 value->SetInteger("material", material); |
62 TracedValue::SetIDRef(shared_quad_state, value, "shared_state"); | 62 value->Set("shared_state", |
| 63 TracedValue::CreateIDRef(shared_quad_state).release()); |
63 | 64 |
64 value->BeginArray("content_space_rect"); | 65 value->Set("content_space_rect", MathUtil::AsValue(rect).release()); |
65 MathUtil::AddToTracedValue(rect, value); | |
66 value->EndArray(); | |
67 | |
68 bool rect_is_clipped; | 66 bool rect_is_clipped; |
69 gfx::QuadF rect_as_target_space_quad = MathUtil::MapQuad( | 67 gfx::QuadF rect_as_target_space_quad = MathUtil::MapQuad( |
70 shared_quad_state->content_to_target_transform, | 68 shared_quad_state->content_to_target_transform, |
71 gfx::QuadF(rect), | 69 gfx::QuadF(rect), |
72 &rect_is_clipped); | 70 &rect_is_clipped); |
73 value->BeginArray("rect_as_target_space_quad"); | 71 value->Set("rect_as_target_space_quad", |
74 MathUtil::AddToTracedValue(rect_as_target_space_quad, value); | 72 MathUtil::AsValue(rect_as_target_space_quad).release()); |
75 value->EndArray(); | |
76 | |
77 value->SetBoolean("rect_is_clipped", rect_is_clipped); | 73 value->SetBoolean("rect_is_clipped", rect_is_clipped); |
78 | 74 |
79 value->BeginArray("content_space_opaque_rect"); | 75 value->Set("content_space_opaque_rect", |
80 MathUtil::AddToTracedValue(opaque_rect, value); | 76 MathUtil::AsValue(opaque_rect).release()); |
81 value->EndArray(); | |
82 | |
83 bool opaque_rect_is_clipped; | 77 bool opaque_rect_is_clipped; |
84 gfx::QuadF opaque_rect_as_target_space_quad = MathUtil::MapQuad( | 78 gfx::QuadF opaque_rect_as_target_space_quad = MathUtil::MapQuad( |
85 shared_quad_state->content_to_target_transform, | 79 shared_quad_state->content_to_target_transform, |
86 gfx::QuadF(opaque_rect), | 80 gfx::QuadF(opaque_rect), |
87 &opaque_rect_is_clipped); | 81 &opaque_rect_is_clipped); |
88 value->BeginArray("opaque_rect_as_target_space_quad"); | 82 value->Set("opaque_rect_as_target_space_quad", |
89 MathUtil::AddToTracedValue(opaque_rect_as_target_space_quad, value); | 83 MathUtil::AsValue(opaque_rect_as_target_space_quad).release()); |
90 value->EndArray(); | |
91 | |
92 value->SetBoolean("opaque_rect_is_clipped", opaque_rect_is_clipped); | 84 value->SetBoolean("opaque_rect_is_clipped", opaque_rect_is_clipped); |
93 | 85 |
94 value->BeginArray("content_space_visible_rect"); | 86 value->Set("content_space_visible_rect", |
95 MathUtil::AddToTracedValue(visible_rect, value); | 87 MathUtil::AsValue(visible_rect).release()); |
96 value->EndArray(); | |
97 | |
98 bool visible_rect_is_clipped; | 88 bool visible_rect_is_clipped; |
99 gfx::QuadF visible_rect_as_target_space_quad = MathUtil::MapQuad( | 89 gfx::QuadF visible_rect_as_target_space_quad = MathUtil::MapQuad( |
100 shared_quad_state->content_to_target_transform, | 90 shared_quad_state->content_to_target_transform, |
101 gfx::QuadF(visible_rect), | 91 gfx::QuadF(visible_rect), |
102 &visible_rect_is_clipped); | 92 &visible_rect_is_clipped); |
103 | 93 value->Set("visible_rect_as_target_space_quad", |
104 value->BeginArray("visible_rect_as_target_space_quad"); | 94 MathUtil::AsValue(visible_rect_as_target_space_quad).release()); |
105 MathUtil::AddToTracedValue(visible_rect_as_target_space_quad, value); | |
106 value->EndArray(); | |
107 | |
108 value->SetBoolean("visible_rect_is_clipped", visible_rect_is_clipped); | 95 value->SetBoolean("visible_rect_is_clipped", visible_rect_is_clipped); |
109 | 96 |
110 value->SetBoolean("needs_blending", needs_blending); | 97 value->SetBoolean("needs_blending", needs_blending); |
111 value->SetBoolean("should_draw_with_blending", ShouldDrawWithBlending()); | 98 value->SetBoolean("should_draw_with_blending", ShouldDrawWithBlending()); |
112 ExtendValue(value); | 99 ExtendValue(value.get()); |
| 100 return value.PassAs<base::Value>(); |
113 } | 101 } |
114 | 102 |
115 } // namespace cc | 103 } // namespace cc |
OLD | NEW |