MonochromeRectangleDetector.smali
.class public final Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;
.super Ljava/lang/Object;
# static fields
.field private static final MAX_MODULES:I = 0x20
# instance fields
.field private final image:Lcom/dcloud/zxing2/common/BitMatrix;
# direct methods
.method public constructor <init>(Lcom/dcloud/zxing2/common/BitMatrix;)V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
iput-object p1, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
return-void
.end method
.method private blackWhiteRange(IIIIZ)[I
.registers 11
add-int v0, p3, p4
const/4 v1, 0x2
.line 1
div-int/2addr v0, v1
move v2, v0
:goto_5
if-lt v2, p3, :cond_3e
if-eqz p5, :cond_12
.line 6
iget-object v3, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v3, v2, p1}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v3
if-eqz v3, :cond_1d
goto :goto_1a
:cond_12
iget-object v3, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v3, p1, v2}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v3
if-eqz v3, :cond_1d
:goto_1a
add-int/lit8 v2, v2, -0x1
goto :goto_5
:cond_1d
move v3, v2
:cond_1e
add-int/lit8 v3, v3, -0x1
if-lt v3, p3, :cond_35
if-eqz p5, :cond_2d
.line 12
iget-object v4, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v4, v3, p1}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v4
if-eqz v4, :cond_1e
goto :goto_35
:cond_2d
iget-object v4, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
.line 13
invoke-virtual {v4, p1, v3}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v4
if-eqz v4, :cond_1e
:cond_35
:goto_35
sub-int v4, v2, v3
if-lt v3, p3, :cond_3e
if-le v4, p2, :cond_3c
goto :goto_3e
:cond_3c
move v2, v3
goto :goto_5
:cond_3e
:goto_3e
const/4 p3, 0x1
add-int/2addr v2, p3
:goto_40
if-ge v0, p4, :cond_78
if-eqz p5, :cond_4d
.line 26
iget-object v3, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v3, v0, p1}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v3
if-eqz v3, :cond_58
goto :goto_55
:cond_4d
iget-object v3, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v3, p1, v0}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v3
if-eqz v3, :cond_58
:goto_55
add-int/lit8 v0, v0, 0x1
goto :goto_40
:cond_58
move v3, v0
:cond_59
add-int/2addr v3, p3
if-ge v3, p4, :cond_6f
if-eqz p5, :cond_67
.line 32
iget-object v4, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v4, v3, p1}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v4
if-eqz v4, :cond_59
goto :goto_6f
:cond_67
iget-object v4, p0, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
.line 33
invoke-virtual {v4, p1, v3}, Lcom/dcloud/zxing2/common/BitMatrix;->get(II)Z
move-result v4
if-eqz v4, :cond_59
:cond_6f
:goto_6f
sub-int v4, v3, v0
if-ge v3, p4, :cond_78
if-le v4, p2, :cond_76
goto :goto_78
:cond_76
move v0, v3
goto :goto_40
:cond_78
:goto_78
add-int/lit8 v0, v0, -0x1
if-le v0, v2, :cond_84
new-array p1, v1, [I
const/4 p2, 0x0
aput v2, p1, p2
aput v0, p1, p3
goto :goto_85
:cond_84
const/4 p1, 0x0
:goto_85
return-object p1
.end method
.method private findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
.registers 25
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/dcloud/zxing2/NotFoundException;
}
.end annotation
move/from16 v0, p1
move/from16 v1, p5
const/4 v2, 0x0
move/from16 v9, p8
move v11, v0
move v10, v1
:goto_9
if-ge v10, v9, :cond_a2
move/from16 v12, p7
if-lt v10, v12, :cond_a2
move/from16 v13, p4
if-ge v11, v13, :cond_a2
move/from16 v14, p3
if-lt v11, v14, :cond_a2
if-nez p2, :cond_27
const/4 v8, 0x1
move-object v3, p0
move v4, v10
move/from16 v5, p9
move/from16 v6, p3
move/from16 v7, p4
.line 1
invoke-direct/range {v3 .. v8}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->blackWhiteRange(IIIIZ)[I
move-result-object v3
goto :goto_34
:cond_27
const/4 v8, 0x0
move-object v3, p0
move v4, v11
move/from16 v5, p9
move/from16 v6, p7
move/from16 v7, p8
.line 4
invoke-direct/range {v3 .. v8}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->blackWhiteRange(IIIIZ)[I
move-result-object v3
:goto_34
if-nez v3, :cond_9b
if-eqz v2, :cond_96
const/4 v3, 0x1
const/4 v4, 0x0
if-nez p2, :cond_69
sub-int v10, v10, p6
.line 13
aget v1, v2, v4
if-ge v1, v0, :cond_5f
.line 14
aget v1, v2, v3
if-le v1, v0, :cond_55
.line 16
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
if-lez p6, :cond_4d
aget v1, v2, v4
goto :goto_4f
:cond_4d
aget v1, v2, v3
:goto_4f
int-to-float v1, v1
int-to-float v2, v10
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
.line 18
:cond_55
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
aget v1, v2, v4
int-to-float v1, v1
int-to-float v2, v10
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
.line 20
:cond_5f
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
aget v1, v2, v3
int-to-float v1, v1
int-to-float v2, v10
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
:cond_69
sub-int v11, v11, p2
.line 24
aget v0, v2, v4
if-ge v0, v1, :cond_8c
.line 25
aget v0, v2, v3
if-le v0, v1, :cond_82
.line 26
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
int-to-float v1, v11
if-gez p2, :cond_7b
aget v2, v2, v4
goto :goto_7d
:cond_7b
aget v2, v2, v3
:goto_7d
int-to-float v2, v2
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
.line 28
:cond_82
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
int-to-float v1, v11
aget v2, v2, v4
int-to-float v2, v2
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
.line 30
:cond_8c
new-instance v0, Lcom/dcloud/zxing2/ResultPoint;
int-to-float v1, v11
aget v2, v2, v3
int-to-float v2, v2
invoke-direct {v0, v1, v2}, Lcom/dcloud/zxing2/ResultPoint;-><init>(FF)V
return-object v0
.line 31
:cond_96
invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;
move-result-object v0
throw v0
:cond_9b
add-int v10, v10, p6
add-int v11, v11, p2
move-object v2, v3
goto/16 :goto_9
.line 59
:cond_a2
invoke-static {}, Lcom/dcloud/zxing2/NotFoundException;->getNotFoundInstance()Lcom/dcloud/zxing2/NotFoundException;
move-result-object v0
throw v0
.end method
# virtual methods
.method public detect()[Lcom/dcloud/zxing2/ResultPoint;
.registers 25
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/dcloud/zxing2/NotFoundException;
}
.end annotation
move-object/from16 v10, p0
.line 1
iget-object v0, v10, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v0}, Lcom/dcloud/zxing2/common/BitMatrix;->getHeight()I
move-result v11
.line 2
iget-object v0, v10, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->image:Lcom/dcloud/zxing2/common/BitMatrix;
invoke-virtual {v0}, Lcom/dcloud/zxing2/common/BitMatrix;->getWidth()I
move-result v12
.line 3
div-int/lit8 v13, v11, 0x2
.line 4
div-int/lit8 v14, v12, 0x2
.line 5
div-int/lit16 v0, v11, 0x100
const/4 v15, 0x1
invoke-static {v15, v0}, Ljava/lang/Math;->max(II)I
move-result v9
.line 6
div-int/lit16 v0, v12, 0x100
invoke-static {v15, v0}, Ljava/lang/Math;->max(II)I
move-result v8
neg-int v7, v9
.line 12
div-int/lit8 v16, v14, 0x2
const/4 v2, 0x0
const/4 v3, 0x0
const/16 v17, 0x0
move-object/from16 v0, p0
move v1, v14
move v4, v12
move v5, v13
move v6, v7
move/from16 v18, v7
move/from16 v7, v17
move/from16 v19, v8
move v8, v11
move/from16 v17, v9
move/from16 v9, v16
invoke-direct/range {v0 .. v9}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
move-result-object v0
.line 14
invoke-virtual {v0}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
move-result v0
float-to-int v0, v0
add-int/lit8 v20, v0, -0x1
move/from16 v9, v19
neg-int v2, v9
.line 15
div-int/lit8 v19, v13, 0x2
const/4 v6, 0x0
move-object/from16 v0, p0
move/from16 v7, v20
move/from16 v21, v9
move/from16 v9, v19
invoke-direct/range {v0 .. v9}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
move-result-object v22
.line 17
invoke-virtual/range {v22 .. v22}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
move-result v0
float-to-int v0, v0
add-int/lit8 v23, v0, -0x1
move-object/from16 v0, p0
move/from16 v2, v21
move/from16 v3, v23
.line 18
invoke-direct/range {v0 .. v9}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
move-result-object v12
.line 20
invoke-virtual {v12}, Lcom/dcloud/zxing2/ResultPoint;->getX()F
move-result v0
float-to-int v0, v0
add-int/lit8 v19, v0, 0x1
const/4 v2, 0x0
move-object/from16 v0, p0
move/from16 v4, v19
move/from16 v6, v17
move/from16 v9, v16
.line 21
invoke-direct/range {v0 .. v9}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
move-result-object v11
.line 23
invoke-virtual {v11}, Lcom/dcloud/zxing2/ResultPoint;->getY()F
move-result v0
float-to-int v0, v0
add-int/lit8 v8, v0, 0x1
.line 26
div-int/lit8 v9, v14, 0x4
move-object/from16 v0, p0
move/from16 v6, v18
invoke-direct/range {v0 .. v9}, Lcom/dcloud/zxing2/common/detector/MonochromeRectangleDetector;->findCornerFromCenter(IIIIIIIII)Lcom/dcloud/zxing2/ResultPoint;
move-result-object v0
const/4 v1, 0x4
new-array v1, v1, [Lcom/dcloud/zxing2/ResultPoint;
aput-object v0, v1, v2
aput-object v22, v1, v15
const/4 v0, 0x2
aput-object v12, v1, v0
const/4 v0, 0x3
aput-object v11, v1, v0
return-object v1
.end method