/*
* 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);
}