OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/base/scoped_ptr_vector.h" | 5 #include "cc/base/scoped_ptr_vector.h" |
6 #include "cc/output/compositor_frame_metadata.h" | 6 #include "cc/output/compositor_frame_metadata.h" |
7 #include "cc/output/gl_renderer.h" | 7 #include "cc/output/gl_renderer.h" |
8 #include "cc/output/output_surface.h" | 8 #include "cc/output/output_surface.h" |
9 #include "cc/output/output_surface_client.h" | 9 #include "cc/output/output_surface_client.h" |
10 #include "cc/output/overlay_candidate_validator.h" | 10 #include "cc/output/overlay_candidate_validator.h" |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
71 EXPECT_NEAR(kOverlayRect.height(), candidate.display_rect.height(), 0.01f); | 71 EXPECT_NEAR(kOverlayRect.height(), candidate.display_rect.height(), 0.01f); |
72 } | 72 } |
73 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(), | 73 EXPECT_EQ(BoundingRect(kUVTopLeft, kUVBottomRight).ToString(), |
74 candidate.uv_rect.ToString()); | 74 candidate.uv_rect.ToString()); |
75 candidate.overlay_handled = true; | 75 candidate.overlay_handled = true; |
76 } | 76 } |
77 | 77 |
78 template <typename OverlayStrategyType> | 78 template <typename OverlayStrategyType> |
79 class SingleOverlayProcessor : public OverlayProcessor { | 79 class SingleOverlayProcessor : public OverlayProcessor { |
80 public: | 80 public: |
81 SingleOverlayProcessor(OutputSurface* surface, | 81 explicit SingleOverlayProcessor(OutputSurface* surface) |
82 ResourceProvider* resource_provider) | 82 : OverlayProcessor(surface) { |
83 : OverlayProcessor(surface, resource_provider) { | |
84 EXPECT_EQ(surface, surface_); | 83 EXPECT_EQ(surface, surface_); |
85 EXPECT_EQ(resource_provider, resource_provider_); | |
86 } | 84 } |
87 | 85 |
88 // Virtual to allow testing different strategies. | 86 // Virtual to allow testing different strategies. |
89 void Initialize() override { | 87 void Initialize() override { |
90 OverlayCandidateValidator* candidates = | 88 OverlayCandidateValidator* candidates = |
91 surface_->GetOverlayCandidateValidator(); | 89 surface_->GetOverlayCandidateValidator(); |
92 ASSERT_TRUE(candidates != NULL); | 90 ASSERT_TRUE(candidates != NULL); |
93 strategies_.push_back(scoped_ptr<Strategy>( | 91 strategies_.push_back( |
94 new OverlayStrategyType(candidates, resource_provider_))); | 92 scoped_ptr<Strategy>(new OverlayStrategyType(candidates))); |
95 } | 93 } |
96 }; | 94 }; |
97 | 95 |
98 class DefaultOverlayProcessor : public OverlayProcessor { | 96 class DefaultOverlayProcessor : public OverlayProcessor { |
99 public: | 97 public: |
100 DefaultOverlayProcessor(OutputSurface* surface, | 98 explicit DefaultOverlayProcessor(OutputSurface* surface); |
101 ResourceProvider* resource_provider); | |
102 size_t GetStrategyCount(); | 99 size_t GetStrategyCount(); |
103 }; | 100 }; |
104 | 101 |
105 DefaultOverlayProcessor::DefaultOverlayProcessor( | 102 DefaultOverlayProcessor::DefaultOverlayProcessor(OutputSurface* surface) |
106 OutputSurface* surface, | 103 : OverlayProcessor(surface) { |
107 ResourceProvider* resource_provider) | 104 } |
108 : OverlayProcessor(surface, resource_provider) {} | |
109 | 105 |
110 size_t DefaultOverlayProcessor::GetStrategyCount() { | 106 size_t DefaultOverlayProcessor::GetStrategyCount() { |
111 return strategies_.size(); | 107 return strategies_.size(); |
112 } | 108 } |
113 | 109 |
114 class OverlayOutputSurface : public OutputSurface { | 110 class OverlayOutputSurface : public OutputSurface { |
115 public: | 111 public: |
116 explicit OverlayOutputSurface(scoped_refptr<ContextProvider> context_provider) | 112 explicit OverlayOutputSurface(scoped_refptr<ContextProvider> context_provider) |
117 : OutputSurface(context_provider) {} | 113 : OutputSurface(context_provider) {} |
118 | 114 |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
150 | 146 |
151 SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState(); | 147 SharedQuadState* shared_state = pass->CreateAndAppendSharedQuadState(); |
152 shared_state->opacity = 1.f; | 148 shared_state->opacity = 1.f; |
153 return pass.Pass(); | 149 return pass.Pass(); |
154 } | 150 } |
155 | 151 |
156 ResourceId CreateResource(ResourceProvider* resource_provider) { | 152 ResourceId CreateResource(ResourceProvider* resource_provider) { |
157 unsigned sync_point = 0; | 153 unsigned sync_point = 0; |
158 TextureMailbox mailbox = | 154 TextureMailbox mailbox = |
159 TextureMailbox(gpu::Mailbox::Generate(), GL_TEXTURE_2D, sync_point); | 155 TextureMailbox(gpu::Mailbox::Generate(), GL_TEXTURE_2D, sync_point); |
160 mailbox.set_allow_overlay(true); | |
161 scoped_ptr<SingleReleaseCallbackImpl> release_callback = | 156 scoped_ptr<SingleReleaseCallbackImpl> release_callback = |
162 SingleReleaseCallbackImpl::Create(base::Bind(&MailboxReleased)); | 157 SingleReleaseCallbackImpl::Create(base::Bind(&MailboxReleased)); |
163 | 158 |
164 return resource_provider->CreateResourceFromTextureMailbox( | 159 return resource_provider->CreateResourceFromTextureMailbox( |
165 mailbox, release_callback.Pass()); | 160 mailbox, release_callback.Pass()); |
166 } | 161 } |
167 | 162 |
168 SolidColorDrawQuad* CreateSolidColorQuadAt( | 163 SolidColorDrawQuad* CreateSolidColorQuadAt( |
169 const SharedQuadState* shared_quad_state, | 164 const SharedQuadState* shared_quad_state, |
170 SkColor color, | 165 SkColor color, |
171 RenderPass* render_pass, | 166 RenderPass* render_pass, |
172 const gfx::Rect& rect) { | 167 const gfx::Rect& rect) { |
173 SolidColorDrawQuad* quad = | 168 SolidColorDrawQuad* quad = |
174 render_pass->CreateAndAppendDrawQuad<SolidColorDrawQuad>(); | 169 render_pass->CreateAndAppendDrawQuad<SolidColorDrawQuad>(); |
175 quad->SetNew(shared_quad_state, rect, rect, color, false); | 170 quad->SetNew(shared_quad_state, rect, rect, color, false); |
176 return quad; | 171 return quad; |
177 } | 172 } |
178 | 173 |
179 TextureDrawQuad* CreateCandidateQuadAt(ResourceProvider* resource_provider, | 174 TextureDrawQuad* CreateCandidateQuadAt(ResourceProvider* resource_provider, |
180 const SharedQuadState* shared_quad_state, | 175 const SharedQuadState* shared_quad_state, |
181 RenderPass* render_pass, | 176 RenderPass* render_pass, |
182 const gfx::Rect& rect) { | 177 const gfx::Rect& rect) { |
183 ResourceId resource_id = CreateResource(resource_provider); | 178 ResourceId resource_id = CreateResource(resource_provider); |
184 bool premultiplied_alpha = false; | 179 bool premultiplied_alpha = false; |
185 bool flipped = false; | 180 bool flipped = false; |
186 bool nearest_neighbor = false; | 181 bool nearest_neighbor = false; |
187 float vertex_opacity[4] = {1.0f, 1.0f, 1.0f, 1.0f}; | 182 float vertex_opacity[4] = {1.0f, 1.0f, 1.0f, 1.0f}; |
| 183 gfx::Size resource_size_in_pixels = gfx::Size(64, 64); |
| 184 bool allow_overlay = true; |
188 | 185 |
189 TextureDrawQuad* overlay_quad = | 186 TextureDrawQuad* overlay_quad = |
190 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); | 187 render_pass->CreateAndAppendDrawQuad<TextureDrawQuad>(); |
191 overlay_quad->SetNew(shared_quad_state, | 188 overlay_quad->SetNew(shared_quad_state, |
192 rect, | 189 rect, |
193 rect, | 190 rect, |
194 rect, | 191 rect, |
195 resource_id, | 192 resource_id, |
196 premultiplied_alpha, | 193 premultiplied_alpha, |
197 kUVTopLeft, | 194 kUVTopLeft, |
198 kUVBottomRight, | 195 kUVBottomRight, |
199 SK_ColorTRANSPARENT, | 196 SK_ColorTRANSPARENT, |
200 vertex_opacity, | 197 vertex_opacity, |
201 flipped, | 198 flipped, |
202 nearest_neighbor); | 199 nearest_neighbor); |
| 200 overlay_quad->set_allow_overlay(allow_overlay); |
| 201 overlay_quad->set_resource_size_in_pixels(resource_size_in_pixels); |
203 | 202 |
204 return overlay_quad; | 203 return overlay_quad; |
205 } | 204 } |
206 | 205 |
207 StreamVideoDrawQuad* CreateCandidateVideoQuadAt( | 206 StreamVideoDrawQuad* CreateCandidateVideoQuadAt( |
208 ResourceProvider* resource_provider, | 207 ResourceProvider* resource_provider, |
209 const SharedQuadState* shared_quad_state, | 208 const SharedQuadState* shared_quad_state, |
210 RenderPass* render_pass, | 209 RenderPass* render_pass, |
211 const gfx::Rect& rect, | 210 const gfx::Rect& rect, |
212 const gfx::Transform& transform) { | 211 const gfx::Transform& transform) { |
213 ResourceId resource_id = CreateResource(resource_provider); | 212 ResourceId resource_id = CreateResource(resource_provider); |
| 213 gfx::Size resource_size_in_pixels = gfx::Size(64, 64); |
| 214 bool allow_overlay = true; |
214 | 215 |
215 StreamVideoDrawQuad* overlay_quad = | 216 StreamVideoDrawQuad* overlay_quad = |
216 render_pass->CreateAndAppendDrawQuad<StreamVideoDrawQuad>(); | 217 render_pass->CreateAndAppendDrawQuad<StreamVideoDrawQuad>(); |
217 overlay_quad->SetNew(shared_quad_state, rect, rect, rect, resource_id, | 218 overlay_quad->SetNew(shared_quad_state, rect, rect, rect, resource_id, |
218 transform); | 219 resource_size_in_pixels, allow_overlay, transform); |
219 | 220 |
220 return overlay_quad; | 221 return overlay_quad; |
221 } | 222 } |
222 | 223 |
223 TextureDrawQuad* CreateFullscreenCandidateQuad( | 224 TextureDrawQuad* CreateFullscreenCandidateQuad( |
224 ResourceProvider* resource_provider, | 225 ResourceProvider* resource_provider, |
225 const SharedQuadState* shared_quad_state, | 226 const SharedQuadState* shared_quad_state, |
226 RenderPass* render_pass) { | 227 RenderPass* render_pass) { |
227 return CreateCandidateQuadAt( | 228 return CreateCandidateQuadAt( |
228 resource_provider, shared_quad_state, render_pass, kOverlayRect); | 229 resource_provider, shared_quad_state, render_pass, kOverlayRect); |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
299 EXPECT_TRUE(output_surface.BindToClient(&client)); | 300 EXPECT_TRUE(output_surface.BindToClient(&client)); |
300 output_surface.InitWithSingleOverlayValidator(); | 301 output_surface.InitWithSingleOverlayValidator(); |
301 EXPECT_TRUE(output_surface.GetOverlayCandidateValidator() != NULL); | 302 EXPECT_TRUE(output_surface.GetOverlayCandidateValidator() != NULL); |
302 | 303 |
303 scoped_ptr<SharedBitmapManager> shared_bitmap_manager( | 304 scoped_ptr<SharedBitmapManager> shared_bitmap_manager( |
304 new TestSharedBitmapManager()); | 305 new TestSharedBitmapManager()); |
305 scoped_ptr<ResourceProvider> resource_provider = FakeResourceProvider::Create( | 306 scoped_ptr<ResourceProvider> resource_provider = FakeResourceProvider::Create( |
306 &output_surface, shared_bitmap_manager.get()); | 307 &output_surface, shared_bitmap_manager.get()); |
307 | 308 |
308 scoped_ptr<DefaultOverlayProcessor> overlay_processor( | 309 scoped_ptr<DefaultOverlayProcessor> overlay_processor( |
309 new DefaultOverlayProcessor(&output_surface, resource_provider.get())); | 310 new DefaultOverlayProcessor(&output_surface)); |
310 overlay_processor->Initialize(); | 311 overlay_processor->Initialize(); |
311 EXPECT_GE(2U, overlay_processor->GetStrategyCount()); | 312 EXPECT_GE(2U, overlay_processor->GetStrategyCount()); |
312 } | 313 } |
313 | 314 |
314 template <typename OverlayStrategyType> | 315 template <typename OverlayStrategyType> |
315 class OverlayTest : public testing::Test { | 316 class OverlayTest : public testing::Test { |
316 protected: | 317 protected: |
317 void SetUp() override { | 318 void SetUp() override { |
318 provider_ = TestContextProvider::Create(); | 319 provider_ = TestContextProvider::Create(); |
319 output_surface_.reset(new OverlayOutputSurface(provider_)); | 320 output_surface_.reset(new OverlayOutputSurface(provider_)); |
320 EXPECT_TRUE(output_surface_->BindToClient(&client_)); | 321 EXPECT_TRUE(output_surface_->BindToClient(&client_)); |
321 output_surface_->InitWithSingleOverlayValidator(); | 322 output_surface_->InitWithSingleOverlayValidator(); |
322 EXPECT_TRUE(output_surface_->GetOverlayCandidateValidator() != NULL); | 323 EXPECT_TRUE(output_surface_->GetOverlayCandidateValidator() != NULL); |
323 | 324 |
324 shared_bitmap_manager_.reset(new TestSharedBitmapManager()); | 325 shared_bitmap_manager_.reset(new TestSharedBitmapManager()); |
325 resource_provider_ = FakeResourceProvider::Create( | 326 resource_provider_ = FakeResourceProvider::Create( |
326 output_surface_.get(), shared_bitmap_manager_.get()); | 327 output_surface_.get(), shared_bitmap_manager_.get()); |
327 | 328 |
328 overlay_processor_.reset(new SingleOverlayProcessor<OverlayStrategyType>( | 329 overlay_processor_.reset( |
329 output_surface_.get(), resource_provider_.get())); | 330 new SingleOverlayProcessor<OverlayStrategyType>(output_surface_.get())); |
330 overlay_processor_->Initialize(); | 331 overlay_processor_->Initialize(); |
331 } | 332 } |
332 | 333 |
333 scoped_refptr<TestContextProvider> provider_; | 334 scoped_refptr<TestContextProvider> provider_; |
334 scoped_ptr<OverlayOutputSurface> output_surface_; | 335 scoped_ptr<OverlayOutputSurface> output_surface_; |
335 FakeOutputSurfaceClient client_; | 336 FakeOutputSurfaceClient client_; |
336 scoped_ptr<SharedBitmapManager> shared_bitmap_manager_; | 337 scoped_ptr<SharedBitmapManager> shared_bitmap_manager_; |
337 scoped_ptr<ResourceProvider> resource_provider_; | 338 scoped_ptr<ResourceProvider> resource_provider_; |
338 scoped_ptr<SingleOverlayProcessor<OverlayStrategyType>> overlay_processor_; | 339 scoped_ptr<SingleOverlayProcessor<OverlayStrategyType>> overlay_processor_; |
339 }; | 340 }; |
(...skipping 841 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1181 renderer_->BeginDrawingFrame(&frame3); | 1182 renderer_->BeginDrawingFrame(&frame3); |
1182 renderer_->FinishDrawingFrame(&frame3); | 1183 renderer_->FinishDrawingFrame(&frame3); |
1183 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1)); | 1184 EXPECT_TRUE(resource_provider_->InUseByConsumer(resource1)); |
1184 SwapBuffers(); | 1185 SwapBuffers(); |
1185 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1)); | 1186 EXPECT_FALSE(resource_provider_->InUseByConsumer(resource1)); |
1186 Mock::VerifyAndClearExpectations(&scheduler_); | 1187 Mock::VerifyAndClearExpectations(&scheduler_); |
1187 } | 1188 } |
1188 | 1189 |
1189 } // namespace | 1190 } // namespace |
1190 } // namespace cc | 1191 } // namespace cc |
OLD | NEW |