| 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/compositor/delegated_frame_host.h" | 5 #include "content/browser/compositor/delegated_frame_host.h" |
| 6 | 6 |
| 7 #include "base/callback_helpers.h" | 7 #include "base/callback_helpers.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "cc/output/compositor_frame.h" | 9 #include "cc/output/compositor_frame.h" |
| 10 #include "cc/output/compositor_frame_ack.h" | 10 #include "cc/output/compositor_frame_ack.h" |
| (...skipping 162 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 173 callback.Run(SkBitmap(), content::READBACK_SURFACE_UNAVAILABLE); | 173 callback.Run(SkBitmap(), content::READBACK_SURFACE_UNAVAILABLE); |
| 174 return; | 174 return; |
| 175 } | 175 } |
| 176 | 176 |
| 177 scoped_ptr<cc::CopyOutputRequest> request = | 177 scoped_ptr<cc::CopyOutputRequest> request = |
| 178 cc::CopyOutputRequest::CreateRequest(base::Bind( | 178 cc::CopyOutputRequest::CreateRequest(base::Bind( |
| 179 &DelegatedFrameHost::CopyFromCompositingSurfaceHasResult, | 179 &DelegatedFrameHost::CopyFromCompositingSurfaceHasResult, |
| 180 output_size, | 180 output_size, |
| 181 color_type, | 181 color_type, |
| 182 callback)); | 182 callback)); |
| 183 request->set_area(src_subrect); | 183 if (!src_subrect.IsEmpty()) |
| 184 request->set_area(src_subrect); |
| 184 client_->RequestCopyOfOutput(request.Pass()); | 185 client_->RequestCopyOfOutput(request.Pass()); |
| 185 } | 186 } |
| 186 | 187 |
| 187 void DelegatedFrameHost::CopyFromCompositingSurfaceToVideoFrame( | 188 void DelegatedFrameHost::CopyFromCompositingSurfaceToVideoFrame( |
| 188 const gfx::Rect& src_subrect, | 189 const gfx::Rect& src_subrect, |
| 189 const scoped_refptr<media::VideoFrame>& target, | 190 const scoped_refptr<media::VideoFrame>& target, |
| 190 const base::Callback<void(bool)>& callback) { | 191 const base::Callback<void(bool)>& callback) { |
| 191 if (!CanCopyToVideoFrame()) { | 192 if (!CanCopyToVideoFrame()) { |
| 192 callback.Run(false); | 193 callback.Run(false); |
| 193 return; | 194 return; |
| (...skipping 368 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 562 void DelegatedFrameHost::CopyFromCompositingSurfaceHasResult( | 563 void DelegatedFrameHost::CopyFromCompositingSurfaceHasResult( |
| 563 const gfx::Size& dst_size_in_pixel, | 564 const gfx::Size& dst_size_in_pixel, |
| 564 const SkColorType color_type, | 565 const SkColorType color_type, |
| 565 ReadbackRequestCallback& callback, | 566 ReadbackRequestCallback& callback, |
| 566 scoped_ptr<cc::CopyOutputResult> result) { | 567 scoped_ptr<cc::CopyOutputResult> result) { |
| 567 if (result->IsEmpty() || result->size().IsEmpty()) { | 568 if (result->IsEmpty() || result->size().IsEmpty()) { |
| 568 callback.Run(SkBitmap(), content::READBACK_FAILED); | 569 callback.Run(SkBitmap(), content::READBACK_FAILED); |
| 569 return; | 570 return; |
| 570 } | 571 } |
| 571 | 572 |
| 573 gfx::Size output_size_in_pixel; |
| 574 if (dst_size_in_pixel.IsEmpty()) |
| 575 output_size_in_pixel = result->size(); |
| 576 else |
| 577 output_size_in_pixel = dst_size_in_pixel; |
| 578 |
| 572 if (result->HasTexture()) { | 579 if (result->HasTexture()) { |
| 573 // GPU-accelerated path | 580 // GPU-accelerated path |
| 574 PrepareTextureCopyOutputResult(dst_size_in_pixel, color_type, | 581 PrepareTextureCopyOutputResult(output_size_in_pixel, color_type, |
| 575 callback, | 582 callback, |
| 576 result.Pass()); | 583 result.Pass()); |
| 577 return; | 584 return; |
| 578 } | 585 } |
| 579 | 586 |
| 580 DCHECK(result->HasBitmap()); | 587 DCHECK(result->HasBitmap()); |
| 581 // Software path | 588 // Software path |
| 582 PrepareBitmapCopyOutputResult(dst_size_in_pixel, color_type, callback, | 589 PrepareBitmapCopyOutputResult(output_size_in_pixel, color_type, callback, |
| 583 result.Pass()); | 590 result.Pass()); |
| 584 } | 591 } |
| 585 | 592 |
| 586 static void CopyFromCompositingSurfaceFinished( | 593 static void CopyFromCompositingSurfaceFinished( |
| 587 ReadbackRequestCallback& callback, | 594 ReadbackRequestCallback& callback, |
| 588 scoped_ptr<cc::SingleReleaseCallback> release_callback, | 595 scoped_ptr<cc::SingleReleaseCallback> release_callback, |
| 589 scoped_ptr<SkBitmap> bitmap, | 596 scoped_ptr<SkBitmap> bitmap, |
| 590 scoped_ptr<SkAutoLockPixels> bitmap_pixels_lock, | 597 scoped_ptr<SkAutoLockPixels> bitmap_pixels_lock, |
| 591 bool result) { | 598 bool result) { |
| 592 bitmap_pixels_lock.reset(); | 599 bitmap_pixels_lock.reset(); |
| (...skipping 433 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1026 cc::SurfaceManager* manager = factory->GetSurfaceManager(); | 1033 cc::SurfaceManager* manager = factory->GetSurfaceManager(); |
| 1027 new_layer->SetShowSurface( | 1034 new_layer->SetShowSurface( |
| 1028 surface_id_, base::Bind(&SatisfyCallback, base::Unretained(manager)), | 1035 surface_id_, base::Bind(&SatisfyCallback, base::Unretained(manager)), |
| 1029 base::Bind(&RequireCallback, base::Unretained(manager)), | 1036 base::Bind(&RequireCallback, base::Unretained(manager)), |
| 1030 current_surface_size_, current_scale_factor_, | 1037 current_surface_size_, current_scale_factor_, |
| 1031 current_frame_size_in_dip_); | 1038 current_frame_size_in_dip_); |
| 1032 } | 1039 } |
| 1033 } | 1040 } |
| 1034 | 1041 |
| 1035 } // namespace content | 1042 } // namespace content |
| OLD | NEW |