| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/layers/delegated_frame_provider.h" | 5 #include "cc/layers/delegated_frame_provider.h" |
| 6 | 6 |
| 7 #include "cc/layers/delegated_frame_resource_collection.h" | 7 #include "cc/layers/delegated_frame_resource_collection.h" |
| 8 #include "cc/layers/delegated_renderer_layer.h" | 8 #include "cc/layers/delegated_renderer_layer.h" |
| 9 #include "cc/output/delegated_frame_data.h" | 9 #include "cc/output/delegated_frame_data.h" |
| 10 #include "cc/quads/render_pass_draw_quad.h" | 10 #include "cc/quads/render_pass_draw_quad.h" |
| 11 | 11 |
| 12 namespace cc { | 12 namespace cc { |
| 13 | 13 |
| 14 DelegatedFrameProvider::DelegatedFrameProvider( | 14 DelegatedFrameProvider::DelegatedFrameProvider( |
| 15 const scoped_refptr<DelegatedFrameResourceCollection>& resource_collection, | 15 const scoped_refptr<DelegatedFrameResourceCollection>& resource_collection, |
| 16 scoped_ptr<DelegatedFrameData> frame) | 16 scoped_ptr<DelegatedFrameData> frame) |
| 17 : resource_collection_(resource_collection) { | 17 : resource_collection_(resource_collection) { |
| 18 RenderPass* root_pass = frame->render_pass_list.back(); | 18 RenderPass* root_pass = frame->render_pass_list.back().get(); |
| 19 frame_size_ = root_pass->output_rect.size(); | 19 frame_size_ = root_pass->output_rect.size(); |
| 20 DCHECK(!frame_size_.IsEmpty()); | 20 DCHECK(!frame_size_.IsEmpty()); |
| 21 SetFrameData(frame.Pass()); | 21 SetFrameData(frame.Pass()); |
| 22 } | 22 } |
| 23 | 23 |
| 24 DelegatedFrameProvider::~DelegatedFrameProvider() { | 24 DelegatedFrameProvider::~DelegatedFrameProvider() { |
| 25 ReturnedResourceArray returned; | 25 ReturnedResourceArray returned; |
| 26 TransferableResource::ReturnResources(frame_->resource_list, &returned); | 26 TransferableResource::ReturnResources(frame_->resource_list, &returned); |
| 27 resource_collection_->UnrefResources(returned); | 27 resource_collection_->UnrefResources(returned); |
| 28 } | 28 } |
| (...skipping 30 matching lines...) Expand all Loading... |
| 59 ReturnedResourceArray returned; | 59 ReturnedResourceArray returned; |
| 60 TransferableResource::ReturnResources(frame_->resource_list, &returned); | 60 TransferableResource::ReturnResources(frame_->resource_list, &returned); |
| 61 resource_collection_->UnrefResources(returned); | 61 resource_collection_->UnrefResources(returned); |
| 62 } | 62 } |
| 63 | 63 |
| 64 frame_ = frame.Pass(); | 64 frame_ = frame.Pass(); |
| 65 | 65 |
| 66 resource_collection_->ReceivedResources(frame_->resource_list); | 66 resource_collection_->ReceivedResources(frame_->resource_list); |
| 67 resource_collection_->RefResources(frame_->resource_list); | 67 resource_collection_->RefResources(frame_->resource_list); |
| 68 | 68 |
| 69 RenderPass* root_pass = frame_->render_pass_list.back(); | 69 RenderPass* root_pass = frame_->render_pass_list.back().get(); |
| 70 DCHECK_EQ(frame_size_.ToString(), root_pass->output_rect.size().ToString()) | 70 DCHECK_EQ(frame_size_.ToString(), root_pass->output_rect.size().ToString()) |
| 71 << "All frames in a single DelegatedFrameProvider must have the same " | 71 << "All frames in a single DelegatedFrameProvider must have the same " |
| 72 << "size. Use a new frame provider for frames of a different size."; | 72 << "size. Use a new frame provider for frames of a different size."; |
| 73 | 73 |
| 74 for (size_t i = 0; i < observers_.size(); ++i) { | 74 for (size_t i = 0; i < observers_.size(); ++i) { |
| 75 observers_[i].damage = | 75 observers_[i].damage = |
| 76 gfx::UnionRects(observers_[i].damage, root_pass->damage_rect); | 76 gfx::UnionRects(observers_[i].damage, root_pass->damage_rect); |
| 77 observers_[i].layer->ProviderHasNewFrame(); | 77 observers_[i].layer->ProviderHasNewFrame(); |
| 78 } | 78 } |
| 79 } | 79 } |
| (...skipping 20 matching lines...) Expand all Loading... |
| 100 DelegatedFrameProvider::GetReturnResourcesCallbackForImplThread() { | 100 DelegatedFrameProvider::GetReturnResourcesCallbackForImplThread() { |
| 101 return resource_collection_->GetReturnResourcesCallbackForImplThread(); | 101 return resource_collection_->GetReturnResourcesCallbackForImplThread(); |
| 102 } | 102 } |
| 103 | 103 |
| 104 void DelegatedFrameProvider::UnrefResourcesOnMainThread( | 104 void DelegatedFrameProvider::UnrefResourcesOnMainThread( |
| 105 const ReturnedResourceArray& returned) { | 105 const ReturnedResourceArray& returned) { |
| 106 resource_collection_->UnrefResources(returned); | 106 resource_collection_->UnrefResources(returned); |
| 107 } | 107 } |
| 108 | 108 |
| 109 } // namespace cc | 109 } // namespace cc |
| OLD | NEW |