summaryrefslogtreecommitdiff
path: root/xfa/src/fxbarcode/qrcode/BC_QRFinderPatternFinder.h
blob: f24d22bed28f3ad3e47f0611e7e1f1e40c960259 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// Copyright 2014 PDFium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com

#ifndef _BC_QRFINDERPATTERNFINDER_H_
#define _BC_QRFINDERPATTERNFINDER_H_
class CBC_CommonBitMatrix;
class CBC_QRFinderPattern;
class CBC_ResultPoint;
class CBC_QRFinderPatternInfo;

class CBC_QRFinderPatternFinder
{
private:
    const static int32_t CENTER_QUORUM;
    const static int32_t MIN_SKIP;
    const static int32_t MAX_MODULES;
    const static int32_t INTEGER_MATH_SHIFT;
    FX_BOOL m_hasSkipped;
    CBC_CommonBitMatrix* m_image;
    CFX_Int32Array m_crossCheckStateCount;
    CFX_PtrArray m_possibleCenters;
public:
    CBC_QRFinderPatternFinder(CBC_CommonBitMatrix *image);
    virtual ~CBC_QRFinderPatternFinder();
    int32_t FindRowSkip();
    CBC_CommonBitMatrix* GetImage();
    CBC_QRFinderPatternInfo* Find(int32_t hint, int32_t &e);

    CFX_Int32Array &GetCrossCheckStateCount();
    CFX_PtrArray *GetPossibleCenters();
    CFX_PtrArray *SelectBestpatterns(int32_t &e);

    FX_BOOL HandlePossibleCenter(const CFX_Int32Array &stateCount, int32_t i, int32_t j);
    FX_BOOL HaveMultiplyConfirmedCenters();
    FX_FLOAT CenterFromEnd(const CFX_Int32Array &stateCount, int32_t end);
    FX_FLOAT CrossCheckVertical(int32_t startI, int32_t centerJ, int32_t maxCount, int32_t originalStateCountTotal);
    FX_FLOAT CrossCheckHorizontal(int32_t startJ, int32_t CenterI, int32_t maxCOunt, int32_t originalStateCountTotal);
    static void OrderBestPatterns(CFX_PtrArray *patterns);
    static FX_BOOL FoundPatternCross(const CFX_Int32Array &stateCount);
    static FX_FLOAT Distance(CBC_ResultPoint* point1, CBC_ResultPoint* point2);
};
#endif