Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(41)

Side by Side Diff: services/ui/ws/compositor_frame_sink_client_binding.cc

Issue 2890913002: Add CompositorFrameSinkClientBinding To Be Used By FrameGenerator (Closed)
Patch Set: LastBeginFrameAck() Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "services/ui/ws/compositor_frame_sink_client_binding.h"
6
7 namespace ui {
8 namespace ws {
9
10 DefaultCompositorFrameSinkClientBinding::
11 DefaultCompositorFrameSinkClientBinding(
12 cc::mojom::MojoCompositorFrameSinkClient* sink_client,
13 cc::mojom::MojoCompositorFrameSinkClientRequest sink_client_request,
14 cc::mojom::MojoCompositorFrameSinkAssociatedPtr compositor_frame_sink,
15 cc::mojom::DisplayPrivateAssociatedPtr display_private)
16 : binding_(sink_client, std::move(sink_client_request)),
17 display_private_(std::move(display_private)),
18 compositor_frame_sink_(std::move(compositor_frame_sink)) {}
19
20 DefaultCompositorFrameSinkClientBinding::
21 ~DefaultCompositorFrameSinkClientBinding() = default;
22
23 void DefaultCompositorFrameSinkClientBinding::SetNeedsBeginFrame(
24 bool needs_begin_frame) {
25 compositor_frame_sink_->SetNeedsBeginFrame(needs_begin_frame);
26 }
27
28 void DefaultCompositorFrameSinkClientBinding::SubmitCompositorFrame(
29 cc::CompositorFrame frame) {
30 gfx::Size frame_size = last_submitted_frame_size_;
31 if (!frame.render_pass_list.empty())
32 frame_size = frame.render_pass_list.back()->output_rect.size();
33
34 if (!local_surface_id_.is_valid() ||
35 frame_size != last_submitted_frame_size_) {
36 local_surface_id_ = id_allocator_.GenerateId();
37 display_private_->ResizeDisplay(frame_size);
38 display_private_->SetLocalSurfaceId(local_surface_id_,
39 frame.metadata.device_scale_factor);
40 }
41
42 compositor_frame_sink_->SubmitCompositorFrame(local_surface_id_,
43 std::move(frame));
44 compositor_frame_sink_->SetNeedsBeginFrame(false);
45 last_submitted_frame_size_ = frame_size;
46 }
47
48 void DefaultCompositorFrameSinkClientBinding::BeginFrameDidNotSwap(
49 const cc::BeginFrameAck& ack) {
50 compositor_frame_sink_->BeginFrameDidNotSwap(ack);
51 }
52
53 } // namespace ws
54 } // namespace ui
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698