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/surfaces/display.h" | 5 #include "cc/surfaces/display.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
10 #include "base/trace_event/trace_event.h" | 10 #include "base/trace_event/trace_event.h" |
(...skipping 15 matching lines...) Expand all Loading... |
26 | 26 |
27 #if defined(ENABLE_VULKAN) | 27 #if defined(ENABLE_VULKAN) |
28 #include "cc/output/vulkan_renderer.h" | 28 #include "cc/output/vulkan_renderer.h" |
29 #endif | 29 #endif |
30 | 30 |
31 namespace cc { | 31 namespace cc { |
32 | 32 |
33 Display::Display(SharedBitmapManager* bitmap_manager, | 33 Display::Display(SharedBitmapManager* bitmap_manager, |
34 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | 34 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, |
35 const RendererSettings& settings, | 35 const RendererSettings& settings, |
36 std::unique_ptr<BeginFrameSource> begin_frame_source, | 36 BeginFrameSource* begin_frame_source, |
37 std::unique_ptr<OutputSurface> output_surface, | 37 std::unique_ptr<OutputSurface> output_surface, |
38 std::unique_ptr<DisplayScheduler> scheduler, | 38 std::unique_ptr<DisplayScheduler> scheduler, |
39 std::unique_ptr<TextureMailboxDeleter> texture_mailbox_deleter) | 39 std::unique_ptr<TextureMailboxDeleter> texture_mailbox_deleter) |
40 : bitmap_manager_(bitmap_manager), | 40 : bitmap_manager_(bitmap_manager), |
41 gpu_memory_buffer_manager_(gpu_memory_buffer_manager), | 41 gpu_memory_buffer_manager_(gpu_memory_buffer_manager), |
42 settings_(settings), | 42 settings_(settings), |
43 begin_frame_source_(std::move(begin_frame_source)), | 43 begin_frame_source_(begin_frame_source), |
44 output_surface_(std::move(output_surface)), | 44 output_surface_(std::move(output_surface)), |
45 scheduler_(std::move(scheduler)), | 45 scheduler_(std::move(scheduler)), |
46 texture_mailbox_deleter_(std::move(texture_mailbox_deleter)) { | 46 texture_mailbox_deleter_(std::move(texture_mailbox_deleter)) { |
47 DCHECK(output_surface_); | 47 DCHECK(output_surface_); |
48 DCHECK_EQ(!scheduler_, !begin_frame_source_); | 48 DCHECK_EQ(!scheduler_, !begin_frame_source_); |
49 if (scheduler_) | 49 if (scheduler_) |
50 scheduler_->SetClient(this); | 50 scheduler_->SetClient(this); |
51 } | 51 } |
52 | 52 |
53 Display::~Display() { | 53 Display::~Display() { |
54 // Only do this if Initialize() happened. | 54 // Only do this if Initialize() happened. |
55 if (client_) { | 55 if (client_) { |
56 if (begin_frame_source_) | 56 if (begin_frame_source_) |
57 surface_manager_->UnregisterBeginFrameSource(begin_frame_source_.get()); | 57 surface_manager_->UnregisterBeginFrameSource(begin_frame_source_); |
58 surface_manager_->RemoveObserver(this); | 58 surface_manager_->RemoveObserver(this); |
59 } | 59 } |
60 if (aggregator_) { | 60 if (aggregator_) { |
61 for (const auto& id_entry : aggregator_->previous_contained_surfaces()) { | 61 for (const auto& id_entry : aggregator_->previous_contained_surfaces()) { |
62 Surface* surface = surface_manager_->GetSurfaceForId(id_entry.first); | 62 Surface* surface = surface_manager_->GetSurfaceForId(id_entry.first); |
63 if (surface) | 63 if (surface) |
64 surface->RunDrawCallbacks(); | 64 surface->RunDrawCallbacks(); |
65 } | 65 } |
66 } | 66 } |
67 } | 67 } |
68 | 68 |
69 void Display::Initialize(DisplayClient* client, | 69 void Display::Initialize(DisplayClient* client, |
70 SurfaceManager* surface_manager, | 70 SurfaceManager* surface_manager, |
71 uint32_t compositor_surface_namespace) { | 71 uint32_t compositor_surface_namespace) { |
72 DCHECK(client); | 72 DCHECK(client); |
73 DCHECK(surface_manager); | 73 DCHECK(surface_manager); |
74 client_ = client; | 74 client_ = client; |
75 surface_manager_ = surface_manager; | 75 surface_manager_ = surface_manager; |
76 compositor_surface_namespace_ = compositor_surface_namespace; | 76 compositor_surface_namespace_ = compositor_surface_namespace; |
77 | 77 |
78 surface_manager_->AddObserver(this); | 78 surface_manager_->AddObserver(this); |
79 | 79 |
80 // This must be done in Initialize() so that the caller can delay this until | 80 // This must be done in Initialize() so that the caller can delay this until |
81 // they are ready to receive a BeginFrameSource. | 81 // they are ready to receive a BeginFrameSource. |
82 if (begin_frame_source_) { | 82 if (begin_frame_source_) { |
83 surface_manager_->RegisterBeginFrameSource(begin_frame_source_.get(), | 83 surface_manager_->RegisterBeginFrameSource(begin_frame_source_, |
84 compositor_surface_namespace_); | 84 compositor_surface_namespace_); |
85 } | 85 } |
86 | 86 |
87 bool ok = output_surface_->BindToClient(this); | 87 bool ok = output_surface_->BindToClient(this); |
88 // The context given to the Display's OutputSurface should already be | 88 // The context given to the Display's OutputSurface should already be |
89 // initialized, so Bind can not fail. | 89 // initialized, so Bind can not fail. |
90 DCHECK(ok); | 90 DCHECK(ok); |
91 InitializeRenderer(); | 91 InitializeRenderer(); |
92 } | 92 } |
93 | 93 |
(...skipping 339 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
433 const SurfaceId& Display::CurrentSurfaceId() { | 433 const SurfaceId& Display::CurrentSurfaceId() { |
434 return current_surface_id_; | 434 return current_surface_id_; |
435 } | 435 } |
436 | 436 |
437 void Display::ForceImmediateDrawAndSwapIfPossible() { | 437 void Display::ForceImmediateDrawAndSwapIfPossible() { |
438 if (scheduler_) | 438 if (scheduler_) |
439 scheduler_->ForceImmediateSwapIfPossible(); | 439 scheduler_->ForceImmediateSwapIfPossible(); |
440 } | 440 } |
441 | 441 |
442 } // namespace cc | 442 } // namespace cc |
OLD | NEW |