ArcMotion.smali

.class public Landroid/support/transition/ArcMotion;
.super Landroid/support/transition/PathMotion;


# static fields
.field private static final DEFAULT_MAX_ANGLE_DEGREES:F = 70.0f

.field private static final DEFAULT_MAX_TANGENT:F

.field private static final DEFAULT_MIN_ANGLE_DEGREES:F


# instance fields
.field private mMaximumAngle:F

.field private mMaximumTangent:F

.field private mMinimumHorizontalAngle:F

.field private mMinimumHorizontalTangent:F

.field private mMinimumVerticalAngle:F

.field private mMinimumVerticalTangent:F


# direct methods
.method static constructor <clinit>()V
    .registers 2

    const-wide v0, 0x4041800000000000L    # 35.0

    invoke-static {v0, v1}, Ljava/lang/Math;->toRadians(D)D

    move-result-wide v0

    invoke-static {v0, v1}, Ljava/lang/Math;->tan(D)D

    move-result-wide v0

    double-to-float v0, v0

    sput v0, Landroid/support/transition/ArcMotion;->DEFAULT_MAX_TANGENT:F

    return-void
.end method

.method public constructor <init>()V
    .registers 3

    const/4 v1, 0x0

    invoke-direct {p0}, Landroid/support/transition/PathMotion;-><init>()V

    iput v1, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalAngle:F

    iput v1, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalAngle:F

    const/high16 v0, 0x428c0000    # 70.0f

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMaximumAngle:F

    iput v1, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalTangent:F

    iput v1, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalTangent:F

    sget v0, Landroid/support/transition/ArcMotion;->DEFAULT_MAX_TANGENT:F

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMaximumTangent:F

    return-void
.end method

