blob: f93b10beadcfa0f2cfbffed5454f3d3e62b2ba35 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_SCHEDULER_RENDERER_USER_MODEL_H_
#define COMPONENTS_SCHEDULER_RENDERER_USER_MODEL_H_
#include "base/macros.h"
#include "base/trace_event/trace_event.h"
#include "base/trace_event/trace_event_argument.h"
#include "components/scheduler/renderer/renderer_scheduler.h"
#include "components/scheduler/scheduler_export.h"
#include "third_party/WebKit/public/web/WebInputEvent.h"
namespace scheduler {
class SCHEDULER_EXPORT UserModel {
public:
UserModel();
~UserModel();
// Tells us that the system started processing an input event. Must be paired
// with a call to DidFinishProcessingInputEvent.
void DidStartProcessingInputEvent(blink::WebInputEvent::Type type,
const base::TimeTicks now);
// Tells us that the system finished processing an input event.
void DidFinishProcessingInputEvent(const base::TimeTicks now);
// Returns the estimated amount of time left in the current user gesture, to a
// maximum of |kGestureEstimationLimitMillis|. After that time has elapased
// this function should be called again.
base::TimeDelta TimeLeftInUserGesture(base::TimeTicks now) const;
// Tries to guess if a user gesture is expected soon. Currently this is
// very simple, but one day I hope to do something more sophisticated here.
// The prediction may change after |prediction_valid_duration| has elapsed.
bool IsGestureExpectedSoon(const base::TimeTicks now,
base::TimeDelta* prediction_valid_duration);
// Returns true if a gesture has been in progress for less than the median
// gesture duration. The prediction may change after
// |prediction_valid_duration| has elapsed.
bool IsGestureExpectedToContinue(
const base::TimeTicks now,
base::TimeDelta* prediction_valid_duration) const;
void AsValueInto(base::trace_event::TracedValue* state) const;
// The time we should stay in a priority-escalated mode after an input event.
static const int kGestureEstimationLimitMillis = 100;
// This is based on two weeks of Android usage data.
static const int kMedianGestureDurationMillis = 300;
// We consider further gesture start events to be likely if the user has
// interacted with the device in the past two seconds.
// Based on Android usage data, 2000ms between gestures is the 75th percentile
// with 700ms being the 50th.
static const int kExpectSubsequentGestureMillis = 2000;
// Clears input signals.
void Reset(base::TimeTicks now);
private:
bool IsGestureExpectedSoonImpl(
const base::TimeTicks now,
base::TimeDelta* prediction_valid_duration) const;
int pending_input_event_count_;
base::TimeTicks last_input_signal_time_;
base::TimeTicks last_gesture_start_time_;
base::TimeTicks last_continuous_gesture_time_; // Doesn't include Taps.
base::TimeTicks last_gesture_expected_start_time_;
base::TimeTicks last_reset_time_;
bool is_gesture_active_; // This typically means the user's finger is down.
bool is_gesture_expected_;
DISALLOW_COPY_AND_ASSIGN(UserModel);
};
} // namespace scheduler
#endif // COMPONENTS_SCHEDULER_RENDERER_USER_MODEL_H_
|