Detector.smali
.class public final Lcom/google/zxing/datamatrix/detector/Detector;
.super Ljava/lang/Object;
.source "Detector.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitionsComparator;,
Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
}
.end annotation
# instance fields
.field private final image:Lcom/google/zxing/common/BitMatrix;
.field private final rectangleDetector:Lcom/google/zxing/common/detector/WhiteRectangleDetector;
# direct methods
.method public constructor <init>(Lcom/google/zxing/common/BitMatrix;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/zxing/NotFoundException;
}
.end annotation
.line 46
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 47
iput-object p1, p0, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
.line 48
new-instance v0, Lcom/google/zxing/common/detector/WhiteRectangleDetector;
invoke-direct {v0, p1}, Lcom/google/zxing/common/detector/WhiteRectangleDetector;-><init>(Lcom/google/zxing/common/BitMatrix;)V
iput-object v0, p0, Lcom/google/zxing/datamatrix/detector/Detector;->rectangleDetector:Lcom/google/zxing/common/detector/WhiteRectangleDetector;
return-void
.end method
.method private correctTopRight(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;I)Lcom/google/zxing/ResultPoint;
.registers 11
.line 273
invoke-static {p1, p2}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result v0
int-to-float v0, v0
int-to-float p5, p5
div-float/2addr v0, p5
.line 274
invoke-static {p3, p4}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result v1
.line 275
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v2
invoke-virtual {p3}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v3
sub-float/2addr v2, v3
int-to-float v1, v1
div-float/2addr v2, v1
.line 276
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v3
invoke-virtual {p3}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v4
sub-float/2addr v3, v4
div-float/2addr v3, v1
.line 278
new-instance v1, Lcom/google/zxing/ResultPoint;
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v4
mul-float v2, v2, v0
add-float/2addr v4, v2
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v2
mul-float v0, v0, v3
add-float/2addr v2, v0
invoke-direct {v1, v4, v2}, Lcom/google/zxing/ResultPoint;-><init>(FF)V
.line 280
invoke-static {p1, p3}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result p1
int-to-float p1, p1
div-float/2addr p1, p5
.line 281
invoke-static {p2, p4}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result p5
.line 282
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v0
invoke-virtual {p2}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v2
sub-float/2addr v0, v2
int-to-float p5, p5
div-float/2addr v0, p5
.line 283
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v2
invoke-virtual {p2}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v3
sub-float/2addr v2, v3
div-float/2addr v2, p5
.line 285
new-instance p5, Lcom/google/zxing/ResultPoint;
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v3
mul-float v0, v0, p1
add-float/2addr v3, v0
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result p4
mul-float p1, p1, v2
add-float/2addr p4, p1
invoke-direct {p5, v3, p4}, Lcom/google/zxing/ResultPoint;-><init>(FF)V
.line 287
invoke-direct {p0, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-nez p1, :cond_74
.line 288
invoke-direct {p0, p5}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-eqz p1, :cond_72
return-object p5
:cond_72
const/4 p1, 0x0
return-object p1
.line 293
:cond_74
invoke-direct {p0, p5}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-nez p1, :cond_7b
return-object v1
.line 297
:cond_7b
invoke-direct {p0, p3, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p1
invoke-virtual {p1}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p1
.line 298
invoke-direct {p0, p2, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p4
invoke-virtual {p4}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p4
sub-int/2addr p1, p4
.line 297
invoke-static {p1}, Ljava/lang/Math;->abs(I)I
move-result p1
.line 299
invoke-direct {p0, p3, p5}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p3
invoke-virtual {p3}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p3
.line 300
invoke-direct {p0, p2, p5}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p2
invoke-virtual {p2}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p2
sub-int/2addr p3, p2
.line 299
invoke-static {p3}, Ljava/lang/Math;->abs(I)I
move-result p2
if-gt p1, p2, :cond_a8
return-object v1
:cond_a8
return-object p5
.end method
.method private correctTopRightRectangular(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;II)Lcom/google/zxing/ResultPoint;
.registers 12
.line 227
invoke-static {p1, p2}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result v0
int-to-float v0, v0
int-to-float v1, p5
div-float/2addr v0, v1
.line 228
invoke-static {p3, p4}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result v1
.line 229
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v2
invoke-virtual {p3}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v3
sub-float/2addr v2, v3
int-to-float v1, v1
div-float/2addr v2, v1
.line 230
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v3
invoke-virtual {p3}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v4
sub-float/2addr v3, v4
div-float/2addr v3, v1
.line 232
new-instance v1, Lcom/google/zxing/ResultPoint;
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v4
mul-float v2, v2, v0
add-float/2addr v4, v2
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v2
mul-float v0, v0, v3
add-float/2addr v2, v0
invoke-direct {v1, v4, v2}, Lcom/google/zxing/ResultPoint;-><init>(FF)V
.line 234
invoke-static {p1, p3}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result p1
int-to-float p1, p1
int-to-float v0, p6
div-float/2addr p1, v0
.line 235
invoke-static {p2, p4}, Lcom/google/zxing/datamatrix/detector/Detector;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
move-result v0
.line 236
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v2
invoke-virtual {p2}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v3
sub-float/2addr v2, v3
int-to-float v0, v0
div-float/2addr v2, v0
.line 237
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v3
invoke-virtual {p2}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v4
sub-float/2addr v3, v4
div-float/2addr v3, v0
.line 239
new-instance v0, Lcom/google/zxing/ResultPoint;
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v4
mul-float v2, v2, p1
add-float/2addr v4, v2
invoke-virtual {p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result p4
mul-float p1, p1, v3
add-float/2addr p4, p1
invoke-direct {v0, v4, p4}, Lcom/google/zxing/ResultPoint;-><init>(FF)V
.line 241
invoke-direct {p0, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-nez p1, :cond_75
.line 242
invoke-direct {p0, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-eqz p1, :cond_73
return-object v0
:cond_73
const/4 p1, 0x0
return-object p1
.line 247
:cond_75
invoke-direct {p0, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->isValid(Lcom/google/zxing/ResultPoint;)Z
move-result p1
if-nez p1, :cond_7c
return-object v1
.line 251
:cond_7c
invoke-direct {p0, p3, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p1
invoke-virtual {p1}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p1
sub-int p1, p5, p1
invoke-static {p1}, Ljava/lang/Math;->abs(I)I
move-result p1
.line 252
invoke-direct {p0, p2, v1}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p4
invoke-virtual {p4}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p4
sub-int p4, p6, p4
invoke-static {p4}, Ljava/lang/Math;->abs(I)I
move-result p4
add-int/2addr p1, p4
.line 253
invoke-direct {p0, p3, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p3
invoke-virtual {p3}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p3
sub-int/2addr p5, p3
invoke-static {p5}, Ljava/lang/Math;->abs(I)I
move-result p3
.line 254
invoke-direct {p0, p2, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object p2
invoke-virtual {p2}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result p2
sub-int/2addr p6, p2
invoke-static {p6}, Ljava/lang/Math;->abs(I)I
move-result p2
add-int/2addr p3, p2
if-gt p1, p3, :cond_b7
return-object v1
:cond_b7
return-object v0
.end method
.method private static distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)I
.registers 2
.line 310
invoke-static {p0, p1}, Lcom/google/zxing/ResultPoint;->distance(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)F
move-result p0
invoke-static {p0}, Lcom/google/zxing/common/detector/MathUtils;->round(F)I
move-result p0
return p0
.end method
.method private static increment(Ljava/util/Map;Lcom/google/zxing/ResultPoint;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Map<",
"Lcom/google/zxing/ResultPoint;",
"Ljava/lang/Integer;",
">;",
"Lcom/google/zxing/ResultPoint;",
")V"
}
.end annotation
.line 317
invoke-interface {p0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Integer;
const/4 v1, 0x1
if-nez v0, :cond_a
goto :goto_f
.line 318
:cond_a
invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I
move-result v0
add-int/2addr v1, v0
:goto_f
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
invoke-interface {p0, p1, v0}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-void
.end method
.method private isValid(Lcom/google/zxing/ResultPoint;)Z
.registers 5
.line 306
invoke-virtual {p1}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v0
const/4 v1, 0x0
cmpl-float v0, v0, v1
if-ltz v0, :cond_31
invoke-virtual {p1}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v0
iget-object v2, p0, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
invoke-virtual {v2}, Lcom/google/zxing/common/BitMatrix;->getWidth()I
move-result v2
int-to-float v2, v2
cmpg-float v0, v0, v2
if-gez v0, :cond_31
invoke-virtual {p1}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v0
cmpl-float v0, v0, v1
if-lez v0, :cond_31
invoke-virtual {p1}, Lcom/google/zxing/ResultPoint;->getY()F
move-result p1
iget-object v0, p0, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
invoke-virtual {v0}, Lcom/google/zxing/common/BitMatrix;->getHeight()I
move-result v0
int-to-float v0, v0
cmpg-float p1, p1, v0
if-gez p1, :cond_31
const/4 p1, 0x1
return p1
:cond_31
const/4 p1, 0x0
return p1
.end method
.method private static sampleGrid(Lcom/google/zxing/common/BitMatrix;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;II)Lcom/google/zxing/common/BitMatrix;
.registers 27
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/zxing/NotFoundException;
}
.end annotation
move-object/from16 v1, p0
move/from16 v2, p5
move/from16 v3, p6
.line 329
invoke-static {}, Lcom/google/zxing/common/GridSampler;->getInstance()Lcom/google/zxing/common/GridSampler;
move-result-object v0
move/from16 v4, p5
int-to-float v4, v4
const/high16 v5, 0x3f000000 # 0.5f
sub-float v6, v4, v5
move v8, v6
move/from16 v4, p6
int-to-float v4, v4
sub-float v11, v4, v5
move v9, v11
.line 342
invoke-virtual/range {p1 .. p1}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v12
.line 343
invoke-virtual/range {p1 .. p1}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v13
.line 344
invoke-virtual/range {p4 .. p4}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v14
.line 345
invoke-virtual/range {p4 .. p4}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v15
.line 346
invoke-virtual/range {p3 .. p3}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v16
.line 347
invoke-virtual/range {p3 .. p3}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v17
.line 348
invoke-virtual/range {p2 .. p2}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v18
.line 349
invoke-virtual/range {p2 .. p2}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v19
const/high16 v4, 0x3f000000 # 0.5f
const/high16 v7, 0x3f000000 # 0.5f
const/high16 v10, 0x3f000000 # 0.5f
.line 331
invoke-virtual/range {v0 .. v19}, Lcom/google/zxing/common/GridSampler;->sampleGrid(Lcom/google/zxing/common/BitMatrix;IIFFFFFFFFFFFFFFFF)Lcom/google/zxing/common/BitMatrix;
move-result-object v0
return-object v0
.end method
.method private transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
.registers 21
move-object/from16 v0, p0
.line 357
invoke-virtual/range {p1 .. p1}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v1
float-to-int v1, v1
.line 358
invoke-virtual/range {p1 .. p1}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v2
float-to-int v2, v2
.line 359
invoke-virtual/range {p2 .. p2}, Lcom/google/zxing/ResultPoint;->getX()F
move-result v3
float-to-int v3, v3
.line 360
invoke-virtual/range {p2 .. p2}, Lcom/google/zxing/ResultPoint;->getY()F
move-result v4
float-to-int v4, v4
sub-int v5, v4, v2
.line 361
invoke-static {v5}, Ljava/lang/Math;->abs(I)I
move-result v5
sub-int v6, v3, v1
invoke-static {v6}, Ljava/lang/Math;->abs(I)I
move-result v6
const/4 v7, 0x0
const/4 v8, 0x1
if-le v5, v6, :cond_28
const/4 v5, 0x1
goto :goto_29
:cond_28
const/4 v5, 0x0
:goto_29
if-eqz v5, :cond_35
move/from16 v16, v2
move v2, v1
move/from16 v1, v16
move/from16 v17, v4
move v4, v3
move/from16 v3, v17
:cond_35
sub-int v6, v3, v1
.line 371
invoke-static {v6}, Ljava/lang/Math;->abs(I)I
move-result v6
sub-int v9, v4, v2
.line 372
invoke-static {v9}, Ljava/lang/Math;->abs(I)I
move-result v9
neg-int v10, v6
.line 373
div-int/lit8 v10, v10, 0x2
const/4 v11, -0x1
if-ge v2, v4, :cond_49
const/4 v12, 0x1
goto :goto_4a
:cond_49
const/4 v12, -0x1
:goto_4a
if-ge v1, v3, :cond_4d
goto :goto_4e
:cond_4d
const/4 v8, -0x1
.line 377
:goto_4e
iget-object v11, v0, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
if-eqz v5, :cond_54
move v13, v2
goto :goto_55
:cond_54
move v13, v1
:goto_55
if-eqz v5, :cond_59
move v14, v1
goto :goto_5a
:cond_59
move v14, v2
:goto_5a
invoke-virtual {v11, v13, v14}, Lcom/google/zxing/common/BitMatrix;->get(II)Z
move-result v11
:goto_5e
if-eq v1, v3, :cond_7e
.line 379
iget-object v13, v0, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
if-eqz v5, :cond_66
move v14, v2
goto :goto_67
:cond_66
move v14, v1
:goto_67
if-eqz v5, :cond_6b
move v15, v1
goto :goto_6c
:cond_6b
move v15, v2
:goto_6c
invoke-virtual {v13, v14, v15}, Lcom/google/zxing/common/BitMatrix;->get(II)Z
move-result v13
if-eq v13, v11, :cond_75
add-int/lit8 v7, v7, 0x1
move v11, v13
:cond_75
add-int/2addr v10, v9
if-lez v10, :cond_7c
if-eq v2, v4, :cond_7e
add-int/2addr v2, v12
sub-int/2addr v10, v6
:cond_7c
add-int/2addr v1, v8
goto :goto_5e
.line 393
:cond_7e
new-instance v1, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
const/4 v2, 0x0
move-object/from16 v3, p1
move-object/from16 v4, p2
invoke-direct {v1, v3, v4, v7, v2}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;-><init>(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;ILcom/google/zxing/datamatrix/detector/Detector$1;)V
return-object v1
.end method
# virtual methods
.method public detect()Lcom/google/zxing/common/DetectorResult;
.registers 24
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/google/zxing/NotFoundException;
}
.end annotation
move-object/from16 v7, p0
.line 59
iget-object v0, v7, Lcom/google/zxing/datamatrix/detector/Detector;->rectangleDetector:Lcom/google/zxing/common/detector/WhiteRectangleDetector;
invoke-virtual {v0}, Lcom/google/zxing/common/detector/WhiteRectangleDetector;->detect()[Lcom/google/zxing/ResultPoint;
move-result-object v0
const/4 v8, 0x0
.line 60
aget-object v1, v0, v8
const/4 v9, 0x1
.line 61
aget-object v2, v0, v9
const/4 v10, 0x2
.line 62
aget-object v3, v0, v10
const/4 v11, 0x3
.line 63
aget-object v0, v0, v11
.line 68
new-instance v4, Ljava/util/ArrayList;
const/4 v12, 0x4
invoke-direct {v4, v12}, Ljava/util/ArrayList;-><init>(I)V
.line 69
invoke-direct {v7, v1, v2}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v5
invoke-interface {v4, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 70
invoke-direct {v7, v1, v3}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v5
invoke-interface {v4, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 71
invoke-direct {v7, v2, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v5
invoke-interface {v4, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 72
invoke-direct {v7, v3, v0}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v5
invoke-interface {v4, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 73
new-instance v5, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitionsComparator;
const/4 v6, 0x0
invoke-direct {v5, v6}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitionsComparator;-><init>(Lcom/google/zxing/datamatrix/detector/Detector$1;)V
invoke-static {v4, v5}, Ljava/util/Collections;->sort(Ljava/util/List;Ljava/util/Comparator;)V
.line 77
invoke-interface {v4, v8}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v5
check-cast v5, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
.line 78
invoke-interface {v4, v9}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
.line 82
new-instance v13, Ljava/util/HashMap;
invoke-direct {v13}, Ljava/util/HashMap;-><init>()V
.line 83
invoke-virtual {v5}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getFrom()Lcom/google/zxing/ResultPoint;
move-result-object v14
invoke-static {v13, v14}, Lcom/google/zxing/datamatrix/detector/Detector;->increment(Ljava/util/Map;Lcom/google/zxing/ResultPoint;)V
.line 84
invoke-virtual {v5}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTo()Lcom/google/zxing/ResultPoint;
move-result-object v5
invoke-static {v13, v5}, Lcom/google/zxing/datamatrix/detector/Detector;->increment(Ljava/util/Map;Lcom/google/zxing/ResultPoint;)V
.line 85
invoke-virtual {v4}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getFrom()Lcom/google/zxing/ResultPoint;
move-result-object v5
invoke-static {v13, v5}, Lcom/google/zxing/datamatrix/detector/Detector;->increment(Ljava/util/Map;Lcom/google/zxing/ResultPoint;)V
.line 86
invoke-virtual {v4}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTo()Lcom/google/zxing/ResultPoint;
move-result-object v4
invoke-static {v13, v4}, Lcom/google/zxing/datamatrix/detector/Detector;->increment(Ljava/util/Map;Lcom/google/zxing/ResultPoint;)V
.line 91
invoke-interface {v13}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v4
invoke-interface {v4}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v4
move-object v5, v6
move-object v14, v5
:goto_76
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v15
if-eqz v15, :cond_9f
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v15
check-cast v15, Ljava/util/Map$Entry;
.line 92
invoke-interface {v15}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v16
check-cast v16, Lcom/google/zxing/ResultPoint;
.line 93
invoke-interface {v15}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v15
check-cast v15, Ljava/lang/Integer;
.line 94
invoke-virtual {v15}, Ljava/lang/Integer;->intValue()I
move-result v15
if-ne v15, v10, :cond_97
move-object/from16 v5, v16
goto :goto_76
:cond_97
if-nez v6, :cond_9c
move-object/from16 v6, v16
goto :goto_76
:cond_9c
move-object/from16 v14, v16
goto :goto_76
:cond_9f
if-eqz v6, :cond_18e
if-eqz v5, :cond_18e
if-eqz v14, :cond_18e
new-array v4, v11, [Lcom/google/zxing/ResultPoint;
aput-object v6, v4, v8
aput-object v5, v4, v9
aput-object v14, v4, v10
.line 113
invoke-static {v4}, Lcom/google/zxing/ResultPoint;->orderBestPatterns([Lcom/google/zxing/ResultPoint;)V
.line 116
aget-object v14, v4, v8
.line 117
aget-object v22, v4, v9
.line 118
aget-object v6, v4, v10
.line 122
invoke-interface {v13, v1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v4
if-nez v4, :cond_be
move-object v13, v1
goto :goto_cf
.line 124
:cond_be
invoke-interface {v13, v2}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_c6
move-object v13, v2
goto :goto_cf
.line 126
:cond_c6
invoke-interface {v13, v3}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_ce
move-object v13, v3
goto :goto_cf
:cond_ce
move-object v13, v0
.line 141
:goto_cf
invoke-direct {v7, v6, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v0
invoke-virtual {v0}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v0
.line 142
invoke-direct {v7, v14, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v1
invoke-virtual {v1}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v1
and-int/lit8 v2, v0, 0x1
if-ne v2, v9, :cond_e5
add-int/lit8 v0, v0, 0x1
:cond_e5
add-int/lit8 v5, v0, 0x2
and-int/lit8 v0, v1, 0x1
if-ne v0, v9, :cond_ed
add-int/lit8 v1, v1, 0x1
:cond_ed
add-int/lit8 v15, v1, 0x2
mul-int/lit8 v0, v5, 0x4
mul-int/lit8 v1, v15, 0x7
if-ge v0, v1, :cond_13e
mul-int/lit8 v0, v15, 0x4
mul-int/lit8 v1, v5, 0x7
if-lt v0, v1, :cond_fc
goto :goto_13e
.line 189
:cond_fc
invoke-static {v15, v5}, Ljava/lang/Math;->min(II)I
move-result v5
move-object/from16 v0, p0
move-object/from16 v1, v22
move-object v2, v14
move-object v3, v6
move-object v4, v13
.line 191
invoke-direct/range {v0 .. v5}, Lcom/google/zxing/datamatrix/detector/Detector;->correctTopRight(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;I)Lcom/google/zxing/ResultPoint;
move-result-object v0
if-nez v0, :cond_10e
goto :goto_10f
:cond_10e
move-object v13, v0
.line 197
:goto_10f
invoke-direct {v7, v6, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v0
invoke-virtual {v0}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v0
.line 198
invoke-direct {v7, v14, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v1
invoke-virtual {v1}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v1
.line 197
invoke-static {v0, v1}, Ljava/lang/Math;->max(II)I
move-result v0
add-int/2addr v0, v9
and-int/lit8 v1, v0, 0x1
if-ne v1, v9, :cond_12a
add-int/lit8 v0, v0, 0x1
:cond_12a
move/from16 v21, v0
.line 204
iget-object v15, v7, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
move-object/from16 v16, v6
move-object/from16 v17, v22
move-object/from16 v18, v14
move-object/from16 v19, v13
move/from16 v20, v21
invoke-static/range {v15 .. v21}, Lcom/google/zxing/datamatrix/detector/Detector;->sampleGrid(Lcom/google/zxing/common/BitMatrix;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;II)Lcom/google/zxing/common/BitMatrix;
move-result-object v0
move-object v11, v6
goto :goto_17d
:cond_13e
:goto_13e
move-object/from16 v0, p0
move-object/from16 v1, v22
move-object v2, v14
move-object v3, v6
move-object v4, v13
move-object v11, v6
move v6, v15
.line 166
invoke-direct/range {v0 .. v6}, Lcom/google/zxing/datamatrix/detector/Detector;->correctTopRightRectangular(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;II)Lcom/google/zxing/ResultPoint;
move-result-object v0
if-nez v0, :cond_14e
goto :goto_14f
:cond_14e
move-object v13, v0
.line 171
:goto_14f
invoke-direct {v7, v11, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v0
invoke-virtual {v0}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v0
.line 172
invoke-direct {v7, v14, v13}, Lcom/google/zxing/datamatrix/detector/Detector;->transitionsBetween(Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;)Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;
move-result-object v1
invoke-virtual {v1}, Lcom/google/zxing/datamatrix/detector/Detector$ResultPointsAndTransitions;->getTransitions()I
move-result v1
and-int/lit8 v2, v0, 0x1
if-ne v2, v9, :cond_165
add-int/lit8 v0, v0, 0x1
:cond_165
move/from16 v20, v0
and-int/lit8 v0, v1, 0x1
if-ne v0, v9, :cond_16d
add-int/lit8 v1, v1, 0x1
:cond_16d
move/from16 v21, v1
.line 184
iget-object v15, v7, Lcom/google/zxing/datamatrix/detector/Detector;->image:Lcom/google/zxing/common/BitMatrix;
move-object/from16 v16, v11
move-object/from16 v17, v22
move-object/from16 v18, v14
move-object/from16 v19, v13
invoke-static/range {v15 .. v21}, Lcom/google/zxing/datamatrix/detector/Detector;->sampleGrid(Lcom/google/zxing/common/BitMatrix;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;Lcom/google/zxing/ResultPoint;II)Lcom/google/zxing/common/BitMatrix;
move-result-object v0
.line 213
:goto_17d
new-instance v1, Lcom/google/zxing/common/DetectorResult;
new-array v2, v12, [Lcom/google/zxing/ResultPoint;
aput-object v11, v2, v8
aput-object v22, v2, v9
aput-object v14, v2, v10
const/4 v3, 0x3
aput-object v13, v2, v3
invoke-direct {v1, v0, v2}, Lcom/google/zxing/common/DetectorResult;-><init>(Lcom/google/zxing/common/BitMatrix;[Lcom/google/zxing/ResultPoint;)V
return-object v1
.line 107
:cond_18e
invoke-static {}, Lcom/google/zxing/NotFoundException;->getNotFoundInstance()Lcom/google/zxing/NotFoundException;
move-result-object v0
throw v0
.end method