blob: 5a0c1e1919d4174ad6368bf1b7369fec0edee6d6 (
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
85
86
87
88
|
// Copyright (c) 2011 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.
#include "ui/base/animation/multi_animation.h"
#include "base/logging.h"
#include "ui/base/animation/animation_delegate.h"
namespace ui {
// Default interval, in ms.
static const int kDefaultInterval = 20;
static int TotalTime(const MultiAnimation::Parts& parts) {
int time_ms = 0;
for (size_t i = 0; i < parts.size(); ++i) {
DCHECK(parts[i].end_time_ms - parts[i].start_time_ms >= parts[i].time_ms);
time_ms += parts[i].time_ms;
}
return time_ms;
}
MultiAnimation::MultiAnimation(const Parts& parts)
: Animation(base::TimeDelta::FromMilliseconds(kDefaultInterval)),
parts_(parts),
cycle_time_ms_(TotalTime(parts)),
current_value_(0),
current_part_index_(0),
continuous_(true) {
DCHECK(!parts_.empty());
}
MultiAnimation::~MultiAnimation() {}
double MultiAnimation::GetCurrentValue() const {
return current_value_;
}
void MultiAnimation::Step(base::TimeTicks time_now) {
double last_value = current_value_;
size_t last_index = current_part_index_;
int delta = static_cast<int>((time_now - start_time()).InMilliseconds());
if (delta >= cycle_time_ms_ && !continuous_) {
current_part_index_ = parts_.size() - 1;
current_value_ = Tween::CalculateValue(parts_[current_part_index_].type, 1);
Stop();
return;
}
delta %= cycle_time_ms_;
const Part& part = GetPart(&delta, ¤t_part_index_);
double percent = static_cast<double>(delta + part.start_time_ms) /
static_cast<double>(part.end_time_ms);
DCHECK(percent <= 1);
current_value_ = Tween::CalculateValue(part.type, percent);
if ((current_value_ != last_value || current_part_index_ != last_index) &&
delegate()) {
delegate()->AnimationProgressed(this);
}
}
void MultiAnimation::SetStartTime(base::TimeTicks start_time) {
Animation::SetStartTime(start_time);
current_value_ = 0;
current_part_index_ = 0;
}
const MultiAnimation::Part& MultiAnimation::GetPart(int* time_ms,
size_t* part_index) {
DCHECK(*time_ms < cycle_time_ms_);
for (size_t i = 0; i < parts_.size(); ++i) {
if (*time_ms < parts_[i].time_ms) {
*part_index = i;
return parts_[i];
}
*time_ms -= parts_[i].time_ms;
}
NOTREACHED();
*time_ms = 0;
*part_index = 0;
return parts_[0];
}
} // namespace ui
|