.method public constructor <init>(Landroid/content/Context;Landroid/util/AttributeSet;)V
    .registers 8

    const/high16 v4, 0x428c0000    # 70.0f

    const/4 v3, 0x0

    invoke-direct {p0, p1, p2}, Landroid/support/transition/PathMotion;-><init>(Landroid/content/Context;Landroid/util/AttributeSet;)V

    iput v3, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalAngle:F

    iput v3, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalAngle:F

    iput v4, p0, Landroid/support/transition/ArcMotion;->mMaximumAngle:F

    iput v3, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalTangent:F

    iput v3, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalTangent:F

    sget v0, Landroid/support/transition/ArcMotion;->DEFAULT_MAX_TANGENT:F

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMaximumTangent:F

    sget-object v0, Landroid/support/transition/Styleable;->ARC_MOTION:[I

    invoke-virtual {p1, p2, v0}, Landroid/content/Context;->obtainStyledAttributes(Landroid/util/AttributeSet;[I)Landroid/content/res/TypedArray;

    move-result-object v0

    check-cast p2, Lorg/xmlpull/v1/XmlPullParser;

    const-string/jumbo v1, "minimumVerticalAngle"

    const/4 v2, 0x1

    invoke-static {v0, p2, v1, v2, v3}, Landroid/support/v4/content/res/TypedArrayUtils;->getNamedFloat(Landroid/content/res/TypedArray;Lorg/xmlpull/v1/XmlPullParser;Ljava/lang/String;IF)F

    move-result v1

    invoke-virtual {p0, v1}, Landroid/support/transition/ArcMotion;->setMinimumVerticalAngle(F)V

    const-string/jumbo v1, "minimumHorizontalAngle"

    const/4 v2, 0x0

    invoke-static {v0, p2, v1, v2, v3}, Landroid/support/v4/content/res/TypedArrayUtils;->getNamedFloat(Landroid/content/res/TypedArray;Lorg/xmlpull/v1/XmlPullParser;Ljava/lang/String;IF)F

    move-result v1

    invoke-virtual {p0, v1}, Landroid/support/transition/ArcMotion;->setMinimumHorizontalAngle(F)V

    const-string/jumbo v1, "maximumAngle"

    const/4 v2, 0x2

    invoke-static {v0, p2, v1, v2, v4}, Landroid/support/v4/content/res/TypedArrayUtils;->getNamedFloat(Landroid/content/res/TypedArray;Lorg/xmlpull/v1/XmlPullParser;Ljava/lang/String;IF)F

    move-result v1

    invoke-virtual {p0, v1}, Landroid/support/transition/ArcMotion;->setMaximumAngle(F)V

    invoke-virtual {v0}, Landroid/content/res/TypedArray;->recycle()V

    return-void
.end method

.method private static toTangent(F)F
    .registers 3

    const/4 v0, 0x0

    cmpg-float v0, p0, v0

    if-ltz v0, :cond_b

    const/high16 v0, 0x42b40000    # 90.0f

    cmpl-float v0, p0, v0

    if-lez v0, :cond_14

    :cond_b
    new-instance v0, Ljava/lang/IllegalArgumentException;

    const-string/jumbo v1, "Arc must be between 0 and 90 degrees"

    invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    throw v0

    :cond_14
    const/high16 v0, 0x40000000    # 2.0f

    div-float v0, p0, v0

    float-to-double v0, v0

    invoke-static {v0, v1}, Ljava/lang/Math;->toRadians(D)D

    move-result-wide v0

    invoke-static {v0, v1}, Ljava/lang/Math;->tan(D)D

    move-result-wide v0

    double-to-float v0, v0

    return v0
.end method


# virtual methods
.method public getMaximumAngle()F
    .registers 2

    iget v0, p0, Landroid/support/transition/ArcMotion;->mMaximumAngle:F

    return v0
.end method

.method public getMinimumHorizontalAngle()F
    .registers 2

    iget v0, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalAngle:F

    return v0
.end method

.method public getMinimumVerticalAngle()F
    .registers 2

    iget v0, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalAngle:F

    return v0
.end method

.method public getPath(FFFF)Landroid/graphics/Path;
    .registers 16

    new-instance v0, Landroid/graphics/Path;

    invoke-direct {v0}, Landroid/graphics/Path;-><init>()V

    invoke-virtual {v0, p1, p2}, Landroid/graphics/Path;->moveTo(FF)V

    sub-float v2, p3, p1

    sub-float v3, p4, p2

    mul-float v1, v2, v2

    mul-float v4, v3, v3

    add-float/2addr v4, v1

    add-float v1, p1, p3

    const/high16 v5, 0x40000000    # 2.0f

    div-float v6, v1, v5

    add-float v1, p2, p4

    const/high16 v5, 0x40000000    # 2.0f

    div-float v7, v1, v5

    const/high16 v1, 0x3e800000    # 0.25f

    mul-float v5, v4, v1

    cmpl-float v1, p2, p4

    if-lez v1, :cond_88

    const/4 v1, 0x1

    :goto_26
    invoke-static {v2}, Ljava/lang/Math;->abs(F)F

    move-result v8

    invoke-static {v3}, Ljava/lang/Math;->abs(F)F

    move-result v9

    cmpg-float v8, v8, v9

    if-gez v8, :cond_8e

    const/high16 v2, 0x40000000    # 2.0f

    mul-float/2addr v2, v3

    div-float v2, v4, v2

    invoke-static {v2}, Ljava/lang/Math;->abs(F)F

    move-result v2

    if-eqz v1, :cond_8a

    add-float v1, p4, v2

    move v2, p3

    :goto_40
    iget v3, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalTangent:F

    mul-float/2addr v3, v5

    iget v4, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalTangent:F

    mul-float/2addr v3, v4

    move v10, v3

    move v3, v2

    move v2, v1

    move v1, v10

    :goto_4a
    sub-float v4, v6, v3

    sub-float v8, v7, v2

    mul-float/2addr v4, v4

    mul-float/2addr v8, v8

    add-float/2addr v8, v4

    iget v4, p0, Landroid/support/transition/ArcMotion;->mMaximumTangent:F

    mul-float/2addr v4, v5

    iget v5, p0, Landroid/support/transition/ArcMotion;->mMaximumTangent:F

    mul-float/2addr v4, v5

    const/4 v5, 0x0

    cmpg-float v9, v8, v1

    if-gez v9, :cond_a9

    :goto_5c
    const/4 v4, 0x0

    cmpl-float v4, v1, v4

    if-eqz v4, :cond_af

    div-float/2addr v1, v8

    float-to-double v4, v1

    invoke-static {v4, v5}, Ljava/lang/Math;->sqrt(D)D

    move-result-wide v4

    double-to-float v1, v4

    sub-float/2addr v3, v6

    mul-float/2addr v3, v1

    add-float/2addr v3, v6

    sub-float/2addr v2, v7

    mul-float/2addr v1, v2

    add-float v2, v7, v1

    move v4, v2

    :goto_70
    add-float v1, p1, v3

    const/high16 v2, 0x40000000    # 2.0f

    div-float/2addr v1, v2

    add-float v2, p2, v4

    const/high16 v5, 0x40000000    # 2.0f

    div-float/2addr v2, v5

    add-float/2addr v3, p3

    const/high16 v5, 0x40000000    # 2.0f

    div-float/2addr v3, v5

    add-float/2addr v4, p4

    const/high16 v5, 0x40000000    # 2.0f

    div-float/2addr v4, v5

    move v5, p3

    move v6, p4

    invoke-virtual/range {v0 .. v6}, Landroid/graphics/Path;->cubicTo(FFFFFF)V

    return-object v0

    :cond_88
    const/4 v1, 0x0

    goto :goto_26

    :cond_8a
    add-float v1, p2, v2

    move v2, p1

    goto :goto_40

    :cond_8e
    const/high16 v3, 0x40000000    # 2.0f

    mul-float/2addr v2, v3

    div-float v2, v4, v2

    if-eqz v1, :cond_a4

    add-float v1, p1, v2

    move v2, v1

    move v1, p2

    :goto_99
    iget v3, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalTangent:F

    mul-float/2addr v3, v5

    iget v4, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalTangent:F

    mul-float/2addr v3, v4

    move v10, v3

    move v3, v2

    move v2, v1

    move v1, v10

    goto :goto_4a

    :cond_a4
    sub-float v1, p3, v2

    move v2, v1

    move v1, p4

    goto :goto_99

    :cond_a9
    cmpl-float v1, v8, v4

    if-lez v1, :cond_b1

    move v1, v4

    goto :goto_5c

    :cond_af
    move v4, v2

    goto :goto_70

    :cond_b1
    move v1, v5

    goto :goto_5c
.end method

.method public setMaximumAngle(F)V
    .registers 3

    iput p1, p0, Landroid/support/transition/ArcMotion;->mMaximumAngle:F

    invoke-static {p1}, Landroid/support/transition/ArcMotion;->toTangent(F)F

    move-result v0

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMaximumTangent:F

    return-void
.end method

.method public setMinimumHorizontalAngle(F)V
    .registers 3

    iput p1, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalAngle:F

    invoke-static {p1}, Landroid/support/transition/ArcMotion;->toTangent(F)F

    move-result v0

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMinimumHorizontalTangent:F

    return-void
.end method

.method public setMinimumVerticalAngle(F)V
    .registers 3

    iput p1, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalAngle:F

    invoke-static {p1}, Landroid/support/transition/ArcMotion;->toTangent(F)F

    move-result v0

    iput v0, p0, Landroid/support/transition/ArcMotion;->mMinimumVerticalTangent:F

    return-void
.end method