| 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.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>()), | |
| 28 platform_window_(new ui::X11Window(this)) { | 29 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)); | 30 platform_window_->SetBounds(gfx::Rect(window_size)); |
| 31 |
| 32 compositor_dependencies_ = base::MakeUnique<BlimpCompositorDependencies>( |
| 33 base::MakeUnique<CompositorDependenciesImpl>()); |
| 34 |
| 35 compositor_ = base::MakeUnique<BrowserCompositor>( |
| 36 compositor_dependencies_->GetEmbedderDependencies()); |
| 37 compositor_->SetSize(platform_window_->GetBounds().size()); |
| 38 |
| 39 compositor_manager_ = base::MakeUnique<BlimpCompositorManager>( |
| 40 render_widget_feature, compositor_dependencies_.get()); |
| 41 |
| 42 compositor_->SetContentLayer(compositor_manager_->layer()); |
| 43 |
| 34 platform_window_->Show(); | 44 platform_window_->Show(); |
| 35 | 45 |
| 36 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), | 46 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), |
| 37 device_pixel_ratio_); | 47 device_pixel_ratio_); |
| 38 | |
| 39 compositor_->SetSize(platform_window_->GetBounds().size()); | |
| 40 compositor_->SetContentLayer(blimp_compositor_manager_->layer()); | |
| 41 } | 48 } |
| 42 | 49 |
| 43 BlimpDisplayManager::~BlimpDisplayManager() {} | 50 BlimpDisplayManager::~BlimpDisplayManager() {} |
| 44 | 51 |
| 45 void BlimpDisplayManager::OnBoundsChanged(const gfx::Rect& new_bounds) { | 52 void BlimpDisplayManager::OnBoundsChanged(const gfx::Rect& new_bounds) { |
| 46 compositor_->SetSize(new_bounds.size()); | 53 compositor_->SetSize(new_bounds.size()); |
| 47 tab_control_feature_->SetSizeAndScale(new_bounds.size(), device_pixel_ratio_); | 54 tab_control_feature_->SetSizeAndScale(new_bounds.size(), device_pixel_ratio_); |
| 48 } | 55 } |
| 49 | 56 |
| 50 void BlimpDisplayManager::DispatchEvent(ui::Event* event) { | 57 void BlimpDisplayManager::DispatchEvent(ui::Event* event) { |
| 51 // TODO(dtrainor): Look into using web_input_event_aura to translate these to | 58 // TODO(dtrainor): Look into using web_input_event_aura to translate these to |
| 52 // blink events. | 59 // blink events. |
| 53 } | 60 } |
| 54 | 61 |
| 55 void BlimpDisplayManager::OnCloseRequest() { | 62 void BlimpDisplayManager::OnCloseRequest() { |
| 56 blimp_compositor_manager_->SetVisible(false); | 63 compositor_manager_->SetVisible(false); |
| 57 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 64 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
| 58 platform_window_->Close(); | 65 platform_window_->Close(); |
| 59 } | 66 } |
| 60 | 67 |
| 61 void BlimpDisplayManager::OnClosed() { | 68 void BlimpDisplayManager::OnClosed() { |
| 62 if (delegate_) | 69 if (delegate_) |
| 63 delegate_->OnClosed(); | 70 delegate_->OnClosed(); |
| 64 } | 71 } |
| 65 | 72 |
| 66 void BlimpDisplayManager::OnAcceleratedWidgetAvailable( | 73 void BlimpDisplayManager::OnAcceleratedWidgetAvailable( |
| 67 gfx::AcceleratedWidget widget, | 74 gfx::AcceleratedWidget widget, |
| 68 float device_pixel_ratio) { | 75 float device_pixel_ratio) { |
| 69 device_pixel_ratio_ = device_pixel_ratio; | 76 device_pixel_ratio_ = device_pixel_ratio; |
| 70 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), | 77 tab_control_feature_->SetSizeAndScale(platform_window_->GetBounds().size(), |
| 71 device_pixel_ratio_); | 78 device_pixel_ratio_); |
| 72 | 79 |
| 73 if (widget != gfx::kNullAcceleratedWidget) { | 80 if (widget != gfx::kNullAcceleratedWidget) { |
| 74 blimp_compositor_manager_->SetVisible(true); | 81 compositor_manager_->SetVisible(true); |
| 75 compositor_->SetAcceleratedWidget(widget); | 82 compositor_->SetAcceleratedWidget(widget); |
| 76 } | 83 } |
| 77 } | 84 } |
| 78 | 85 |
| 79 void BlimpDisplayManager::OnAcceleratedWidgetDestroyed() { | 86 void BlimpDisplayManager::OnAcceleratedWidgetDestroyed() { |
| 80 blimp_compositor_manager_->SetVisible(false); | 87 compositor_manager_->SetVisible(false); |
| 81 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); | 88 compositor_->SetAcceleratedWidget(gfx::kNullAcceleratedWidget); |
| 82 } | 89 } |
| 83 | 90 |
| 84 } // namespace client | 91 } // namespace client |
| 85 } // namespace blimp | 92 } // namespace blimp |
| OLD | NEW |