| 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/compositor_frame_metadata.h" | 7 #include "cc/compositor_frame_metadata.h" |
| 8 #include "cc/quad_sink.h" | 8 #include "cc/quad_sink.h" |
| 9 #include "cc/render_pass.h" | 9 #include "cc/render_pass.h" |
| 10 #include "cc/render_pass_draw_quad.h" | 10 #include "cc/render_pass_draw_quad.h" |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 83 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 83 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 84 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), gfx::Transf
orm()); | 84 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), gfx::Transf
orm()); |
| 85 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); | 85 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); |
| 86 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); | 86 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); |
| 87 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); | 87 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); |
| 88 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); | 88 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); |
| 89 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); | 89 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 90 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 90 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 91 | 91 |
| 92 RenderPassList list; | 92 RenderPassList list; |
| 93 list.append(rootRenderPass.PassAs<RenderPass>()); | 93 list.push_back(rootRenderPass.PassAs<RenderPass>()); |
| 94 renderer()->drawFrame(list); | 94 renderer()->drawFrame(list); |
| 95 | 95 |
| 96 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); | 96 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); |
| 97 renderer()->getFramebufferPixels(pixels.get(), outerRect); | 97 renderer()->getFramebufferPixels(pixels.get(), outerRect); |
| 98 | 98 |
| 99 // FIXME: This fails on Android. Endianness maybe? | 99 // FIXME: This fails on Android. Endianness maybe? |
| 100 // Yellow: expects 0xFFFFFF00, was 0xFF00FFFF on android. | 100 // Yellow: expects 0xFFFFFF00, was 0xFF00FFFF on android. |
| 101 // Cyan: expects 0xFF00FFFF, was 0xFFFFFF00 on android. | 101 // Cyan: expects 0xFF00FFFF, was 0xFFFFFF00 on android. |
| 102 // http://crbug.com/154528 | 102 // http://crbug.com/154528 |
| 103 #ifndef OS_ANDROID | 103 #ifndef OS_ANDROID |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 142 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 142 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 143 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), gfx::Transform()); | 143 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), gfx::Transform()); |
| 144 scoped_ptr<TileDrawQuad> outerQuad = TileDrawQuad::Create(); | 144 scoped_ptr<TileDrawQuad> outerQuad = TileDrawQuad::Create(); |
| 145 outerQuad->SetNew(sharedQuadState.get(), outerRect, outerRect, resourceYello
w, gfx::RectF(gfx::PointF(), outerSize), outerSize, false, false, false, false,
false); | 145 outerQuad->SetNew(sharedQuadState.get(), outerRect, outerRect, resourceYello
w, gfx::RectF(gfx::PointF(), outerSize), outerSize, false, false, false, false,
false); |
| 146 scoped_ptr<TileDrawQuad> innerQuad = TileDrawQuad::Create(); | 146 scoped_ptr<TileDrawQuad> innerQuad = TileDrawQuad::Create(); |
| 147 innerQuad->SetNew(sharedQuadState.get(), innerRect, innerRect, resourceCyan,
gfx::RectF(gfx::PointF(), innerSize), innerSize, false, false, false, false, fa
lse); | 147 innerQuad->SetNew(sharedQuadState.get(), innerRect, innerRect, resourceCyan,
gfx::RectF(gfx::PointF(), innerSize), innerSize, false, false, false, false, fa
lse); |
| 148 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); | 148 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 149 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 149 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 150 | 150 |
| 151 RenderPassList list; | 151 RenderPassList list; |
| 152 list.append(rootRenderPass.PassAs<RenderPass>()); | 152 list.push_back(rootRenderPass.PassAs<RenderPass>()); |
| 153 renderer()->drawFrame(list); | 153 renderer()->drawFrame(list); |
| 154 | 154 |
| 155 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); | 155 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); |
| 156 renderer()->getFramebufferPixels(pixels.get(), outerRect); | 156 renderer()->getFramebufferPixels(pixels.get(), outerRect); |
| 157 | 157 |
| 158 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); | 158 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); |
| 159 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); | 159 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); |
| 160 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); | 160 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); |
| 161 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); | 161 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); |
| 162 } | 162 } |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 200 // If we didn't clear, the borders should still be green. | 200 // If we didn't clear, the borders should still be green. |
| 201 EXPECT_EQ(SK_ColorGREEN, pixels[0]); | 201 EXPECT_EQ(SK_ColorGREEN, pixels[0]); |
| 202 EXPECT_EQ(SK_ColorGREEN, pixels[viewportPixels - 1]); | 202 EXPECT_EQ(SK_ColorGREEN, pixels[viewportPixels - 1]); |
| 203 | 203 |
| 204 EXPECT_EQ(SK_ColorMAGENTA, pixels[smallerRect.y() * viewportRect.width() + s
mallerRect.x()]); | 204 EXPECT_EQ(SK_ColorMAGENTA, pixels[smallerRect.y() * viewportRect.width() + s
mallerRect.x()]); |
| 205 EXPECT_EQ(SK_ColorMAGENTA, pixels[(smallerRect.bottom() - 1) * viewportRect.
width() + smallerRect.right() - 1]); | 205 EXPECT_EQ(SK_ColorMAGENTA, pixels[(smallerRect.bottom() - 1) * viewportRect.
width() + smallerRect.right() - 1]); |
| 206 } | 206 } |
| 207 | 207 |
| 208 } // namespace | 208 } // namespace |
| 209 } // namespace cc | 209 } // namespace cc |
| OLD | NEW |