| 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/software_renderer.h" | 5 #include "cc/software_renderer.h" |
| 6 | 6 |
| 7 #include "cc/quad_sink.h" | 7 #include "cc/quad_sink.h" |
| 8 #include "cc/render_pass.h" | 8 #include "cc/render_pass.h" |
| 9 #include "cc/render_pass_draw_quad.h" | 9 #include "cc/render_pass_draw_quad.h" |
| 10 #include "cc/solid_color_draw_quad.h" | 10 #include "cc/solid_color_draw_quad.h" |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 63 gfx::Rect outerRect(gfx::Point(), outerSize); | 63 gfx::Rect outerRect(gfx::Point(), outerSize); |
| 64 gfx::Rect innerRect(gfx::Point(1, 1), innerSize); | 64 gfx::Rect innerRect(gfx::Point(1, 1), innerSize); |
| 65 setViewportSize(outerSize); | 65 setViewportSize(outerSize); |
| 66 | 66 |
| 67 initializeRenderer(); | 67 initializeRenderer(); |
| 68 | 68 |
| 69 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); | 69 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); |
| 70 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, 1.0
); | 70 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, 1.0
); |
| 71 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); | 71 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); |
| 72 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 72 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 73 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), WebTransfor
mationMatrix()); | 73 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), WebTransfor
mationMatrix(), NULL); |
| 74 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); | 74 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); |
| 75 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); | 75 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); |
| 76 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); | 76 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); |
| 77 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); | 77 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); |
| 78 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); | 78 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 79 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 79 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 80 | 80 |
| 81 RenderPassList list; | 81 RenderPassList list; |
| 82 RenderPassIdHashMap hashmap; | 82 RenderPassIdHashMap hashmap; |
| 83 list.push_back(rootRenderPass.get()); | 83 list.push_back(rootRenderPass.get()); |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 124 | 124 |
| 125 resourceProvider()->setPixels(resourceYellow, reinterpret_cast<uint8_t*>(yel
lowPixels.get()), gfx::Rect(gfx::Point(), outerSize), gfx::Rect(gfx::Point(), ou
terSize), gfx::Vector2d()); | 125 resourceProvider()->setPixels(resourceYellow, reinterpret_cast<uint8_t*>(yel
lowPixels.get()), gfx::Rect(gfx::Point(), outerSize), gfx::Rect(gfx::Point(), ou
terSize), gfx::Vector2d()); |
| 126 resourceProvider()->setPixels(resourceCyan, reinterpret_cast<uint8_t*>(cyanP
ixels.get()), gfx::Rect(gfx::Point(), innerSize), gfx::Rect(gfx::Point(), innerS
ize), gfx::Vector2d()); | 126 resourceProvider()->setPixels(resourceCyan, reinterpret_cast<uint8_t*>(cyanP
ixels.get()), gfx::Rect(gfx::Point(), innerSize), gfx::Rect(gfx::Point(), innerS
ize), gfx::Vector2d()); |
| 127 | 127 |
| 128 gfx::Rect rect = gfx::Rect(gfx::Point(), deviceViewportSize()); | 128 gfx::Rect rect = gfx::Rect(gfx::Point(), deviceViewportSize()); |
| 129 | 129 |
| 130 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); | 130 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); |
| 131 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, 1.0
); | 131 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, 1.0
); |
| 132 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); | 132 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); |
| 133 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 133 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 134 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), WebTransformationMatrix()); | 134 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), WebTransformationMatrix(), NULL); |
| 135 scoped_ptr<TileDrawQuad> outerQuad = TileDrawQuad::Create(); | 135 scoped_ptr<TileDrawQuad> outerQuad = TileDrawQuad::Create(); |
| 136 outerQuad->SetNew(sharedQuadState.get(), outerRect, outerRect, resourceYello
w, gfx::RectF(gfx::PointF(), outerSize), outerSize, false, false, false, false,
false); | 136 outerQuad->SetNew(sharedQuadState.get(), outerRect, outerRect, resourceYello
w, gfx::RectF(gfx::PointF(), outerSize), outerSize, false, false, false, false,
false); |
| 137 scoped_ptr<TileDrawQuad> innerQuad = TileDrawQuad::Create(); | 137 scoped_ptr<TileDrawQuad> innerQuad = TileDrawQuad::Create(); |
| 138 innerQuad->SetNew(sharedQuadState.get(), innerRect, innerRect, resourceCyan,
gfx::RectF(gfx::PointF(), innerSize), innerSize, false, false, false, false, fa
lse); | 138 innerQuad->SetNew(sharedQuadState.get(), innerRect, innerRect, resourceCyan,
gfx::RectF(gfx::PointF(), innerSize), innerSize, false, false, false, false, fa
lse); |
| 139 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); | 139 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 140 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 140 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 141 | 141 |
| 142 RenderPassList list; | 142 RenderPassList list; |
| 143 RenderPassIdHashMap hashmap; | 143 RenderPassIdHashMap hashmap; |
| 144 list.push_back(rootRenderPass.get()); | 144 list.push_back(rootRenderPass.get()); |
| 145 hashmap.add(rootRenderPassId, rootRenderPass.PassAs<RenderPass>()); | 145 hashmap.add(rootRenderPassId, rootRenderPass.PassAs<RenderPass>()); |
| 146 renderer()->drawFrame(list, hashmap); | 146 renderer()->drawFrame(list, hashmap); |
| 147 | 147 |
| 148 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); | 148 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); |
| 149 renderer()->getFramebufferPixels(pixels.get(), outerRect); | 149 renderer()->getFramebufferPixels(pixels.get(), outerRect); |
| 150 | 150 |
| 151 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); | 151 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); |
| 152 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); | 152 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); |
| 153 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); | 153 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); |
| 154 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); | 154 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); |
| 155 } | 155 } |
| 156 | 156 |
| 157 } // namespace | 157 } // namespace |
| 158 } // namespace cc | 158 } // namespace cc |
| OLD | NEW |