Chromium Code Reviews| 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 "ash/system/chromeos/rotation/tray_rotation_lock.h" | 5 #include "ash/system/chromeos/rotation/tray_rotation_lock.h" |
| 6 | 6 |
| 7 #include "ash/common/system/tray/actionable_view.h" | 7 #include "ash/common/system/tray/actionable_view.h" |
| 8 #include "ash/common/system/tray/system_tray.h" | 8 #include "ash/common/system/tray/system_tray.h" |
| 9 #include "ash/common/system/tray/tray_constants.h" | 9 #include "ash/common/system/tray/tray_constants.h" |
| 10 #include "ash/common/system/tray/tray_popup_item_style.h" | 10 #include "ash/common/system/tray/tray_popup_item_style.h" |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 27 namespace ash { | 27 namespace ash { |
| 28 | 28 |
| 29 namespace { | 29 namespace { |
| 30 | 30 |
| 31 bool IsMaximizeModeWindowManagerEnabled() { | 31 bool IsMaximizeModeWindowManagerEnabled() { |
| 32 return WmShell::Get() | 32 return WmShell::Get() |
| 33 ->maximize_mode_controller() | 33 ->maximize_mode_controller() |
| 34 ->IsMaximizeModeWindowManagerEnabled(); | 34 ->IsMaximizeModeWindowManagerEnabled(); |
| 35 } | 35 } |
| 36 | 36 |
| 37 bool IsRotationLocked() { | 37 bool IsUserRotationLocked() { |
| 38 return Shell::GetInstance() | 38 return Shell::GetInstance() |
| 39 ->screen_orientation_controller() | 39 ->screen_orientation_controller() |
| 40 ->rotation_locked(); | 40 ->user_rotation_locked(); |
| 41 } | 41 } |
| 42 | 42 |
| 43 } // namespace | 43 } // namespace |
| 44 | 44 |
| 45 namespace tray { | 45 namespace tray { |
| 46 | 46 |
| 47 class RotationLockDefaultView : public ActionableView, | 47 class RotationLockDefaultView : public ActionableView, |
| 48 public ShellObserver, | 48 public ShellObserver, |
| 49 public ScreenOrientationController::Observer { | 49 public ScreenOrientationController::Observer { |
| 50 public: | 50 public: |
| 51 explicit RotationLockDefaultView(SystemTrayItem* owner); | 51 explicit RotationLockDefaultView(SystemTrayItem* owner); |
| 52 ~RotationLockDefaultView() override; | 52 ~RotationLockDefaultView() override; |
| 53 | 53 |
| 54 private: | 54 private: |
| 55 // Updates icon and label according to current rotation lock status. | 55 // Updates icon and label according to current rotation lock status. |
| 56 void Update(); | 56 void Update(); |
| 57 | 57 |
| 58 // Stop observing rotation lock status. | 58 // Stop observing rotation lock status. |
| 59 void StopObservingRotation(); | 59 void StopObservingRotation(); |
| 60 | 60 |
| 61 // ActionableView: | 61 // ActionableView: |
| 62 void GetAccessibleNodeData(ui::AXNodeData* node_data) override; | 62 void GetAccessibleNodeData(ui::AXNodeData* node_data) override; |
| 63 bool PerformAction(const ui::Event& event) override; | 63 bool PerformAction(const ui::Event& event) override; |
| 64 | 64 |
| 65 // ShellObserver: | 65 // ShellObserver: |
| 66 void OnMaximizeModeStarted() override; | 66 void OnMaximizeModeStarted() override; |
| 67 void OnMaximizeModeEnded() override; | 67 void OnMaximizeModeEnded() override; |
| 68 | 68 |
| 69 // ScreenOrientationController::Obsever: | 69 // ScreenOrientationController::Obsever: |
| 70 void OnRotationLockChanged(bool rotation_locked) override; | 70 void OnUserRotationLockChanged() override; |
| 71 | 71 |
| 72 views::ImageView* icon_; | 72 views::ImageView* icon_; |
| 73 views::Label* label_; | 73 views::Label* label_; |
| 74 | 74 |
| 75 DISALLOW_COPY_AND_ASSIGN(RotationLockDefaultView); | 75 DISALLOW_COPY_AND_ASSIGN(RotationLockDefaultView); |
| 76 }; | 76 }; |
| 77 | 77 |
| 78 RotationLockDefaultView::RotationLockDefaultView(SystemTrayItem* owner) | 78 RotationLockDefaultView::RotationLockDefaultView(SystemTrayItem* owner) |
| 79 : ActionableView(owner, TrayPopupInkDropStyle::FILL_BOUNDS), | 79 : ActionableView(owner, TrayPopupInkDropStyle::FILL_BOUNDS), |
| 80 icon_(TrayPopupUtils::CreateMainImageView()), | 80 icon_(TrayPopupUtils::CreateMainImageView()), |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 96 Shell::GetInstance()->AddShellObserver(this); | 96 Shell::GetInstance()->AddShellObserver(this); |
| 97 if (IsMaximizeModeWindowManagerEnabled()) | 97 if (IsMaximizeModeWindowManagerEnabled()) |
| 98 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); | 98 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); |
| 99 } | 99 } |
| 100 | 100 |
| 101 RotationLockDefaultView::~RotationLockDefaultView() { | 101 RotationLockDefaultView::~RotationLockDefaultView() { |
| 102 StopObservingRotation(); | 102 StopObservingRotation(); |
| 103 Shell::GetInstance()->RemoveShellObserver(this); | 103 Shell::GetInstance()->RemoveShellObserver(this); |
| 104 } | 104 } |
| 105 | 105 |
| 106 void RotationLockDefaultView::Update() { | 106 void RotationLockDefaultView::Update() { |
|
jonross
2017/03/21 14:56:44
So this might become confusing for users.
As an A
oshima
2017/03/21 15:10:57
Basically, we're making this consistent with Andro
jonross
2017/03/22 23:51:56
SGTM
| |
| 107 TrayPopupItemStyle style(TrayPopupItemStyle::FontStyle::DEFAULT_VIEW_LABEL); | 107 TrayPopupItemStyle style(TrayPopupItemStyle::FontStyle::DEFAULT_VIEW_LABEL); |
| 108 icon_->SetImage(gfx::CreateVectorIcon(IsRotationLocked() | 108 icon_->SetImage(gfx::CreateVectorIcon(IsUserRotationLocked() |
| 109 ? kSystemMenuRotationLockLockedIcon | 109 ? kSystemMenuRotationLockLockedIcon |
| 110 : kSystemMenuRotationLockAutoIcon, | 110 : kSystemMenuRotationLockAutoIcon, |
| 111 kMenuIconSize, style.GetIconColor())); | 111 kMenuIconSize, style.GetIconColor())); |
| 112 | 112 |
| 113 base::string16 label = l10n_util::GetStringUTF16( | 113 base::string16 label = l10n_util::GetStringUTF16( |
| 114 IsRotationLocked() ? IDS_ASH_STATUS_TRAY_ROTATION_LOCK_LOCKED | 114 IsUserRotationLocked() ? IDS_ASH_STATUS_TRAY_ROTATION_LOCK_LOCKED |
| 115 : IDS_ASH_STATUS_TRAY_ROTATION_LOCK_AUTO); | 115 : IDS_ASH_STATUS_TRAY_ROTATION_LOCK_AUTO); |
| 116 label_->SetText(label); | 116 label_->SetText(label); |
| 117 style.SetupLabel(label_); | 117 style.SetupLabel(label_); |
| 118 | 118 |
| 119 Layout(); | 119 Layout(); |
| 120 SchedulePaint(); | 120 SchedulePaint(); |
| 121 } | 121 } |
| 122 | 122 |
| 123 void RotationLockDefaultView::StopObservingRotation() { | 123 void RotationLockDefaultView::StopObservingRotation() { |
| 124 ScreenOrientationController* controller = | 124 ScreenOrientationController* controller = |
| 125 Shell::GetInstance()->screen_orientation_controller(); | 125 Shell::GetInstance()->screen_orientation_controller(); |
| 126 if (controller) | 126 if (controller) |
| 127 controller->RemoveObserver(this); | 127 controller->RemoveObserver(this); |
| 128 } | 128 } |
| 129 | 129 |
| 130 void RotationLockDefaultView::GetAccessibleNodeData(ui::AXNodeData* node_data) { | 130 void RotationLockDefaultView::GetAccessibleNodeData(ui::AXNodeData* node_data) { |
| 131 ActionableView::GetAccessibleNodeData(node_data); | 131 ActionableView::GetAccessibleNodeData(node_data); |
| 132 if (!label_->text().empty()) | 132 if (!label_->text().empty()) |
| 133 node_data->SetName(label_->text()); | 133 node_data->SetName(label_->text()); |
| 134 } | 134 } |
| 135 | 135 |
| 136 bool RotationLockDefaultView::PerformAction(const ui::Event& event) { | 136 bool RotationLockDefaultView::PerformAction(const ui::Event& event) { |
| 137 Shell::GetInstance()->screen_orientation_controller()->SetRotationLocked( | 137 Shell::GetInstance() |
| 138 !IsRotationLocked()); | 138 ->screen_orientation_controller() |
| 139 ->ToggleUserRotationLock(); | |
| 139 return true; | 140 return true; |
| 140 } | 141 } |
| 141 | 142 |
| 142 void RotationLockDefaultView::OnMaximizeModeStarted() { | 143 void RotationLockDefaultView::OnMaximizeModeStarted() { |
| 143 Update(); | 144 Update(); |
| 144 SetVisible(true); | 145 SetVisible(true); |
| 145 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); | 146 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); |
| 146 } | 147 } |
| 147 | 148 |
| 148 void RotationLockDefaultView::OnMaximizeModeEnded() { | 149 void RotationLockDefaultView::OnMaximizeModeEnded() { |
| 149 SetVisible(false); | 150 SetVisible(false); |
| 150 StopObservingRotation(); | 151 StopObservingRotation(); |
| 151 } | 152 } |
| 152 | 153 |
| 153 void RotationLockDefaultView::OnRotationLockChanged(bool rotation_locked) { | 154 void RotationLockDefaultView::OnUserRotationLockChanged() { |
| 154 Update(); | 155 Update(); |
| 155 } | 156 } |
| 156 | 157 |
| 157 } // namespace tray | 158 } // namespace tray |
| 158 | 159 |
| 159 TrayRotationLock::TrayRotationLock(SystemTray* system_tray) | 160 TrayRotationLock::TrayRotationLock(SystemTray* system_tray) |
| 160 : TrayImageItem(system_tray, | 161 : TrayImageItem(system_tray, |
| 161 kSystemTrayRotationLockLockedIcon, | 162 kSystemTrayRotationLockLockedIcon, |
| 162 UMA_ROTATION_LOCK) { | 163 UMA_ROTATION_LOCK) { |
| 163 Shell::GetInstance()->AddShellObserver(this); | 164 Shell::GetInstance()->AddShellObserver(this); |
| 164 } | 165 } |
| 165 | 166 |
| 166 TrayRotationLock::~TrayRotationLock() { | 167 TrayRotationLock::~TrayRotationLock() { |
| 167 Shell::GetInstance()->RemoveShellObserver(this); | 168 Shell::GetInstance()->RemoveShellObserver(this); |
| 168 } | 169 } |
| 169 | 170 |
| 170 void TrayRotationLock::OnRotationLockChanged(bool rotation_locked) { | 171 void TrayRotationLock::OnUserRotationLockChanged() { |
| 171 tray_view()->SetVisible(ShouldBeVisible()); | 172 tray_view()->SetVisible(ShouldBeVisible()); |
| 172 } | 173 } |
| 173 | 174 |
| 174 views::View* TrayRotationLock::CreateDefaultView(LoginStatus status) { | 175 views::View* TrayRotationLock::CreateDefaultView(LoginStatus status) { |
| 175 if (OnPrimaryDisplay()) | 176 if (OnPrimaryDisplay()) |
| 176 return new tray::RotationLockDefaultView(this); | 177 return new tray::RotationLockDefaultView(this); |
| 177 return nullptr; | 178 return nullptr; |
| 178 } | 179 } |
| 179 | 180 |
| 180 void TrayRotationLock::OnMaximizeModeStarted() { | 181 void TrayRotationLock::OnMaximizeModeStarted() { |
| 181 tray_view()->SetVisible(IsRotationLocked()); | 182 tray_view()->SetVisible(IsUserRotationLocked()); |
| 182 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); | 183 Shell::GetInstance()->screen_orientation_controller()->AddObserver(this); |
| 183 } | 184 } |
| 184 | 185 |
| 185 void TrayRotationLock::OnMaximizeModeEnded() { | 186 void TrayRotationLock::OnMaximizeModeEnded() { |
| 186 tray_view()->SetVisible(false); | 187 tray_view()->SetVisible(false); |
| 187 StopObservingRotation(); | 188 StopObservingRotation(); |
| 188 } | 189 } |
| 189 | 190 |
| 190 void TrayRotationLock::DestroyTrayView() { | 191 void TrayRotationLock::DestroyTrayView() { |
| 191 StopObservingRotation(); | 192 StopObservingRotation(); |
| 192 Shell::GetInstance()->RemoveShellObserver(this); | 193 Shell::GetInstance()->RemoveShellObserver(this); |
| 193 TrayImageItem::DestroyTrayView(); | 194 TrayImageItem::DestroyTrayView(); |
| 194 } | 195 } |
| 195 | 196 |
| 196 bool TrayRotationLock::GetInitialVisibility() { | 197 bool TrayRotationLock::GetInitialVisibility() { |
| 197 return ShouldBeVisible(); | 198 return ShouldBeVisible(); |
| 198 } | 199 } |
| 199 | 200 |
| 200 bool TrayRotationLock::ShouldBeVisible() { | 201 bool TrayRotationLock::ShouldBeVisible() { |
| 201 return OnPrimaryDisplay() && IsMaximizeModeWindowManagerEnabled() && | 202 return OnPrimaryDisplay() && IsMaximizeModeWindowManagerEnabled() && |
| 202 IsRotationLocked(); | 203 IsUserRotationLocked(); |
| 203 } | 204 } |
| 204 | 205 |
| 205 bool TrayRotationLock::OnPrimaryDisplay() const { | 206 bool TrayRotationLock::OnPrimaryDisplay() const { |
| 206 gfx::NativeView native_view = system_tray()->GetWidget()->GetNativeView(); | 207 gfx::NativeView native_view = system_tray()->GetWidget()->GetNativeView(); |
| 207 display::Display parent_display = | 208 display::Display parent_display = |
| 208 display::Screen::GetScreen()->GetDisplayNearestWindow(native_view); | 209 display::Screen::GetScreen()->GetDisplayNearestWindow(native_view); |
| 209 return parent_display.IsInternal(); | 210 return parent_display.IsInternal(); |
| 210 } | 211 } |
| 211 | 212 |
| 212 void TrayRotationLock::StopObservingRotation() { | 213 void TrayRotationLock::StopObservingRotation() { |
| 213 ScreenOrientationController* controller = | 214 ScreenOrientationController* controller = |
| 214 Shell::GetInstance()->screen_orientation_controller(); | 215 Shell::GetInstance()->screen_orientation_controller(); |
| 215 if (controller) | 216 if (controller) |
| 216 controller->RemoveObserver(this); | 217 controller->RemoveObserver(this); |
| 217 } | 218 } |
| 218 | 219 |
| 219 } // namespace ash | 220 } // namespace ash |
| OLD | NEW |