Chromium Code Reviews| 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/gl_renderer.h" | 5 #include "cc/gl_renderer.h" |
| 6 | 6 |
| 7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
| 8 #include "base/path_service.h" | 8 #include "base/path_service.h" |
| 9 #include "cc/compositor_frame_metadata.h" | 9 #include "cc/compositor_frame_metadata.h" |
| 10 #include "cc/draw_quad.h" | 10 #include "cc/draw_quad.h" |
| (...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 109 | 109 |
| 110 scoped_ptr<DrawQuad> CreateTestRenderPassDrawQuad( | 110 scoped_ptr<DrawQuad> CreateTestRenderPassDrawQuad( |
| 111 SharedQuadState* shared_state, gfx::Rect rect, RenderPass::Id pass_id) { | 111 SharedQuadState* shared_state, gfx::Rect rect, RenderPass::Id pass_id) { |
| 112 scoped_ptr<RenderPassDrawQuad> quad = RenderPassDrawQuad::Create(); | 112 scoped_ptr<RenderPassDrawQuad> quad = RenderPassDrawQuad::Create(); |
| 113 quad->SetNew(shared_state, | 113 quad->SetNew(shared_state, |
| 114 rect, | 114 rect, |
| 115 pass_id, | 115 pass_id, |
| 116 false, // is_replica | 116 false, // is_replica |
| 117 0, // mask_resource_id | 117 0, // mask_resource_id |
| 118 rect, // contents_changed_since_last_frame | 118 rect, // contents_changed_since_last_frame |
| 119 gfx::RectF()); // mask_uv_rect | 119 gfx::RectF(), // mask_uv_rect |
| 120 WebKit::WebFilterOperations(), | |
|
danakj
2012/12/19 21:22:52
// foreground filter
piman
2012/12/19 21:50:00
Done.
| |
| 121 skia::RefPtr<SkImageFilter>(), | |
|
danakj
2012/12/19 21:22:52
// foreground filter
piman
2012/12/19 21:50:00
Done.
| |
| 122 WebKit::WebFilterOperations()); | |
|
danakj
2012/12/19 21:22:52
// background filter
piman
2012/12/19 21:50:00
Done.
| |
| 120 | 123 |
| 121 return quad.PassAs<DrawQuad>(); | 124 return quad.PassAs<DrawQuad>(); |
| 122 } | 125 } |
| 123 | 126 |
| 124 | 127 |
| 125 #if !defined(OS_ANDROID) | 128 #if !defined(OS_ANDROID) |
| 126 TEST_F(GLRendererPixelTest, simpleGreenRect) { | 129 TEST_F(GLRendererPixelTest, simpleGreenRect) { |
| 127 gfx::Rect rect(0, 0, 200, 200); | 130 gfx::Rect rect(0, 0, 200, 200); |
| 128 | 131 |
| 129 RenderPass::Id id(1, 1); | 132 RenderPass::Id id(1, 1); |
| 130 scoped_ptr<RenderPass> pass = CreateTestRenderPass(id, rect); | 133 scoped_ptr<RenderPass> pass = CreateTestRenderPass(id, rect); |
| 131 | 134 |
| 132 gfx::Transform content_to_target_transform; | 135 gfx::Transform content_to_target_transform; |
| 133 scoped_ptr<SharedQuadState> shared_state = | 136 scoped_ptr<SharedQuadState> shared_state = |
| 134 CreateTestSharedQuadState(content_to_target_transform, rect); | 137 CreateTestSharedQuadState(content_to_target_transform, rect); |
| 135 | 138 |
| 136 scoped_ptr<SolidColorDrawQuad> color_quad = SolidColorDrawQuad::Create(); | 139 scoped_ptr<SolidColorDrawQuad> color_quad = SolidColorDrawQuad::Create(); |
| 137 color_quad->SetNew(shared_state.get(), rect, SK_ColorGREEN); | 140 color_quad->SetNew(shared_state.get(), rect, SK_ColorGREEN); |
| 138 | 141 |
| 139 pass->quad_list.append(color_quad.PassAs<DrawQuad>()); | 142 pass->quad_list.append(color_quad.PassAs<DrawQuad>()); |
| 140 | 143 |
| 141 RenderPassList pass_list; | 144 RenderPassList pass_list; |
| 142 pass_list.push_back(pass.get()); | 145 pass_list.push_back(pass.get()); |
| 143 RenderPassIdHashMap pass_map; | |
| 144 pass_map.add(id, pass.PassAs<RenderPass>()); | |
| 145 | 146 |
| 146 renderer_->drawFrame(pass_list, pass_map); | 147 renderer_->drawFrame(pass_list); |
| 147 | 148 |
| 148 EXPECT_TRUE(PixelsMatchReference(FilePath(FILE_PATH_LITERAL("green.png")), | 149 EXPECT_TRUE(PixelsMatchReference(FilePath(FILE_PATH_LITERAL("green.png")), |
| 149 rect)); | 150 rect)); |
| 150 } | 151 } |
| 151 | 152 |
| 152 TEST_F(GLRendererPixelTest, RenderPassChangesSize) { | 153 TEST_F(GLRendererPixelTest, RenderPassChangesSize) { |
| 153 gfx::Rect viewport_rect(200, 200); | 154 gfx::Rect viewport_rect(200, 200); |
| 154 | 155 |
| 155 RenderPass::Id root_pass_id(1, 1); | 156 RenderPass::Id root_pass_id(1, 1); |
| 156 scoped_ptr<RenderPass> root_pass = | 157 scoped_ptr<RenderPass> root_pass = |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 177 CreateTestSharedQuadState(gfx::Transform(), pass_rect); | 178 CreateTestSharedQuadState(gfx::Transform(), pass_rect); |
| 178 root_pass->quad_list.append( | 179 root_pass->quad_list.append( |
| 179 CreateTestRenderPassDrawQuad(pass_shared_state.get(), | 180 CreateTestRenderPassDrawQuad(pass_shared_state.get(), |
| 180 pass_rect, | 181 pass_rect, |
| 181 child_pass_id)); | 182 child_pass_id)); |
| 182 | 183 |
| 183 RenderPassList pass_list; | 184 RenderPassList pass_list; |
| 184 pass_list.push_back(child_pass.get()); | 185 pass_list.push_back(child_pass.get()); |
| 185 pass_list.push_back(root_pass.get()); | 186 pass_list.push_back(root_pass.get()); |
| 186 | 187 |
| 187 RenderPassIdHashMap pass_map; | |
| 188 pass_map.add(child_pass_id, child_pass.Pass()); | |
| 189 pass_map.add(root_pass_id, root_pass.Pass()); | |
| 190 | |
| 191 renderer_->setEnlargePassTextureAmountForTesting(gfx::Vector2d(50, 75)); | 188 renderer_->setEnlargePassTextureAmountForTesting(gfx::Vector2d(50, 75)); |
| 192 renderer_->decideRenderPassAllocationsForFrame(pass_list); | 189 renderer_->decideRenderPassAllocationsForFrame(pass_list); |
| 193 renderer_->drawFrame(pass_list, pass_map); | 190 renderer_->drawFrame(pass_list); |
| 194 | 191 |
| 195 EXPECT_TRUE(PixelsMatchReference( | 192 EXPECT_TRUE(PixelsMatchReference( |
| 196 FilePath(FILE_PATH_LITERAL("blue_yellow.png")), viewport_rect)); | 193 FilePath(FILE_PATH_LITERAL("blue_yellow.png")), viewport_rect)); |
| 197 } | 194 } |
| 198 #endif | 195 #endif |
| 199 | 196 |
| 200 } // namespace | 197 } // namespace |
| 201 } // namespace cc | 198 } // namespace cc |
| OLD | NEW |