| Index: mojo/services/view_manager/scheduled_animation_group.h
|
| diff --git a/mojo/services/view_manager/scheduled_animation_group.h b/mojo/services/view_manager/scheduled_animation_group.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..63aa89938431995e2355e674beb40a44ef46d5a6
|
| --- /dev/null
|
| +++ b/mojo/services/view_manager/scheduled_animation_group.h
|
| @@ -0,0 +1,110 @@
|
| +// Copyright 2014 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 SERVICES_VIEW_MANAGER_SCHEDULED_ANIMATION_GROUP_H_
|
| +#define SERVICES_VIEW_MANAGER_SCHEDULED_ANIMATION_GROUP_H_
|
| +
|
| +#include <vector>
|
| +
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/time/time.h"
|
| +#include "third_party/mojo_services/src/view_manager/public/interfaces/animations.mojom.h"
|
| +#include "ui/gfx/animation/tween.h"
|
| +#include "ui/gfx/transform.h"
|
| +
|
| +namespace view_manager {
|
| +
|
| +class ServerView;
|
| +
|
| +struct ScheduledAnimationValue {
|
| + ScheduledAnimationValue();
|
| + ~ScheduledAnimationValue();
|
| +
|
| + float float_value;
|
| + gfx::Transform transform;
|
| +};
|
| +
|
| +struct ScheduledAnimationElement {
|
| + ScheduledAnimationElement();
|
| + ~ScheduledAnimationElement();
|
| +
|
| + mojo::AnimationProperty property;
|
| + base::TimeDelta duration;
|
| + gfx::Tween::Type tween_type;
|
| + bool is_start_valid;
|
| + ScheduledAnimationValue start_value;
|
| + ScheduledAnimationValue target_value;
|
| + // Start time is based on scheduled time and relative to any other elements
|
| + // in the sequence.
|
| + base::TimeTicks start_time;
|
| +};
|
| +
|
| +struct ScheduledAnimationSequence {
|
| + ScheduledAnimationSequence();
|
| + ~ScheduledAnimationSequence();
|
| +
|
| + bool run_until_stopped;
|
| + std::vector<ScheduledAnimationElement> elements;
|
| +
|
| + // Sum of the duration of all elements. This does not take into account
|
| + // |cycle_count|.
|
| + base::TimeDelta duration;
|
| +
|
| + // The following values are updated as the animation progresses.
|
| +
|
| + // Number of cycles remaining. This is only used if |run_until_stopped| is
|
| + // false.
|
| + uint32_t cycle_count;
|
| +
|
| + // Index into |elements| of the element currently animating.
|
| + size_t current_index;
|
| +};
|
| +
|
| +// Corresponds to a mojo::AnimationGroup and is responsible for running the
|
| +// actual animation.
|
| +class ScheduledAnimationGroup {
|
| + public:
|
| + ~ScheduledAnimationGroup();
|
| +
|
| + // Returns a new ScheduledAnimationGroup from the supplied parameters, or
|
| + // null if |transport_group| isn't valid.
|
| + static scoped_ptr<ScheduledAnimationGroup> Create(
|
| + ServerView* view,
|
| + base::TimeTicks now,
|
| + uint32_t id,
|
| + const mojo::AnimationGroup& transport_group);
|
| +
|
| + uint32_t id() const { return id_; }
|
| +
|
| + // Gets the start value for any elements that don't have an explicit start.
|
| + // value.
|
| + void ObtainStartValues();
|
| +
|
| + // Sets the values of any properties that are not in |other| to their final
|
| + // value.
|
| + void SetValuesToTargetValuesForPropertiesNotIn(
|
| + const ScheduledAnimationGroup& other);
|
| +
|
| + // Advances the group. |time| is the current time. Returns true if the group
|
| + // is done (nothing left to animate).
|
| + bool Tick(base::TimeTicks time);
|
| +
|
| + ServerView* view() { return view_; }
|
| +
|
| + private:
|
| + ScheduledAnimationGroup(ServerView* view,
|
| + uint32_t id,
|
| + base::TimeTicks time_scheduled);
|
| +
|
| + ServerView* view_;
|
| + const uint32_t id_;
|
| + base::TimeTicks time_scheduled_;
|
| + std::vector<ScheduledAnimationSequence> sequences_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(ScheduledAnimationGroup);
|
| +};
|
| +
|
| +} // namespace view_manager
|
| +
|
| +#endif // SERVICES_VIEW_MANAGER_SCHEDULED_ANIMATION_GROUP_H_
|
|
|