UNPKG

@zxing/library

Version:

TypeScript port of ZXing multi-format 1D/2D barcode image processing library.

108 lines (107 loc) 4.33 kB
"use strict"; /* * Copyright 2013 ZXing authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ var __values = (this && this.__values) || function(o) { var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; if (m) return m.call(o); if (o && typeof o.length === "number") return { next: function () { if (o && i >= o.length) o = void 0; return { value: o && o[i++], done: !o }; } }; throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); }; Object.defineProperty(exports, "__esModule", { value: true }); // package com.google.zxing.pdf417.decoder; // import java.util.Formatter; var Formatter_1 = require("../../util/Formatter"); var BoundingBox_1 = require("./BoundingBox"); /** * @author Guenther Grau */ var DetectionResultColumn = /** @class */ (function () { function DetectionResultColumn(boundingBox) { this.boundingBox = new BoundingBox_1.default(boundingBox); // this.codewords = new Codeword[boundingBox.getMaxY() - boundingBox.getMinY() + 1]; this.codewords = new Array(boundingBox.getMaxY() - boundingBox.getMinY() + 1); } /*final*/ DetectionResultColumn.prototype.getCodewordNearby = function (imageRow) { var codeword = this.getCodeword(imageRow); if (codeword != null) { return codeword; } for (var i = 1; i < DetectionResultColumn.MAX_NEARBY_DISTANCE; i++) { var nearImageRow = this.imageRowToCodewordIndex(imageRow) - i; if (nearImageRow >= 0) { codeword = this.codewords[nearImageRow]; if (codeword != null) { return codeword; } } nearImageRow = this.imageRowToCodewordIndex(imageRow) + i; if (nearImageRow < this.codewords.length) { codeword = this.codewords[nearImageRow]; if (codeword != null) { return codeword; } } } return null; }; /*final int*/ DetectionResultColumn.prototype.imageRowToCodewordIndex = function (imageRow) { return imageRow - this.boundingBox.getMinY(); }; /*final void*/ DetectionResultColumn.prototype.setCodeword = function (imageRow, codeword) { this.codewords[this.imageRowToCodewordIndex(imageRow)] = codeword; }; /*final*/ DetectionResultColumn.prototype.getCodeword = function (imageRow) { return this.codewords[this.imageRowToCodewordIndex(imageRow)]; }; /*final*/ DetectionResultColumn.prototype.getBoundingBox = function () { return this.boundingBox; }; /*final*/ DetectionResultColumn.prototype.getCodewords = function () { return this.codewords; }; // @Override DetectionResultColumn.prototype.toString = function () { var e_1, _a; var formatter = new Formatter_1.default(); var row = 0; try { for (var _b = __values(this.codewords), _c = _b.next(); !_c.done; _c = _b.next()) { var codeword = _c.value; if (codeword == null) { formatter.format('%3d: | %n', row++); continue; } formatter.format('%3d: %3d|%3d%n', row++, codeword.getRowNumber(), codeword.getValue()); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } return formatter.toString(); }; DetectionResultColumn.MAX_NEARBY_DISTANCE = 5; return DetectionResultColumn; }()); exports.default = DetectionResultColumn;