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 "content/browser/renderer_host/delegated_frame_host.h" | 5 #include "content/browser/renderer_host/delegated_frame_host.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <utility> | 9 #include <utility> |
10 #include <vector> | 10 #include <vector> |
(...skipping 487 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
498 renderer_compositor_frame_sink_->DidReceiveCompositorFrameAck(resources); | 498 renderer_compositor_frame_sink_->DidReceiveCompositorFrameAck(resources); |
499 } | 499 } |
500 | 500 |
501 void DelegatedFrameHost::ReclaimResources( | 501 void DelegatedFrameHost::ReclaimResources( |
502 const cc::ReturnedResourceArray& resources) { | 502 const cc::ReturnedResourceArray& resources) { |
503 renderer_compositor_frame_sink_->ReclaimResources(resources); | 503 renderer_compositor_frame_sink_->ReclaimResources(resources); |
504 } | 504 } |
505 | 505 |
506 void DelegatedFrameHost::WillDrawSurface(const cc::LocalSurfaceId& id, | 506 void DelegatedFrameHost::WillDrawSurface(const cc::LocalSurfaceId& id, |
507 const gfx::Rect& damage_rect) { | 507 const gfx::Rect& damage_rect) { |
508 // Frame subscribers are only interested in changes to the target surface, so | 508 if (id != local_surface_id_) |
509 // do not attempt capture if |damage_rect| is empty. This prevents the draws | |
510 // of parent surfaces from triggering extra frame captures, which can affect | |
511 // smoothness. | |
512 if (id != local_surface_id_ || damage_rect.IsEmpty()) | |
513 return; | 509 return; |
514 AttemptFrameSubscriberCapture(damage_rect); | 510 AttemptFrameSubscriberCapture(damage_rect); |
515 } | 511 } |
516 | 512 |
517 void DelegatedFrameHost::OnBeginFrame(const cc::BeginFrameArgs& args) { | 513 void DelegatedFrameHost::OnBeginFrame(const cc::BeginFrameArgs& args) { |
518 client_->OnBeginFrame(args); | 514 client_->OnBeginFrame(args); |
519 } | 515 } |
520 | 516 |
521 void DelegatedFrameHost::EvictDelegatedFrame() { | 517 void DelegatedFrameHost::EvictDelegatedFrame() { |
522 if (!has_frame_) | 518 if (!has_frame_) |
(...skipping 339 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
862 } | 858 } |
863 | 859 |
864 if (!skipped_frames_) { | 860 if (!skipped_frames_) { |
865 latest_confirmed_begin_frame_source_id_ = ack.source_id; | 861 latest_confirmed_begin_frame_source_id_ = ack.source_id; |
866 latest_confirmed_begin_frame_sequence_number_ = | 862 latest_confirmed_begin_frame_sequence_number_ = |
867 ack.latest_confirmed_sequence_number; | 863 ack.latest_confirmed_sequence_number; |
868 } | 864 } |
869 } | 865 } |
870 | 866 |
871 } // namespace content | 867 } // namespace content |
OLD | NEW |