mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
347 lines
15 KiB
Java
Executable File
347 lines
15 KiB
Java
Executable File
/*
|
|
* Copyright (C) 2011 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.nineoldandroids.view;
|
|
|
|
import java.util.WeakHashMap;
|
|
import android.os.Build;
|
|
import android.view.View;
|
|
import android.view.animation.Interpolator;
|
|
import com.nineoldandroids.animation.Animator;
|
|
|
|
/**
|
|
* This class enables automatic and optimized animation of select properties on View objects.
|
|
* If only one or two properties on a View object are being animated, then using an
|
|
* {@link android.animation.ObjectAnimator} is fine; the property setters called by ObjectAnimator
|
|
* are well equipped to do the right thing to set the property and invalidate the view
|
|
* appropriately. But if several properties are animated simultaneously, or if you just want a
|
|
* more convenient syntax to animate a specific property, then ViewPropertyAnimator might be
|
|
* more well-suited to the task.
|
|
*
|
|
* <p>This class may provide better performance for several simultaneous animations, because
|
|
* it will optimize invalidate calls to take place only once for several properties instead of each
|
|
* animated property independently causing its own invalidation. Also, the syntax of using this
|
|
* class could be easier to use because the caller need only tell the View object which
|
|
* property to animate, and the value to animate either to or by, and this class handles the
|
|
* details of configuring the underlying Animator class and starting it.</p>
|
|
*
|
|
* <p>This class is not constructed by the caller, but rather by the View whose properties
|
|
* it will animate. Calls to {@link android.view.View#animate()} will return a reference
|
|
* to the appropriate ViewPropertyAnimator object for that View.</p>
|
|
*
|
|
*/
|
|
public abstract class ViewPropertyAnimator {
|
|
private static final WeakHashMap<View, ViewPropertyAnimator> ANIMATORS =
|
|
new WeakHashMap<View, ViewPropertyAnimator>(0);
|
|
|
|
/**
|
|
* This method returns a ViewPropertyAnimator object, which can be used to animate specific
|
|
* properties on this View.
|
|
*
|
|
* @param view View to animate.
|
|
* @return The ViewPropertyAnimator associated with this View.
|
|
*/
|
|
public static ViewPropertyAnimator animate(View view) {
|
|
ViewPropertyAnimator animator = ANIMATORS.get(view);
|
|
if (animator == null) {
|
|
final int version = Integer.valueOf(Build.VERSION.SDK);
|
|
if (version >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
|
|
animator = new ViewPropertyAnimatorICS(view);
|
|
} else if (version >= Build.VERSION_CODES.HONEYCOMB) {
|
|
animator = new ViewPropertyAnimatorHC(view);
|
|
} else {
|
|
animator = new ViewPropertyAnimatorPreHC(view);
|
|
}
|
|
ANIMATORS.put(view, animator);
|
|
}
|
|
return animator;
|
|
}
|
|
|
|
|
|
/**
|
|
* Sets the duration for the underlying animator that animates the requested properties.
|
|
* By default, the animator uses the default value for ValueAnimator. Calling this method
|
|
* will cause the declared value to be used instead.
|
|
* @param duration The length of ensuing property animations, in milliseconds. The value
|
|
* cannot be negative.
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator setDuration(long duration);
|
|
|
|
/**
|
|
* Returns the current duration of property animations. If the duration was set on this
|
|
* object, that value is returned. Otherwise, the default value of the underlying Animator
|
|
* is returned.
|
|
*
|
|
* @see #setDuration(long)
|
|
* @return The duration of animations, in milliseconds.
|
|
*/
|
|
public abstract long getDuration();
|
|
|
|
/**
|
|
* Returns the current startDelay of property animations. If the startDelay was set on this
|
|
* object, that value is returned. Otherwise, the default value of the underlying Animator
|
|
* is returned.
|
|
*
|
|
* @see #setStartDelay(long)
|
|
* @return The startDelay of animations, in milliseconds.
|
|
*/
|
|
public abstract long getStartDelay();
|
|
|
|
/**
|
|
* Sets the startDelay for the underlying animator that animates the requested properties.
|
|
* By default, the animator uses the default value for ValueAnimator. Calling this method
|
|
* will cause the declared value to be used instead.
|
|
* @param startDelay The delay of ensuing property animations, in milliseconds. The value
|
|
* cannot be negative.
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator setStartDelay(long startDelay);
|
|
|
|
/**
|
|
* Sets the interpolator for the underlying animator that animates the requested properties.
|
|
* By default, the animator uses the default interpolator for ValueAnimator. Calling this method
|
|
* will cause the declared object to be used instead.
|
|
*
|
|
* @param interpolator The TimeInterpolator to be used for ensuing property animations.
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator setInterpolator(/*Time*/Interpolator interpolator);
|
|
|
|
/**
|
|
* Sets a listener for events in the underlying Animators that run the property
|
|
* animations.
|
|
*
|
|
* @param listener The listener to be called with AnimatorListener events.
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator setListener(Animator.AnimatorListener listener);
|
|
|
|
/**
|
|
* Starts the currently pending property animations immediately. Calling <code>start()</code>
|
|
* is optional because all animations start automatically at the next opportunity. However,
|
|
* if the animations are needed to start immediately and synchronously (not at the time when
|
|
* the next event is processed by the hierarchy, which is when the animations would begin
|
|
* otherwise), then this method can be used.
|
|
*/
|
|
public abstract void start();
|
|
|
|
/**
|
|
* Cancels all property animations that are currently running or pending.
|
|
*/
|
|
public abstract void cancel();
|
|
|
|
/**
|
|
* This method will cause the View's <code>x</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator x(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>x</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator xBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>y</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator y(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>y</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator yBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotation</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setRotation(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotation(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotation</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setRotation(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotationBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotationX</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setRotationX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotationX(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotationX</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setRotationX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotationXBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotationY</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setRotationY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotationY(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>rotationY</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setRotationY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator rotationYBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>translationX</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setTranslationX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator translationX(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>translationX</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setTranslationX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator translationXBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>translationY</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setTranslationY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator translationY(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>translationY</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setTranslationY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator translationYBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>scaleX</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setScaleX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator scaleX(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>scaleX</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setScaleX(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator scaleXBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>scaleY</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setScaleY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator scaleY(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>scaleY</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setScaleY(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator scaleYBy(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>alpha</code> property to be animated to the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The value to be animated to.
|
|
* @see View#setAlpha(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator alpha(float value);
|
|
|
|
/**
|
|
* This method will cause the View's <code>alpha</code> property to be animated by the
|
|
* specified value. Animations already running on the property will be canceled.
|
|
*
|
|
* @param value The amount to be animated by, as an offset from the current value.
|
|
* @see View#setAlpha(float)
|
|
* @return This object, allowing calls to methods in this class to be chained.
|
|
*/
|
|
public abstract ViewPropertyAnimator alphaBy(float value);
|
|
}
|