OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/core/contents/blimp_contents_impl.h" | 5 #include "blimp/client/core/contents/blimp_contents_impl.h" |
6 | 6 |
7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
8 #include "base/metrics/histogram_macros.h" | 8 #include "base/metrics/histogram_macros.h" |
9 #include "base/supports_user_data.h" | 9 #include "base/supports_user_data.h" |
10 #include "blimp/client/core/contents/blimp_contents_view.h" | |
11 #include "blimp/client/core/contents/tab_control_feature.h" | 10 #include "blimp/client/core/contents/tab_control_feature.h" |
12 #include "blimp/client/public/contents/blimp_contents_observer.h" | 11 #include "blimp/client/public/contents/blimp_contents_observer.h" |
13 #include "ui/gfx/native_widget_types.h" | 12 #include "ui/gfx/native_widget_types.h" |
14 | 13 |
15 #if defined(OS_ANDROID) | 14 #if defined(OS_ANDROID) |
16 #include "blimp/client/core/contents/android/blimp_contents_impl_android.h" | 15 #include "blimp/client/core/contents/android/blimp_contents_impl_android.h" |
17 #endif // OS_ANDROID | 16 #endif // OS_ANDROID |
18 | 17 |
19 namespace blimp { | 18 namespace blimp { |
20 namespace client { | 19 namespace client { |
(...skipping 13 matching lines...) Expand all Loading... |
34 NavigationFeature* navigation_feature, | 33 NavigationFeature* navigation_feature, |
35 RenderWidgetFeature* render_widget_feature, | 34 RenderWidgetFeature* render_widget_feature, |
36 TabControlFeature* tab_control_feature) | 35 TabControlFeature* tab_control_feature) |
37 : navigation_controller_(id, this, navigation_feature), | 36 : navigation_controller_(id, this, navigation_feature), |
38 compositor_manager_(id, render_widget_feature, compositor_deps), | 37 compositor_manager_(id, render_widget_feature, compositor_deps), |
39 id_(id), | 38 id_(id), |
40 ime_feature_(ime_feature), | 39 ime_feature_(ime_feature), |
41 window_(window), | 40 window_(window), |
42 tab_control_feature_(tab_control_feature) { | 41 tab_control_feature_(tab_control_feature) { |
43 blimp_contents_view_ = | 42 blimp_contents_view_ = |
44 BlimpContentsView::Create(this, compositor_manager_.layer()); | 43 BlimpContentsViewImpl::Create(this, compositor_manager_.layer()); |
45 ime_feature_->set_delegate(blimp_contents_view_->GetImeDelegate()); | 44 ime_feature_->set_delegate(blimp_contents_view_->GetImeDelegate()); |
46 } | 45 } |
47 | 46 |
48 BlimpContentsImpl::~BlimpContentsImpl() { | 47 BlimpContentsImpl::~BlimpContentsImpl() { |
49 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, BlimpContentsDying()); | 48 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, BlimpContentsDying()); |
50 ime_feature_->set_delegate(nullptr); | 49 ime_feature_->set_delegate(nullptr); |
51 } | 50 } |
52 | 51 |
53 #if defined(OS_ANDROID) | 52 #if defined(OS_ANDROID) |
54 | 53 |
(...skipping 23 matching lines...) Expand all Loading... |
78 } | 77 } |
79 | 78 |
80 void BlimpContentsImpl::AddObserver(BlimpContentsObserver* observer) { | 79 void BlimpContentsImpl::AddObserver(BlimpContentsObserver* observer) { |
81 observers_.AddObserver(observer); | 80 observers_.AddObserver(observer); |
82 } | 81 } |
83 | 82 |
84 void BlimpContentsImpl::RemoveObserver(BlimpContentsObserver* observer) { | 83 void BlimpContentsImpl::RemoveObserver(BlimpContentsObserver* observer) { |
85 observers_.RemoveObserver(observer); | 84 observers_.RemoveObserver(observer); |
86 } | 85 } |
87 | 86 |
88 gfx::NativeView BlimpContentsImpl::GetNativeView() { | 87 BlimpContentsViewImpl* BlimpContentsImpl::GetView() { |
89 return blimp_contents_view_->GetNativeView(); | 88 return blimp_contents_view_.get(); |
90 } | 89 } |
91 | 90 |
92 void BlimpContentsImpl::Show() { | 91 void BlimpContentsImpl::Show() { |
93 compositor_manager_.SetVisible(true); | 92 compositor_manager_.SetVisible(true); |
94 UMA_HISTOGRAM_BOOLEAN("Blimp.Tab.Visible", true); | 93 UMA_HISTOGRAM_BOOLEAN("Blimp.Tab.Visible", true); |
95 } | 94 } |
96 | 95 |
97 void BlimpContentsImpl::Hide() { | 96 void BlimpContentsImpl::Hide() { |
98 compositor_manager_.SetVisible(false); | 97 compositor_manager_.SetVisible(false); |
99 UMA_HISTOGRAM_BOOLEAN("Blimp.Tab.Visible", false); | 98 UMA_HISTOGRAM_BOOLEAN("Blimp.Tab.Visible", false); |
100 } | 99 } |
101 | 100 |
102 bool BlimpContentsImpl::HasObserver(BlimpContentsObserver* observer) { | 101 bool BlimpContentsImpl::HasObserver(BlimpContentsObserver* observer) { |
103 return observers_.HasObserver(observer); | 102 return observers_.HasObserver(observer); |
104 } | 103 } |
105 | 104 |
106 void BlimpContentsImpl::OnNavigationStateChanged() { | 105 void BlimpContentsImpl::OnNavigationStateChanged() { |
107 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, | 106 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, |
108 OnNavigationStateChanged()); | 107 OnNavigationStateChanged()); |
109 } | 108 } |
110 | 109 |
111 void BlimpContentsImpl::OnLoadingStateChanged(bool loading) { | 110 void BlimpContentsImpl::OnLoadingStateChanged(bool loading) { |
112 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, | 111 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, |
113 OnLoadingStateChanged(loading)); | 112 OnLoadingStateChanged(loading)); |
114 } | 113 } |
115 | 114 |
| 115 void BlimpContentsImpl::OnPageLoadingStateChanged(bool loading) { |
| 116 FOR_EACH_OBSERVER(BlimpContentsObserver, observers_, |
| 117 OnPageLoadingStateChanged(loading)); |
| 118 } |
| 119 |
116 void BlimpContentsImpl::SetSizeAndScale(const gfx::Size& size, | 120 void BlimpContentsImpl::SetSizeAndScale(const gfx::Size& size, |
117 float device_pixel_ratio) { | 121 float device_pixel_ratio) { |
118 tab_control_feature_->SetSizeAndScale(size, device_pixel_ratio); | 122 tab_control_feature_->SetSizeAndScale(size, device_pixel_ratio); |
119 } | 123 } |
120 | 124 |
121 BlimpContentsView* BlimpContentsImpl::GetBlimpContentsView() { | |
122 return blimp_contents_view_.get(); | |
123 } | |
124 | |
125 } // namespace client | 125 } // namespace client |
126 } // namespace blimp | 126 } // namespace blimp |
OLD | NEW |