summaryrefslogtreecommitdiff
path: root/xfa/fxbarcode/qrcode/BC_QRFinderPatternFinder.h
blob: ada224787b055e369f0169882545cf64e03a6114 (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
46
47
48
49
50
51
52
53
54
55
56
57
// 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 XFA_FXBARCODE_QRCODE_BC_QRFINDERPATTERNFINDER_H_
#define XFA_FXBARCODE_QRCODE_BC_QRFINDERPATTERNFINDER_H_

#include "core/fxcrt/include/fx_basic.h"

class CBC_CommonBitMatrix;
class CBC_QRFinderPattern;
class CBC_ResultPoint;
class CBC_QRFinderPatternInfo;

class CBC_QRFinderPatternFinder {
 private:
  static const int32_t CENTER_QUORUM;
  static const int32_t MIN_SKIP;
  static const int32_t MAX_MODULES;
  static const 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  // XFA_FXBARCODE_QRCODE_BC_QRFINDERPATTERNFINDER_H_