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 "ui/aura/mus/window_compositor_frame_sink.h" | 5 #include "ui/aura/mus/window_compositor_frame_sink.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "cc/output/begin_frame_args.h" |
8 #include "cc/output/compositor_frame_sink_client.h" | 9 #include "cc/output/compositor_frame_sink_client.h" |
9 #include "gpu/ipc/client/gpu_channel_host.h" | 10 #include "gpu/ipc/client/gpu_channel_host.h" |
10 | 11 |
11 namespace aura { | 12 namespace aura { |
12 | 13 |
13 // static | 14 // static |
14 std::unique_ptr<WindowCompositorFrameSink> WindowCompositorFrameSink::Create( | 15 std::unique_ptr<WindowCompositorFrameSink> WindowCompositorFrameSink::Create( |
15 scoped_refptr<cc::ContextProvider> context_provider, | 16 scoped_refptr<cc::ContextProvider> context_provider, |
16 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | 17 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, |
17 std::unique_ptr<WindowCompositorFrameSinkBinding>* | 18 std::unique_ptr<WindowCompositorFrameSinkBinding>* |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
113 | 114 |
114 void WindowCompositorFrameSink::WillDrawSurface() { | 115 void WindowCompositorFrameSink::WillDrawSurface() { |
115 // TODO(fsamuel, staraz): Implement this. | 116 // TODO(fsamuel, staraz): Implement this. |
116 NOTIMPLEMENTED(); | 117 NOTIMPLEMENTED(); |
117 } | 118 } |
118 | 119 |
119 void WindowCompositorFrameSink::OnNeedsBeginFrames(bool needs_begin_frames) { | 120 void WindowCompositorFrameSink::OnNeedsBeginFrames(bool needs_begin_frames) { |
120 compositor_frame_sink_->SetNeedsBeginFrame(needs_begin_frames); | 121 compositor_frame_sink_->SetNeedsBeginFrame(needs_begin_frames); |
121 } | 122 } |
122 | 123 |
| 124 void WindowCompositorFrameSink::OnDidFinishFrame(const cc::BeginFrameAck& ack) { |
| 125 // If there were updates, SubmitCompositorFrame serves as ack. |
| 126 if (!ack.has_updates) |
| 127 compositor_frame_sink_->BeginFrameDidNotDraw(ack); |
| 128 } |
| 129 |
123 WindowCompositorFrameSinkBinding::~WindowCompositorFrameSinkBinding() {} | 130 WindowCompositorFrameSinkBinding::~WindowCompositorFrameSinkBinding() {} |
124 | 131 |
125 WindowCompositorFrameSinkBinding::WindowCompositorFrameSinkBinding( | 132 WindowCompositorFrameSinkBinding::WindowCompositorFrameSinkBinding( |
126 cc::mojom::MojoCompositorFrameSinkRequest compositor_frame_sink_request, | 133 cc::mojom::MojoCompositorFrameSinkRequest compositor_frame_sink_request, |
127 mojo::InterfacePtrInfo<cc::mojom::MojoCompositorFrameSinkClient> | 134 mojo::InterfacePtrInfo<cc::mojom::MojoCompositorFrameSinkClient> |
128 compositor_frame_sink_client) | 135 compositor_frame_sink_client) |
129 : compositor_frame_sink_request_(std::move(compositor_frame_sink_request)), | 136 : compositor_frame_sink_request_(std::move(compositor_frame_sink_request)), |
130 compositor_frame_sink_client_(std::move(compositor_frame_sink_client)) {} | 137 compositor_frame_sink_client_(std::move(compositor_frame_sink_client)) {} |
131 | 138 |
132 } // namespace aura | 139 } // namespace aura |
OLD | NEW |