| 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" |
| 11 #include "cc/test/animation_test_common.h" | 11 #include "cc/test/animation_test_common.h" |
| 12 #include "cc/test/fake_web_compositor_output_surface.h" | 12 #include "cc/test/fake_web_compositor_output_surface.h" |
| 13 #include "cc/test/fake_web_compositor_software_output_device.h" | 13 #include "cc/test/fake_web_compositor_software_output_device.h" |
| 14 #include "cc/test/geometry_test_utils.h" | 14 #include "cc/test/geometry_test_utils.h" |
| 15 #include "cc/test/render_pass_test_common.h" | 15 #include "cc/test/render_pass_test_common.h" |
| 16 #include "cc/tile_draw_quad.h" | 16 #include "cc/tile_draw_quad.h" |
| 17 #include "testing/gmock/include/gmock/gmock.h" | 17 #include "testing/gmock/include/gmock/gmock.h" |
| 18 #include "testing/gtest/include/gtest/gtest.h" | 18 #include "testing/gtest/include/gtest/gtest.h" |
| 19 | 19 |
| 20 using namespace WebKit; | 20 using namespace WebKit; |
| 21 using namespace WebKitTests; | 21 using namespace WebKitTests; |
| 22 | 22 |
| 23 using gfx::Transform; |
| 24 |
| 23 namespace cc { | 25 namespace cc { |
| 24 namespace { | 26 namespace { |
| 25 | 27 |
| 26 class SoftwareRendererTest : public testing::Test, public RendererClient { | 28 class SoftwareRendererTest : public testing::Test, public RendererClient { |
| 27 public: | 29 public: |
| 28 void initializeRenderer() { | 30 void initializeRenderer() { |
| 29 m_outputSurface = FakeWebCompositorOutputSurface::createSoftware(scoped_
ptr<WebKit::WebCompositorSoftwareOutputDevice>(new FakeWebCompositorSoftwareOutp
utDevice)); | 31 m_outputSurface = FakeWebCompositorOutputSurface::createSoftware(scoped_
ptr<WebKit::WebCompositorSoftwareOutputDevice>(new FakeWebCompositorSoftwareOutp
utDevice)); |
| 30 m_resourceProvider = ResourceProvider::create(m_outputSurface.get()); | 32 m_resourceProvider = ResourceProvider::create(m_outputSurface.get()); |
| 31 m_renderer = SoftwareRenderer::create(this, resourceProvider(), software
Device()); | 33 m_renderer = SoftwareRenderer::create(this, resourceProvider(), software
Device()); |
| 32 } | 34 } |
| (...skipping 27 matching lines...) Expand all Loading... |
| 60 gfx::Size outerSize(100, 100); | 62 gfx::Size outerSize(100, 100); |
| 61 int outerPixels = outerSize.width() * outerSize.height(); | 63 int outerPixels = outerSize.width() * outerSize.height(); |
| 62 gfx::Size innerSize(98, 98); | 64 gfx::Size innerSize(98, 98); |
| 63 gfx::Rect outerRect(gfx::Point(), outerSize); | 65 gfx::Rect outerRect(gfx::Point(), outerSize); |
| 64 gfx::Rect innerRect(gfx::Point(1, 1), innerSize); | 66 gfx::Rect innerRect(gfx::Point(1, 1), innerSize); |
| 65 setViewportSize(outerSize); | 67 setViewportSize(outerSize); |
| 66 | 68 |
| 67 initializeRenderer(); | 69 initializeRenderer(); |
| 68 | 70 |
| 69 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); | 71 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); |
| 70 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, out
erRect, false, 1.0); | 72 sharedQuadState->SetAll(Transform(), outerRect, outerRect, outerRect, false,
1.0); |
| 71 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); | 73 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); |
| 72 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 74 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 73 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), WebTransfor
mationMatrix()); | 75 rootRenderPass->SetNew(rootRenderPassId, outerRect, gfx::Rect(), Transform()
); |
| 74 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); | 76 scoped_ptr<SolidColorDrawQuad> outerQuad = SolidColorDrawQuad::Create(); |
| 75 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); | 77 outerQuad->SetNew(sharedQuadState.get(), outerRect, SK_ColorYELLOW); |
| 76 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); | 78 scoped_ptr<SolidColorDrawQuad> innerQuad = SolidColorDrawQuad::Create(); |
| 77 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); | 79 innerQuad->SetNew(sharedQuadState.get(), innerRect, SK_ColorCYAN); |
| 78 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); | 80 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 79 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 81 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 80 | 82 |
| 81 RenderPassList list; | 83 RenderPassList list; |
| 82 RenderPassIdHashMap hashmap; | 84 RenderPassIdHashMap hashmap; |
| 83 list.push_back(rootRenderPass.get()); | 85 list.push_back(rootRenderPass.get()); |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 121 yellowPixels[i] = yellow; | 123 yellowPixels[i] = yellow; |
| 122 for (int i = 0; i < innerPixels; i++) | 124 for (int i = 0; i < innerPixels; i++) |
| 123 cyanPixels[i] = cyan; | 125 cyanPixels[i] = cyan; |
| 124 | 126 |
| 125 resourceProvider()->setPixels(resourceYellow, reinterpret_cast<uint8_t*>(yel
lowPixels.get()), gfx::Rect(gfx::Point(), outerSize), gfx::Rect(gfx::Point(), ou
terSize), gfx::Vector2d()); | 127 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()); | 128 resourceProvider()->setPixels(resourceCyan, reinterpret_cast<uint8_t*>(cyanP
ixels.get()), gfx::Rect(gfx::Point(), innerSize), gfx::Rect(gfx::Point(), innerS
ize), gfx::Vector2d()); |
| 127 | 129 |
| 128 gfx::Rect rect = gfx::Rect(gfx::Point(), deviceViewportSize()); | 130 gfx::Rect rect = gfx::Rect(gfx::Point(), deviceViewportSize()); |
| 129 | 131 |
| 130 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); | 132 scoped_ptr<SharedQuadState> sharedQuadState = SharedQuadState::Create(); |
| 131 sharedQuadState->SetAll(WebTransformationMatrix(), outerRect, outerRect, out
erRect, false, 1.0); | 133 sharedQuadState->SetAll(Transform(), outerRect, outerRect, outerRect, false,
1.0); |
| 132 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); | 134 RenderPass::Id rootRenderPassId = RenderPass::Id(1, 1); |
| 133 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); | 135 scoped_ptr<TestRenderPass> rootRenderPass = TestRenderPass::Create(); |
| 134 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), WebTransformationMatrix()); | 136 rootRenderPass->SetNew(rootRenderPassId, gfx::Rect(gfx::Point(), deviceViewp
ortSize()), gfx::Rect(), Transform()); |
| 135 scoped_ptr<TileDrawQuad> outerQuad = TileDrawQuad::Create(); | 137 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); | 138 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(); | 139 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); | 140 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>()); | 141 rootRenderPass->AppendQuad(innerQuad.PassAs<DrawQuad>()); |
| 140 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); | 142 rootRenderPass->AppendQuad(outerQuad.PassAs<DrawQuad>()); |
| 141 | 143 |
| 142 RenderPassList list; | 144 RenderPassList list; |
| 143 RenderPassIdHashMap hashmap; | 145 RenderPassIdHashMap hashmap; |
| 144 list.push_back(rootRenderPass.get()); | 146 list.push_back(rootRenderPass.get()); |
| 145 hashmap.add(rootRenderPassId, rootRenderPass.PassAs<RenderPass>()); | 147 hashmap.add(rootRenderPassId, rootRenderPass.PassAs<RenderPass>()); |
| 146 renderer()->drawFrame(list, hashmap); | 148 renderer()->drawFrame(list, hashmap); |
| 147 | 149 |
| 148 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); | 150 scoped_array<SkColor> pixels(new SkColor[deviceViewportSize().width() * devi
ceViewportSize().height()]); |
| 149 renderer()->getFramebufferPixels(pixels.get(), outerRect); | 151 renderer()->getFramebufferPixels(pixels.get(), outerRect); |
| 150 | 152 |
| 151 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); | 153 EXPECT_EQ(SK_ColorYELLOW, pixels[0]); |
| 152 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); | 154 EXPECT_EQ(SK_ColorYELLOW, pixels[outerPixels - 1]); |
| 153 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); | 155 EXPECT_EQ(SK_ColorCYAN, pixels[outerSize.width() + 1]); |
| 154 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); | 156 EXPECT_EQ(SK_ColorCYAN, pixels[outerPixels - outerSize.width() - 2]); |
| 155 } | 157 } |
| 156 | 158 |
| 157 } // namespace | 159 } // namespace |
| 158 } // namespace cc | 160 } // namespace cc |
| OLD | NEW |