WhiteRectangleDetector.smali

.class public final Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;
.super Ljava/lang/Object;


# static fields
.field private static final CORR:I = 0x1

.field private static final INIT_SIZE:I = 0xa


# instance fields
.field private final downInit:I

.field private final height:I

.field private final image:Lcom/dcloud/zxing2/common/BitMatrix;

.field private final leftInit:I

.field private final rightInit:I

.field private final upInit:I

.field private final width:I


# direct methods
.method public constructor <init>(Lcom/dcloud/zxing2/common/BitMatrix;)V
    .registers 5
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/dcloud/zxing2/NotFoundException;
        }
    .end annotation

    .line 1
    invoke-virtual {p1}, Lcom/dcloud/zxing2/common/BitMatrix;->getWidth()I

    move-result v0

    div-int/lit8 v0, v0, 0x2

    invoke-virtual {p1}, Lcom/dcloud/zxing2/common/BitMatrix;->getHeight()I

    move-result v1

    div-int/lit8 v1, v1, 0x2

    const/16 v2, 0xa

    invoke-direct {p0, p1, v2, v0, v1}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;-><init>(Lcom/dcloud/zxing2/common/BitMatrix;III)V

    return-void
.end method

.method public constructor <init>(Lcom/dcloud/zxing2/common/BitMatrix;III)V
    .registers 8
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/dcloud/zxing2/NotFoundException;
        }
    .end annotation

    .line 2
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 3
    iput-object p1, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;

    .line 4
    invoke-virtual {p1}, Lcom/dcloud/zxing2/common/BitMatrix;->getHeight()I

    move-result v0

    iput v0, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->height:I

    .line 5
    invoke-virtual {p1}, Lcom/dcloud/zxing2/common/BitMatrix;->getWidth()I

    move-result p1

    iput p1, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->width:I

    .line 6
    div-int/lit8 p2, p2, 0x2

    sub-int v1, p3, p2

    .line 7
    iput v1, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->leftInit:I

    add-int/2addr p3, p2

    .line 8
    iput p3, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->rightInit:I

    sub-int v2, p4, p2

    .line 9
    iput v2, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->upInit:I

    add-int/2addr p4, p2

    .line 10
    iput p4, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->downInit:I

    if-ltz v2, :cond_2a

    if-ltz v1, :cond_2a

    if-ge p4, v0, :cond_2a

    if-ge p3, p1, :cond_2a

    return-void

    .line 12
    :cond_2a
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object p1

    throw p1
.end method

