Chromium Code Reviews| Index: content/browser/compositor/onscreen_display_client.cc |
| diff --git a/content/browser/compositor/onscreen_display_client.cc b/content/browser/compositor/onscreen_display_client.cc |
| index a071a213a28c3b750be768eada7f6e694893b2d2..c814dff4617f80b2b86f13150120f5cc27fa13e4 100644 |
| --- a/content/browser/compositor/onscreen_display_client.cc |
| +++ b/content/browser/compositor/onscreen_display_client.cc |
| @@ -14,12 +14,15 @@ namespace content { |
| OnscreenDisplayClient::OnscreenDisplayClient( |
| const scoped_refptr<cc::ContextProvider>& onscreen_context_provider, |
| scoped_ptr<cc::OutputSurface> software_surface, |
| - cc::SurfaceManager* manager) |
| + cc::SurfaceManager* manager, |
| + scoped_refptr<base::SingleThreadTaskRunner> task_runner) |
| : onscreen_context_provider_(onscreen_context_provider), |
| software_surface_(software_surface.Pass()), |
| - display_(new cc::Display(this, |
| - manager, |
| - HostSharedBitmapManager::current())) { |
| + display_( |
| + new cc::Display(this, manager, HostSharedBitmapManager::current())), |
| + task_runner_(task_runner), |
| + scheduled_draw_(false), |
| + weak_ptr_factory_(this) { |
| } |
| OnscreenDisplayClient::~OnscreenDisplayClient() { |
| @@ -32,4 +35,18 @@ scoped_ptr<cc::OutputSurface> OnscreenDisplayClient::CreateOutputSurface() { |
| .Pass(); |
| } |
| +void OnscreenDisplayClient::DisplayDamaged() { |
| + if (scheduled_draw_) |
| + return; |
| + scheduled_draw_ = true; |
| + task_runner_->PostTask( |
|
jamesr
2014/08/11 22:04:43
could you add some traces here and to ::Draw()? we
|
| + FROM_HERE, |
| + base::Bind(&OnscreenDisplayClient::Draw, weak_ptr_factory_.GetWeakPtr())); |
| +} |
| + |
| +void OnscreenDisplayClient::Draw() { |
| + scheduled_draw_ = false; |
| + display_->Draw(); |
| +} |
| + |
| } // namespace content |