| 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" |
| 11 #include "cc/output/copy_output_request.h" | 11 #include "cc/output/copy_output_request.h" |
| 12 #include "cc/resources/single_release_callback.h" | 12 #include "cc/resources/single_release_callback.h" |
| 13 #include "cc/resources/texture_mailbox.h" | 13 #include "cc/resources/texture_mailbox.h" |
| 14 #include "content/browser/compositor/resize_lock.h" | 14 #include "content/browser/compositor/resize_lock.h" |
| 15 #include "content/common/gpu/client/gl_helper.h" | 15 #include "content/common/gpu/client/gl_helper.h" |
| 16 #include "content/public/browser/render_widget_host_view_frame_subscriber.h" | 16 #include "content/public/browser/render_widget_host_view_frame_subscriber.h" |
| 17 #include "content/public/common/content_switches.h" | 17 #include "content/public/common/content_switches.h" |
| 18 #include "media/base/video_frame.h" | 18 #include "media/base/video_frame.h" |
| 19 #include "media/base/video_util.h" | 19 #include "media/base/video_util.h" |
| 20 #include "skia/ext/image_operations.h" | 20 #include "skia/ext/image_operations.h" |
| 21 | 21 |
| 22 namespace content { | 22 namespace content { |
| 23 | 23 |
| 24 //////////////////////////////////////////////////////////////////////////////// | 24 //////////////////////////////////////////////////////////////////////////////// |
| 25 // DelegatedFrameHostClient | 25 // DelegatedFrameHostClient |
| 26 | 26 |
| 27 bool DelegatedFrameHostClient::ShouldCreateResizeLock() { | 27 bool DelegatedFrameHostClient::ShouldCreateResizeLock() { |
| 28 // On Windows and Linux, holding pointer moves will not help throttling |
| 29 // resizes. |
| 30 // TODO(piman): on Windows we need to block (nested message loop?) the |
| 31 // WM_SIZE event. On Linux we need to throttle at the WM level using |
| 32 // _NET_WM_SYNC_REQUEST. |
| 33 // TODO(ccameron): Mac browser window resizing is incompletely implemented. |
| 34 #if !defined(OS_CHROMEOS) |
| 35 return false; |
| 36 #else |
| 28 return GetDelegatedFrameHost()->ShouldCreateResizeLock(); | 37 return GetDelegatedFrameHost()->ShouldCreateResizeLock(); |
| 38 #endif |
| 29 } | 39 } |
| 30 | 40 |
| 31 void DelegatedFrameHostClient::RequestCopyOfOutput( | 41 void DelegatedFrameHostClient::RequestCopyOfOutput( |
| 32 scoped_ptr<cc::CopyOutputRequest> request) { | 42 scoped_ptr<cc::CopyOutputRequest> request) { |
| 33 GetDelegatedFrameHost()->RequestCopyOfOutput(request.Pass()); | 43 GetDelegatedFrameHost()->RequestCopyOfOutput(request.Pass()); |
| 34 } | 44 } |
| 35 | 45 |
| 36 //////////////////////////////////////////////////////////////////////////////// | 46 //////////////////////////////////////////////////////////////////////////////// |
| 37 // DelegatedFrameHost | 47 // DelegatedFrameHost |
| 38 | 48 |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 can_lock_compositor_ == NO_PENDING_RENDERER_FRAME || | 85 can_lock_compositor_ == NO_PENDING_RENDERER_FRAME || |
| 76 can_lock_compositor_ == NO_PENDING_COMMIT; | 86 can_lock_compositor_ == NO_PENDING_COMMIT; |
| 77 | 87 |
| 78 if (can_lock_compositor_ == YES_CAN_LOCK) | 88 if (can_lock_compositor_ == YES_CAN_LOCK) |
| 79 can_lock_compositor_ = YES_DID_LOCK; | 89 can_lock_compositor_ = YES_DID_LOCK; |
| 80 | 90 |
| 81 resize_lock_ = client_->CreateResizeLock(defer_compositor_lock); | 91 resize_lock_ = client_->CreateResizeLock(defer_compositor_lock); |
| 82 } | 92 } |
| 83 | 93 |
| 84 bool DelegatedFrameHost::ShouldCreateResizeLock() { | 94 bool DelegatedFrameHost::ShouldCreateResizeLock() { |
| 85 // On Windows and Linux, holding pointer moves will not help throttling | |
| 86 // resizes. | |
| 87 // TODO(piman): on Windows we need to block (nested message loop?) the | |
| 88 // WM_SIZE event. On Linux we need to throttle at the WM level using | |
| 89 // _NET_WM_SYNC_REQUEST. | |
| 90 // TODO(ccameron): Mac browser window resizing is incompletely implemented. | |
| 91 #if !defined(OS_CHROMEOS) | |
| 92 return false; | |
| 93 #else | |
| 94 RenderWidgetHostImpl* host = client_->GetHost(); | 95 RenderWidgetHostImpl* host = client_->GetHost(); |
| 95 | 96 |
| 96 if (resize_lock_) | 97 if (resize_lock_) |
| 97 return false; | 98 return false; |
| 98 | 99 |
| 99 if (host->should_auto_resize()) | 100 if (host->should_auto_resize()) |
| 100 return false; | 101 return false; |
| 101 | 102 |
| 102 gfx::Size desired_size = client_->DesiredFrameSize(); | 103 gfx::Size desired_size = client_->DesiredFrameSize(); |
| 103 if (desired_size == current_frame_size_in_dip_) | 104 if (desired_size == current_frame_size_in_dip_ || desired_size.IsEmpty()) |
| 104 return false; | 105 return false; |
| 105 | 106 |
| 106 ui::Compositor* compositor = client_->GetCompositor(); | 107 ui::Compositor* compositor = client_->GetCompositor(); |
| 107 if (!compositor) | 108 if (!compositor) |
| 108 return false; | 109 return false; |
| 109 | 110 |
| 110 return true; | 111 return true; |
| 111 #endif | |
| 112 } | 112 } |
| 113 | 113 |
| 114 void DelegatedFrameHost::RequestCopyOfOutput( | 114 void DelegatedFrameHost::RequestCopyOfOutput( |
| 115 scoped_ptr<cc::CopyOutputRequest> request) { | 115 scoped_ptr<cc::CopyOutputRequest> request) { |
| 116 client_->GetLayer()->RequestCopyOfOutput(request.Pass()); | 116 client_->GetLayer()->RequestCopyOfOutput(request.Pass()); |
| 117 } | 117 } |
| 118 | 118 |
| 119 void DelegatedFrameHost::CopyFromCompositingSurface( | 119 void DelegatedFrameHost::CopyFromCompositingSurface( |
| 120 const gfx::Rect& src_subrect, | 120 const gfx::Rect& src_subrect, |
| 121 const gfx::Size& dst_size, | 121 const gfx::Size& dst_size, |
| (...skipping 731 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 853 // that should keep our frame. old_layer will be returned to the | 853 // that should keep our frame. old_layer will be returned to the |
| 854 // RecreateLayer caller, and should have a copy. | 854 // RecreateLayer caller, and should have a copy. |
| 855 if (frame_provider_.get()) { | 855 if (frame_provider_.get()) { |
| 856 new_layer->SetShowDelegatedContent(frame_provider_.get(), | 856 new_layer->SetShowDelegatedContent(frame_provider_.get(), |
| 857 current_frame_size_in_dip_); | 857 current_frame_size_in_dip_); |
| 858 } | 858 } |
| 859 } | 859 } |
| 860 | 860 |
| 861 } // namespace content | 861 } // namespace content |
| 862 | 862 |
| OLD | NEW |