| OLD | NEW |
| 1 // Copyright 2014 PDFium Authors. All rights reserved. | 1 // Copyright 2014 PDFium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com | 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| 6 // Original code is licensed as follows: | 6 // Original code is licensed as follows: |
| 7 /* | 7 /* |
| 8 * Copyright 2011 ZXing authors | 8 * Copyright 2011 ZXing authors |
| 9 * | 9 * |
| 10 * Licensed under the Apache License, Version 2.0 (the "License"); | 10 * Licensed under the Apache License, Version 2.0 (the "License"); |
| 11 * you may not use this file except in compliance with 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 | 12 * You may obtain a copy of the License at |
| 13 * | 13 * |
| 14 * http://www.apache.org/licenses/LICENSE-2.0 | 14 * http://www.apache.org/licenses/LICENSE-2.0 |
| 15 * | 15 * |
| 16 * Unless required by applicable law or agreed to in writing, software | 16 * Unless required by applicable law or agreed to in writing, software |
| 17 * distributed under the License is distributed on an "AS IS" BASIS, | 17 * distributed under the License is distributed on an "AS IS" BASIS, |
| 18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 18 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 19 * See the License for the specific language governing permissions and | 19 * See the License for the specific language governing permissions and |
| 20 * limitations under the License. | 20 * limitations under the License. |
| 21 */ | 21 */ |
| 22 | 22 |
| 23 #include "../barcode.h" | 23 #include "../barcode.h" |
| 24 #include "BC_PDF417BarcodeRow.h" | 24 #include "BC_PDF417BarcodeRow.h" |
| 25 #include "BC_PDF417BarcodeMatrix.h" | 25 #include "BC_PDF417BarcodeMatrix.h" |
| 26 CBC_BarcodeMatrix::CBC_BarcodeMatrix(FX_INT32 height, FX_INT32 width) | 26 CBC_BarcodeMatrix::CBC_BarcodeMatrix(int32_t height, int32_t width) |
| 27 { | 27 { |
| 28 m_matrix.SetSize(height + 2); | 28 m_matrix.SetSize(height + 2); |
| 29 for (FX_INT32 i = 0, matrixLength = m_matrix.GetSize(); i < matrixLength; i+
+) { | 29 for (int32_t i = 0, matrixLength = m_matrix.GetSize(); i < matrixLength; i++
) { |
| 30 m_matrix[i] = FX_NEW CBC_BarcodeRow((width + 4) * 17 + 1); | 30 m_matrix[i] = FX_NEW CBC_BarcodeRow((width + 4) * 17 + 1); |
| 31 } | 31 } |
| 32 m_width = width * 17; | 32 m_width = width * 17; |
| 33 m_height = height + 2; | 33 m_height = height + 2; |
| 34 m_currentRow = 0; | 34 m_currentRow = 0; |
| 35 m_outHeight = 0; | 35 m_outHeight = 0; |
| 36 m_outWidth = 0; | 36 m_outWidth = 0; |
| 37 } | 37 } |
| 38 CBC_BarcodeMatrix::~CBC_BarcodeMatrix() | 38 CBC_BarcodeMatrix::~CBC_BarcodeMatrix() |
| 39 { | 39 { |
| 40 for (FX_INT32 i = 0; i < m_matrix.GetSize(); i++) { | 40 for (int32_t i = 0; i < m_matrix.GetSize(); i++) { |
| 41 delete (CBC_BarcodeRow*)m_matrix.GetAt(i); | 41 delete (CBC_BarcodeRow*)m_matrix.GetAt(i); |
| 42 } | 42 } |
| 43 m_matrix.RemoveAll(); | 43 m_matrix.RemoveAll(); |
| 44 m_matrixOut.RemoveAll(); | 44 m_matrixOut.RemoveAll(); |
| 45 } | 45 } |
| 46 void CBC_BarcodeMatrix::set(FX_INT32 x, FX_INT32 y, FX_BYTE value) | 46 void CBC_BarcodeMatrix::set(int32_t x, int32_t y, uint8_t value) |
| 47 { | 47 { |
| 48 ((CBC_BarcodeRow*)m_matrix[y])->set(x, value); | 48 ((CBC_BarcodeRow*)m_matrix[y])->set(x, value); |
| 49 } | 49 } |
| 50 void CBC_BarcodeMatrix::setMatrix(FX_INT32 x, FX_INT32 y, FX_BOOL black) | 50 void CBC_BarcodeMatrix::setMatrix(int32_t x, int32_t y, FX_BOOL black) |
| 51 { | 51 { |
| 52 set(x, y, (FX_BYTE) (black ? 1 : 0)); | 52 set(x, y, (uint8_t) (black ? 1 : 0)); |
| 53 } | 53 } |
| 54 void CBC_BarcodeMatrix::startRow() | 54 void CBC_BarcodeMatrix::startRow() |
| 55 { | 55 { |
| 56 ++m_currentRow; | 56 ++m_currentRow; |
| 57 } | 57 } |
| 58 CBC_BarcodeRow* CBC_BarcodeMatrix::getCurrentRow() | 58 CBC_BarcodeRow* CBC_BarcodeMatrix::getCurrentRow() |
| 59 { | 59 { |
| 60 return (CBC_BarcodeRow*)m_matrix[m_currentRow]; | 60 return (CBC_BarcodeRow*)m_matrix[m_currentRow]; |
| 61 } | 61 } |
| 62 FX_INT32 CBC_BarcodeMatrix::getWidth() | 62 int32_t CBC_BarcodeMatrix::getWidth() |
| 63 { | 63 { |
| 64 return m_outWidth; | 64 return m_outWidth; |
| 65 } | 65 } |
| 66 FX_INT32 CBC_BarcodeMatrix::getHeight() | 66 int32_t CBC_BarcodeMatrix::getHeight() |
| 67 { | 67 { |
| 68 return m_outHeight; | 68 return m_outHeight; |
| 69 } | 69 } |
| 70 CFX_ByteArray& CBC_BarcodeMatrix::getMatrix() | 70 CFX_ByteArray& CBC_BarcodeMatrix::getMatrix() |
| 71 { | 71 { |
| 72 return getScaledMatrix(1, 1); | 72 return getScaledMatrix(1, 1); |
| 73 } | 73 } |
| 74 CFX_ByteArray& CBC_BarcodeMatrix::getScaledMatrix(FX_INT32 scale) | 74 CFX_ByteArray& CBC_BarcodeMatrix::getScaledMatrix(int32_t scale) |
| 75 { | 75 { |
| 76 return getScaledMatrix(scale, scale); | 76 return getScaledMatrix(scale, scale); |
| 77 } | 77 } |
| 78 CFX_ByteArray& CBC_BarcodeMatrix::getScaledMatrix(FX_INT32 xScale, FX_INT32 ySca
le) | 78 CFX_ByteArray& CBC_BarcodeMatrix::getScaledMatrix(int32_t xScale, int32_t yScale
) |
| 79 { | 79 { |
| 80 FX_INT32 yMax = m_height * yScale; | 80 int32_t yMax = m_height * yScale; |
| 81 CFX_ByteArray bytearray; | 81 CFX_ByteArray bytearray; |
| 82 bytearray.Copy(((CBC_BarcodeRow*)m_matrix[0])->getScaledRow(xScale)); | 82 bytearray.Copy(((CBC_BarcodeRow*)m_matrix[0])->getScaledRow(xScale)); |
| 83 FX_INT32 xMax = bytearray.GetSize(); | 83 int32_t xMax = bytearray.GetSize(); |
| 84 m_matrixOut.SetSize(xMax * yMax); | 84 m_matrixOut.SetSize(xMax * yMax); |
| 85 m_outWidth = xMax; | 85 m_outWidth = xMax; |
| 86 m_outHeight = yMax; | 86 m_outHeight = yMax; |
| 87 FX_INT32 k = 0; | 87 int32_t k = 0; |
| 88 for (FX_INT32 i = 0; i < yMax; i++) { | 88 for (int32_t i = 0; i < yMax; i++) { |
| 89 if (i != 0) { | 89 if (i != 0) { |
| 90 bytearray.Copy(((CBC_BarcodeRow*)m_matrix[i / yScale])->getScaledRow
(xScale)); | 90 bytearray.Copy(((CBC_BarcodeRow*)m_matrix[i / yScale])->getScaledRow
(xScale)); |
| 91 } | 91 } |
| 92 k = i * xMax; | 92 k = i * xMax; |
| 93 for (FX_INT32 l = 0; l < xMax; l++) { | 93 for (int32_t l = 0; l < xMax; l++) { |
| 94 m_matrixOut[k + l] = bytearray.GetAt(l); | 94 m_matrixOut[k + l] = bytearray.GetAt(l); |
| 95 } | 95 } |
| 96 } | 96 } |
| 97 return m_matrixOut; | 97 return m_matrixOut; |
| 98 } | 98 } |
| OLD | NEW |