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
3 // found in the LICENSE file.
5 #include "ash/metrics/user_metrics_recorder.h"
7 #include "ash/shelf/shelf_layout_manager.h"
8 #include "ash/shelf/shelf_view.h"
9 #include "ash/shelf/shelf_widget.h"
10 #include "ash/shell.h"
11 #include "ash/wm/window_state.h"
12 #include "base/metrics/histogram.h"
13 #include "base/metrics/user_metrics.h"
17 // Time in seconds between calls to "RecordPeriodicMetrics".
18 const int kAshPeriodicMetricsTimeInSeconds
= 30 * 60;
20 UserMetricsRecorder::UserMetricsRecorder() {
21 timer_
.Start(FROM_HERE
,
22 base::TimeDelta::FromSeconds(kAshPeriodicMetricsTimeInSeconds
),
24 &UserMetricsRecorder::RecordPeriodicMetrics
);
27 UserMetricsRecorder::~UserMetricsRecorder() {
31 void UserMetricsRecorder::RecordUserMetricsAction(UserMetricsAction action
) {
33 case ash::UMA_ACCEL_KEYBOARD_BRIGHTNESS_DOWN_F6
:
35 base::UserMetricsAction("Accel_KeyboardBrightnessDown_F6"));
37 case ash::UMA_ACCEL_KEYBOARD_BRIGHTNESS_UP_F7
:
39 base::UserMetricsAction("Accel_KeyboardBrightnessUp_F7"));
41 case ash::UMA_ACCEL_LOCK_SCREEN_LOCK_BUTTON
:
43 base::UserMetricsAction("Accel_LockScreen_LockButton"));
45 case ash::UMA_ACCEL_LOCK_SCREEN_POWER_BUTTON
:
47 base::UserMetricsAction("Accel_LockScreen_PowerButton"));
49 case ash::UMA_ACCEL_MAXIMIZE_RESTORE_F4
:
51 base::UserMetricsAction("Accel_Maximize_Restore_F4"));
53 case ash::UMA_ACCEL_PREVWINDOW_F5
:
54 base::RecordAction(base::UserMetricsAction("Accel_PrevWindow_F5"));
56 case ash::UMA_ACCEL_EXIT_FIRST_Q
:
57 base::RecordAction(base::UserMetricsAction("Accel_Exit_First_Q"));
59 case ash::UMA_ACCEL_EXIT_SECOND_Q
:
60 base::RecordAction(base::UserMetricsAction("Accel_Exit_Second_Q"));
62 case ash::UMA_ACCEL_RESTART_POWER_BUTTON
:
64 base::UserMetricsAction("Accel_Restart_PowerButton"));
66 case ash::UMA_ACCEL_SHUT_DOWN_POWER_BUTTON
:
68 base::UserMetricsAction("Accel_ShutDown_PowerButton"));
70 case ash::UMA_CLOSE_THROUGH_CONTEXT_MENU
:
71 base::RecordAction(base::UserMetricsAction("CloseFromContextMenu"));
73 case ash::UMA_DRAG_MAXIMIZE_LEFT
:
74 base::RecordAction(base::UserMetricsAction("WindowDrag_MaximizeLeft"));
76 case ash::UMA_DRAG_MAXIMIZE_RIGHT
:
77 base::RecordAction(base::UserMetricsAction("WindowDrag_MaximizeRight"));
79 case ash::UMA_GESTURE_OVERVIEW
:
80 base::RecordAction(base::UserMetricsAction("Gesture_Overview"));
82 case ash::UMA_LAUNCHER_CLICK_ON_APP
:
83 base::RecordAction(base::UserMetricsAction("Launcher_ClickOnApp"));
85 case ash::UMA_LAUNCHER_CLICK_ON_APPLIST_BUTTON
:
87 base::UserMetricsAction("Launcher_ClickOnApplistButton"));
89 case ash::UMA_MOUSE_DOWN
:
90 base::RecordAction(base::UserMetricsAction("Mouse_Down"));
92 case ash::UMA_PANEL_MINIMIZE_CAPTION_CLICK
:
94 base::UserMetricsAction("Panel_Minimize_Caption_Click"));
96 case ash::UMA_PANEL_MINIMIZE_CAPTION_GESTURE
:
98 base::UserMetricsAction("Panel_Minimize_Caption_Gesture"));
100 case ash::UMA_SHELF_ALIGNMENT_SET_BOTTOM
:
102 base::UserMetricsAction("Shelf_AlignmentSetBottom"));
104 case ash::UMA_SHELF_ALIGNMENT_SET_LEFT
:
106 base::UserMetricsAction("Shelf_AlignmentSetLeft"));
108 case ash::UMA_SHELF_ALIGNMENT_SET_RIGHT
:
110 base::UserMetricsAction("Shelf_AlignmentSetRight"));
112 case ash::UMA_STATUS_AREA_AUDIO_CURRENT_INPUT_DEVICE
:
114 base::UserMetricsAction("StatusArea_Audio_CurrentInputDevice"));
116 case ash::UMA_STATUS_AREA_AUDIO_CURRENT_OUTPUT_DEVICE
:
118 base::UserMetricsAction("StatusArea_Audio_CurrentOutputDevice"));
120 case ash::UMA_STATUS_AREA_AUDIO_SWITCH_INPUT_DEVICE
:
122 base::UserMetricsAction("StatusArea_Audio_SwitchInputDevice"));
124 case ash::UMA_STATUS_AREA_AUDIO_SWITCH_OUTPUT_DEVICE
:
126 base::UserMetricsAction("StatusArea_Audio_SwitchOutputDevice"));
128 case ash::UMA_STATUS_AREA_BRIGHTNESS_CHANGED
:
130 base::UserMetricsAction("StatusArea_BrightnessChanged"));
132 case ash::UMA_STATUS_AREA_BLUETOOTH_CONNECT_KNOWN_DEVICE
:
134 base::UserMetricsAction("StatusArea_Bluetooth_Connect_Known"));
136 case ash::UMA_STATUS_AREA_BLUETOOTH_CONNECT_UNKNOWN_DEVICE
:
138 base::UserMetricsAction("StatusArea_Bluetooth_Connect_Unknown"));
140 case ash::UMA_STATUS_AREA_BLUETOOTH_DISABLED
:
142 base::UserMetricsAction("StatusArea_Bluetooth_Disabled"));
144 case ash::UMA_STATUS_AREA_BLUETOOTH_ENABLED
:
146 base::UserMetricsAction("StatusArea_Bluetooth_Enabled"));
148 case ash::UMA_STATUS_AREA_CAPS_LOCK_DETAILED
:
150 base::UserMetricsAction("StatusArea_CapsLock_Detailed"));
152 case ash::UMA_STATUS_AREA_CAPS_LOCK_DISABLED_BY_CLICK
:
154 base::UserMetricsAction("StatusArea_CapsLock_DisabledByClick"));
156 case ash::UMA_STATUS_AREA_CAPS_LOCK_ENABLED_BY_CLICK
:
158 base::UserMetricsAction("StatusArea_CapsLock_EnabledByClick"));
160 case ash::UMA_STATUS_AREA_CAPS_LOCK_POPUP
:
162 base::UserMetricsAction("StatusArea_CapsLock_Popup"));
164 case ash::UMA_STATUS_AREA_CONNECT_TO_CONFIGURED_NETWORK
:
166 base::UserMetricsAction("StatusArea_Network_ConnectConfigured"));
168 case ash::UMA_STATUS_AREA_CONNECT_TO_UNCONFIGURED_NETWORK
:
170 base::UserMetricsAction("StatusArea_Network_ConnectUnconfigured"));
172 case ash::UMA_STATUS_AREA_CONNECT_TO_VPN
:
174 base::UserMetricsAction("StatusArea_VPN_ConnectToNetwork"));
176 case ash::UMA_STATUS_AREA_CHANGED_VOLUME_MENU
:
178 base::UserMetricsAction("StatusArea_Volume_ChangedMenu"));
180 case ash::UMA_STATUS_AREA_CHANGED_VOLUME_POPUP
:
182 base::UserMetricsAction("StatusArea_Volume_ChangedPopup"));
184 case ash::UMA_STATUS_AREA_DETAILED_ACCESSABILITY
:
186 base::UserMetricsAction("StatusArea_Accessability_DetailedView"));
188 case ash::UMA_STATUS_AREA_DETAILED_AUDIO_VIEW
:
190 base::UserMetricsAction("StatusArea_Audio_Detailed"));
192 case ash::UMA_STATUS_AREA_DETAILED_BLUETOOTH_VIEW
:
194 base::UserMetricsAction("StatusArea_Bluetooth_Detailed"));
196 case ash::UMA_STATUS_AREA_DETAILED_BRIGHTNESS_VIEW
:
198 base::UserMetricsAction("StatusArea_Brightness_Detailed"));
200 case ash::UMA_STATUS_AREA_DETAILED_DRIVE_VIEW
:
202 base::UserMetricsAction("StatusArea_Drive_Detailed"));
204 case ash::UMA_STATUS_AREA_DETAILED_NETWORK_VIEW
:
206 base::UserMetricsAction("StatusArea_Network_Detailed"));
208 case ash::UMA_STATUS_AREA_DETAILED_VPN_VIEW
:
210 base::UserMetricsAction("StatusArea_VPN_Detailed"));
212 case ash::UMA_STATUS_AREA_DISABLE_AUTO_CLICK
:
214 base::UserMetricsAction("StatusArea_AutoClickDisabled"));
216 case ash::UMA_STATUS_AREA_DISABLE_HIGH_CONTRAST
:
218 base::UserMetricsAction("StatusArea_HighContrastDisabled"));
220 case ash::UMA_STATUS_AREA_DISABLE_LARGE_CURSOR
:
222 base::UserMetricsAction("StatusArea_LargeCursorDisabled"));
224 case ash::UMA_STATUS_AREA_DISABLE_MAGNIFIER
:
226 base::UserMetricsAction("StatusArea_MagnifierDisabled"));
228 case ash::UMA_STATUS_AREA_DISABLE_SPOKEN_FEEDBACK
:
230 base::UserMetricsAction("StatusArea_SpokenFeedbackDisabled"));
232 case ash::UMA_STATUS_AREA_DISABLE_VIRTUAL_KEYBOARD
:
234 base::UserMetricsAction("StatusArea_VirtualKeyboardDisabled"));
236 case ash::UMA_STATUS_AREA_DISABLE_WIFI
:
238 base::UserMetricsAction("StatusArea_Network_WifiDisabled"));
240 case ash::UMA_STATUS_AREA_DRIVE_CANCEL_OPERATION
:
242 base::UserMetricsAction("StatusArea_Drive_CancelOperation"));
244 case ash::UMA_STATUS_AREA_DRIVE_SETTINGS
:
246 base::UserMetricsAction("StatusArea_Drive_Settings"));
248 case ash::UMA_STATUS_AREA_ENABLE_AUTO_CLICK
:
250 base::UserMetricsAction("StatusArea_AutoClickEnabled"));
252 case ash::UMA_STATUS_AREA_ENABLE_HIGH_CONTRAST
:
254 base::UserMetricsAction("StatusArea_HighContrastEnabled"));
256 case ash::UMA_STATUS_AREA_ENABLE_LARGE_CURSOR
:
258 base::UserMetricsAction("StatusArea_LargeCursorEnabled"));
260 case ash::UMA_STATUS_AREA_ENABLE_MAGNIFIER
:
262 base::UserMetricsAction("StatusArea_MagnifierEnabled"));
264 case ash::UMA_STATUS_AREA_ENABLE_SPOKEN_FEEDBACK
:
266 base::UserMetricsAction("StatusArea_SpokenFeedbackEnabled"));
268 case ash::UMA_STATUS_AREA_ENABLE_VIRTUAL_KEYBOARD
:
270 base::UserMetricsAction("StatusArea_VirtualKeyboardEnabled"));
272 case ash::UMA_STATUS_AREA_ENABLE_WIFI
:
274 base::UserMetricsAction("StatusArea_Network_WifiEnabled"));
276 case ash::UMA_STATUS_AREA_IME_SHOW_DETAILED
:
278 base::UserMetricsAction("StatusArea_IME_Detailed"));
280 case ash::UMA_STATUS_AREA_IME_SWITCH_MODE
:
282 base::UserMetricsAction("StatusArea_IME_SwitchMode"));
284 case ash::UMA_STATUS_AREA_MENU_OPENED
:
286 base::UserMetricsAction("StatusArea_MenuOpened"));
288 case ash::UMA_STATUS_AREA_NETWORK_JOIN_OTHER_CLICKED
:
290 base::UserMetricsAction("StatusArea_Network_JoinOther"));
292 case ash::UMA_STATUS_AREA_NETWORK_SETTINGS_CLICKED
:
294 base::UserMetricsAction("StatusArea_Network_Settings"));
296 case ash::UMA_STATUS_AREA_SHOW_NETWORK_CONNECTION_DETAILS
:
298 base::UserMetricsAction("StatusArea_Network_ConnectionDetails"));
300 case ash::UMA_STATUS_AREA_SHOW_VPN_CONNECTION_DETAILS
:
302 base::UserMetricsAction("StatusArea_VPN_ConnectionDetails"));
304 case ash::UMA_STATUS_AREA_SIGN_OUT
:
306 base::UserMetricsAction("StatusArea_SignOut"));
308 case ash::UMA_STATUS_AREA_VPN_ADD_BUILT_IN_CLICKED
:
309 base::RecordAction(base::UserMetricsAction("StatusArea_VPN_AddBuiltIn"));
311 case ash::UMA_STATUS_AREA_VPN_ADD_THIRD_PARTY_CLICKED
:
313 base::UserMetricsAction("StatusArea_VPN_AddThirdParty"));
315 case ash::UMA_STATUS_AREA_VPN_DISCONNECT_CLICKED
:
316 base::RecordAction(base::UserMetricsAction("StatusArea_VPN_Disconnect"));
318 case ash::UMA_STATUS_AREA_VPN_SETTINGS_CLICKED
:
320 base::UserMetricsAction("StatusArea_VPN_Settings"));
322 case ash::UMA_TOGGLE_MAXIMIZE_CAPTION_CLICK
:
324 base::UserMetricsAction("Caption_ClickTogglesMaximize"));
326 case ash::UMA_TOGGLE_MAXIMIZE_CAPTION_GESTURE
:
328 base::UserMetricsAction("Caption_GestureTogglesMaximize"));
330 case ash::UMA_TOGGLE_SINGLE_AXIS_MAXIMIZE_BORDER_CLICK
:
332 base::UserMetricsAction(
333 "WindowBorder_ClickTogglesSingleAxisMaximize"));
335 case ash::UMA_TOUCHPAD_GESTURE_OVERVIEW
:
337 base::UserMetricsAction("Touchpad_Gesture_Overview"));
339 case ash::UMA_TOUCHSCREEN_TAP_DOWN
:
340 base::RecordAction(base::UserMetricsAction("Touchscreen_Down"));
342 case ash::UMA_TRAY_HELP
:
343 base::RecordAction(base::UserMetricsAction("Tray_Help"));
345 case ash::UMA_TRAY_LOCK_SCREEN
:
346 base::RecordAction(base::UserMetricsAction("Tray_LockScreen"));
348 case ash::UMA_TRAY_SHUT_DOWN
:
349 base::RecordAction(base::UserMetricsAction("Tray_ShutDown"));
351 case ash::UMA_WINDOW_APP_CLOSE_BUTTON_CLICK
:
352 base::RecordAction(base::UserMetricsAction("AppCloseButton_Clk"));
354 case ash::UMA_WINDOW_CLOSE_BUTTON_CLICK
:
355 base::RecordAction(base::UserMetricsAction("CloseButton_Clk"));
357 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_CLICK_EXIT_FULLSCREEN
:
358 base::RecordAction(base::UserMetricsAction("MaxButton_Clk_ExitFS"));
360 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_CLICK_RESTORE
:
362 base::UserMetricsAction("MaxButton_Clk_Restore"));
364 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_CLICK_MAXIMIZE
:
366 base::UserMetricsAction("MaxButton_Clk_Maximize"));
368 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_CLICK_MINIMIZE
:
369 base::RecordAction(base::UserMetricsAction("MinButton_Clk"));
371 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_MAXIMIZE_LEFT
:
372 base::RecordAction(base::UserMetricsAction("MaxButton_MaxLeft"));
374 case ash::UMA_WINDOW_MAXIMIZE_BUTTON_MAXIMIZE_RIGHT
:
375 base::RecordAction(base::UserMetricsAction("MaxButton_MaxRight"));
377 case ash::UMA_WINDOW_OVERVIEW
:
379 base::UserMetricsAction("WindowSelector_Overview"));
381 case ash::UMA_WINDOW_OVERVIEW_ENTER_KEY
:
383 base::UserMetricsAction("WindowSelector_OverviewEnterKey"));
385 case ash::UMA_WINDOW_CYCLE
:
387 base::UserMetricsAction("WindowCycleController_Cycle"));
392 void UserMetricsRecorder::RecordPeriodicMetrics() {
393 ShelfLayoutManager
* manager
=
394 ShelfLayoutManager::ForShelf(Shell::GetPrimaryRootWindow());
396 UMA_HISTOGRAM_ENUMERATION("Ash.ShelfAlignmentOverTime",
397 manager
->SelectValueForShelfAlignment(
398 SHELF_ALIGNMENT_UMA_ENUM_VALUE_BOTTOM
,
399 SHELF_ALIGNMENT_UMA_ENUM_VALUE_LEFT
,
400 SHELF_ALIGNMENT_UMA_ENUM_VALUE_RIGHT
,
402 SHELF_ALIGNMENT_UMA_ENUM_VALUE_COUNT
);
405 enum ActiveWindowStateType
{
406 ACTIVE_WINDOW_STATE_TYPE_NO_ACTIVE_WINDOW
,
407 ACTIVE_WINDOW_STATE_TYPE_OTHER
,
408 ACTIVE_WINDOW_STATE_TYPE_MAXIMIZED
,
409 ACTIVE_WINDOW_STATE_TYPE_FULLSCREEN
,
410 ACTIVE_WINDOW_STATE_TYPE_SNAPPED
,
411 ACTIVE_WINDOW_STATE_TYPE_DOCKED
,
412 ACTIVE_WINDOW_STATE_TYPE_COUNT
415 ActiveWindowStateType active_window_state_type
=
416 ACTIVE_WINDOW_STATE_TYPE_NO_ACTIVE_WINDOW
;
417 wm::WindowState
* active_window_state
= ash::wm::GetActiveWindowState();
418 if (active_window_state
) {
419 switch (active_window_state
->GetStateType()) {
420 case wm::WINDOW_STATE_TYPE_MAXIMIZED
:
421 active_window_state_type
= ACTIVE_WINDOW_STATE_TYPE_MAXIMIZED
;
423 case wm::WINDOW_STATE_TYPE_FULLSCREEN
:
424 active_window_state_type
= ACTIVE_WINDOW_STATE_TYPE_FULLSCREEN
;
426 case wm::WINDOW_STATE_TYPE_LEFT_SNAPPED
:
427 case wm::WINDOW_STATE_TYPE_RIGHT_SNAPPED
:
428 active_window_state_type
= ACTIVE_WINDOW_STATE_TYPE_SNAPPED
;
430 case wm::WINDOW_STATE_TYPE_DOCKED
:
431 case wm::WINDOW_STATE_TYPE_DOCKED_MINIMIZED
:
432 active_window_state_type
= ACTIVE_WINDOW_STATE_TYPE_DOCKED
;
434 case wm::WINDOW_STATE_TYPE_DEFAULT
:
435 case wm::WINDOW_STATE_TYPE_NORMAL
:
436 case wm::WINDOW_STATE_TYPE_MINIMIZED
:
437 case wm::WINDOW_STATE_TYPE_INACTIVE
:
438 case wm::WINDOW_STATE_TYPE_END
:
439 case wm::WINDOW_STATE_TYPE_AUTO_POSITIONED
:
440 active_window_state_type
= ACTIVE_WINDOW_STATE_TYPE_OTHER
;
444 UMA_HISTOGRAM_ENUMERATION("Ash.ActiveWindowShowTypeOverTime",
445 active_window_state_type
,
446 ACTIVE_WINDOW_STATE_TYPE_COUNT
);