/*
|
* Copyright (C) 2013 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 android.animation;
|
|
/**
|
* Abstract base class used convert type T to another type V. This
|
* is necessary when the value types of in animation are different
|
* from the property type.
|
* @see PropertyValuesHolder#setConverter(TypeConverter)
|
*/
|
public abstract class TypeConverter<T, V> {
|
private Class<T> mFromClass;
|
private Class<V> mToClass;
|
|
public TypeConverter(Class<T> fromClass, Class<V> toClass) {
|
mFromClass = fromClass;
|
mToClass = toClass;
|
}
|
|
/**
|
* Returns the target converted type. Used by the animation system to determine
|
* the proper setter function to call.
|
* @return The Class to convert the input to.
|
*/
|
Class<V> getTargetType() {
|
return mToClass;
|
}
|
|
/**
|
* Returns the source conversion type.
|
*/
|
Class<T> getSourceType() {
|
return mFromClass;
|
}
|
|
/**
|
* Converts a value from one type to another.
|
* @param value The Object to convert.
|
* @return A value of type V, converted from <code>value</code>.
|
*/
|
public abstract V convert(T value);
|
}
|