Home | History | Annotate | Download | only in pdf417
      1 // Copyright 2014 PDFium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
      6 // Original code is licensed as follows:
      7 /*
      8  * Copyright 2011 ZXing authors
      9  *
     10  * Licensed under the Apache License, Version 2.0 (the "License");
     11  * you may not use this file except in compliance with the License.
     12  * You may obtain a copy of the License at
     13  *
     14  *      http://www.apache.org/licenses/LICENSE-2.0
     15  *
     16  * Unless required by applicable law or agreed to in writing, software
     17  * distributed under the License is distributed on an "AS IS" BASIS,
     18  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     19  * See the License for the specific language governing permissions and
     20  * limitations under the License.
     21  */
     22 
     23 #include "fxbarcode/pdf417/BC_PDF417BarcodeMatrix.h"
     24 #include "fxbarcode/pdf417/BC_PDF417BarcodeRow.h"
     25 #include "third_party/base/ptr_util.h"
     26 
     27 CBC_BarcodeMatrix::CBC_BarcodeMatrix(int32_t height, int32_t width) {
     28   m_matrix.resize(height + 2);
     29   for (size_t i = 0; i < m_matrix.size(); ++i)
     30     m_matrix[i] = pdfium::MakeUnique<CBC_BarcodeRow>((width + 4) * 17 + 1);
     31 
     32   m_width = width * 17;
     33   m_height = height + 2;
     34   m_currentRow = 0;
     35   m_outHeight = 0;
     36   m_outWidth = 0;
     37 }
     38 
     39 CBC_BarcodeMatrix::~CBC_BarcodeMatrix() {}
     40 
     41 void CBC_BarcodeMatrix::set(int32_t x, int32_t y, uint8_t value) {
     42   m_matrix[y]->set(x, value);
     43 }
     44 void CBC_BarcodeMatrix::setMatrix(int32_t x, int32_t y, bool black) {
     45   set(x, y, (uint8_t)(black ? 1 : 0));
     46 }
     47 void CBC_BarcodeMatrix::startRow() {
     48   ++m_currentRow;
     49 }
     50 std::vector<uint8_t>& CBC_BarcodeMatrix::getMatrix() {
     51   return getScaledMatrix(1, 1);
     52 }
     53 std::vector<uint8_t>& CBC_BarcodeMatrix::getScaledMatrix(int32_t scale) {
     54   return getScaledMatrix(scale, scale);
     55 }
     56 std::vector<uint8_t>& CBC_BarcodeMatrix::getScaledMatrix(int32_t xScale,
     57                                                          int32_t yScale) {
     58   size_t yMax = m_height * yScale;
     59   std::vector<uint8_t> bytearray = m_matrix[0]->getScaledRow(xScale);
     60   size_t xMax = bytearray.size();
     61   m_matrixOut.resize(xMax * yMax);
     62   m_outWidth = xMax;
     63   m_outHeight = yMax;
     64   int32_t k = 0;
     65   for (size_t i = 0; i < yMax; i++) {
     66     if (i != 0)
     67       bytearray = m_matrix[i / yScale]->getScaledRow(xScale);
     68     k = i * xMax;
     69     for (size_t l = 0; l < xMax; l++)
     70       m_matrixOut[k + l] = bytearray[l];
     71   }
     72   return m_matrixOut;
     73 }
     74