| 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->allow_overlay = allow_overlay; |
| 201 overlay_quad->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 |