5 * Created by Lukasz Warchol on 10-01-25.
6 * Copyright 2010 ZXing authors All rights reserved.
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
21 #include "EAN8Reader.h"
22 #include <zxing/ReaderException.h>
27 EAN8Reader::EAN8Reader(){
28 decodeMiddleCounters = new int[4];
29 for (int i=0; i<4; i++) {
30 decodeMiddleCounters[i] = 0;
34 int EAN8Reader::decodeMiddle(Ref<BitArray> row, int startRange[], int startRangeLen, std::string& resultString){
36 int* counters = decodeMiddleCounters;
43 int end = row->getSize();
44 int rowOffset = startRange[1];
46 for (int x = 0; x < 4 && rowOffset < end; x++) {
47 int bestMatch = decodeDigit(row, counters, countersLen, rowOffset, UPC_EAN_PATTERNS_L_PATTERNS);
48 resultString.append(1, (char) ('0' + bestMatch));
49 for (int i = 0; i < countersLen; i++) {
50 rowOffset += counters[i];
54 int* middleRange = findGuardPattern(row, rowOffset, true, (int*)getMIDDLE_PATTERN(), getMIDDLE_PATTERN_LEN());
55 rowOffset = middleRange[1];
57 for (int x = 0; x < 4 && rowOffset < end; x++) {
58 int bestMatch = decodeDigit(row, counters, countersLen, rowOffset, UPC_EAN_PATTERNS_L_PATTERNS);
59 resultString.append(1, (char) ('0' + bestMatch));
60 for (int i = 0; i < countersLen; i++) {
61 rowOffset += counters[i];
68 BarcodeFormat EAN8Reader::getBarcodeFormat(){
69 return BarcodeFormat_EAN_8;
71 EAN8Reader::~EAN8Reader(){
72 delete [] decodeMiddleCounters;