Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "blimp/client/app/linux/blimp_display_manager.h" | 5 #include "blimp/client/app/linux/blimp_display_manager.h" |
| 6 | 6 |
| 7 #include "blimp/client/app/compositor/browser_compositor.h" | 7 #include "blimp/client/app/compositor/browser_compositor.h" |
| 8 #include "blimp/client/core/compositor/blimp_compositor_dependencies_impl.h" | |
| 8 #include "blimp/client/core/contents/tab_control_feature.h" | 9 #include "blimp/client/core/contents/tab_control_feature.h" |
| 9 #include "blimp/client/feature/compositor/blimp_compositor_manager.h" | 10 #include "blimp/client/feature/compositor/blimp_compositor_manager.h" |
| 10 #include "blimp/client/feature/render_widget_feature.h" | 11 #include "blimp/client/feature/render_widget_feature.h" |
| 12 #include "blimp/client/support/compositor/compositor_dependencies_impl.h" | |
| 11 #include "ui/events/event.h" | 13 #include "ui/events/event.h" |
| 12 #include "ui/gfx/geometry/size.h" | 14 #include "ui/gfx/geometry/size.h" |
| 13 #include "ui/platform_window/platform_window.h" | 15 #include "ui/platform_window/platform_window.h" |
| 14 #include "ui/platform_window/x11/x11_window.h" | 16 #include "ui/platform_window/x11/x11_window.h" |
| 15 | 17 |
| 16 namespace blimp { | 18 namespace blimp { |
| 17 namespace client { | 19 namespace client { |
| 18 | 20 |
| 19 BlimpDisplayManager::BlimpDisplayManager( | 21 BlimpDisplayManager::BlimpDisplayManager( |
| 20 const gfx::Size& window_size, | 22 const gfx::Size& window_size, |
| 21 BlimpDisplayManagerDelegate* delegate, | 23 BlimpDisplayManagerDelegate* delegate, |
| 22 RenderWidgetFeature* render_widget_feature, | 24 RenderWidgetFeature* render_widget_feature, |
| 23 TabControlFeature* tab_control_feature) | 25 TabControlFeature* tab_control_feature) |
| 24 : device_pixel_ratio_(1.f), | 26 : device_pixel_ratio_(1.f), |
| 25 delegate_(delegate), | 27 delegate_(delegate), |
| 26 tab_control_feature_(tab_control_feature), | 28 tab_control_feature_(tab_control_feature), |
| 27 compositor_(base::MakeUnique<BrowserCompositor>()), | 29 compositor_(base::MakeUnique<BrowserCompositor>()), |
| 28 platform_window_(new ui::X11Window(this)) { | 30 platform_window_(new ui::X11Window(this)) { |
| 29 blimp_compositor_manager_ = base::MakeUnique<BlimpCompositorManager>( | |
| 30 render_widget_feature, BrowserCompositor::GetSurfaceManager(), | |
| 31 BrowserCompositor::GetGpuMemoryBufferManager(), | |
| 32 base::Bind(&BrowserCompositor::AllocateSurfaceClientId)); | |
| 33 platform_window_->SetBounds(gfx::Rect(window_size)); | 31 platform_window_->SetBounds(gfx::Rect(window_size)); |
| 32 | |
| 33 compositor_dependencies_ = | |
| 34 base::WrapUnique(new BlimpCompositorDependenciesImpl( | |
|
Khushal
2016/08/24 23:22:45
nit: MakeUnique!
David Trainor- moved to gerrit
2016/08/26 17:15:53
Done.
| |
| 35 base::WrapUnique(new CompositorDependenciesImpl()))); | |
| 36 | |
| 37 compositor_ = base::MakeUnique<BrowserCompositor>( | |
| 38 compositor_dependencies_->GetEmbedderDependencies()); | |
| 39 compositor_->SetSize(platform_window_->GetBounds().size()); | |
| 40 | |
| 41 compositor_manager_ = base::MakeUnique<BlimpCompositorManager>( | |
| 42 render_widget_feature, compositor_dependencies_.get()); | |
| 43 | |
| 44 compositor_->SetContentLayer(compositor_manager_->layer()); | |
| 45 | |
| 34 platform_window_->Show(); | 46 platform_window_->Show(); |
| 35 | 47 |
| 36 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), | 48 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), |
| 37 device_pixel_ratio_); | 49 device_pixel_ratio_); |
| 38 | |
| 39 compositor_->SetSize(platform_window_->GetBounds().size()); | |
| 40 compositor_->SetContentLayer(blimp_compositor_manager_->layer()); | |
| 41 } | 50 } |
| 42 | 51 |
| 43 BlimpDisplayManager::~BlimpDisplayManager() {} | 52 BlimpDisplayManager::~BlimpDisplayManager() {} |
| 44 | 53 |
| 45 void BlimpDisplayManager::OnBoundsChanged(const gfx::Rect& new_bounds) { | 54 void BlimpDisplayManager::OnBoundsChanged(const gfx::Rect& new_bounds) { |
| 46 compositor_->SetSize(new_bounds.size()); | 55 compositor_->SetSize(new_bounds.size()); |
| 47 tab_control_feature_->SetSizeAndScale(new_bounds.size(), device_pixel_ratio_); | 56 tab_control_feature_->SetSizeAndScale(new_bounds.size(), device_pixel_ratio_); |
| 48 } | 57 } |
| 49 | 58 |
| 50 void BlimpDisplayManager::DispatchEvent(ui::Event* event) { | 59 void BlimpDisplayManager::DispatchEvent(ui::Event* event) { |
| 51 // TODO(dtrainor): Look into using web_input_event_aura to translate these to | 60 // TODO(dtrainor): Look into using web_input_event_aura to translate these to |
| 52 // blink events. | 61 // blink events. |
| 53 } | 62 } |
| 54 | 63 |
| 55 void BlimpDisplayManager::OnCloseRequest() { | 64 void BlimpDisplayManager::OnCloseRequest() { |
| 56 blimp_compositor_manager_->SetVisible(false); | 65 compositor_manager_->SetVisible(false); |
| 57 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 66 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
| 58 platform_window_->Close(); | 67 platform_window_->Close(); |
| 59 } | 68 } |
| 60 | 69 |
| 61 void BlimpDisplayManager::OnClosed() { | 70 void BlimpDisplayManager::OnClosed() { |
| 62 if (delegate_) | 71 if (delegate_) |
| 63 delegate_->OnClosed(); | 72 delegate_->OnClosed(); |
| 64 } | 73 } |
| 65 | 74 |
| 66 void BlimpDisplayManager::OnAcceleratedWidgetAvailable( | 75 void BlimpDisplayManager::OnAcceleratedWidgetAvailable( |
| 67 gfx::AcceleratedWidget widget, | 76 gfx::AcceleratedWidget widget, |
| 68 float device_pixel_ratio) { | 77 float device_pixel_ratio) { |
| 69 device_pixel_ratio_ = device_pixel_ratio; | 78 device_pixel_ratio_ = device_pixel_ratio; |
| 70 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), | 79 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), |
| 71 device_pixel_ratio_); | 80 device_pixel_ratio_); |
| 72 | 81 |
| 73 if (widget != gfx::kNullAcceleratedWidget) { | 82 if (widget != gfx::kNullAcceleratedWidget) { |
| 74 blimp_compositor_manager_->SetVisible(true); | 83 compositor_manager_->SetVisible(true); |
| 75 compositor_->SetAcceleratedWidget(widget); | 84 compositor_->SetAcceleratedWidget(widget); |
| 76 } | 85 } |
| 77 } | 86 } |
| 78 | 87 |
| 79 void BlimpDisplayManager::OnAcceleratedWidgetDestroyed() { | 88 void BlimpDisplayManager::OnAcceleratedWidgetDestroyed() { |
| 80 blimp_compositor_manager_->SetVisible(false); | 89 compositor_manager_->SetVisible(false); |
| 81 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 90 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
| 82 } | 91 } |
| 83 | 92 |
| 84 } // namespace client | 93 } // namespace client |
| 85 } // namespace blimp | 94 } // namespace blimp |
| OLD | NEW |