.method private centerEdges(Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;)[Lcom/dcloud/zxing2/ResultPoint;
    .registers 16

    .line 1
    invoke-virtual {p1}, Lcom/dcloud/zxing2/ResultPoint;->getX()F

    move-result v0

    .line 2
    invoke-virtual {p1}, Lcom/dcloud/zxing2/ResultPoint;->getY()F

    move-result p1

    .line 3
    invoke-virtual {p2}, Lcom/dcloud/zxing2/ResultPoint;->getX()F

    move-result v1

    .line 4
    invoke-virtual {p2}, Lcom/dcloud/zxing2/ResultPoint;->getY()F

    move-result p2

    .line 5
    invoke-virtual {p3}, Lcom/dcloud/zxing2/ResultPoint;->getX()F

    move-result v2

    .line 6
    invoke-virtual {p3}, Lcom/dcloud/zxing2/ResultPoint;->getY()F

    move-result p3

    .line 7
    invoke-virtual {p4}, Lcom/dcloud/zxing2/ResultPoint;->getX()F

    move-result v3

    .line 8
    invoke-virtual {p4}, Lcom/dcloud/zxing2/ResultPoint;->getY()F

    move-result p4

    .line 10
    iget v4, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->width:I

    int-to-float v4, v4

    const/high16 v5, 0x40000000    # 2.0f

    div-float/2addr v4, v5

    cmpg-float v4, v0, v4

    const/4 v5, 0x3

    const/4 v6, 0x2

    const/4 v7, 0x1

    const/4 v8, 0x0

    const/4 v9, 0x4

    const/high16 v10, 0x3f800000    # 1.0f

    if-gez v4, :cond_58

    new-array v4, v9, [Lcom/dcloud/zxing2/ResultPoint;

    .line 11
    new-instance v9, Lcom/dcloud/zxing2/ResultPoint;

    sub-float/2addr v3, v10

    add-float/2addr p4, v10

    invoke-direct {v9, v3, p4}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object v9, v4, v8

    new-instance p4, Lcom/dcloud/zxing2/ResultPoint;

    add-float/2addr v1, v10

    add-float/2addr p2, v10

    invoke-direct {p4, v1, p2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p4, v4, v7

    new-instance p2, Lcom/dcloud/zxing2/ResultPoint;

    sub-float/2addr v2, v10

    sub-float/2addr p3, v10

    invoke-direct {p2, v2, p3}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p2, v4, v6

    new-instance p2, Lcom/dcloud/zxing2/ResultPoint;

    add-float/2addr v0, v10

    sub-float/2addr p1, v10

    invoke-direct {p2, v0, p1}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p2, v4, v5

    return-object v4

    :cond_58
    new-array v4, v9, [Lcom/dcloud/zxing2/ResultPoint;

    .line 17
    new-instance v9, Lcom/dcloud/zxing2/ResultPoint;

    add-float/2addr v3, v10

    add-float/2addr p4, v10

    invoke-direct {v9, v3, p4}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object v9, v4, v8

    new-instance p4, Lcom/dcloud/zxing2/ResultPoint;

    add-float/2addr v1, v10

    sub-float/2addr p2, v10

    invoke-direct {p4, v1, p2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p4, v4, v7

    new-instance p2, Lcom/dcloud/zxing2/ResultPoint;

    sub-float/2addr v2, v10

    add-float/2addr p3, v10

    invoke-direct {p2, v2, p3}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p2, v4, v6

    new-instance p2, Lcom/dcloud/zxing2/ResultPoint;

    sub-float/2addr v0, v10

    sub-float/2addr p1, v10

    invoke-direct {p2, v0, p1}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    aput-object p2, v4, v5

    return-object v4
.end method

.method private containsBlackPoint(IIIZ)Z
    .registers 6

    const/4 v0, 0x1

    if-eqz p4, :cond_11

    :goto_3
    if-gt p1, p2, :cond_1f

    .line 1
    iget-object p4, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;

    invoke-virtual {p4, p1, p3}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z

    move-result p4

    if-eqz p4, :cond_e

    return v0

    :cond_e
    add-int/lit8 p1, p1, 0x1

    goto :goto_3

    :cond_11
    :goto_11
    if-gt p1, p2, :cond_1f

    .line 7
    iget-object p4, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;

    invoke-virtual {p4, p3, p1}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z

    move-result p4

    if-eqz p4, :cond_1c

    return v0

    :cond_1c
    add-int/lit8 p1, p1, 0x1

    goto :goto_11

    :cond_1f
    const/4 p1, 0x0

    return p1
.end method

.method private getBlackPointOnSegment(FFFF)Lcom/dcloud/zxing2/ResultPoint;
    .registers 10

    .line 1
    invoke-static {p1, p2, p3, p4}, Lcom/dcloud/zxing2/common/detector/MathUtils;->distance(FFFF)F

    move-result v0

    invoke-static {v0}, Lcom/dcloud/zxing2/common/detector/MathUtils;->round(F)I

    move-result v0

    sub-float/2addr p3, p1

    int-to-float v1, v0

    div-float/2addr p3, v1

    sub-float/2addr p4, p2

    div-float/2addr p4, v1

    const/4 v1, 0x0

    :goto_e
    if-ge v1, v0, :cond_31

    int-to-float v2, v1

    mul-float v3, v2, p3

    add-float/2addr v3, p1

    .line 6
    invoke-static {v3}, Lcom/dcloud/zxing2/common/detector/MathUtils;->round(F)I

    move-result v3

    mul-float/2addr v2, p4

    add-float/2addr v2, p2

    .line 7
    invoke-static {v2}, Lcom/dcloud/zxing2/common/detector/MathUtils;->round(F)I

    move-result v2

    .line 8
    iget-object v4, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;

    invoke-virtual {v4, v3, v2}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z

    move-result v4

    if-eqz v4, :cond_2e

    .line 9
    new-instance p1, Lcom/dcloud/zxing2/ResultPoint;

    int-to-float p2, v3

    int-to-float p3, v2

    invoke-direct {p1, p2, p3}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V

    return-object p1

    :cond_2e
    add-int/lit8 v1, v1, 0x1

    goto :goto_e

    :cond_31
    const/4 p1, 0x0

    return-object p1
.end method


# virtual methods
.method public detect()[Lcom/dcloud/zxing2/ResultPoint;
    .registers 14
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/dcloud/zxing2/NotFoundException;
        }
    .end annotation

    .line 1
    iget v0, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->leftInit:I

    .line 2
    iget v1, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->rightInit:I

    .line 3
    iget v2, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->upInit:I

    .line 4
    iget v3, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->downInit:I

    const/4 v4, 0x0

    const/4 v5, 0x1

    move v7, v4

    move v8, v7

    move v9, v8

    move v10, v9

    move v11, v10

    move v6, v5

    :cond_10
    :goto_10
    if-eqz v6, :cond_8a

    move v12, v4

    move v6, v5

    :cond_14
    :goto_14
    if-nez v6, :cond_18

    if-nez v8, :cond_2c

    .line 22
    :cond_18
    iget v6, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->width:I

    if-ge v1, v6, :cond_2c

    .line 23
    invoke-direct {p0, v2, v3, v1, v4}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->containsBlackPoint(IIIZ)Z

    move-result v6

    if-eqz v6, :cond_27

    add-int/lit8 v1, v1, 0x1

    move v8, v5

    move v12, v8

    goto :goto_14

    :cond_27
    if-nez v8, :cond_14

    add-int/lit8 v1, v1, 0x1

    goto :goto_14

    .line 33
    :cond_2c
    iget v6, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->width:I

    if-lt v1, v6, :cond_32

    goto/16 :goto_84

    :cond_32
    move v6, v5

    :cond_33
    :goto_33
    if-nez v6, :cond_37

    if-nez v9, :cond_4b

    .line 42
    :cond_37
    iget v6, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->height:I

    if-ge v3, v6, :cond_4b

    .line 43
    invoke-direct {p0, v0, v1, v3, v5}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->containsBlackPoint(IIIZ)Z

    move-result v6

    if-eqz v6, :cond_46

    add-int/lit8 v3, v3, 0x1

    move v9, v5

    move v12, v9

    goto :goto_33

    :cond_46
    if-nez v9, :cond_33

    add-int/lit8 v3, v3, 0x1

    goto :goto_33

    .line 53
    :cond_4b
    iget v6, p0, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->height:I

    if-lt v3, v6, :cond_50

    goto :goto_84

    :cond_50
    move v6, v5

    :cond_51
    :goto_51
    if-nez v6, :cond_55

    if-nez v10, :cond_67

    :cond_55
    if-ltz v0, :cond_67

    .line 63
    invoke-direct {p0, v2, v3, v0, v4}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->containsBlackPoint(IIIZ)Z

    move-result v6

    if-eqz v6, :cond_62

    add-int/lit8 v0, v0, -0x1

    move v10, v5

    move v12, v10

    goto :goto_51

    :cond_62
    if-nez v10, :cond_51

    add-int/lit8 v0, v0, -0x1

    goto :goto_51

    :cond_67
    if-gez v0, :cond_6a

    goto :goto_84

    :cond_6a
    move v6, v12

    move v12, v5

    :cond_6c
    :goto_6c
    if-nez v12, :cond_70

    if-nez v11, :cond_82

    :cond_70
    if-ltz v2, :cond_82

    .line 83
    invoke-direct {p0, v0, v1, v2, v5}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->containsBlackPoint(IIIZ)Z

    move-result v12

    if-eqz v12, :cond_7d

    add-int/lit8 v2, v2, -0x1

    move v6, v5

    move v11, v6

    goto :goto_6c

    :cond_7d
    if-nez v11, :cond_6c

    add-int/lit8 v2, v2, -0x1

    goto :goto_6c

    :cond_82
    if-gez v2, :cond_86

    :goto_84
    move v4, v5

    goto :goto_8a

    :cond_86
    if-eqz v6, :cond_10

    move v7, v5

    goto :goto_10

    :cond_8a
    :goto_8a
    if-nez v4, :cond_108

    if-eqz v7, :cond_108

    sub-int v4, v1, v0

    const/4 v6, 0x0

    move v7, v5

    move-object v8, v6

    :goto_93
    if-ge v7, v4, :cond_a7

    int-to-float v8, v0

    sub-int v9, v3, v7

    int-to-float v9, v9

    add-int v10, v0, v7

    int-to-float v10, v10

    int-to-float v11, v3

    .line 110
    invoke-direct {p0, v8, v9, v10, v11}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->getBlackPointOnSegment(FFFF)Lcom/dcloud/zxing2/ResultPoint;

    move-result-object v8

    if-eqz v8, :cond_a4

    goto :goto_a7

    :cond_a4
    add-int/lit8 v7, v7, 0x1

    goto :goto_93

    :cond_a7
    :goto_a7
    if-eqz v8, :cond_103

    move v7, v5

    move-object v9, v6

    :goto_ab
    if-ge v7, v4, :cond_bf

    int-to-float v9, v0

    add-int v10, v2, v7

    int-to-float v10, v10

    add-int v11, v0, v7

    int-to-float v11, v11

    int-to-float v12, v2

    .line 123
    invoke-direct {p0, v9, v10, v11, v12}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->getBlackPointOnSegment(FFFF)Lcom/dcloud/zxing2/ResultPoint;

    move-result-object v9

    if-eqz v9, :cond_bc

    goto :goto_bf

    :cond_bc
    add-int/lit8 v7, v7, 0x1

    goto :goto_ab

    :cond_bf
    :goto_bf
    if-eqz v9, :cond_fe

    move v0, v5

    move-object v7, v6

    :goto_c3
    if-ge v0, v4, :cond_d7

    int-to-float v7, v1

    add-int v10, v2, v0

    int-to-float v10, v10

    sub-int v11, v1, v0

    int-to-float v11, v11

    int-to-float v12, v2

    .line 136
    invoke-direct {p0, v7, v10, v11, v12}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->getBlackPointOnSegment(FFFF)Lcom/dcloud/zxing2/ResultPoint;

    move-result-object v7

    if-eqz v7, :cond_d4

    goto :goto_d7

    :cond_d4
    add-int/lit8 v0, v0, 0x1

    goto :goto_c3

    :cond_d7
    :goto_d7
    if-eqz v7, :cond_f9

    :goto_d9
    if-ge v5, v4, :cond_ed

    int-to-float v0, v1

    sub-int v2, v3, v5

    int-to-float v2, v2

    sub-int v6, v1, v5

    int-to-float v6, v6

    int-to-float v10, v3

    .line 149
    invoke-direct {p0, v0, v2, v6, v10}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->getBlackPointOnSegment(FFFF)Lcom/dcloud/zxing2/ResultPoint;

    move-result-object v6

    if-eqz v6, :cond_ea

    goto :goto_ed

    :cond_ea
    add-int/lit8 v5, v5, 0x1

    goto :goto_d9

    :cond_ed
    :goto_ed
    if-eqz v6, :cond_f4

    .line 159
    invoke-direct {p0, v6, v8, v7, v9}, Lcom/dcloud/zxing2/common/detector/WhiteRectangleDetector;->centerEdges(Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;Lcom/dcloud/zxing2/ResultPoint;)[Lcom/dcloud/zxing2/ResultPoint;

    move-result-object v0

    return-object v0

    .line 160
    :cond_f4
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object v0

    throw v0

    .line 161
    :cond_f9
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object v0

    throw v0

    .line 162
    :cond_fe
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object v0

    throw v0

    .line 163
    :cond_103
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object v0

    throw v0

    .line 208
    :cond_108
    invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;

    move-result-object v0

    throw v0
.end method