PathInterpolator
public class PathInterpolator
extends BaseInterpolator
| java.lang.Object | ||
| ↳ | android.view.animation.BaseInterpolator | |
| ↳ | android.view.animation.PathInterpolator | |
An interpolator that can traverse a Path that extends from Point (0, 0) to (1, 1). The x coordinate along the Path is the input value and the output is the y coordinate of the line at that point. This means that the Path must conform to a function y = f(x).
The Path must not have gaps in the x direction and must not loop back on itself such that there can be two points sharing the same x coordinate. It is alright to have a disjoint line in the vertical direction:
Path path = new Path(); path.lineTo(0.25f, 0.25f); path.moveTo(0.25f, 0.5f); path.lineTo(1f, 1f);
Summary
Public constructors | |
|---|---|
PathInterpolator(Context context, AttributeSet attrs) | |
PathInterpolator(Path path) Create an interpolator for an arbitrary | |
PathInterpolator(float controlX, float controlY) Create an interpolator for a quadratic Bezier curve. | |
PathInterpolator(float controlX1, float controlY1, float controlX2, float controlY2) Create an interpolator for a cubic Bezier curve. | |
Public methods | |
|---|---|
float | getInterpolation(float t) Using the line in the Path in this interpolator that can be described as |
Inherited methods | |
|---|---|
Public constructors
PathInterpolator
public PathInterpolator (Context context, AttributeSet attrs)
| Parameters | |
|---|---|
context | Context |
attrs | AttributeSet |
PathInterpolator
public PathInterpolator (Path path)
Create an interpolator for an arbitrary Path. The Path must begin at (0, 0) and end at (1, 1).
| Parameters | |
|---|---|
path | Path: The Path to use to make the line representing the interpolator. This value cannot be null. |
PathInterpolator
public PathInterpolator (float controlX, float controlY)
Create an interpolator for a quadratic Bezier curve. The end points (0, 0) and (1, 1) are assumed.
| Parameters | |
|---|---|
controlX | float: The x coordinate of the quadratic Bezier control point. |
controlY | float: The y coordinate of the quadratic Bezier control point. |
PathInterpolator
public PathInterpolator (float controlX1, float controlY1, float controlX2, float controlY2)
Create an interpolator for a cubic Bezier curve. The end points (0, 0) and (1, 1) are assumed.
| Parameters | |
|---|---|
controlX1 | float: The x coordinate of the first control point of the cubic Bezier. |
controlY1 | float: The y coordinate of the first control point of the cubic Bezier. |
controlX2 | float: The x coordinate of the second control point of the cubic Bezier. |
controlY2 | float: The y coordinate of the second control point of the cubic Bezier. |
Public methods
getInterpolation
public float getInterpolation (float t)
Using the line in the Path in this interpolator that can be described as y = f(x), finds the y coordinate of the line given t as the x coordinate. Values less than 0 will always return 0 and values greater than 1 will always return 1.
| Parameters | |
|---|---|
t | float: Treated as the x coordinate along the line. |
| Returns | |
|---|---|
float | The y coordinate of the Path along the line where x = t. |
See also: