OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "content/browser/compositor/reflector_impl.h" | |
6 | |
7 #include "base/memory/ptr_util.h" | |
8 #include "base/run_loop.h" | 5 #include "base/run_loop.h" |
9 #include "base/single_thread_task_runner.h" | 6 #include "base/single_thread_task_runner.h" |
10 #include "build/build_config.h" | 7 #include "build/build_config.h" |
11 #include "cc/test/fake_output_surface_client.h" | 8 #include "cc/test/fake_output_surface_client.h" |
12 #include "cc/test/test_context_provider.h" | 9 #include "cc/test/test_context_provider.h" |
13 #include "cc/test/test_web_graphics_context_3d.h" | 10 #include "cc/test/test_web_graphics_context_3d.h" |
14 #include "content/browser/compositor/browser_compositor_output_surface.h" | 11 #include "content/browser/compositor/browser_compositor_output_surface.h" |
15 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor.h" | 12 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor.h" |
| 13 #include "content/browser/compositor/reflector_impl.h" |
16 #include "content/browser/compositor/reflector_texture.h" | 14 #include "content/browser/compositor/reflector_texture.h" |
17 #include "content/browser/compositor/test/no_transport_image_transport_factory.h
" | 15 #include "content/browser/compositor/test/no_transport_image_transport_factory.h
" |
18 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
19 #include "ui/compositor/compositor.h" | 17 #include "ui/compositor/compositor.h" |
20 #include "ui/compositor/layer.h" | 18 #include "ui/compositor/layer.h" |
21 #include "ui/compositor/test/context_factories_for_test.h" | 19 #include "ui/compositor/test/context_factories_for_test.h" |
22 | 20 |
23 #if defined(USE_OZONE) | 21 #if defined(USE_OZONE) |
24 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor_ozone.h" | 22 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor_ozone.h" |
25 #include "ui/ozone/public/overlay_candidates_ozone.h" | 23 #include "ui/ozone/public/overlay_candidates_ozone.h" |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
68 new TestOverlayCandidatesOzone()))); | 66 new TestOverlayCandidatesOzone()))); |
69 #else | 67 #else |
70 return nullptr; | 68 return nullptr; |
71 #endif // defined(USE_OZONE) | 69 #endif // defined(USE_OZONE) |
72 } | 70 } |
73 | 71 |
74 class TestOutputSurface : public BrowserCompositorOutputSurface { | 72 class TestOutputSurface : public BrowserCompositorOutputSurface { |
75 public: | 73 public: |
76 TestOutputSurface( | 74 TestOutputSurface( |
77 const scoped_refptr<cc::ContextProvider>& context_provider, | 75 const scoped_refptr<cc::ContextProvider>& context_provider, |
78 const scoped_refptr<ui::CompositorVSyncManager>& vsync_manager) | 76 const scoped_refptr<ui::CompositorVSyncManager>& vsync_manager, |
| 77 base::SingleThreadTaskRunner* task_runner) |
79 : BrowserCompositorOutputSurface(context_provider, | 78 : BrowserCompositorOutputSurface(context_provider, |
80 nullptr, | 79 nullptr, |
81 vsync_manager, | 80 vsync_manager, |
| 81 task_runner, |
82 CreateTestValidatorOzone()) { | 82 CreateTestValidatorOzone()) { |
83 surface_size_ = gfx::Size(256, 256); | 83 surface_size_ = gfx::Size(256, 256); |
84 device_scale_factor_ = 1.f; | 84 device_scale_factor_ = 1.f; |
85 } | 85 } |
86 | 86 |
87 void SetFlip(bool flip) { capabilities_.flipped_output_surface = flip; } | 87 void SetFlip(bool flip) { capabilities_.flipped_output_surface = flip; } |
88 | 88 |
89 void SwapBuffers(cc::CompositorFrame* frame) override {} | 89 void SwapBuffers(cc::CompositorFrame* frame) override {} |
90 | 90 |
91 void OnReflectorChanged() override { | 91 void OnReflectorChanged() override { |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
129 new NoTransportImageTransportFactory)); | 129 new NoTransportImageTransportFactory)); |
130 message_loop_.reset(new base::MessageLoop()); | 130 message_loop_.reset(new base::MessageLoop()); |
131 task_runner_ = message_loop_->task_runner(); | 131 task_runner_ = message_loop_->task_runner(); |
132 compositor_task_runner_ = new FakeTaskRunner(); | 132 compositor_task_runner_ = new FakeTaskRunner(); |
133 compositor_.reset( | 133 compositor_.reset( |
134 new ui::Compositor(context_factory, compositor_task_runner_.get())); | 134 new ui::Compositor(context_factory, compositor_task_runner_.get())); |
135 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 135 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
136 context_provider_ = | 136 context_provider_ = |
137 cc::TestContextProvider::Create(cc::TestWebGraphicsContext3D::Create()); | 137 cc::TestContextProvider::Create(cc::TestWebGraphicsContext3D::Create()); |
138 output_surface_ = std::unique_ptr<TestOutputSurface>( | 138 output_surface_ = std::unique_ptr<TestOutputSurface>( |
139 new TestOutputSurface(context_provider_, compositor_->vsync_manager())); | 139 new TestOutputSurface(context_provider_, compositor_->vsync_manager(), |
| 140 compositor_task_runner_.get())); |
140 CHECK(output_surface_->BindToClient(&output_surface_client_)); | 141 CHECK(output_surface_->BindToClient(&output_surface_client_)); |
141 | 142 |
142 root_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR)); | 143 root_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR)); |
143 compositor_->SetRootLayer(root_layer_.get()); | 144 compositor_->SetRootLayer(root_layer_.get()); |
144 mirroring_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR)); | 145 mirroring_layer_.reset(new ui::Layer(ui::LAYER_SOLID_COLOR)); |
145 compositor_->root_layer()->Add(mirroring_layer_.get()); | 146 compositor_->root_layer()->Add(mirroring_layer_.get()); |
146 gfx::Size size = output_surface_->SurfaceSize(); | 147 gfx::Size size = output_surface_->SurfaceSize(); |
147 mirroring_layer_->SetBounds(gfx::Rect(size.width(), size.height())); | 148 mirroring_layer_->SetBounds(gfx::Rect(size.width(), size.height())); |
148 } | 149 } |
149 | 150 |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
221 plane_2.plane_z_order = 1; | 222 plane_2.plane_z_order = 1; |
222 list.push_back(plane_1); | 223 list.push_back(plane_1); |
223 list.push_back(plane_2); | 224 list.push_back(plane_2); |
224 output_surface_->GetOverlayCandidateValidator()->CheckOverlaySupport(&list); | 225 output_surface_->GetOverlayCandidateValidator()->CheckOverlaySupport(&list); |
225 EXPECT_FALSE(list[0].overlay_handled); | 226 EXPECT_FALSE(list[0].overlay_handled); |
226 } | 227 } |
227 #endif // defined(USE_OZONE) | 228 #endif // defined(USE_OZONE) |
228 | 229 |
229 } // namespace | 230 } // namespace |
230 } // namespace content | 231 } // namespace content |
OLD | NEW |