OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/metrics/user_metrics_recorder.h" | 5 #include "ash/metrics/user_metrics_recorder.h" |
6 | 6 |
| 7 #include "ash/session/session_state_delegate.h" |
7 #include "ash/shelf/shelf_layout_manager.h" | 8 #include "ash/shelf/shelf_layout_manager.h" |
8 #include "ash/shelf/shelf_view.h" | 9 #include "ash/shelf/shelf_view.h" |
9 #include "ash/shelf/shelf_widget.h" | 10 #include "ash/shelf/shelf_widget.h" |
10 #include "ash/shell.h" | 11 #include "ash/shell.h" |
11 #include "ash/shell_window_ids.h" | 12 #include "ash/shell_window_ids.h" |
| 13 #include "ash/system/tray/system_tray_delegate.h" |
12 #include "ash/wm/window_state.h" | 14 #include "ash/wm/window_state.h" |
13 #include "base/metrics/histogram.h" | 15 #include "base/metrics/histogram.h" |
14 #include "base/metrics/user_metrics.h" | 16 #include "base/metrics/user_metrics.h" |
15 #include "ui/aura/window.h" | 17 #include "ui/aura/window.h" |
16 | 18 |
17 namespace ash { | 19 namespace ash { |
18 | 20 |
19 namespace { | 21 namespace { |
20 | 22 |
21 // Time in seconds between calls to "RecordPeriodicMetrics". | 23 // Time in seconds between calls to "RecordPeriodicMetrics". |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
57 case wm::WINDOW_STATE_TYPE_INACTIVE: | 59 case wm::WINDOW_STATE_TYPE_INACTIVE: |
58 case wm::WINDOW_STATE_TYPE_END: | 60 case wm::WINDOW_STATE_TYPE_END: |
59 case wm::WINDOW_STATE_TYPE_AUTO_POSITIONED: | 61 case wm::WINDOW_STATE_TYPE_AUTO_POSITIONED: |
60 active_window_state_type = ACTIVE_WINDOW_STATE_TYPE_OTHER; | 62 active_window_state_type = ACTIVE_WINDOW_STATE_TYPE_OTHER; |
61 break; | 63 break; |
62 } | 64 } |
63 } | 65 } |
64 return active_window_state_type; | 66 return active_window_state_type; |
65 } | 67 } |
66 | 68 |
| 69 // Returns true if kiosk mode is active. |
| 70 bool IsKioskModeActive() { |
| 71 return Shell::GetInstance()->system_tray_delegate()->GetUserLoginStatus() == |
| 72 user::LOGGED_IN_KIOSK_APP; |
| 73 } |
| 74 |
| 75 // Returns true if there is an active user and their session isn't currently |
| 76 // locked. |
| 77 bool IsUserActive() { |
| 78 switch (Shell::GetInstance()->system_tray_delegate()->GetUserLoginStatus()) { |
| 79 case user::LOGGED_IN_NONE: |
| 80 case user::LOGGED_IN_LOCKED: |
| 81 return false; |
| 82 case user::LOGGED_IN_USER: |
| 83 case user::LOGGED_IN_OWNER: |
| 84 case user::LOGGED_IN_GUEST: |
| 85 case user::LOGGED_IN_PUBLIC: |
| 86 case user::LOGGED_IN_SUPERVISED: |
| 87 case user::LOGGED_IN_KIOSK_APP: |
| 88 return true; |
| 89 } |
| 90 NOTREACHED(); |
| 91 return false; |
| 92 } |
| 93 |
67 // Array of window container ids that contain visible windows to be counted for | 94 // Array of window container ids that contain visible windows to be counted for |
68 // UMA statistics. Note the containers are ordered from top most visible | 95 // UMA statistics. Note the containers are ordered from top most visible |
69 // container to the lowest to allow the |GetNumVisibleWindows| method to short | 96 // container to the lowest to allow the |GetNumVisibleWindows| method to short |
70 // circuit when processing a maximized or fullscreen window. | 97 // circuit when processing a maximized or fullscreen window. |
71 int kVisibleWindowContainerIds[] = {kShellWindowId_PanelContainer, | 98 int kVisibleWindowContainerIds[] = {kShellWindowId_PanelContainer, |
72 kShellWindowId_DockedContainer, | 99 kShellWindowId_DockedContainer, |
73 kShellWindowId_AlwaysOnTopContainer, | 100 kShellWindowId_AlwaysOnTopContainer, |
74 kShellWindowId_DefaultContainer}; | 101 kShellWindowId_DefaultContainer}; |
75 | 102 |
76 // Returns an approximate count of how many windows are currently visible in the | 103 // Returns an approximate count of how many windows are currently visible in the |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
117 break; | 144 break; |
118 } | 145 } |
119 } | 146 } |
120 } | 147 } |
121 return visible_window_count; | 148 return visible_window_count; |
122 } | 149 } |
123 | 150 |
124 } // namespace | 151 } // namespace |
125 | 152 |
126 UserMetricsRecorder::UserMetricsRecorder() { | 153 UserMetricsRecorder::UserMetricsRecorder() { |
127 timer_.Start(FROM_HERE, | 154 StartTimer(); |
128 base::TimeDelta::FromSeconds(kAshPeriodicMetricsTimeInSeconds), | 155 } |
129 this, | 156 |
130 &UserMetricsRecorder::RecordPeriodicMetrics); | 157 UserMetricsRecorder::UserMetricsRecorder(bool record_periodic_metrics) { |
| 158 if (record_periodic_metrics) |
| 159 StartTimer(); |
131 } | 160 } |
132 | 161 |
133 UserMetricsRecorder::~UserMetricsRecorder() { | 162 UserMetricsRecorder::~UserMetricsRecorder() { |
134 timer_.Stop(); | 163 timer_.Stop(); |
135 } | 164 } |
136 | 165 |
137 void UserMetricsRecorder::RecordUserMetricsAction(UserMetricsAction action) { | 166 void UserMetricsRecorder::RecordUserMetricsAction(UserMetricsAction action) { |
138 switch (action) { | 167 switch (action) { |
139 case ash::UMA_ACCEL_KEYBOARD_BRIGHTNESS_DOWN_F6: | 168 case ash::UMA_ACCEL_KEYBOARD_BRIGHTNESS_DOWN_F6: |
140 base::RecordAction( | 169 base::RecordAction( |
(...skipping 371 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
512 case ash::UMA_WINDOW_CYCLE: | 541 case ash::UMA_WINDOW_CYCLE: |
513 base::RecordAction( | 542 base::RecordAction( |
514 base::UserMetricsAction("WindowCycleController_Cycle")); | 543 base::UserMetricsAction("WindowCycleController_Cycle")); |
515 break; | 544 break; |
516 } | 545 } |
517 } | 546 } |
518 | 547 |
519 void UserMetricsRecorder::RecordPeriodicMetrics() { | 548 void UserMetricsRecorder::RecordPeriodicMetrics() { |
520 ShelfLayoutManager* manager = | 549 ShelfLayoutManager* manager = |
521 ShelfLayoutManager::ForShelf(Shell::GetPrimaryRootWindow()); | 550 ShelfLayoutManager::ForShelf(Shell::GetPrimaryRootWindow()); |
| 551 // TODO(bruthig): Investigating whether the check for |manager| is necessary |
| 552 // and add tests if it is. |
522 if (manager) { | 553 if (manager) { |
| 554 // TODO(bruthig): Consider tracking the time spent in each alignment. |
523 UMA_HISTOGRAM_ENUMERATION("Ash.ShelfAlignmentOverTime", | 555 UMA_HISTOGRAM_ENUMERATION("Ash.ShelfAlignmentOverTime", |
524 manager->SelectValueForShelfAlignment( | 556 manager->SelectValueForShelfAlignment( |
525 SHELF_ALIGNMENT_UMA_ENUM_VALUE_BOTTOM, | 557 SHELF_ALIGNMENT_UMA_ENUM_VALUE_BOTTOM, |
526 SHELF_ALIGNMENT_UMA_ENUM_VALUE_LEFT, | 558 SHELF_ALIGNMENT_UMA_ENUM_VALUE_LEFT, |
527 SHELF_ALIGNMENT_UMA_ENUM_VALUE_RIGHT, | 559 SHELF_ALIGNMENT_UMA_ENUM_VALUE_RIGHT, |
528 -1), | 560 -1), |
529 SHELF_ALIGNMENT_UMA_ENUM_VALUE_COUNT); | 561 SHELF_ALIGNMENT_UMA_ENUM_VALUE_COUNT); |
530 } | 562 } |
531 | 563 |
532 UMA_HISTOGRAM_COUNTS_100("Ash.NumberOfVisibleWindowsInPrimaryDisplay", | 564 if (IsUserInActiveDesktopEnvironment()) { |
533 GetNumVisibleWindowsInPrimaryDisplay()); | 565 UMA_HISTOGRAM_COUNTS_100("Ash.NumberOfVisibleWindowsInPrimaryDisplay", |
| 566 GetNumVisibleWindowsInPrimaryDisplay()); |
| 567 } |
534 | 568 |
| 569 // TODO(bruthig): Find out if this should only be logged when the user is |
| 570 // active. |
| 571 // TODO(bruthig): Consider tracking how long a particular type of window is |
| 572 // active at a time. |
535 UMA_HISTOGRAM_ENUMERATION("Ash.ActiveWindowShowTypeOverTime", | 573 UMA_HISTOGRAM_ENUMERATION("Ash.ActiveWindowShowTypeOverTime", |
536 GetActiveWindowState(), | 574 GetActiveWindowState(), |
537 ACTIVE_WINDOW_STATE_TYPE_COUNT); | 575 ACTIVE_WINDOW_STATE_TYPE_COUNT); |
538 } | 576 } |
539 | 577 |
| 578 bool UserMetricsRecorder::IsUserInActiveDesktopEnvironment() const { |
| 579 return IsUserActive() && !IsKioskModeActive(); |
| 580 } |
| 581 |
| 582 void UserMetricsRecorder::StartTimer() { |
| 583 timer_.Start(FROM_HERE, |
| 584 base::TimeDelta::FromSeconds(kAshPeriodicMetricsTimeInSeconds), |
| 585 this, &UserMetricsRecorder::RecordPeriodicMetrics); |
| 586 } |
| 587 |
540 } // namespace ash | 588 } // namespace ash |
OLD | NEW |