MaskUtil.smali
.class final Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;
.super Ljava/lang/Object;
# static fields
.field private static final N1:I = 0x3
.field private static final N2:I = 0x3
.field private static final N3:I = 0x28
.field private static final N4:I = 0xa
# direct methods
.method private constructor <init>()V
.registers 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method static applyMaskPenaltyRule1(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;)I
.registers 3
const/4 v0, 0x1
.line 1
invoke-static {p0, v0}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->applyMaskPenaltyRule1Internal(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;Z)I
move-result v0
const/4 v1, 0x0
invoke-static {p0, v1}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->applyMaskPenaltyRule1Internal(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;Z)I
move-result p0
add-int/2addr v0, p0
return v0
.end method
.method private static applyMaskPenaltyRule1Internal(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;Z)I
.registers 12
if-eqz p1, :cond_7
.line 1
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result v0
goto :goto_b
:cond_7
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result v0
:goto_b
if-eqz p1, :cond_12
.line 2
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result v1
goto :goto_16
:cond_12
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result v1
.line 3
:goto_16
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getArray()[[B
move-result-object p0
const/4 v2, 0x0
move v3, v2
move v4, v3
:goto_1d
if-ge v3, v0, :cond_4c
const/4 v5, -0x1
move v6, v2
move v7, v6
:goto_22
const/4 v8, 0x5
if-ge v6, v1, :cond_42
if-eqz p1, :cond_2c
.line 8
aget-object v9, p0, v3
aget-byte v9, v9, v6
goto :goto_30
:cond_2c
aget-object v9, p0, v6
aget-byte v9, v9, v3
:goto_30
if-ne v9, v5, :cond_35
add-int/lit8 v7, v7, 0x1
goto :goto_3f
:cond_35
if-lt v7, v8, :cond_3c
add-int/lit8 v7, v7, -0x5
add-int/lit8 v7, v7, 0x3
add-int/2addr v4, v7
:cond_3c
const/4 v5, 0x1
move v7, v5
move v5, v9
:goto_3f
add-int/lit8 v6, v6, 0x1
goto :goto_22
:cond_42
if-lt v7, v8, :cond_49
add-int/lit8 v7, v7, -0x5
add-int/lit8 v7, v7, 0x3
add-int/2addr v4, v7
:cond_49
add-int/lit8 v3, v3, 0x1
goto :goto_1d
:cond_4c
return v4
.end method
.method static applyMaskPenaltyRule2(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;)I
.registers 11
.line 1
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getArray()[[B
move-result-object v0
.line 2
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result v1
.line 3
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result p0
const/4 v2, 0x0
move v3, v2
move v4, v3
:goto_f
add-int/lit8 v5, p0, -0x1
if-ge v3, v5, :cond_39
move v5, v2
:goto_14
add-int/lit8 v6, v1, -0x1
if-ge v5, v6, :cond_36
.line 6
aget-object v6, v0, v3
aget-byte v6, v6, v5
.line 7
aget-object v7, v0, v3
add-int/lit8 v8, v5, 0x1
aget-byte v7, v7, v8
if-ne v6, v7, :cond_34
add-int/lit8 v7, v3, 0x1
aget-object v9, v0, v7
aget-byte v5, v9, v5
if-ne v6, v5, :cond_34
aget-object v5, v0, v7
aget-byte v5, v5, v8
if-ne v6, v5, :cond_34
add-int/lit8 v4, v4, 0x1
:cond_34
move v5, v8
goto :goto_14
:cond_36
add-int/lit8 v3, v3, 0x1
goto :goto_f
:cond_39
mul-int/lit8 v4, v4, 0x3
return v4
.end method
.method static applyMaskPenaltyRule3(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;)I
.registers 11
.line 1
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getArray()[[B
move-result-object v0
.line 2
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result v1
.line 3
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result p0
const/4 v2, 0x0
move v3, v2
move v4, v3
:goto_f
if-ge v3, p0, :cond_a9
move v5, v2
:goto_12
if-ge v5, v1, :cond_a5
.line 6
aget-object v6, v0, v3
add-int/lit8 v7, v5, 0x6
const/4 v8, 0x1
if-ge v7, v1, :cond_55
.line 7
aget-byte v9, v6, v5
if-ne v9, v8, :cond_55
add-int/lit8 v9, v5, 0x1
aget-byte v9, v6, v9
if-nez v9, :cond_55
add-int/lit8 v9, v5, 0x2
aget-byte v9, v6, v9
if-ne v9, v8, :cond_55
add-int/lit8 v9, v5, 0x3
aget-byte v9, v6, v9
if-ne v9, v8, :cond_55
add-int/lit8 v9, v5, 0x4
aget-byte v9, v6, v9
if-ne v9, v8, :cond_55
add-int/lit8 v9, v5, 0x5
aget-byte v9, v6, v9
if-nez v9, :cond_55
aget-byte v7, v6, v7
if-ne v7, v8, :cond_55
add-int/lit8 v7, v5, -0x4
.line 15
invoke-static {v6, v7, v5}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->isWhiteHorizontal([BII)Z
move-result v7
if-nez v7, :cond_53
add-int/lit8 v7, v5, 0x7
add-int/lit8 v9, v5, 0xb
invoke-static {v6, v7, v9}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->isWhiteHorizontal([BII)Z
move-result v6
if-eqz v6, :cond_55
:cond_53
add-int/lit8 v4, v4, 0x1
:cond_55
add-int/lit8 v6, v3, 0x6
if-ge v6, p0, :cond_a1
.line 18
aget-object v7, v0, v3
aget-byte v7, v7, v5
if-ne v7, v8, :cond_a1
add-int/lit8 v7, v3, 0x1
aget-object v7, v0, v7
aget-byte v7, v7, v5
if-nez v7, :cond_a1
add-int/lit8 v7, v3, 0x2
aget-object v7, v0, v7
aget-byte v7, v7, v5
if-ne v7, v8, :cond_a1
add-int/lit8 v7, v3, 0x3
aget-object v7, v0, v7
aget-byte v7, v7, v5
if-ne v7, v8, :cond_a1
add-int/lit8 v7, v3, 0x4
aget-object v7, v0, v7
aget-byte v7, v7, v5
if-ne v7, v8, :cond_a1
add-int/lit8 v7, v3, 0x5
aget-object v7, v0, v7
aget-byte v7, v7, v5
if-nez v7, :cond_a1
aget-object v6, v0, v6
aget-byte v6, v6, v5
if-ne v6, v8, :cond_a1
add-int/lit8 v6, v3, -0x4
.line 26
invoke-static {v0, v5, v6, v3}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->isWhiteVertical([[BIII)Z
move-result v6
if-nez v6, :cond_9f
add-int/lit8 v6, v3, 0x7
add-int/lit8 v7, v3, 0xb
invoke-static {v0, v5, v6, v7}, Lcom/dcloud/zxing2/qrcode/encoder/MaskUtil;->isWhiteVertical([[BIII)Z
move-result v6
if-eqz v6, :cond_a1
:cond_9f
add-int/lit8 v4, v4, 0x1
:cond_a1
add-int/lit8 v5, v5, 0x1
goto/16 :goto_12
:cond_a5
add-int/lit8 v3, v3, 0x1
goto/16 :goto_f
:cond_a9
mul-int/lit8 v4, v4, 0x28
return v4
.end method
.method static applyMaskPenaltyRule4(Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;)I
.registers 11
.line 1
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getArray()[[B
move-result-object v0
.line 2
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result v1
.line 3
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result v2
const/4 v3, 0x0
move v4, v3
move v5, v4
:goto_f
if-ge v4, v2, :cond_23
.line 5
aget-object v6, v0, v4
move v7, v3
:goto_14
if-ge v7, v1, :cond_20
.line 7
aget-byte v8, v6, v7
const/4 v9, 0x1
if-ne v8, v9, :cond_1d
add-int/lit8 v5, v5, 0x1
:cond_1d
add-int/lit8 v7, v7, 0x1
goto :goto_14
:cond_20
add-int/lit8 v4, v4, 0x1
goto :goto_f
.line 12
:cond_23
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getHeight()I
move-result v0
invoke-virtual {p0}, Lcom/dcloud/zxing2/qrcode/encoder/ByteMatrix;->getWidth()I
move-result p0
mul-int/2addr v0, p0
mul-int/lit8 v5, v5, 0x2
sub-int/2addr v5, v0
.line 13
invoke-static {v5}, Ljava/lang/Math;->abs(I)I
move-result p0
mul-int/lit8 p0, p0, 0xa
div-int/2addr p0, v0
mul-int/lit8 p0, p0, 0xa
return p0
.end method
.method static getDataMaskBit(III)Z
.registers 4
const/4 v0, 0x1
packed-switch p0, :pswitch_data_48
.line 1
new-instance p1, Ljava/lang/IllegalArgumentException;
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Invalid mask pattern: "
invoke-virtual {p2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, p0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-direct {p1, p0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
:pswitch_1b
mul-int p0, p2, p1
.line 2
rem-int/lit8 p0, p0, 0x3
add-int/2addr p2, p1
and-int/lit8 p1, p2, 0x1
add-int/2addr p0, p1
goto :goto_2a
:pswitch_24
mul-int/2addr p2, p1
and-int/lit8 p0, p2, 0x1
.line 3
rem-int/lit8 p2, p2, 0x3
add-int/2addr p0, p2
:goto_2a
and-int/2addr p0, v0
goto :goto_42
:pswitch_2c
mul-int/2addr p2, p1
and-int/lit8 p0, p2, 0x1
.line 4
rem-int/lit8 p2, p2, 0x3
add-int/2addr p0, p2
goto :goto_42
.line 5
:pswitch_33
div-int/lit8 p2, p2, 0x2
div-int/lit8 p1, p1, 0x3
goto :goto_3f
:pswitch_38
add-int/2addr p2, p1
.line 6
rem-int/lit8 p0, p2, 0x3
goto :goto_42
.line 7
:pswitch_3c
rem-int/lit8 p0, p1, 0x3
goto :goto_42
:goto_3f
:pswitch_3f
add-int/2addr p2, p1
:pswitch_40
and-int/lit8 p0, p2, 0x1
:goto_42
if-nez p0, :cond_45
goto :goto_46
:cond_45
const/4 v0, 0x0
:goto_46
return v0
nop
:pswitch_data_48
.packed-switch 0x0
:pswitch_3f
:pswitch_40
:pswitch_3c
:pswitch_38
:pswitch_33
:pswitch_2c
:pswitch_24
:pswitch_1b
.end packed-switch
.end method
.method private static isWhiteHorizontal([BII)Z
.registers 5
:goto_0
const/4 v0, 0x1
if-ge p1, p2, :cond_11
if-ltz p1, :cond_e
.line 1
array-length v1, p0
if-ge p1, v1, :cond_e
aget-byte v1, p0, p1
if-ne v1, v0, :cond_e
const/4 p0, 0x0
return p0
:cond_e
add-int/lit8 p1, p1, 0x1
goto :goto_0
:cond_11
return v0
.end method
.method private static isWhiteVertical([[BIII)Z
.registers 6
:goto_0
const/4 v0, 0x1
if-ge p2, p3, :cond_13
if-ltz p2, :cond_10
.line 1
array-length v1, p0
if-ge p2, v1, :cond_10
aget-object v1, p0, p2
aget-byte v1, v1, p1
if-ne v1, v0, :cond_10
const/4 p0, 0x0
return p0
:cond_10
add-int/lit8 p2, p2, 0x1
goto :goto_0
:cond_13
return v0
.end method