Chromium Code Reviews| Index: services/ui/ws/frame_generator.cc |
| diff --git a/services/ui/ws/frame_generator.cc b/services/ui/ws/frame_generator.cc |
| index 77b9b35bd4a93fd89a8fba68ee0113dd4f0d247b..d70279ae851b5607a17b635de7d77e101ad9206d 100644 |
| --- a/services/ui/ws/frame_generator.cc |
| +++ b/services/ui/ws/frame_generator.cc |
| @@ -129,8 +129,16 @@ void FrameGenerator::OnBeginFrame(const cc::BeginFrameArgs& begin_frame_arags) { |
| // TODO(fsamuel): We should add a trace for generating a top level frame. |
| cc::CompositorFrame frame(GenerateCompositorFrame(root_window_->bounds())); |
| + |
| if (compositor_frame_sink_) { |
| - compositor_frame_sink_->SubmitCompositorFrame(std::move(frame)); |
| + gfx::Size frame_size; |
|
sadrul
2016/11/22 19:53:29
= last_submitted_frame_size_;
Fady Samuel
2016/11/22 20:17:26
Done.
|
| + if (!frame.render_pass_list.empty()) |
| + frame_size = frame.render_pass_list[0]->output_rect.size(); |
| + if (!local_frame_id_.is_valid() || frame_size != last_submitted_frame_size_) |
| + local_frame_id_ = id_allocator_.GenerateId(); |
| + compositor_frame_sink_->SubmitCompositorFrame(local_frame_id_, |
| + std::move(frame)); |
| + last_submitted_frame_size_ = frame_size; |
| // Remove dead references after we submit a frame. This has to happen after |
| // the frame is submitted otherwise we could end up deleting a surface that |