| // 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 |
| // Original code is licensed as follows: |
| /* |
| * Copyright 2012 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. |
| */ |
| |
| #include "fxbarcode/pdf417/BC_PDF417Writer.h" |
| |
| #include <algorithm> |
| |
| #include "fxbarcode/BC_TwoDimWriter.h" |
| #include "fxbarcode/common/BC_CommonBitArray.h" |
| #include "fxbarcode/common/BC_CommonBitMatrix.h" |
| #include "fxbarcode/pdf417/BC_PDF417.h" |
| #include "fxbarcode/pdf417/BC_PDF417BarcodeMatrix.h" |
| #include "fxbarcode/pdf417/BC_PDF417Compaction.h" |
| |
| CBC_PDF417Writer::CBC_PDF417Writer() { |
| m_bFixedSize = false; |
| } |
| CBC_PDF417Writer::~CBC_PDF417Writer() { |
| m_bTruncated = true; |
| } |
| bool CBC_PDF417Writer::SetErrorCorrectionLevel(int32_t level) { |
| if (level < 0 || level > 8) { |
| return false; |
| } |
| m_iCorrectLevel = level; |
| return true; |
| } |
| void CBC_PDF417Writer::SetTruncated(bool truncated) { |
| m_bTruncated = truncated; |
| } |
| |
| uint8_t* CBC_PDF417Writer::Encode(const WideString& contents, |
| int32_t& outWidth, |
| int32_t& outHeight) { |
| CBC_PDF417 encoder; |
| int32_t col = (m_Width / m_ModuleWidth - 69) / 17; |
| int32_t row = m_Height / (m_ModuleWidth * 20); |
| if (row >= 3 && row <= 90 && col >= 1 && col <= 30) |
| encoder.setDimensions(col, col, row, row); |
| else if (col >= 1 && col <= 30) |
| encoder.setDimensions(col, col, 90, 3); |
| else if (row >= 3 && row <= 90) |
| encoder.setDimensions(30, 1, row, row); |
| if (!encoder.generateBarcodeLogic(contents, m_iCorrectLevel)) |
| return nullptr; |
| |
| int32_t lineThickness = 2; |
| int32_t aspectRatio = 4; |
| CBC_BarcodeMatrix* barcodeMatrix = encoder.getBarcodeMatrix(); |
| std::vector<uint8_t> originalScale = barcodeMatrix->getScaledMatrix( |
| lineThickness, aspectRatio * lineThickness); |
| int32_t width = outWidth; |
| int32_t height = outHeight; |
| outWidth = barcodeMatrix->getWidth(); |
| outHeight = barcodeMatrix->getHeight(); |
| bool rotated = false; |
| if ((height > width) ^ (outWidth < outHeight)) { |
| rotateArray(originalScale, outHeight, outWidth); |
| rotated = true; |
| int32_t temp = outHeight; |
| outHeight = outWidth; |
| outWidth = temp; |
| } |
| int32_t scaleX = width / outWidth; |
| int32_t scaleY = height / outHeight; |
| int32_t scale = std::min(scaleX, scaleY); |
| if (scale > 1) { |
| originalScale = barcodeMatrix->getScaledMatrix( |
| scale * lineThickness, scale * aspectRatio * lineThickness); |
| if (rotated) { |
| rotateArray(originalScale, outHeight, outWidth); |
| int32_t temp = outHeight; |
| outHeight = outWidth; |
| outWidth = temp; |
| } |
| } |
| uint8_t* result = FX_Alloc2D(uint8_t, outHeight, outWidth); |
| memcpy(result, originalScale.data(), outHeight * outWidth); |
| return result; |
| } |
| |
| void CBC_PDF417Writer::rotateArray(std::vector<uint8_t>& bitarray, |
| int32_t height, |
| int32_t width) { |
| std::vector<uint8_t> temp = bitarray; |
| for (int32_t ii = 0; ii < height; ii++) { |
| int32_t inverseii = height - ii - 1; |
| for (int32_t jj = 0; jj < width; jj++) { |
| bitarray[jj * height + inverseii] = temp[ii * width + jj]; |
| } |
| } |
| } |