From 317c64f47e9f88d30cac340b50572cf883113d6e Mon Sep 17 00:00:00 2001 From: Syrone Wong Date: Fri, 31 Mar 2017 20:47:10 +0800 Subject: [PATCH] update NuGet packages replace zxing with NuGet pkg --- shadowsocks-csharp/3rd/zxing/BarcodeFormat.cs | 89 -- .../3rd/zxing/BaseLuminanceSource.cs | 206 ----- shadowsocks-csharp/3rd/zxing/Binarizer.cs | 104 --- shadowsocks-csharp/3rd/zxing/BinaryBitmap.cs | 186 ---- .../3rd/zxing/BitmapLuminanceSource.cs | 242 ------ .../3rd/zxing/DecodeHintType.cs | 125 --- .../3rd/zxing/EncodeHintType.cs | 131 --- .../3rd/zxing/LuminanceSource.cs | 198 ----- shadowsocks-csharp/3rd/zxing/Result.cs | 161 ---- .../3rd/zxing/ResultMetadataType.cs | 102 --- shadowsocks-csharp/3rd/zxing/ResultPoint.cs | 191 ----- .../3rd/zxing/ResultPointCallback.cs | 26 - .../3rd/zxing/WriterException.cs | 55 -- .../3rd/zxing/common/BitArray.cs | 278 ------ .../3rd/zxing/common/BitMatrix.cs | 259 ------ .../3rd/zxing/common/BitSource.cs | 124 --- .../3rd/zxing/common/DecoderResult.cs | 76 -- .../3rd/zxing/common/DefaultGridSampler.cs | 82 -- .../3rd/zxing/common/DetectorResult.cs | 39 - .../zxing/common/GlobalHistogramBinarizer.cs | 243 ------ .../3rd/zxing/common/GridSampler.cs | 192 ----- .../3rd/zxing/common/HybridBinarizer.cs | 288 ------- .../3rd/zxing/common/PerspectiveTransform.cs | 159 ---- .../3rd/zxing/common/StringUtils.cs | 266 ------ .../3rd/zxing/common/detector/MathUtils.cs | 48 -- .../3rd/zxing/common/reedsolomon/GenericGF.cs | 242 ------ .../zxing/common/reedsolomon/GenericGFPoly.cs | 331 ------- .../common/reedsolomon/ReedSolomonDecoder.cs | 227 ----- .../common/reedsolomon/ReedSolomonEncoder.cs | 84 -- .../3rd/zxing/qrcode/QRCodeReader.cs | 255 ------ .../zxing/qrcode/decoder/BitMatrixParser.cs | 281 ------ .../3rd/zxing/qrcode/decoder/DataBlock.cs | 146 ---- .../3rd/zxing/qrcode/decoder/DataMask.cs | 165 ---- .../qrcode/decoder/DecodedBitStreamParser.cs | 514 ----------- .../3rd/zxing/qrcode/decoder/Decoder.cs | 195 ----- .../qrcode/decoder/ErrorCorrectionLevel.cs | 109 --- .../zxing/qrcode/decoder/FormatInformation.cs | 197 ----- .../3rd/zxing/qrcode/decoder/Mode.cs | 179 ---- .../qrcode/decoder/QRCodeDecoderMetaData.cs | 60 -- .../3rd/zxing/qrcode/decoder/Version.cs | 424 --------- .../zxing/qrcode/detector/AlignmentPattern.cs | 68 -- .../qrcode/detector/AlignmentPatternFinder.cs | 324 ------- .../3rd/zxing/qrcode/detector/Detector.cs | 429 ---------- .../zxing/qrcode/detector/FinderPattern.cs | 107 --- .../qrcode/detector/FinderPatternFinder.cs | 808 ------------------ .../qrcode/detector/FinderPatternInfo.cs | 74 -- .../3rd/zxing/qrcode/encoder/BlockPair.cs | 40 - .../3rd/zxing/qrcode/encoder/ByteMatrix.cs | 148 ---- .../3rd/zxing/qrcode/encoder/Encoder.cs | 597 ------------- .../3rd/zxing/qrcode/encoder/MaskUtil.cs | 271 ------ .../3rd/zxing/qrcode/encoder/MatrixUtil.cs | 600 ------------- .../3rd/zxing/qrcode/encoder/QRCode.cs | 125 --- shadowsocks-csharp/Data/libsscrypto.dll.gz | Bin 79596 -> 140908 bytes shadowsocks-csharp/Data/sysproxy.exe.gz | Bin 55391 -> 56029 bytes shadowsocks-csharp/Data/sysproxy64.exe.gz | Bin 61079 -> 61784 bytes shadowsocks-csharp/packages.config | 3 +- shadowsocks-csharp/shadowsocks-csharp.csproj | 63 +- shadowsocks-windows.sln | 64 +- test/packages.config | 4 + test/test.csproj | 4 +- 60 files changed, 49 insertions(+), 10959 deletions(-) delete mode 100755 shadowsocks-csharp/3rd/zxing/BarcodeFormat.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/BaseLuminanceSource.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/Binarizer.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/BinaryBitmap.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/BitmapLuminanceSource.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/DecodeHintType.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/EncodeHintType.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/LuminanceSource.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/Result.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/ResultMetadataType.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/ResultPoint.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/ResultPointCallback.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/WriterException.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/BitArray.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/BitMatrix.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/BitSource.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/DecoderResult.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/DefaultGridSampler.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/DetectorResult.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/GlobalHistogramBinarizer.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/GridSampler.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/HybridBinarizer.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/PerspectiveTransform.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/StringUtils.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/detector/MathUtils.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGF.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGFPoly.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonDecoder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonEncoder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/QRCodeReader.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/BitMatrixParser.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataBlock.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataMask.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/DecodedBitStreamParser.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/Decoder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/ErrorCorrectionLevel.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/FormatInformation.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/Mode.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/QRCodeDecoderMetaData.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/decoder/Version.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPattern.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPatternFinder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/Detector.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPattern.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternFinder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternInfo.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/BlockPair.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/ByteMatrix.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/Encoder.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/MaskUtil.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/MatrixUtil.cs delete mode 100755 shadowsocks-csharp/3rd/zxing/qrcode/encoder/QRCode.cs create mode 100644 test/packages.config diff --git a/shadowsocks-csharp/3rd/zxing/BarcodeFormat.cs b/shadowsocks-csharp/3rd/zxing/BarcodeFormat.cs deleted file mode 100755 index e20f65357..000000000 --- a/shadowsocks-csharp/3rd/zxing/BarcodeFormat.cs +++ /dev/null @@ -1,89 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing -{ - /// - /// Enumerates barcode formats known to this package. - /// - /// Sean Owen - [System.Flags] - public enum BarcodeFormat - { - /// Aztec 2D barcode format. - AZTEC = 1, - - /// CODABAR 1D format. - CODABAR = 2, - - /// Code 39 1D format. - CODE_39 = 4, - - /// Code 93 1D format. - CODE_93 = 8, - - /// Code 128 1D format. - CODE_128 = 16, - - /// Data Matrix 2D barcode format. - DATA_MATRIX = 32, - - /// EAN-8 1D format. - EAN_8 = 64, - - /// EAN-13 1D format. - EAN_13 = 128, - - /// ITF (Interleaved Two of Five) 1D format. - ITF = 256, - - /// MaxiCode 2D barcode format. - MAXICODE = 512, - - /// PDF417 format. - PDF_417 = 1024, - - /// QR Code 2D barcode format. - QR_CODE = 2048, - - /// RSS 14 - RSS_14 = 4096, - - /// RSS EXPANDED - RSS_EXPANDED = 8192, - - /// UPC-A 1D format. - UPC_A = 16384, - - /// UPC-E 1D format. - UPC_E = 32768, - - /// UPC/EAN extension format. Not a stand-alone format. - UPC_EAN_EXTENSION = 65536, - - /// MSI - MSI = 131072, - - /// Plessey - PLESSEY = 262144, - - /// - /// UPC_A | UPC_E | EAN_13 | EAN_8 | CODABAR | CODE_39 | CODE_93 | CODE_128 | ITF | RSS_14 | RSS_EXPANDED - /// without MSI (to many false-positives) - /// - All_1D = UPC_A | UPC_E | EAN_13 | EAN_8 | CODABAR | CODE_39 | CODE_93 | CODE_128 | ITF | RSS_14 | RSS_EXPANDED - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/BaseLuminanceSource.cs b/shadowsocks-csharp/3rd/zxing/BaseLuminanceSource.cs deleted file mode 100755 index c91d81db9..000000000 --- a/shadowsocks-csharp/3rd/zxing/BaseLuminanceSource.cs +++ /dev/null @@ -1,206 +0,0 @@ -/* -* Copyright 2012 ZXing.Net 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. -*/ - -using System; - -namespace ZXing -{ - /// - /// The base class for luminance sources which supports - /// cropping and rotating based upon the luminance values. - /// - public abstract class BaseLuminanceSource : LuminanceSource - { - // the following channel weights give nearly the same - // gray scale picture as the java version with BufferedImage.TYPE_BYTE_GRAY - // they are used in sub classes for luminance / gray scale calculation - protected const int RChannelWeight = 19562; - protected const int GChannelWeight = 38550; - protected const int BChannelWeight = 7424; - protected const int ChannelWeight = 16; - - /// - /// - /// - protected byte[] luminances; - - /// - /// Initializes a new instance of the class. - /// - /// The width. - /// The height. - protected BaseLuminanceSource(int width, int height) - : base(width, height) - { - luminances = new byte[width * height]; - } - - /// - /// Initializes a new instance of the class. - /// - /// The luminance array. - /// The width. - /// The height. - protected BaseLuminanceSource(byte[] luminanceArray, int width, int height) - : base(width, height) - { - luminances = new byte[width * height]; - Buffer.BlockCopy(luminanceArray, 0, luminances, 0, width * height); - } - - /// - /// Fetches one row of luminance data from the underlying platform's bitmap. Values range from - /// 0 (black) to 255 (white). It is preferable for implementations of this method - /// to only fetch this row rather than the whole image, since no 2D Readers may be installed and - /// getMatrix() may never be called. - /// - /// The row to fetch, 0 <= y < Height. - /// An optional preallocated array. If null or too small, it will be ignored. - /// Always use the returned object, and ignore the .length of the array. - /// - /// An array containing the luminance data. - /// - override public byte[] getRow(int y, byte[] row) - { - int width = Width; - if (row == null || row.Length < width) - { - row = new byte[width]; - } - for (int i = 0; i < width; i++) - row[i] = luminances[y * width + i]; - return row; - } - - public override byte[] Matrix - { - get { return luminances; } - } - - /// - /// Returns a new object with rotated image data by 90 degrees counterclockwise. - /// Only callable if {@link #isRotateSupported()} is true. - /// - /// - /// A rotated version of this object. - /// - public override LuminanceSource rotateCounterClockwise() - { - var rotatedLuminances = new byte[Width * Height]; - var newWidth = Height; - var newHeight = Width; - var localLuminances = Matrix; - for (var yold = 0; yold < Height; yold++) - { - for (var xold = 0; xold < Width; xold++) - { - var ynew = newHeight - xold - 1; - var xnew = yold; - rotatedLuminances[ynew * newWidth + xnew] = localLuminances[yold * Width + xold]; - } - } - return CreateLuminanceSource(rotatedLuminances, newWidth, newHeight); - } - - /// - /// TODO: not implemented yet - /// - /// - /// A rotated version of this object. - /// - public override LuminanceSource rotateCounterClockwise45() - { - // TODO: implement a good 45 degrees rotation without lost of information - return base.rotateCounterClockwise45(); - } - - /// - /// - /// Whether this subclass supports counter-clockwise rotation. - public override bool RotateSupported - { - get - { - return true; - } - } - - /// - /// Returns a new object with cropped image data. Implementations may keep a reference to the - /// original data rather than a copy. Only callable if CropSupported is true. - /// - /// The left coordinate, 0 <= left < Width. - /// The top coordinate, 0 <= top <= Height. - /// The width of the rectangle to crop. - /// The height of the rectangle to crop. - /// - /// A cropped version of this object. - /// - public override LuminanceSource crop(int left, int top, int width, int height) - { - if (left + width > Width || top + height > Height) - { - throw new ArgumentException("Crop rectangle does not fit within image data."); - } - var croppedLuminances = new byte[width * height]; - var oldLuminances = Matrix; - var oldWidth = Width; - var oldRightBound = left + width; - var oldBottomBound = top + height; - for (int yold = top, ynew = 0; yold < oldBottomBound; yold++, ynew++) - { - for (int xold = left, xnew = 0; xold < oldRightBound; xold++, xnew++) - { - croppedLuminances[ynew * width + xnew] = oldLuminances[yold * oldWidth + xold]; - } - } - return CreateLuminanceSource(croppedLuminances, width, height); - } - - /// - /// - /// Whether this subclass supports cropping. - public override bool CropSupported - { - get - { - return true; - } - } - - /// - /// - /// Whether this subclass supports invertion. - public override bool InversionSupported - { - get - { - return true; - } - } - - - /// - /// Should create a new luminance source with the right class type. - /// The method is used in methods crop and rotate. - /// - /// The new luminances. - /// The width. - /// The height. - /// - protected abstract LuminanceSource CreateLuminanceSource(byte[] newLuminances, int width, int height); - } -} diff --git a/shadowsocks-csharp/3rd/zxing/Binarizer.cs b/shadowsocks-csharp/3rd/zxing/Binarizer.cs deleted file mode 100755 index 213ec66aa..000000000 --- a/shadowsocks-csharp/3rd/zxing/Binarizer.cs +++ /dev/null @@ -1,104 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -using System; - -using ZXing.Common; - -namespace ZXing -{ - /// This class hierarchy provides a set of methods to convert luminance data to 1 bit data. - /// It allows the algorithm to vary polymorphically, for example allowing a very expensive - /// thresholding technique for servers and a fast one for mobile. It also permits the implementation - /// to vary, e.g. a JNI version for Android and a Java fallback version for other platforms. - /// - /// dswitkin@google.com (Daniel Switkin) - /// - public abstract class Binarizer - { - private readonly LuminanceSource source; - - /// - /// Initializes a new instance of the class. - /// - /// The source. - protected internal Binarizer(LuminanceSource source) - { - if (source == null) - { - throw new ArgumentException("Source must be non-null."); - } - this.source = source; - } - - /// - /// Gets the luminance source object. - /// - virtual public LuminanceSource LuminanceSource - { - get - { - return source; - } - } - - /// Converts one row of luminance data to 1 bit data. May actually do the conversion, or return - /// cached data. Callers should assume this method is expensive and call it as seldom as possible. - /// This method is intended for decoding 1D barcodes and may choose to apply sharpening. - /// For callers which only examine one row of pixels at a time, the same BitArray should be reused - /// and passed in with each call for performance. However it is legal to keep more than one row - /// at a time if needed. - /// - /// The row to fetch, 0 <= y < bitmap height. - /// An optional preallocated array. If null or too small, it will be ignored. - /// If used, the Binarizer will call BitArray.clear(). Always use the returned object. - /// - /// The array of bits for this row (true means black). - public abstract BitArray getBlackRow(int y, BitArray row); - - /// Converts a 2D array of luminance data to 1 bit data. As above, assume this method is expensive - /// and do not call it repeatedly. This method is intended for decoding 2D barcodes and may or - /// may not apply sharpening. Therefore, a row from this matrix may not be identical to one - /// fetched using getBlackRow(), so don't mix and match between them. - /// - /// The 2D array of bits for the image (true means black). - public abstract BitMatrix BlackMatrix { get; } - - /// Creates a new object with the same type as this Binarizer implementation, but with pristine - /// state. This is needed because Binarizer implementations may be stateful, e.g. keeping a cache - /// of 1 bit data. See Effective Java for why we can't use Java's clone() method. - /// - /// The LuminanceSource this Binarizer will operate on. - /// A new concrete Binarizer implementation object. - public abstract Binarizer createBinarizer(LuminanceSource source); - - /// - /// Gets the width of the luminance source object. - /// - public int Width - { - get { return source.Width; } - } - - /// - /// Gets the height of the luminance source object. - /// - public int Height - { - get { return source.Height; } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/BinaryBitmap.cs b/shadowsocks-csharp/3rd/zxing/BinaryBitmap.cs deleted file mode 100755 index fea1b2667..000000000 --- a/shadowsocks-csharp/3rd/zxing/BinaryBitmap.cs +++ /dev/null @@ -1,186 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -using System; -using ZXing.Common; - -namespace ZXing -{ - - /// This class is the core bitmap class used by ZXing to represent 1 bit data. Reader objects - /// accept a BinaryBitmap and attempt to decode it. - /// - /// - /// dswitkin@google.com (Daniel Switkin) - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - - public sealed class BinaryBitmap - { - private Binarizer binarizer; - private BitMatrix matrix; - - public BinaryBitmap(Binarizer binarizer) - { - if (binarizer == null) - { - throw new ArgumentException("Binarizer must be non-null."); - } - this.binarizer = binarizer; - } - - /// The width of the bitmap. - /// - public int Width - { - get - { - return binarizer.Width; - } - - } - /// The height of the bitmap. - /// - public int Height - { - get - { - return binarizer.Height; - } - - } - - /// Converts one row of luminance data to 1 bit data. May actually do the conversion, or return - /// cached data. Callers should assume this method is expensive and call it as seldom as possible. - /// This method is intended for decoding 1D barcodes and may choose to apply sharpening. - /// - /// - /// The row to fetch, 0 <= y < bitmap height. - /// - /// An optional preallocated array. If null or too small, it will be ignored. - /// If used, the Binarizer will call BitArray.clear(). Always use the returned object. - /// - /// The array of bits for this row (true means black). - /// - public BitArray getBlackRow(int y, BitArray row) - { - return binarizer.getBlackRow(y, row); - } - - /// Converts a 2D array of luminance data to 1 bit. As above, assume this method is expensive - /// and do not call it repeatedly. This method is intended for decoding 2D barcodes and may or - /// may not apply sharpening. Therefore, a row from this matrix may not be identical to one - /// fetched using getBlackRow(), so don't mix and match between them. - /// - /// - /// The 2D array of bits for the image (true means black). - /// - public BitMatrix BlackMatrix - { - get - { - // The matrix is created on demand the first time it is requested, then cached. There are two - // reasons for this: - // 1. This work will never be done if the caller only installs 1D Reader objects, or if a - // 1D Reader finds a barcode before the 2D Readers run. - // 2. This work will only be done once even if the caller installs multiple 2D Readers. - if (matrix == null) - { - matrix = binarizer.BlackMatrix; - } - return matrix; - } - } - - /// Whether this bitmap can be cropped. - /// - public bool CropSupported - { - get - { - return binarizer.LuminanceSource.CropSupported; - } - - } - - /// Returns a new object with cropped image data. Implementations may keep a reference to the - /// original data rather than a copy. Only callable if isCropSupported() is true. - /// - /// - /// The left coordinate, 0 <= left < getWidth(). - /// - /// The top coordinate, 0 <= top <= getHeight(). - /// - /// The width of the rectangle to crop. - /// - /// The height of the rectangle to crop. - /// - /// A cropped version of this object. - /// - public BinaryBitmap crop(int left, int top, int width, int height) - { - var newSource = binarizer.LuminanceSource.crop(left, top, width, height); - return new BinaryBitmap(binarizer.createBinarizer(newSource)); - } - - /// Whether this bitmap supports counter-clockwise rotation. - /// - public bool RotateSupported - { - get - { - return binarizer.LuminanceSource.RotateSupported; - } - - } - - /// - /// Returns a new object with rotated image data by 90 degrees counterclockwise. - /// Only callable if {@link #isRotateSupported()} is true. - /// - /// A rotated version of this object. - /// - public BinaryBitmap rotateCounterClockwise() - { - var newSource = binarizer.LuminanceSource.rotateCounterClockwise(); - return new BinaryBitmap(binarizer.createBinarizer(newSource)); - } - - /// - /// Returns a new object with rotated image data by 45 degrees counterclockwise. - /// Only callable if {@link #isRotateSupported()} is true. - /// - /// A rotated version of this object. - public BinaryBitmap rotateCounterClockwise45() - { - LuminanceSource newSource = binarizer.LuminanceSource.rotateCounterClockwise45(); - return new BinaryBitmap(binarizer.createBinarizer(newSource)); - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override string ToString() - { - var blackMatrix = BlackMatrix; - return blackMatrix != null ? blackMatrix.ToString() : String.Empty; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/BitmapLuminanceSource.cs b/shadowsocks-csharp/3rd/zxing/BitmapLuminanceSource.cs deleted file mode 100755 index 8c61f5318..000000000 --- a/shadowsocks-csharp/3rd/zxing/BitmapLuminanceSource.cs +++ /dev/null @@ -1,242 +0,0 @@ -/* -* Copyright 2012 ZXing.Net 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. -*/ - -using System; -using System.Drawing.Imaging; -using System.Drawing; -using System.Runtime.InteropServices; - -namespace ZXing -{ - public partial class BitmapLuminanceSource : BaseLuminanceSource - { - /// - /// Initializes a new instance of the class. - /// - /// The width. - /// The height. - protected BitmapLuminanceSource(int width, int height) - : base(width, height) - { - } - - /// - /// Initializes a new instance of the class - /// with the image of a Bitmap instance - /// - /// The bitmap. - public BitmapLuminanceSource(Bitmap bitmap) - : base(bitmap.Width, bitmap.Height) - { - var height = bitmap.Height; - var width = bitmap.Width; - - // In order to measure pure decoding speed, we convert the entire image to a greyscale array - // The underlying raster of image consists of bytes with the luminance values -#if WindowsCE - var data = bitmap.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadOnly, PixelFormat.Format24bppRgb); -#else - var data = bitmap.LockBits(new Rectangle(0, 0, width, height), ImageLockMode.ReadOnly, bitmap.PixelFormat); -#endif - try - { - var stride = Math.Abs(data.Stride); - var pixelWidth = stride/width; - - if (pixelWidth > 4) - { - // old slow way for unsupported bit depth - Color c; - for (int y = 0; y < height; y++) - { - int offset = y*width; - for (int x = 0; x < width; x++) - { - c = bitmap.GetPixel(x, y); - luminances[offset + x] = (byte)((RChannelWeight * c.R + GChannelWeight * c.G + BChannelWeight * c.B) >> ChannelWeight); - } - } - } - else - { - var strideStep = data.Stride; - var buffer = new byte[stride]; - var ptrInBitmap = data.Scan0; - -#if !WindowsCE - // prepare palette for 1 and 8 bit indexed bitmaps - var luminancePalette = new byte[bitmap.Palette.Entries.Length]; - for (var index = 0; index < bitmap.Palette.Entries.Length; index++) - { - var color = bitmap.Palette.Entries[index]; - luminancePalette[index] = (byte) ((RChannelWeight*color.R + - GChannelWeight*color.G + - BChannelWeight*color.B) >> ChannelWeight); - } - if (bitmap.PixelFormat == PixelFormat.Format32bppArgb || - bitmap.PixelFormat == PixelFormat.Format32bppPArgb) - { - pixelWidth = 40; - } - if ((int)bitmap.PixelFormat == 8207 || - (bitmap.Flags & (int)ImageFlags.ColorSpaceCmyk) == (int)ImageFlags.ColorSpaceCmyk) - { - pixelWidth = 41; - } -#endif - - for (int y = 0; y < height; y++) - { - // copy a scanline not the whole bitmap because of memory usage - Marshal.Copy(ptrInBitmap, buffer, 0, stride); -#if NET40 - ptrInBitmap = IntPtr.Add(ptrInBitmap, strideStep); -#else - ptrInBitmap = new IntPtr(ptrInBitmap.ToInt64() + strideStep); -#endif - var offset = y*width; - switch (pixelWidth) - { -#if !WindowsCE - case 0: - for (int x = 0; x*8 < width; x++) - { - for (int subX = 0; subX < 8 && 8*x + subX < width; subX++) - { - var index = (buffer[x] >> (7 - subX)) & 1; - luminances[offset + 8*x + subX] = luminancePalette[index]; - } - } - break; - case 1: - for (int x = 0; x < width; x++) - { - luminances[offset + x] = luminancePalette[buffer[x]]; - } - break; -#endif - case 2: - // should be RGB565 or RGB555, assume RGB565 - { - var maxIndex = 2*width; - for (int index = 0; index < maxIndex; index += 2) - { - var byte1 = buffer[index]; - var byte2 = buffer[index + 1]; - - var b5 = byte1 & 0x1F; - var g5 = (((byte1 & 0xE0) >> 5) | ((byte2 & 0x03) << 3)) & 0x1F; - var r5 = (byte2 >> 2) & 0x1F; - var r8 = (r5*527 + 23) >> 6; - var g8 = (g5*527 + 23) >> 6; - var b8 = (b5*527 + 23) >> 6; - - luminances[offset] = (byte)((RChannelWeight * r8 + GChannelWeight * g8 + BChannelWeight * b8) >> ChannelWeight); - offset++; - } - } - break; - case 3: - { - var maxIndex = width*3; - for (int x = 0; x < maxIndex; x += 3) - { - var luminance = (byte) ((BChannelWeight*buffer[x] + - GChannelWeight*buffer[x + 1] + - RChannelWeight*buffer[x + 2]) >> ChannelWeight); - luminances[offset] = luminance; - offset++; - } - } - break; - case 4: - // 4 bytes without alpha channel value - { - var maxIndex = 4*width; - for (int x = 0; x < maxIndex; x += 4) - { - var luminance = (byte) ((BChannelWeight*buffer[x] + - GChannelWeight*buffer[x + 1] + - RChannelWeight*buffer[x + 2]) >> ChannelWeight); - - luminances[offset] = luminance; - offset++; - } - } - break; - case 40: - // with alpha channel; some barcodes are completely black if you - // only look at the r, g and b channel but the alpha channel controls - // the view - { - var maxIndex = 4*width; - for (int x = 0; x < maxIndex; x += 4) - { - var luminance = (byte) ((BChannelWeight*buffer[x] + - GChannelWeight*buffer[x + 1] + - RChannelWeight*buffer[x + 2]) >> ChannelWeight); - - // calculating the resulting luminance based upon a white background - // var alpha = buffer[x * pixelWidth + 3] / 255.0; - // luminance = (byte)(luminance * alpha + 255 * (1 - alpha)); - var alpha = buffer[x + 3]; - luminance = (byte) (((luminance*alpha) >> 8) + (255*(255 - alpha) >> 8) + 1); - luminances[offset] = luminance; - offset++; - } - } - break; - case 41: - // CMYK color space - { - var maxIndex = 4 * width; - for (int x = 0; x < maxIndex; x += 4) - { - var luminance = (byte) (255 - ((BChannelWeight*buffer[x] + - GChannelWeight*buffer[x + 1] + - RChannelWeight*buffer[x + 2]) >> ChannelWeight)); - // Ignore value of k at the moment - luminances[offset] = luminance; - offset++; - } - } - break; - default: - throw new NotSupportedException(); - } - } - } - } - finally - { - bitmap.UnlockBits(data); - } - } - - /// - /// Should create a new luminance source with the right class type. - /// The method is used in methods crop and rotate. - /// - /// The new luminances. - /// The width. - /// The height. - /// - protected override LuminanceSource CreateLuminanceSource(byte[] newLuminances, int width, int height) - { - return new BitmapLuminanceSource(width, height) { luminances = newLuminances }; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/DecodeHintType.cs b/shadowsocks-csharp/3rd/zxing/DecodeHintType.cs deleted file mode 100755 index 8ba21bbb6..000000000 --- a/shadowsocks-csharp/3rd/zxing/DecodeHintType.cs +++ /dev/null @@ -1,125 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -namespace ZXing -{ - /// - /// Encapsulates a type of hint that a caller may pass to a barcode reader to help it - /// more quickly or accurately decode it. It is up to implementations to decide what, - /// if anything, to do with the information that is supplied. - /// - /// - /// Sean Owen - /// dswitkin@google.com (Daniel Switkin) - public enum DecodeHintType - { - /// - /// Unspecified, application-specific hint. Maps to an unspecified . - /// - OTHER, - - /// - /// Image is a pure monochrome image of a barcode. Doesn't matter what it maps to; - /// use = true. - /// - PURE_BARCODE, - - /// - /// Image is known to be of one of a few possible formats. - /// Maps to a of s. - /// - POSSIBLE_FORMATS, - - /// - /// Spend more time to try to find a barcode; optimize for accuracy, not speed. - /// Doesn't matter what it maps to; use = true. - /// - TRY_HARDER, - - /// - /// Specifies what character encoding to use when decoding, where applicable (type String) - /// - CHARACTER_SET, - - /// - /// Allowed lengths of encoded data -- reject anything else. Maps to an int[]. - /// - ALLOWED_LENGTHS, - - /// - /// Assume Code 39 codes employ a check digit. Maps to . - /// - ASSUME_CODE_39_CHECK_DIGIT, - - /// - /// The caller needs to be notified via callback when a possible - /// is found. Maps to a . - /// - NEED_RESULT_POINT_CALLBACK, - - /// - /// Assume MSI codes employ a check digit. Maps to . - /// - ASSUME_MSI_CHECK_DIGIT, - - /// - /// if Code39 could be detected try to use extended mode for full ASCII character set - /// Maps to . - /// - USE_CODE_39_EXTENDED_MODE, - - /// - /// Don't fail if a Code39 is detected but can't be decoded in extended mode. - /// Return the raw Code39 result instead. Maps to . - /// - RELAXED_CODE_39_EXTENDED_MODE, - - /// - /// 1D readers supporting rotation with TRY_HARDER enabled. - /// But BarcodeReader class can do auto-rotating for 1D and 2D codes. - /// Enabling that option prevents 1D readers doing double rotation. - /// BarcodeReader enables that option automatically if "global" auto-rotation is enabled. - /// Maps to . - /// - TRY_HARDER_WITHOUT_ROTATION, - - /// - /// Assume the barcode is being processed as a GS1 barcode, and modify behavior as needed. - /// For example this affects FNC1 handling for Code 128 (aka GS1-128). Doesn't matter what it maps to; - /// use . - /// - ASSUME_GS1, - - /// - /// If true, return the start and end digits in a Codabar barcode instead of stripping them. They - /// are alpha, whereas the rest are numeric. By default, they are stripped, but this causes them - /// to not be. Doesn't matter what it maps to; use . - /// - RETURN_CODABAR_START_END, - - /// - /// Allowed extension lengths for EAN or UPC barcodes. Other formats will ignore this. - /// Maps to an of the allowed extension lengths, for example [2], [5], or [2, 5]. - /// If it is optional to have an extension, do not set this hint. If this is set, - /// and a UPC or EAN barcode is found but an extension is not, then no result will be returned - /// at all. - /// - ALLOWED_EAN_EXTENSIONS - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/EncodeHintType.cs b/shadowsocks-csharp/3rd/zxing/EncodeHintType.cs deleted file mode 100755 index 01b17f8cd..000000000 --- a/shadowsocks-csharp/3rd/zxing/EncodeHintType.cs +++ /dev/null @@ -1,131 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -namespace ZXing -{ - /// - /// These are a set of hints that you may pass to Writers to specify their behavior. - /// - /// dswitkin@google.com (Daniel Switkin) - public enum EncodeHintType - { - /// - /// Specifies the width of the barcode image - /// type: - /// - WIDTH, - - /// - /// Specifies the height of the barcode image - /// type: - /// - HEIGHT, - - /// - /// Don't put the content string into the output image. - /// type: - /// - PURE_BARCODE, - - /// - /// Specifies what degree of error correction to use, for example in QR Codes. - /// Type depends on the encoder. For example for QR codes it's type - /// - /// For Aztec it is of type , representing the minimal percentage of error correction words. - /// Note: an Aztec symbol should have a minimum of 25% EC words. - /// For PDF417 it is of type or (between 0 and 8), - /// - ERROR_CORRECTION, - - /// - /// Specifies what character encoding to use where applicable. - /// type: - /// - CHARACTER_SET, - - /// - /// Specifies margin, in pixels, to use when generating the barcode. The meaning can vary - /// by format; for example it controls margin before and after the barcode horizontally for - /// most 1D formats. - /// type: - /// - MARGIN, - - /// - /// Specifies whether to use compact mode for PDF417. - /// type: - /// - PDF417_COMPACT, - - /// - /// Specifies what compaction mode to use for PDF417. - /// type: - /// - PDF417_COMPACTION, - - /// - /// Specifies the minimum and maximum number of rows and columns for PDF417. - /// type: - /// - PDF417_DIMENSIONS, - - /// - /// Don't append ECI segment. - /// That is against the specification of QR Code but some - /// readers have problems if the charset is switched from - /// ISO-8859-1 (default) to UTF-8 with the necessary ECI segment. - /// If you set the property to true you can use UTF-8 encoding - /// and the ECI segment is omitted. - /// type: - /// - DISABLE_ECI, - - /// - /// Specifies the matrix shape for Data Matrix (type ) - /// - DATA_MATRIX_SHAPE, - - /// - /// Specifies a minimum barcode size (type ). Only applicable to Data Matrix now. - /// - MIN_SIZE, - - /// - /// Specifies a maximum barcode size (type ). Only applicable to Data Matrix now. - /// - MAX_SIZE, - - /// - /// if true, don't switch to codeset C for numbers - /// - CODE128_FORCE_CODESET_B, - - /// - /// Specifies the default encodation for Data Matrix (type ) - /// Make sure that the content fits into the encodation value, otherwise there will be an exception thrown. - /// standard value: Encodation.ASCII - /// - DATA_MATRIX_DEFAULT_ENCODATION, - - /// - /// Specifies the required number of layers for an Aztec code: - /// a negative number (-1, -2, -3, -4) specifies a compact Aztec code - /// 0 indicates to use the minimum number of layers (the default) - /// a positive number (1, 2, .. 32) specifies a normal (non-compact) Aztec code - /// - AZTEC_LAYERS, - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/LuminanceSource.cs b/shadowsocks-csharp/3rd/zxing/LuminanceSource.cs deleted file mode 100755 index 371a27c71..000000000 --- a/shadowsocks-csharp/3rd/zxing/LuminanceSource.cs +++ /dev/null @@ -1,198 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -using System; -using System.Text; - -namespace ZXing -{ - /// The purpose of this class hierarchy is to abstract different bitmap implementations across - /// platforms into a standard interface for requesting greyscale luminance values. The interface - /// only provides immutable methods; therefore crop and rotation create copies. This is to ensure - /// that one Reader does not modify the original luminance source and leave it in an unknown state - /// for other Readers in the chain. - /// - /// dswitkin@google.com (Daniel Switkin) - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public abstract class LuminanceSource - { - private int width; - private int height; - - protected LuminanceSource(int width, int height) - { - this.width = width; - this.height = height; - } - - /// Fetches one row of luminance data from the underlying platform's bitmap. Values range from - /// 0 (black) to 255 (white). Because Java does not have an unsigned byte type, callers will have - /// to bitwise and with 0xff for each value. It is preferable for implementations of this method - /// to only fetch this row rather than the whole image, since no 2D Readers may be installed and - /// getMatrix() may never be called. - /// - /// - /// The row to fetch, 0 <= y < Height. - /// - /// An optional preallocated array. If null or too small, it will be ignored. - /// Always use the returned object, and ignore the .length of the array. - /// - /// An array containing the luminance data. - /// - public abstract byte[] getRow(int y, byte[] row); - - /// Fetches luminance data for the underlying bitmap. Values should be fetched using: - /// int luminance = array[y * width + x] & 0xff; - /// - /// - /// A row-major 2D array of luminance values. Do not use result.length as it may be - /// larger than width * height bytes on some platforms. Do not modify the contents - /// of the result. - /// - public abstract byte[] Matrix { get; } - - /// The width of the bitmap. - virtual public int Width - { - get - { - return width; - } - protected set - { - width = value; - } - } - - /// The height of the bitmap. - virtual public int Height - { - get - { - return height; - } - protected set - { - height = value; - } - } - - /// Whether this subclass supports cropping. - virtual public bool CropSupported - { - get - { - return false; - } - } - - /// Returns a new object with cropped image data. Implementations may keep a reference to the - /// original data rather than a copy. Only callable if CropSupported is true. - /// - /// - /// The left coordinate, 0 <= left < Width. - /// - /// The top coordinate, 0 <= top <= Height. - /// - /// The width of the rectangle to crop. - /// - /// The height of the rectangle to crop. - /// - /// A cropped version of this object. - /// - public virtual LuminanceSource crop(int left, int top, int width, int height) - { - throw new NotSupportedException("This luminance source does not support cropping."); - } - - /// Whether this subclass supports counter-clockwise rotation. - virtual public bool RotateSupported - { - get - { - return false; - } - } - - /// - /// Returns a new object with rotated image data by 90 degrees counterclockwise. - /// Only callable if {@link #isRotateSupported()} is true. - /// - /// A rotated version of this object. - /// - public virtual LuminanceSource rotateCounterClockwise() - { - throw new NotSupportedException("This luminance source does not support rotation."); - } - - /// - /// Returns a new object with rotated image data by 45 degrees counterclockwise. - /// Only callable if {@link #isRotateSupported()} is true. - /// - /// A rotated version of this object. - public virtual LuminanceSource rotateCounterClockwise45() - { - throw new NotSupportedException("This luminance source does not support rotation by 45 degrees."); - } - - /// - /// - /// Whether this subclass supports invertion. - virtual public bool InversionSupported - { - get - { - return false; - } - } - - override public String ToString() - { - var row = new byte[width]; - var result = new StringBuilder(height * (width + 1)); - for (int y = 0; y < height; y++) - { - row = getRow(y, row); - for (int x = 0; x < width; x++) - { - int luminance = row[x] & 0xFF; - char c; - if (luminance < 0x40) - { - c = '#'; - } - else if (luminance < 0x80) - { - c = '+'; - } - else if (luminance < 0xC0) - { - c = '.'; - } - else - { - c = ' '; - } - result.Append(c); - } - result.Append('\n'); - } - return result.ToString(); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/Result.cs b/shadowsocks-csharp/3rd/zxing/Result.cs deleted file mode 100755 index 3aa6f5b81..000000000 --- a/shadowsocks-csharp/3rd/zxing/Result.cs +++ /dev/null @@ -1,161 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -namespace ZXing -{ - /// - /// Encapsulates the result of decoding a barcode within an image. - /// - public sealed class Result - { - /// raw text encoded by the barcode, if applicable, otherwise null - public String Text { get; private set; } - - /// raw bytes encoded by the barcode, if applicable, otherwise null - public byte[] RawBytes { get; private set; } - - /// - /// points related to the barcode in the image. These are typically points - /// identifying finder patterns or the corners of the barcode. The exact meaning is - /// specific to the type of barcode that was decoded. - /// - public ResultPoint[] ResultPoints { get; private set; } - - /// {@link BarcodeFormat} representing the format of the barcode that was decoded - public BarcodeFormat BarcodeFormat { get; private set; } - - /// - /// {@link Hashtable} mapping {@link ResultMetadataType} keys to values. May be - /// null. This contains optional metadata about what was detected about the barcode, - /// like orientation. - /// - public IDictionary ResultMetadata { get; private set; } - - /// - /// Gets the timestamp. - /// - public long Timestamp { get; private set; } - - /// - /// Initializes a new instance of the class. - /// - /// The text. - /// The raw bytes. - /// The result points. - /// The format. - public Result(String text, - byte[] rawBytes, - ResultPoint[] resultPoints, - BarcodeFormat format) - : this(text, rawBytes, resultPoints, format, DateTime.Now.Ticks) - { - } - - /// - /// Initializes a new instance of the class. - /// - /// The text. - /// The raw bytes. - /// The result points. - /// The format. - /// The timestamp. - public Result(String text, byte[] rawBytes, ResultPoint[] resultPoints, BarcodeFormat format, long timestamp) - { - if (text == null && rawBytes == null) - { - throw new ArgumentException("Text and bytes are null"); - } - Text = text; - RawBytes = rawBytes; - ResultPoints = resultPoints; - BarcodeFormat = format; - ResultMetadata = null; - Timestamp = timestamp; - } - - /// - /// Adds one metadata to the result - /// - /// The type. - /// The value. - public void putMetadata(ResultMetadataType type, Object value) - { - if (ResultMetadata == null) - { - ResultMetadata = new Dictionary(); - } - ResultMetadata[type] = value; - } - - /// - /// Adds a list of metadata to the result - /// - /// The metadata. - public void putAllMetadata(IDictionary metadata) - { - if (metadata != null) - { - if (ResultMetadata == null) - { - ResultMetadata = metadata; - } - else - { - foreach (var entry in metadata) - ResultMetadata[entry.Key] = entry.Value; - } - } - } - - /// - /// Adds the result points. - /// - /// The new points. - public void addResultPoints(ResultPoint[] newPoints) - { - var oldPoints = ResultPoints; - if (oldPoints == null) - { - ResultPoints = newPoints; - } - else if (newPoints != null && newPoints.Length > 0) - { - var allPoints = new ResultPoint[oldPoints.Length + newPoints.Length]; - Array.Copy(oldPoints, 0, allPoints, 0, oldPoints.Length); - Array.Copy(newPoints, 0, allPoints, oldPoints.Length, newPoints.Length); - ResultPoints = allPoints; - } - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - if (Text == null) - { - return "[" + RawBytes.Length + " bytes]"; - } - return Text; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/ResultMetadataType.cs b/shadowsocks-csharp/3rd/zxing/ResultMetadataType.cs deleted file mode 100755 index 360357c80..000000000 --- a/shadowsocks-csharp/3rd/zxing/ResultMetadataType.cs +++ /dev/null @@ -1,102 +0,0 @@ -/* - * Copyright 2008 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. - */ - -namespace ZXing -{ - /// - /// Represents some type of metadata about the result of the decoding that the decoder - /// wishes to communicate back to the caller. - /// - /// Sean Owen - public enum ResultMetadataType - { - /// - /// Unspecified, application-specific metadata. Maps to an unspecified {@link Object}. - /// - OTHER, - - /// - /// Denotes the likely approximate orientation of the barcode in the image. This value - /// is given as degrees rotated clockwise from the normal, upright orientation. - /// For example a 1D barcode which was found by reading top-to-bottom would be - /// said to have orientation "90". This key maps to an {@link Integer} whose - /// value is in the range [0,360). - /// - ORIENTATION, - - /// - ///

2D barcode formats typically encode text, but allow for a sort of 'byte mode' - /// which is sometimes used to encode binary data. While {@link Result} makes available - /// the complete raw bytes in the barcode for these formats, it does not offer the bytes - /// from the byte segments alone.

- ///

This maps to a {@link java.util.List} of byte arrays corresponding to the - /// raw bytes in the byte segments in the barcode, in order.

- ///
- BYTE_SEGMENTS, - - /// - /// Error correction level used, if applicable. The value type depends on the - /// format, but is typically a String. - /// - ERROR_CORRECTION_LEVEL, - - /// - /// For some periodicals, indicates the issue number as an {@link Integer}. - /// - ISSUE_NUMBER, - - /// - /// For some products, indicates the suggested retail price in the barcode as a - /// formatted {@link String}. - /// - SUGGESTED_PRICE, - - /// - /// For some products, the possible country of manufacture as a {@link String} denoting the - /// ISO country code. Some map to multiple possible countries, like "US/CA". - /// - POSSIBLE_COUNTRY, - - /// - /// For some products, the extension text - /// - UPC_EAN_EXTENSION, - - /// - /// If the code format supports structured append and - /// the current scanned code is part of one then the - /// sequence number is given with it. - /// - STRUCTURED_APPEND_SEQUENCE, - - /// - /// If the code format supports structured append and - /// the current scanned code is part of one then the - /// parity is given with it. - /// - STRUCTURED_APPEND_PARITY, - - /// - /// PDF417-specific metadata - /// - PDF417_EXTRA_METADATA, - - /// - /// Aztec-specific metadata - /// - AZTEC_EXTRA_METADATA - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/ResultPoint.cs b/shadowsocks-csharp/3rd/zxing/ResultPoint.cs deleted file mode 100755 index d3f39f2df..000000000 --- a/shadowsocks-csharp/3rd/zxing/ResultPoint.cs +++ /dev/null @@ -1,191 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -using ZXing.Common.Detector; - -namespace ZXing -{ - /// - /// Encapsulates a point of interest in an image containing a barcode. Typically, this - /// would be the location of a finder pattern or the corner of the barcode, for example. - /// - /// Sean Owen - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - public class ResultPoint - { - private readonly float x; - private readonly float y; - private readonly byte[] bytesX; - private readonly byte[] bytesY; - private String toString; - - /// - /// Initializes a new instance of the class. - /// - public ResultPoint() - { - } - - /// - /// Initializes a new instance of the class. - /// - /// The x. - /// The y. - public ResultPoint(float x, float y) - { - this.x = x; - this.y = y; - // calculate only once for GetHashCode - bytesX = BitConverter.GetBytes(x); - bytesY = BitConverter.GetBytes(y); - } - - /// - /// Gets the X. - /// - virtual public float X - { - get - { - return x; - } - } - - /// - /// Gets the Y. - /// - virtual public float Y - { - get - { - return y; - } - } - - /// - /// Determines whether the specified is equal to this instance. - /// - /// The to compare with this instance. - /// - /// true if the specified is equal to this instance; otherwise, false. - /// - public override bool Equals(Object other) - { - var otherPoint = other as ResultPoint; - if (otherPoint == null) - return false; - return x == otherPoint.x && y == otherPoint.y; - } - - /// - /// Returns a hash code for this instance. - /// - /// - /// A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - /// - public override int GetHashCode() - { - return 31 * ((bytesX[0] << 24) + (bytesX[1] << 16) + (bytesX[2] << 8) + bytesX[3]) + - (bytesY[0] << 24) + (bytesY[1] << 16) + (bytesY[2] << 8) + bytesY[3]; - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - if (toString == null) - { - var result = new System.Text.StringBuilder(25); - result.AppendFormat(System.Globalization.CultureInfo.CurrentUICulture, "({0}, {1})", x, y); - toString = result.ToString(); - } - return toString; - } - - /// - /// Orders an array of three ResultPoints in an order [A,B,C] such that AB < AC and - /// BC < AC and the angle between BC and BA is less than 180 degrees. - /// - public static void orderBestPatterns(ResultPoint[] patterns) - { - // Find distances between pattern centers - float zeroOneDistance = distance(patterns[0], patterns[1]); - float oneTwoDistance = distance(patterns[1], patterns[2]); - float zeroTwoDistance = distance(patterns[0], patterns[2]); - - ResultPoint pointA, pointB, pointC; - // Assume one closest to other two is B; A and C will just be guesses at first - if (oneTwoDistance >= zeroOneDistance && oneTwoDistance >= zeroTwoDistance) - { - pointB = patterns[0]; - pointA = patterns[1]; - pointC = patterns[2]; - } - else if (zeroTwoDistance >= oneTwoDistance && zeroTwoDistance >= zeroOneDistance) - { - pointB = patterns[1]; - pointA = patterns[0]; - pointC = patterns[2]; - } - else - { - pointB = patterns[2]; - pointA = patterns[0]; - pointC = patterns[1]; - } - - // Use cross product to figure out whether A and C are correct or flipped. - // This asks whether BC x BA has a positive z component, which is the arrangement - // we want for A, B, C. If it's negative, then we've got it flipped around and - // should swap A and C. - if (crossProductZ(pointA, pointB, pointC) < 0.0f) - { - ResultPoint temp = pointA; - pointA = pointC; - pointC = temp; - } - - patterns[0] = pointA; - patterns[1] = pointB; - patterns[2] = pointC; - } - - - /// - /// distance between two points - /// - public static float distance(ResultPoint pattern1, ResultPoint pattern2) - { - return MathUtils.distance(pattern1.x, pattern1.y, pattern2.x, pattern2.y); - } - - /// - /// Returns the z component of the cross product between vectors BC and BA. - /// - private static float crossProductZ(ResultPoint pointA, ResultPoint pointB, ResultPoint pointC) - { - float bX = pointB.x; - float bY = pointB.y; - return ((pointC.x - bX) * (pointA.y - bY)) - ((pointC.y - bY) * (pointA.x - bX)); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/ResultPointCallback.cs b/shadowsocks-csharp/3rd/zxing/ResultPointCallback.cs deleted file mode 100755 index 19c6f23a9..000000000 --- a/shadowsocks-csharp/3rd/zxing/ResultPointCallback.cs +++ /dev/null @@ -1,26 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -namespace ZXing -{ - /// Callback which is invoked when a possible result point (significant - /// point in the barcode image such as a corner) is found. - /// - /// - /// - /// - public delegate void ResultPointCallback(ResultPoint point); -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/WriterException.cs b/shadowsocks-csharp/3rd/zxing/WriterException.cs deleted file mode 100755 index f6cd3395d..000000000 --- a/shadowsocks-csharp/3rd/zxing/WriterException.cs +++ /dev/null @@ -1,55 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using System; - -namespace ZXing -{ - /// - /// A base class which covers the range of exceptions which may occur when encoding a barcode using - /// the Writer framework. - /// - /// dswitkin@google.com (Daniel Switkin) - [Serializable] - public sealed class WriterException : Exception - { - /// - /// Initializes a new instance of the class. - /// - public WriterException() - { - } - - /// - /// Initializes a new instance of the class. - /// - /// The message. - public WriterException(String message) - :base(message) - { - } - - /// - /// Initializes a new instance of the class. - /// - /// The message. - /// The inner exc. - public WriterException(String message, Exception innerExc) - : base(message, innerExc) - { - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/BitArray.cs b/shadowsocks-csharp/3rd/zxing/common/BitArray.cs deleted file mode 100755 index 994d5ef59..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/BitArray.cs +++ /dev/null @@ -1,278 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.Common -{ - /// - /// A simple, fast array of bits, represented compactly by an array of ints internally. - /// - /// Sean Owen - public sealed class BitArray - { - private int[] bits; - private int size; - - public int Size - { - get - { - return size; - } - } - - public int SizeInBytes - { - get - { - return (size + 7) >> 3; - } - } - - public bool this[int i] - { - get - { - return (bits[i >> 5] & (1 << (i & 0x1F))) != 0; - } - set - { - if (value) - bits[i >> 5] |= 1 << (i & 0x1F); - } - } - - public BitArray() - { - this.size = 0; - this.bits = new int[1]; - } - - public BitArray(int size) - { - if (size < 1) - { - throw new ArgumentException("size must be at least 1"); - } - this.size = size; - this.bits = makeArray(size); - } - - // For testing only - private BitArray(int[] bits, int size) - { - this.bits = bits; - this.size = size; - } - - private void ensureCapacity(int size) - { - if (size > bits.Length << 5) - { - int[] newBits = makeArray(size); - System.Array.Copy(bits, 0, newBits, 0, bits.Length); - bits = newBits; - } - } - - - private static int numberOfTrailingZeros(int num) - { - var index = (-num & num)%37; - if (index < 0) - index *= -1; - return _lookup[index]; - } - - private static readonly int[] _lookup = - { - 32, 0, 1, 26, 2, 23, 27, 0, 3, 16, 24, 30, 28, 11, 0, 13, 4, 7, 17, - 0, 25, 22, 31, 15, 29, 10, 12, 6, 0, 21, 14, 9, 5, 20, 8, 19, 18 - }; - - - /// Sets a block of 32 bits, starting at bit i. - /// - /// - /// first bit to set - /// - /// the new value of the next 32 bits. Note again that the least-significant bit - /// corresponds to bit i, the next-least-significant to i+1, and so on. - /// - public void setBulk(int i, int newBits) - { - bits[i >> 5] = newBits; - } - - - /// Clears all bits (sets to false). - public void clear() - { - int max = bits.Length; - for (int i = 0; i < max; i++) - { - bits[i] = 0; - } - } - - /// - /// Appends the bit. - /// - /// The bit. - public void appendBit(bool bit) - { - ensureCapacity(size + 1); - if (bit) - { - bits[size >> 5] |= 1 << (size & 0x1F); - } - size++; - } - - /// underlying array of ints. The first element holds the first 32 bits, and the least - /// significant bit is bit 0. - /// - public int[] Array - { - get { return bits; } - } - - /// - /// Appends the least-significant bits, from value, in order from most-significant to - /// least-significant. For example, appending 6 bits from 0x000001E will append the bits - /// 0, 1, 1, 1, 1, 0 in that order. - /// - /// The value. - /// The num bits. - public void appendBits(int value, int numBits) - { - if (numBits < 0 || numBits > 32) - { - throw new ArgumentException("Num bits must be between 0 and 32"); - } - ensureCapacity(size + numBits); - for (int numBitsLeft = numBits; numBitsLeft > 0; numBitsLeft--) - { - appendBit(((value >> (numBitsLeft - 1)) & 0x01) == 1); - } - } - - public void appendBitArray(BitArray other) - { - int otherSize = other.size; - ensureCapacity(size + otherSize); - for (int i = 0; i < otherSize; i++) - { - appendBit(other[i]); - } - } - - public void xor(BitArray other) - { - if (bits.Length != other.bits.Length) - { - throw new ArgumentException("Sizes don't match"); - } - for (int i = 0; i < bits.Length; i++) - { - // The last byte could be incomplete (i.e. not have 8 bits in - // it) but there is no problem since 0 XOR 0 == 0. - bits[i] ^= other.bits[i]; - } - } - - /// - /// Toes the bytes. - /// - /// first bit to start writing - /// array to write into. Bytes are written most-significant byte first. This is the opposite - /// of the internal representation, which is exposed by BitArray - /// position in array to start writing - /// how many bytes to write - public void toBytes(int bitOffset, byte[] array, int offset, int numBytes) - { - for (int i = 0; i < numBytes; i++) - { - int theByte = 0; - for (int j = 0; j < 8; j++) - { - if (this[bitOffset]) - { - theByte |= 1 << (7 - j); - } - bitOffset++; - } - array[offset + i] = (byte)theByte; - } - } - - private static int[] makeArray(int size) - { - return new int[(size + 31) >> 5]; - } - - /// - /// Determines whether the specified is equal to this instance. - /// - /// The to compare with this instance. - /// - /// true if the specified is equal to this instance; otherwise, false. - /// - public override bool Equals(Object o) - { - var other = o as BitArray; - if (other == null) - return false; - if (size != other.size) - return false; - for (var index = 0; index < size; index++) - { - if (bits[index] != other.bits[index]) - return false; - } - return true; - } - - /// - /// Returns a hash code for this instance. - /// - /// - /// A hash code for this instance, suitable for use in hashing algorithms and data structures like a hash table. - /// - public override int GetHashCode() - { - var hash = size; - foreach (var bit in bits) - { - hash = 31 * hash + bit.GetHashCode(); - } - return hash; - } - - - /// - /// Erstellt ein neues Objekt, das eine Kopie der aktuellen Instanz darstellt. - /// - /// - /// Ein neues Objekt, das eine Kopie dieser Instanz darstellt. - /// - public object Clone() - { - return new BitArray((int[])bits.Clone(), size); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/BitMatrix.cs b/shadowsocks-csharp/3rd/zxing/common/BitMatrix.cs deleted file mode 100755 index 9b250548c..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/BitMatrix.cs +++ /dev/null @@ -1,259 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.Common -{ - /// - ///

Represents a 2D matrix of bits. In function arguments below, and throughout the common - /// module, x is the column position, and y is the row position. The ordering is always x, y. - /// The origin is at the top-left.

- ///

Internally the bits are represented in a 1-D array of 32-bit ints. However, each row begins - /// with a new int. This is done intentionally so that we can copy out a row into a BitArray very - /// efficiently.

- ///

The ordering of bits is row-major. Within each int, the least significant bits are used first, - /// meaning they represent lower x values. This is compatible with BitArray's implementation.

- ///
- /// Sean Owen - /// dswitkin@google.com (Daniel Switkin) - public sealed partial class BitMatrix - { - private readonly int width; - private readonly int height; - private readonly int rowSize; - private readonly int[] bits; - - /// The width of the matrix - /// - public int Width - { - get - { - return width; - } - - } - /// The height of the matrix - /// - public int Height - { - get - { - return height; - } - - } - - // A helper to construct a square matrix. - public BitMatrix(int dimension) - : this(dimension, dimension) - { - } - - public BitMatrix(int width, int height) - { - if (width < 1 || height < 1) - { - throw new System.ArgumentException("Both dimensions must be greater than 0"); - } - this.width = width; - this.height = height; - this.rowSize = (width + 31) >> 5; - bits = new int[rowSize * height]; - } - - private BitMatrix(int width, int height, int rowSize, int[] bits) - { - this.width = width; - this.height = height; - this.rowSize = rowSize; - this.bits = bits; - } - - ///

Gets the requested bit, where true means black.

- /// - ///
- /// The horizontal component (i.e. which column) - /// - /// The vertical component (i.e. which row) - /// - /// value of given bit in matrix - /// - public bool this[int x, int y] - { - get - { - int offset = y * rowSize + (x >> 5); - return (((int)((uint)(bits[offset]) >> (x & 0x1f))) & 1) != 0; - } - set - { - if (value) - { - int offset = y * rowSize + (x >> 5); - bits[offset] |= 1 << (x & 0x1f); - } - } - } - - ///

Flips the given bit.

- /// - ///
- /// The horizontal component (i.e. which column) - /// - /// The vertical component (i.e. which row) - /// - public void flip(int x, int y) - { - int offset = y * rowSize + (x >> 5); - bits[offset] ^= 1 << (x & 0x1f); - } - - - ///

Sets a square region of the bit matrix to true.

- /// - ///
- /// The horizontal position to begin at (inclusive) - /// - /// The vertical position to begin at (inclusive) - /// - /// The width of the region - /// - /// The height of the region - /// - public void setRegion(int left, int top, int width, int height) - { - if (top < 0 || left < 0) - { - throw new System.ArgumentException("Left and top must be nonnegative"); - } - if (height < 1 || width < 1) - { - throw new System.ArgumentException("Height and width must be at least 1"); - } - int right = left + width; - int bottom = top + height; - if (bottom > this.height || right > this.width) - { - throw new System.ArgumentException("The region must fit inside the matrix"); - } - for (int y = top; y < bottom; y++) - { - int offset = y * rowSize; - for (int x = left; x < right; x++) - { - bits[offset + (x >> 5)] |= 1 << (x & 0x1f); - } - } - } - - /// A fast method to retrieve one row of data from the matrix as a BitArray. - /// - /// - /// The row to retrieve - /// - /// An optional caller-allocated BitArray, will be allocated if null or too small - /// - /// The resulting BitArray - this reference should always be used even when passing - /// your own row - /// - public BitArray getRow(int y, BitArray row) - { - if (row == null || row.Size < width) - { - row = new BitArray(width); - } - else - { - row.clear(); - } - int offset = y * rowSize; - for (int x = 0; x < rowSize; x++) - { - row.setBulk(x << 5, bits[offset + x]); - } - return row; - } - - /// - /// Sets the row. - /// - /// row to set - /// {@link BitArray} to copy from - public void setRow(int y, BitArray row) - { - Array.Copy(row.Array, 0, bits, y * rowSize, rowSize); - } - - - /// - /// This is useful in detecting a corner of a 'pure' barcode. - /// - /// {x,y} coordinate of top-left-most 1 bit, or null if it is all white - public int[] getTopLeftOnBit() - { - int bitsOffset = 0; - while (bitsOffset < bits.Length && bits[bitsOffset] == 0) - { - bitsOffset++; - } - if (bitsOffset == bits.Length) - { - return null; - } - int y = bitsOffset / rowSize; - int x = (bitsOffset % rowSize) << 5; - - int theBits = bits[bitsOffset]; - int bit = 0; - while ((theBits << (31 - bit)) == 0) - { - bit++; - } - x += bit; - return new[] { x, y }; - } - - public int[] getBottomRightOnBit() - { - int bitsOffset = bits.Length - 1; - while (bitsOffset >= 0 && bits[bitsOffset] == 0) - { - bitsOffset--; - } - if (bitsOffset < 0) - { - return null; - } - - int y = bitsOffset / rowSize; - int x = (bitsOffset % rowSize) << 5; - - int theBits = bits[bitsOffset]; - int bit = 31; - - while (((int)((uint)theBits >> bit)) == 0) // (theBits >>> bit) - { - bit--; - } - x += bit; - - return new int[] { x, y }; - } - - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/BitSource.cs b/shadowsocks-csharp/3rd/zxing/common/BitSource.cs deleted file mode 100755 index ba9156d21..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/BitSource.cs +++ /dev/null @@ -1,124 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.Common -{ - ///

This provides an easy abstraction to read bits at a time from a sequence of bytes, where the - /// number of bits read is not often a multiple of 8.

- /// - ///

This class is thread-safe but not reentrant. Unless the caller modifies the bytes array - /// it passed in, in which case all bets are off.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public sealed class BitSource - { - private readonly byte[] bytes; - private int byteOffset; - private int bitOffset; - - /// bytes from which this will read bits. Bits will be read from the first byte first. - /// Bits are read within a byte from most-significant to least-significant bit. - /// - public BitSource(byte[] bytes) - { - this.bytes = bytes; - } - - /// - /// index of next bit in current byte which would be read by the next call to {@link #readBits(int)}. - /// - public int BitOffset - { - get { return bitOffset; } - } - - /// - /// index of next byte in input byte array which would be read by the next call to {@link #readBits(int)}. - /// - public int ByteOffset - { - get { return byteOffset; } - } - - /// number of bits to read - /// - /// int representing the bits read. The bits will appear as the least-significant - /// bits of the int - /// - /// if numBits isn't in [1,32] or more than is available - public int readBits(int numBits) - { - if (numBits < 1 || numBits > 32 || numBits > available()) - { - throw new ArgumentException(numBits.ToString(), "numBits"); - } - - int result = 0; - - // First, read remainder from current byte - if (bitOffset > 0) - { - int bitsLeft = 8 - bitOffset; - int toRead = numBits < bitsLeft ? numBits : bitsLeft; - int bitsToNotRead = bitsLeft - toRead; - int mask = (0xFF >> (8 - toRead)) << bitsToNotRead; - result = (bytes[byteOffset] & mask) >> bitsToNotRead; - numBits -= toRead; - bitOffset += toRead; - if (bitOffset == 8) - { - bitOffset = 0; - byteOffset++; - } - } - - // Next read whole bytes - if (numBits > 0) - { - while (numBits >= 8) - { - result = (result << 8) | (bytes[byteOffset] & 0xFF); - byteOffset++; - numBits -= 8; - } - - // Finally read a partial byte - if (numBits > 0) - { - int bitsToNotRead = 8 - numBits; - int mask = (0xFF >> bitsToNotRead) << bitsToNotRead; - result = (result << numBits) | ((bytes[byteOffset] & mask) >> bitsToNotRead); - bitOffset += numBits; - } - } - - return result; - } - - /// number of bits that can be read successfully - /// - public int available() - { - return 8 * (bytes.Length - byteOffset) - bitOffset; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/DecoderResult.cs b/shadowsocks-csharp/3rd/zxing/common/DecoderResult.cs deleted file mode 100755 index 024930f2e..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/DecoderResult.cs +++ /dev/null @@ -1,76 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -namespace ZXing.Common -{ - /// - /// Encapsulates the result of decoding a matrix of bits. This typically - /// applies to 2D barcode formats. For now it contains the raw bytes obtained, - /// as well as a String interpretation of those bytes, if applicable. - /// Sean Owen - /// - public sealed class DecoderResult - { - public byte[] RawBytes { get; private set; } - - public String Text { get; private set; } - - public IList ByteSegments { get; private set; } - - public String ECLevel { get; private set; } - - public bool StructuredAppend - { - get { return StructuredAppendParity >= 0 && StructuredAppendSequenceNumber >= 0; } - } - - public int ErrorsCorrected { get; set; } - - public int StructuredAppendSequenceNumber { get; private set; } - - public int Erasures { get; set; } - - public int StructuredAppendParity { get; private set; } - - /// - /// Miscellanseous data value for the various decoders - /// - /// The other. - public object Other { get; set; } - - public DecoderResult(byte[] rawBytes, String text, IList byteSegments, String ecLevel) - : this(rawBytes, text, byteSegments, ecLevel, -1, -1) - { - } - - public DecoderResult(byte[] rawBytes, String text, IList byteSegments, String ecLevel, int saSequence, int saParity) - { - if (rawBytes == null && text == null) - { - throw new ArgumentException(); - } - RawBytes = rawBytes; - Text = text; - ByteSegments = byteSegments; - ECLevel = ecLevel; - StructuredAppendParity = saParity; - StructuredAppendSequenceNumber = saSequence; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/DefaultGridSampler.cs b/shadowsocks-csharp/3rd/zxing/common/DefaultGridSampler.cs deleted file mode 100755 index b3afaf8e9..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/DefaultGridSampler.cs +++ /dev/null @@ -1,82 +0,0 @@ -/* -* Copyright 2007 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. -*/ -using System; - -namespace ZXing.Common -{ - - /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public sealed class DefaultGridSampler : GridSampler - { - public override BitMatrix sampleGrid(BitMatrix image, int dimensionX, int dimensionY, float p1ToX, float p1ToY, float p2ToX, float p2ToY, float p3ToX, float p3ToY, float p4ToX, float p4ToY, float p1FromX, float p1FromY, float p2FromX, float p2FromY, float p3FromX, float p3FromY, float p4FromX, float p4FromY) - { - PerspectiveTransform transform = PerspectiveTransform.quadrilateralToQuadrilateral( - p1ToX, p1ToY, p2ToX, p2ToY, p3ToX, p3ToY, p4ToX, p4ToY, - p1FromX, p1FromY, p2FromX, p2FromY, p3FromX, p3FromY, p4FromX, p4FromY); - return sampleGrid(image, dimensionX, dimensionY, transform); - } - - public override BitMatrix sampleGrid(BitMatrix image, int dimensionX, int dimensionY, PerspectiveTransform transform) - { - if (dimensionX <= 0 || dimensionY <= 0) - { - return null; - } - BitMatrix bits = new BitMatrix(dimensionX, dimensionY); - float[] points = new float[dimensionX << 1]; - for (int y = 0; y < dimensionY; y++) - { - int max = points.Length; - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - float iValue = (float)y + 0.5f; - for (int x = 0; x < max; x += 2) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - points[x] = (float)(x >> 1) + 0.5f; - points[x + 1] = iValue; - } - transform.transformPoints(points); - // Quick check to see if points transformed to something inside the image; - // sufficient to check the endpoints - if (!checkAndNudgePoints(image, points)) - return null; - try - { - for (int x = 0; x < max; x += 2) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - bits[x >> 1, y] = image[(int)points[x], (int)points[x + 1]]; - } - } - catch (System.IndexOutOfRangeException) - { - // This feels wrong, but, sometimes if the finder patterns are misidentified, the resulting - // transform gets "twisted" such that it maps a straight line of points to a set of points - // whose endpoints are in bounds, but others are not. There is probably some mathematical - // way to detect this about the transformation that I don't know yet. - // This results in an ugly runtime exception despite our clever checks above -- can't have - // that. We could check each point's coordinates but that feels duplicative. We settle for - // catching and wrapping ArrayIndexOutOfBoundsException. - return null; - } - } - return bits; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/DetectorResult.cs b/shadowsocks-csharp/3rd/zxing/common/DetectorResult.cs deleted file mode 100755 index 0f99b9ba3..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/DetectorResult.cs +++ /dev/null @@ -1,39 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.Common -{ - ///

Encapsulates the result of detecting a barcode in an image. This includes the raw - /// matrix of black/white pixels corresponding to the barcode, and possibly points of interest - /// in the image, like the location of finder patterns or corners of the barcode in the image.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public class DetectorResult - { - public BitMatrix Bits { get; private set; } - public ResultPoint[] Points { get; private set; } - - public DetectorResult(BitMatrix bits, ResultPoint[] points) - { - Bits = bits; - Points = points; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/GlobalHistogramBinarizer.cs b/shadowsocks-csharp/3rd/zxing/common/GlobalHistogramBinarizer.cs deleted file mode 100755 index 91f20d55b..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/GlobalHistogramBinarizer.cs +++ /dev/null @@ -1,243 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -namespace ZXing.Common -{ - /// This Binarizer implementation uses the old ZXing global histogram approach. It is suitable - /// for low-end mobile devices which don't have enough CPU or memory to use a local thresholding - /// algorithm. However, because it picks a global black point, it cannot handle difficult shadows - /// and gradients. - /// - /// Faster mobile devices and all desktop applications should probably use HybridBinarizer instead. - /// - /// dswitkin@google.com (Daniel Switkin) - /// Sean Owen - /// - public class GlobalHistogramBinarizer : Binarizer - { - private const int LUMINANCE_BITS = 5; - private const int LUMINANCE_SHIFT = 8 - LUMINANCE_BITS; - private const int LUMINANCE_BUCKETS = 1 << LUMINANCE_BITS; - private static readonly byte[] EMPTY = new byte[0]; - - private byte[] luminances; - private readonly int[] buckets; - - /// - /// Initializes a new instance of the class. - /// - /// The source. - public GlobalHistogramBinarizer(LuminanceSource source) - : base(source) - { - luminances = EMPTY; - buckets = new int[LUMINANCE_BUCKETS]; - } - - /// - /// Applies simple sharpening to the row data to improve performance of the 1D Readers. - /// - /// - /// - /// - public override BitArray getBlackRow(int y, BitArray row) - { - LuminanceSource source = LuminanceSource; - int width = source.Width; - if (row == null || row.Size < width) - { - row = new BitArray(width); - } - else - { - row.clear(); - } - - initArrays(width); - byte[] localLuminances = source.getRow(y, luminances); - int[] localBuckets = buckets; - for (int x = 0; x < width; x++) - { - int pixel = localLuminances[x] & 0xff; - localBuckets[pixel >> LUMINANCE_SHIFT]++; - } - int blackPoint; - if (!estimateBlackPoint(localBuckets, out blackPoint)) - return null; - - int left = localLuminances[0] & 0xff; - int center = localLuminances[1] & 0xff; - for (int x = 1; x < width - 1; x++) - { - int right = localLuminances[x + 1] & 0xff; - // A simple -1 4 -1 box filter with a weight of 2. - int luminance = ((center << 2) - left - right) >> 1; - row[x] = (luminance < blackPoint); - left = center; - center = right; - } - return row; - } - - /// - /// Does not sharpen the data, as this call is intended to only be used by 2D Readers. - /// - override public BitMatrix BlackMatrix - { - get - { - LuminanceSource source = LuminanceSource; - byte[] localLuminances; - - int width = source.Width; - int height = source.Height; - BitMatrix matrix = new BitMatrix(width, height); - - // Quickly calculates the histogram by sampling four rows from the image. This proved to be - // more robust on the blackbox tests than sampling a diagonal as we used to do. - initArrays(width); - int[] localBuckets = buckets; - for (int y = 1; y < 5; y++) - { - int row = height * y / 5; - localLuminances = source.getRow(row, luminances); - int right = (width << 2) / 5; - for (int x = width / 5; x < right; x++) - { - int pixel = localLuminances[x] & 0xff; - localBuckets[pixel >> LUMINANCE_SHIFT]++; - } - } - int blackPoint; - if (!estimateBlackPoint(localBuckets, out blackPoint)) - return null; - - // We delay reading the entire image luminance until the black point estimation succeeds. - // Although we end up reading four rows twice, it is consistent with our motto of - // "fail quickly" which is necessary for continuous scanning. - localLuminances = source.Matrix; - for (int y = 0; y < height; y++) - { - int offset = y * width; - for (int x = 0; x < width; x++) - { - int pixel = localLuminances[offset + x] & 0xff; - matrix[x, y] = (pixel < blackPoint); - } - } - - return matrix; - } - } - - /// - /// Creates a new object with the same type as this Binarizer implementation, but with pristine - /// state. This is needed because Binarizer implementations may be stateful, e.g. keeping a cache - /// of 1 bit data. See Effective Java for why we can't use Java's clone() method. - /// - /// The LuminanceSource this Binarizer will operate on. - /// - /// A new concrete Binarizer implementation object. - /// - public override Binarizer createBinarizer(LuminanceSource source) - { - return new GlobalHistogramBinarizer(source); - } - - private void initArrays(int luminanceSize) - { - if (luminances.Length < luminanceSize) - { - luminances = new byte[luminanceSize]; - } - for (int x = 0; x < LUMINANCE_BUCKETS; x++) - { - buckets[x] = 0; - } - } - - private static bool estimateBlackPoint(int[] buckets, out int blackPoint) - { - blackPoint = 0; - // Find the tallest peak in the histogram. - int numBuckets = buckets.Length; - int maxBucketCount = 0; - int firstPeak = 0; - int firstPeakSize = 0; - for (int x = 0; x < numBuckets; x++) - { - if (buckets[x] > firstPeakSize) - { - firstPeak = x; - firstPeakSize = buckets[x]; - } - if (buckets[x] > maxBucketCount) - { - maxBucketCount = buckets[x]; - } - } - - // Find the second-tallest peak which is somewhat far from the tallest peak. - int secondPeak = 0; - int secondPeakScore = 0; - for (int x = 0; x < numBuckets; x++) - { - int distanceToBiggest = x - firstPeak; - // Encourage more distant second peaks by multiplying by square of distance. - int score = buckets[x] * distanceToBiggest * distanceToBiggest; - if (score > secondPeakScore) - { - secondPeak = x; - secondPeakScore = score; - } - } - - // Make sure firstPeak corresponds to the black peak. - if (firstPeak > secondPeak) - { - int temp = firstPeak; - firstPeak = secondPeak; - secondPeak = temp; - } - - // If there is too little contrast in the image to pick a meaningful black point, throw rather - // than waste time trying to decode the image, and risk false positives. - // TODO: It might be worth comparing the brightest and darkest pixels seen, rather than the - // two peaks, to determine the contrast. - if (secondPeak - firstPeak <= numBuckets >> 4) - { - return false; - } - - // Find a valley between them that is low and closer to the white peak. - int bestValley = secondPeak - 1; - int bestValleyScore = -1; - for (int x = secondPeak - 1; x > firstPeak; x--) - { - int fromFirst = x - firstPeak; - int score = fromFirst*fromFirst*(secondPeak - x)*(maxBucketCount - buckets[x]); - if (score > bestValleyScore) - { - bestValley = x; - bestValleyScore = score; - } - } - - blackPoint = bestValley << LUMINANCE_SHIFT; - return true; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/GridSampler.cs b/shadowsocks-csharp/3rd/zxing/common/GridSampler.cs deleted file mode 100755 index a1bffa996..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/GridSampler.cs +++ /dev/null @@ -1,192 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.Common -{ - /// Implementations of this class can, given locations of finder patterns for a QR code in an - /// image, sample the right points in the image to reconstruct the QR code, accounting for - /// perspective distortion. It is abstracted since it is relatively expensive and should be allowed - /// to take advantage of platform-specific optimized implementations, like Sun's Java Advanced - /// Imaging library, but which may not be available in other environments such as J2ME, and vice - /// versa. - /// - /// The implementation used can be controlled by calling {@link #setGridSampler(GridSampler)} - /// with an instance of a class which implements this interface. - /// - /// - /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public abstract class GridSampler - { - /// the current implementation of {@link GridSampler} - /// - public static GridSampler Instance - { - get - { - return gridSampler; - } - - } - - private static GridSampler gridSampler = new DefaultGridSampler(); - - /// Sets the implementation of {@link GridSampler} used by the library. One global - /// instance is stored, which may sound problematic. But, the implementation provided - /// ought to be appropriate for the entire platform, and all uses of this library - /// in the whole lifetime of the JVM. For instance, an Android activity can swap in - /// an implementation that takes advantage of native platform libraries. - /// - /// - /// The platform-specific object to install. - /// - public static void setGridSampler(GridSampler newGridSampler) - { - if (newGridSampler == null) - { - throw new System.ArgumentException(); - } - gridSampler = newGridSampler; - } - - ///

Samples an image for a square matrix of bits of the given dimension. This is used to extract - /// the black/white modules of a 2D barcode like a QR Code found in an image. Because this barcode - /// may be rotated or perspective-distorted, the caller supplies four points in the source image - /// that define known points in the barcode, so that the image may be sampled appropriately.

- /// - ///

The last eight "from" parameters are four X/Y coordinate pairs of locations of points in - /// the image that define some significant points in the image to be sample. For example, - /// these may be the location of finder pattern in a QR Code.

- /// - ///

The first eight "to" parameters are four X/Y coordinate pairs measured in the destination - /// {@link BitMatrix}, from the top left, where the known points in the image given by the "from" - /// parameters map to.

- /// - ///

These 16 parameters define the transformation needed to sample the image.

- /// - ///
- /// image to sample - /// - /// width/height of {@link BitMatrix} to sample from image - /// - /// {@link BitMatrix} representing a grid of points sampled from the image within a region - /// defined by the "from" parameters - /// - /// ReaderException if image can't be sampled, for example, if the transformation defined - /// by the given points is invalid or results in sampling outside the image boundaries - /// - public abstract BitMatrix sampleGrid(BitMatrix image, int dimensionX, int dimensionY, float p1ToX, float p1ToY, float p2ToX, float p2ToY, float p3ToX, float p3ToY, float p4ToX, float p4ToY, float p1FromX, float p1FromY, float p2FromX, float p2FromY, float p3FromX, float p3FromY, float p4FromX, float p4FromY); - - public virtual BitMatrix sampleGrid(BitMatrix image, int dimensionX, int dimensionY, PerspectiveTransform transform) - { - throw new System.NotSupportedException(); - } - - - ///

Checks a set of points that have been transformed to sample points on an image against - /// the image's dimensions to see if the point are even within the image.

- /// - ///

This method will actually "nudge" the endpoints back onto the image if they are found to be - /// barely (less than 1 pixel) off the image. This accounts for imperfect detection of finder - /// patterns in an image where the QR Code runs all the way to the image border.

- /// - ///

For efficiency, the method will check points from either end of the line until one is found - /// to be within the image. Because the set of points are assumed to be linear, this is valid.

- /// - ///
- /// image into which the points should map - /// - /// actual points in x1,y1,...,xn,yn form - /// - protected internal static bool checkAndNudgePoints(BitMatrix image, float[] points) - { - int width = image.Width; - int height = image.Height; - // Check and nudge points from start until we see some that are OK: - bool nudged = true; - for (int offset = 0; offset < points.Length && nudged; offset += 2) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int x = (int)points[offset]; - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int y = (int)points[offset + 1]; - if (x < -1 || x > width || y < -1 || y > height) - { - return false; - } - nudged = false; - if (x == -1) - { - points[offset] = 0.0f; - nudged = true; - } - else if (x == width) - { - points[offset] = width - 1; - nudged = true; - } - if (y == -1) - { - points[offset + 1] = 0.0f; - nudged = true; - } - else if (y == height) - { - points[offset + 1] = height - 1; - nudged = true; - } - } - // Check and nudge points from end: - nudged = true; - for (int offset = points.Length - 2; offset >= 0 && nudged; offset -= 2) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int x = (int)points[offset]; - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int y = (int)points[offset + 1]; - if (x < -1 || x > width || y < -1 || y > height) - { - return false; - } - nudged = false; - if (x == -1) - { - points[offset] = 0.0f; - nudged = true; - } - else if (x == width) - { - points[offset] = width - 1; - nudged = true; - } - if (y == -1) - { - points[offset + 1] = 0.0f; - nudged = true; - } - else if (y == height) - { - points[offset + 1] = height - 1; - nudged = true; - } - } - - return true; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/HybridBinarizer.cs b/shadowsocks-csharp/3rd/zxing/common/HybridBinarizer.cs deleted file mode 100755 index d8185505e..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/HybridBinarizer.cs +++ /dev/null @@ -1,288 +0,0 @@ -/* -* Copyright 2009 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. -*/ - -namespace ZXing.Common -{ - /// This class implements a local thresholding algorithm, which while slower than the - /// GlobalHistogramBinarizer, is fairly efficient for what it does. It is designed for - /// high frequency images of barcodes with black data on white backgrounds. For this application, - /// it does a much better job than a global blackpoint with severe shadows and gradients. - /// However it tends to produce artifacts on lower frequency images and is therefore not - /// a good general purpose binarizer for uses outside ZXing. - /// - /// This class extends GlobalHistogramBinarizer, using the older histogram approach for 1D readers, - /// and the newer local approach for 2D readers. 1D decoding using a per-row histogram is already - /// inherently local, and only fails for horizontal gradients. We can revisit that problem later, - /// but for now it was not a win to use local blocks for 1D. - /// - /// This Binarizer is the default for the unit tests and the recommended class for library users. - /// - /// - /// dswitkin@google.com (Daniel Switkin) - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public sealed class HybridBinarizer : GlobalHistogramBinarizer - { - override public BitMatrix BlackMatrix - { - get - { - binarizeEntireImage(); - return matrix; - } - } - - // This class uses 5x5 blocks to compute local luminance, where each block is 8x8 pixels. - // So this is the smallest dimension in each axis we can accept. - private const int BLOCK_SIZE_POWER = 3; - private const int BLOCK_SIZE = 1 << BLOCK_SIZE_POWER; // ...0100...00 - private const int BLOCK_SIZE_MASK = BLOCK_SIZE - 1; // ...0011...11 - private const int MINIMUM_DIMENSION = 40; - private const int MIN_DYNAMIC_RANGE = 24; - - private BitMatrix matrix = null; - - public HybridBinarizer(LuminanceSource source) - : base(source) - { - } - - public override Binarizer createBinarizer(LuminanceSource source) - { - return new HybridBinarizer(source); - } - - /// - /// Calculates the final BitMatrix once for all requests. This could be called once from the - /// constructor instead, but there are some advantages to doing it lazily, such as making - /// profiling easier, and not doing heavy lifting when callers don't expect it. - /// - private void binarizeEntireImage() - { - if (matrix == null) - { - LuminanceSource source = LuminanceSource; - int width = source.Width; - int height = source.Height; - if (width >= MINIMUM_DIMENSION && height >= MINIMUM_DIMENSION) - { - byte[] luminances = source.Matrix; - - int subWidth = width >> BLOCK_SIZE_POWER; - if ((width & BLOCK_SIZE_MASK) != 0) - { - subWidth++; - } - int subHeight = height >> BLOCK_SIZE_POWER; - if ((height & BLOCK_SIZE_MASK) != 0) - { - subHeight++; - } - int[][] blackPoints = calculateBlackPoints(luminances, subWidth, subHeight, width, height); - - var newMatrix = new BitMatrix(width, height); - calculateThresholdForBlock(luminances, subWidth, subHeight, width, height, blackPoints, newMatrix); - matrix = newMatrix; - } - else - { - // If the image is too small, fall back to the global histogram approach. - matrix = base.BlackMatrix; - } - } - } - - /// - /// For each 8x8 block in the image, calculate the average black point using a 5x5 grid - /// of the blocks around it. Also handles the corner cases (fractional blocks are computed based - /// on the last 8 pixels in the row/column which are also used in the previous block). - /// - /// The luminances. - /// Width of the sub. - /// Height of the sub. - /// The width. - /// The height. - /// The black points. - /// The matrix. - private static void calculateThresholdForBlock(byte[] luminances, int subWidth, int subHeight, int width, int height, int[][] blackPoints, BitMatrix matrix) - { - for (int y = 0; y < subHeight; y++) - { - int yoffset = y << BLOCK_SIZE_POWER; - int maxYOffset = height - BLOCK_SIZE; - if (yoffset > maxYOffset) - { - yoffset = maxYOffset; - } - for (int x = 0; x < subWidth; x++) - { - int xoffset = x << BLOCK_SIZE_POWER; - int maxXOffset = width - BLOCK_SIZE; - if (xoffset > maxXOffset) - { - xoffset = maxXOffset; - } - int left = cap(x, 2, subWidth - 3); - int top = cap(y, 2, subHeight - 3); - int sum = 0; - for (int z = -2; z <= 2; z++) - { - int[] blackRow = blackPoints[top + z]; - sum += blackRow[left - 2]; - sum += blackRow[left - 1]; - sum += blackRow[left]; - sum += blackRow[left + 1]; - sum += blackRow[left + 2]; - } - int average = sum / 25; - thresholdBlock(luminances, xoffset, yoffset, average, width, matrix); - } - } - } - - private static int cap(int value, int min, int max) - { - return value < min ? min : value > max ? max : value; - } - - /// - /// Applies a single threshold to an 8x8 block of pixels. - /// - /// The luminances. - /// The xoffset. - /// The yoffset. - /// The threshold. - /// The stride. - /// The matrix. - private static void thresholdBlock(byte[] luminances, int xoffset, int yoffset, int threshold, int stride, BitMatrix matrix) - { - int offset = (yoffset * stride) + xoffset; - for (int y = 0; y < BLOCK_SIZE; y++, offset += stride) - { - for (int x = 0; x < BLOCK_SIZE; x++) - { - int pixel = luminances[offset + x] & 0xff; - // Comparison needs to be <= so that black == 0 pixels are black even if the threshold is 0. - matrix[xoffset + x, yoffset + y] = (pixel <= threshold); - } - } - } - - /// - /// Calculates a single black point for each 8x8 block of pixels and saves it away. - /// See the following thread for a discussion of this algorithm: - /// http://groups.google.com/group/zxing/browse_thread/thread/d06efa2c35a7ddc0 - /// - /// The luminances. - /// Width of the sub. - /// Height of the sub. - /// The width. - /// The height. - /// - private static int[][] calculateBlackPoints(byte[] luminances, int subWidth, int subHeight, int width, int height) - { - int[][] blackPoints = new int[subHeight][]; - for (int i = 0; i < subHeight; i++) - { - blackPoints[i] = new int[subWidth]; - } - - for (int y = 0; y < subHeight; y++) - { - int yoffset = y << BLOCK_SIZE_POWER; - int maxYOffset = height - BLOCK_SIZE; - if (yoffset > maxYOffset) - { - yoffset = maxYOffset; - } - for (int x = 0; x < subWidth; x++) - { - int xoffset = x << BLOCK_SIZE_POWER; - int maxXOffset = width - BLOCK_SIZE; - if (xoffset > maxXOffset) - { - xoffset = maxXOffset; - } - int sum = 0; - int min = 0xFF; - int max = 0; - for (int yy = 0, offset = yoffset * width + xoffset; yy < BLOCK_SIZE; yy++, offset += width) - { - for (int xx = 0; xx < BLOCK_SIZE; xx++) - { - int pixel = luminances[offset + xx] & 0xFF; - // still looking for good contrast - sum += pixel; - if (pixel < min) - { - min = pixel; - } - if (pixel > max) - { - max = pixel; - } - } - // short-circuit min/max tests once dynamic range is met - if (max - min > MIN_DYNAMIC_RANGE) - { - // finish the rest of the rows quickly - for (yy++, offset += width; yy < BLOCK_SIZE; yy++, offset += width) - { - for (int xx = 0; xx < BLOCK_SIZE; xx++) - { - sum += luminances[offset + xx] & 0xFF; - } - } - } - } - - // The default estimate is the average of the values in the block. - int average = sum >> (BLOCK_SIZE_POWER * 2); - if (max - min <= MIN_DYNAMIC_RANGE) - { - // If variation within the block is low, assume this is a block with only light or only - // dark pixels. In that case we do not want to use the average, as it would divide this - // low contrast area into black and white pixels, essentially creating data out of noise. - // - // The default assumption is that the block is light/background. Since no estimate for - // the level of dark pixels exists locally, use half the min for the block. - average = min >> 1; - - if (y > 0 && x > 0) - { - // Correct the "white background" assumption for blocks that have neighbors by comparing - // the pixels in this block to the previously calculated black points. This is based on - // the fact that dark barcode symbology is always surrounded by some amount of light - // background for which reasonable black point estimates were made. The bp estimated at - // the boundaries is used for the interior. - - // The (min < bp) is arbitrary but works better than other heuristics that were tried. - int averageNeighborBlackPoint = (blackPoints[y - 1][x] + (2 * blackPoints[y][x - 1]) + - blackPoints[y - 1][x - 1]) >> 2; - if (min < averageNeighborBlackPoint) - { - average = averageNeighborBlackPoint; - } - } - } - blackPoints[y][x] = average; - } - } - return blackPoints; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/PerspectiveTransform.cs b/shadowsocks-csharp/3rd/zxing/common/PerspectiveTransform.cs deleted file mode 100755 index 3515ddd84..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/PerspectiveTransform.cs +++ /dev/null @@ -1,159 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.Common -{ - ///

This class implements a perspective transform in two dimensions. Given four source and four - /// destination points, it will compute the transformation implied between them. The code is based - /// directly upon section 3.4.2 of George Wolberg's "Digital Image Warping"; see pages 54-56.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public sealed class PerspectiveTransform - { - private float a11; - private float a12; - private float a13; - private float a21; - private float a22; - private float a23; - private float a31; - private float a32; - private float a33; - - private PerspectiveTransform(float a11, float a21, float a31, float a12, float a22, float a32, float a13, float a23, float a33) - { - this.a11 = a11; - this.a12 = a12; - this.a13 = a13; - this.a21 = a21; - this.a22 = a22; - this.a23 = a23; - this.a31 = a31; - this.a32 = a32; - this.a33 = a33; - } - - public static PerspectiveTransform quadrilateralToQuadrilateral(float x0, float y0, float x1, float y1, float x2, float y2, float x3, float y3, float x0p, float y0p, float x1p, float y1p, float x2p, float y2p, float x3p, float y3p) - { - - PerspectiveTransform qToS = quadrilateralToSquare(x0, y0, x1, y1, x2, y2, x3, y3); - PerspectiveTransform sToQ = squareToQuadrilateral(x0p, y0p, x1p, y1p, x2p, y2p, x3p, y3p); - return sToQ.times(qToS); - } - - public void transformPoints(float[] points) - { - int max = points.Length; - float a11 = this.a11; - float a12 = this.a12; - float a13 = this.a13; - float a21 = this.a21; - float a22 = this.a22; - float a23 = this.a23; - float a31 = this.a31; - float a32 = this.a32; - float a33 = this.a33; - for (int i = 0; i < max; i += 2) - { - float x = points[i]; - float y = points[i + 1]; - float denominator = a13 * x + a23 * y + a33; - points[i] = (a11 * x + a21 * y + a31) / denominator; - points[i + 1] = (a12 * x + a22 * y + a32) / denominator; - } - } - - /// Convenience method, not optimized for performance. - public void transformPoints(float[] xValues, float[] yValues) - { - int n = xValues.Length; - for (int i = 0; i < n; i++) - { - float x = xValues[i]; - float y = yValues[i]; - float denominator = a13 * x + a23 * y + a33; - xValues[i] = (a11 * x + a21 * y + a31) / denominator; - yValues[i] = (a12 * x + a22 * y + a32) / denominator; - } - } - - public static PerspectiveTransform squareToQuadrilateral(float x0, float y0, - float x1, float y1, - float x2, float y2, - float x3, float y3) - { - float dx3 = x0 - x1 + x2 - x3; - float dy3 = y0 - y1 + y2 - y3; - if (dx3 == 0.0f && dy3 == 0.0f) - { - // Affine - return new PerspectiveTransform(x1 - x0, x2 - x1, x0, - y1 - y0, y2 - y1, y0, - 0.0f, 0.0f, 1.0f); - } - else - { - float dx1 = x1 - x2; - float dx2 = x3 - x2; - float dy1 = y1 - y2; - float dy2 = y3 - y2; - float denominator = dx1*dy2 - dx2*dy1; - float a13 = (dx3*dy2 - dx2*dy3)/denominator; - float a23 = (dx1*dy3 - dx3*dy1)/denominator; - return new PerspectiveTransform(x1 - x0 + a13*x1, x3 - x0 + a23*x3, x0, - y1 - y0 + a13*y1, y3 - y0 + a23*y3, y0, - a13, a23, 1.0f); - } - } - - public static PerspectiveTransform quadrilateralToSquare(float x0, float y0, float x1, float y1, float x2, float y2, float x3, float y3) - { - // Here, the adjoint serves as the inverse: - return squareToQuadrilateral(x0, y0, x1, y1, x2, y2, x3, y3).buildAdjoint(); - } - - internal PerspectiveTransform buildAdjoint() - { - // Adjoint is the transpose of the cofactor matrix: - return new PerspectiveTransform(a22 * a33 - a23 * a32, - a23 * a31 - a21 * a33, - a21 * a32 - a22 * a31, - a13 * a32 - a12 * a33, - a11 * a33 - a13 * a31, - a12 * a31 - a11 * a32, - a12 * a23 - a13 * a22, - a13 * a21 - a11 * a23, - a11 * a22 - a12 * a21); - } - - internal PerspectiveTransform times(PerspectiveTransform other) - { - return new PerspectiveTransform(a11 * other.a11 + a21 * other.a12 + a31 * other.a13, - a11 * other.a21 + a21 * other.a22 + a31 * other.a23, - a11 * other.a31 + a21 * other.a32 + a31 * other.a33, - a12 * other.a11 + a22 * other.a12 + a32 * other.a13, - a12 * other.a21 + a22 * other.a22 + a32 * other.a23, - a12 * other.a31 + a22 * other.a32 + a32 * other.a33, - a13 * other.a11 + a23 * other.a12 + a33 * other.a13, - a13 * other.a21 + a23 * other.a22 + a33 * other.a23, - a13 * other.a31 + a23 * other.a32 + a33 * other.a33); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/StringUtils.cs b/shadowsocks-csharp/3rd/zxing/common/StringUtils.cs deleted file mode 100755 index f15fd8e64..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/StringUtils.cs +++ /dev/null @@ -1,266 +0,0 @@ -/* - * Copyright (C) 2010 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. - */ - -using System; -using System.Collections.Generic; -using System.Text; - -namespace ZXing.Common -{ - /// - /// Common string-related functions. - /// - /// Sean Owen - /// Alex Dupre - public static class StringUtils - { -#if (WINDOWS_PHONE70 || WINDOWS_PHONE71 || WINDOWS_PHONE80 || SILVERLIGHT4 || SILVERLIGHT5 || NETFX_CORE || PORTABLE) - private const String PLATFORM_DEFAULT_ENCODING = "UTF-8"; -#else - private static string PLATFORM_DEFAULT_ENCODING = Encoding.Default.WebName; -#endif - public static string SHIFT_JIS = "SJIS"; - public static string GB2312 = "GB2312"; - private const string EUC_JP = "EUC-JP"; - private const string UTF8 = "UTF-8"; - private const string ISO88591 = "ISO-8859-1"; - private static readonly bool ASSUME_SHIFT_JIS = - string.Equals(SHIFT_JIS, PLATFORM_DEFAULT_ENCODING, StringComparison.OrdinalIgnoreCase) || - string.Equals(EUC_JP, PLATFORM_DEFAULT_ENCODING, StringComparison.OrdinalIgnoreCase); - - /// - /// Guesses the encoding. - /// - /// bytes encoding a string, whose encoding should be guessed - /// decode hints if applicable - /// name of guessed encoding; at the moment will only guess one of: - /// {@link #SHIFT_JIS}, {@link #UTF8}, {@link #ISO88591}, or the platform - /// default encoding if none of these can possibly be correct - public static String guessEncoding(byte[] bytes, IDictionary hints) - { - if (hints != null && hints.ContainsKey(DecodeHintType.CHARACTER_SET)) - { - String characterSet = (String)hints[DecodeHintType.CHARACTER_SET]; - if (characterSet != null) - { - return characterSet; - } - } - - // For now, merely tries to distinguish ISO-8859-1, UTF-8 and Shift_JIS, - // which should be by far the most common encodings. - int length = bytes.Length; - bool canBeISO88591 = true; - bool canBeShiftJIS = true; - bool canBeUTF8 = true; - int utf8BytesLeft = 0; - //int utf8LowChars = 0; - int utf2BytesChars = 0; - int utf3BytesChars = 0; - int utf4BytesChars = 0; - int sjisBytesLeft = 0; - //int sjisLowChars = 0; - int sjisKatakanaChars = 0; - //int sjisDoubleBytesChars = 0; - int sjisCurKatakanaWordLength = 0; - int sjisCurDoubleBytesWordLength = 0; - int sjisMaxKatakanaWordLength = 0; - int sjisMaxDoubleBytesWordLength = 0; - //int isoLowChars = 0; - //int isoHighChars = 0; - int isoHighOther = 0; - - bool utf8bom = bytes.Length > 3 && - bytes[0] == 0xEF && - bytes[1] == 0xBB && - bytes[2] == 0xBF; - - for (int i = 0; - i < length && (canBeISO88591 || canBeShiftJIS || canBeUTF8); - i++) - { - - int value = bytes[i] & 0xFF; - - // UTF-8 stuff - if (canBeUTF8) - { - if (utf8BytesLeft > 0) - { - if ((value & 0x80) == 0) - { - canBeUTF8 = false; - } - else - { - utf8BytesLeft--; - } - } - else if ((value & 0x80) != 0) - { - if ((value & 0x40) == 0) - { - canBeUTF8 = false; - } - else - { - utf8BytesLeft++; - if ((value & 0x20) == 0) - { - utf2BytesChars++; - } - else - { - utf8BytesLeft++; - if ((value & 0x10) == 0) - { - utf3BytesChars++; - } - else - { - utf8BytesLeft++; - if ((value & 0x08) == 0) - { - utf4BytesChars++; - } - else - { - canBeUTF8 = false; - } - } - } - } - } //else { - //utf8LowChars++; - //} - } - - // ISO-8859-1 stuff - if (canBeISO88591) - { - if (value > 0x7F && value < 0xA0) - { - canBeISO88591 = false; - } - else if (value > 0x9F) - { - if (value < 0xC0 || value == 0xD7 || value == 0xF7) - { - isoHighOther++; - } //else { - //isoHighChars++; - //} - } //else { - //isoLowChars++; - //} - } - - // Shift_JIS stuff - if (canBeShiftJIS) - { - if (sjisBytesLeft > 0) - { - if (value < 0x40 || value == 0x7F || value > 0xFC) - { - canBeShiftJIS = false; - } - else - { - sjisBytesLeft--; - } - } - else if (value == 0x80 || value == 0xA0 || value > 0xEF) - { - canBeShiftJIS = false; - } - else if (value > 0xA0 && value < 0xE0) - { - sjisKatakanaChars++; - sjisCurDoubleBytesWordLength = 0; - sjisCurKatakanaWordLength++; - if (sjisCurKatakanaWordLength > sjisMaxKatakanaWordLength) - { - sjisMaxKatakanaWordLength = sjisCurKatakanaWordLength; - } - } - else if (value > 0x7F) - { - sjisBytesLeft++; - //sjisDoubleBytesChars++; - sjisCurKatakanaWordLength = 0; - sjisCurDoubleBytesWordLength++; - if (sjisCurDoubleBytesWordLength > sjisMaxDoubleBytesWordLength) - { - sjisMaxDoubleBytesWordLength = sjisCurDoubleBytesWordLength; - } - } - else - { - //sjisLowChars++; - sjisCurKatakanaWordLength = 0; - sjisCurDoubleBytesWordLength = 0; - } - } - } - - if (canBeUTF8 && utf8BytesLeft > 0) - { - canBeUTF8 = false; - } - if (canBeShiftJIS && sjisBytesLeft > 0) - { - canBeShiftJIS = false; - } - - // Easy -- if there is BOM or at least 1 valid not-single byte character (and no evidence it can't be UTF-8), done - if (canBeUTF8 && (utf8bom || utf2BytesChars + utf3BytesChars + utf4BytesChars > 0)) - { - return UTF8; - } - // Easy -- if assuming Shift_JIS or at least 3 valid consecutive not-ascii characters (and no evidence it can't be), done - if (canBeShiftJIS && (ASSUME_SHIFT_JIS || sjisMaxKatakanaWordLength >= 3 || sjisMaxDoubleBytesWordLength >= 3)) - { - return SHIFT_JIS; - } - // Distinguishing Shift_JIS and ISO-8859-1 can be a little tough for short words. The crude heuristic is: - // - If we saw - // - only two consecutive katakana chars in the whole text, or - // - at least 10% of bytes that could be "upper" not-alphanumeric Latin1, - // - then we conclude Shift_JIS, else ISO-8859-1 - if (canBeISO88591 && canBeShiftJIS) - { - return (sjisMaxKatakanaWordLength == 2 && sjisKatakanaChars == 2) || isoHighOther * 10 >= length - ? SHIFT_JIS : ISO88591; - } - - // Otherwise, try in order ISO-8859-1, Shift JIS, UTF-8 and fall back to default platform encoding - if (canBeISO88591) - { - return ISO88591; - } - if (canBeShiftJIS) - { - return SHIFT_JIS; - } - if (canBeUTF8) - { - return UTF8; - } - // Otherwise, we take a wild guess with platform encoding - return PLATFORM_DEFAULT_ENCODING; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/detector/MathUtils.cs b/shadowsocks-csharp/3rd/zxing/common/detector/MathUtils.cs deleted file mode 100755 index 8782202f4..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/detector/MathUtils.cs +++ /dev/null @@ -1,48 +0,0 @@ -/* - * 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. - */ - -using System; - -namespace ZXing.Common.Detector -{ - public static class MathUtils - { - /// - /// Ends up being a bit faster than {@link Math#round(float)}. This merely rounds its - /// argument to the nearest int, where x.5 rounds up to x+1. - /// - /// The d. - /// - public static int round(float d) - { - return (int)(d + 0.5f); - } - - public static float distance(float aX, float aY, float bX, float bY) - { - float xDiff = aX - bX; - float yDiff = aY - bY; - return (float)Math.Sqrt(xDiff * xDiff + yDiff * yDiff); - } - - public static float distance(int aX, int aY, int bX, int bY) - { - int xDiff = aX - bX; - int yDiff = aY - bY; - return (float)Math.Sqrt(xDiff * xDiff + yDiff * yDiff); - } - } -} diff --git a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGF.cs b/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGF.cs deleted file mode 100755 index 276dc9998..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGF.cs +++ /dev/null @@ -1,242 +0,0 @@ -/* - * Copyright 2007 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. - */ - -using System; - -namespace ZXing.Common.ReedSolomon -{ - /// - ///

This class contains utility methods for performing mathematical operations over - /// the Galois Fields. Operations use a given primitive polynomial in calculations.

- ///

Throughout this package, elements of the GF are represented as an {@code int} - /// for convenience and speed (but at the cost of memory). - ///

- ///
- /// Sean Owen - public sealed class GenericGF - { - public static GenericGF AZTEC_DATA_12 = new GenericGF(0x1069, 4096, 1); // x^12 + x^6 + x^5 + x^3 + 1 - public static GenericGF AZTEC_DATA_10 = new GenericGF(0x409, 1024, 1); // x^10 + x^3 + 1 - public static GenericGF AZTEC_DATA_6 = new GenericGF(0x43, 64, 1); // x^6 + x + 1 - public static GenericGF AZTEC_PARAM = new GenericGF(0x13, 16, 1); // x^4 + x + 1 - public static GenericGF QR_CODE_FIELD_256 = new GenericGF(0x011D, 256, 0); // x^8 + x^4 + x^3 + x^2 + 1 - public static GenericGF DATA_MATRIX_FIELD_256 = new GenericGF(0x012D, 256, 1); // x^8 + x^5 + x^3 + x^2 + 1 - public static GenericGF AZTEC_DATA_8 = DATA_MATRIX_FIELD_256; - public static GenericGF MAXICODE_FIELD_64 = AZTEC_DATA_6; - - private const int INITIALIZATION_THRESHOLD = 0; - - private int[] expTable; - private int[] logTable; - private GenericGFPoly zero; - private GenericGFPoly one; - private readonly int size; - private readonly int primitive; - private readonly int generatorBase; - private bool initialized = false; - - /// - /// Create a representation of GF(size) using the given primitive polynomial. - /// - /// irreducible polynomial whose coefficients are represented by - /// * the bits of an int, where the least-significant bit represents the constant - /// * coefficient - /// the size of the field - /// the factor b in the generator polynomial can be 0- or 1-based - /// * (g(x) = (x+a^b)(x+a^(b+1))...(x+a^(b+2t-1))). - /// * In most cases it should be 1, but for QR code it is 0. - public GenericGF(int primitive, int size, int genBase) - { - this.primitive = primitive; - this.size = size; - this.generatorBase = genBase; - - if (size <= INITIALIZATION_THRESHOLD) - { - initialize(); - } - } - - private void initialize() - { - expTable = new int[size]; - logTable = new int[size]; - int x = 1; - for (int i = 0; i < size; i++) - { - expTable[i] = x; - x <<= 1; // x = x * 2; we're assuming the generator alpha is 2 - if (x >= size) - { - x ^= primitive; - x &= size - 1; - } - } - for (int i = 0; i < size - 1; i++) - { - logTable[expTable[i]] = i; - } - // logTable[0] == 0 but this should never be used - zero = new GenericGFPoly(this, new int[] { 0 }); - one = new GenericGFPoly(this, new int[] { 1 }); - initialized = true; - } - - private void checkInit() - { - if (!initialized) - { - initialize(); - } - } - - internal GenericGFPoly Zero - { - get - { - checkInit(); - return zero; - } - } - - internal GenericGFPoly One - { - get - { - checkInit(); - return one; - } - } - - /// - /// Builds the monomial. - /// - /// The degree. - /// The coefficient. - /// the monomial representing coefficient * x^degree - internal GenericGFPoly buildMonomial(int degree, int coefficient) - { - checkInit(); - - if (degree < 0) - { - throw new ArgumentException(); - } - if (coefficient == 0) - { - return zero; - } - int[] coefficients = new int[degree + 1]; - coefficients[0] = coefficient; - return new GenericGFPoly(this, coefficients); - } - - /// - /// Implements both addition and subtraction -- they are the same in GF(size). - /// - /// sum/difference of a and b - static internal int addOrSubtract(int a, int b) - { - return a ^ b; - } - - /// - /// Exps the specified a. - /// - /// 2 to the power of a in GF(size) - internal int exp(int a) - { - checkInit(); - - return expTable[a]; - } - - /// - /// Logs the specified a. - /// - /// A. - /// base 2 log of a in GF(size) - internal int log(int a) - { - checkInit(); - - if (a == 0) - { - throw new ArgumentException(); - } - return logTable[a]; - } - - /// - /// Inverses the specified a. - /// - /// multiplicative inverse of a - internal int inverse(int a) - { - checkInit(); - - if (a == 0) - { - throw new ArithmeticException(); - } - return expTable[size - logTable[a] - 1]; - } - - /// - /// Multiplies the specified a with b. - /// - /// A. - /// The b. - /// product of a and b in GF(size) - internal int multiply(int a, int b) - { - checkInit(); - - if (a == 0 || b == 0) - { - return 0; - } - return expTable[(logTable[a] + logTable[b]) % (size - 1)]; - } - - /// - /// Gets the size. - /// - public int Size - { - get { return size; } - } - - /// - /// Gets the generator base. - /// - public int GeneratorBase - { - get { return generatorBase; } - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - override public String ToString() - { - return "GF(0x" + primitive.ToString("X") + ',' + size + ')'; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGFPoly.cs b/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGFPoly.cs deleted file mode 100755 index 96df3e69b..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/GenericGFPoly.cs +++ /dev/null @@ -1,331 +0,0 @@ -/* - * Copyright 2007 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. - */ - -using System; -using System.Text; - -namespace ZXing.Common.ReedSolomon -{ - /// - ///

Represents a polynomial whose coefficients are elements of a GF. - /// Instances of this class are immutable.

- ///

Much credit is due to William Rucklidge since portions of this code are an indirect - /// port of his C++ Reed-Solomon implementation.

- ///
- /// Sean Owen - internal sealed class GenericGFPoly - { - private readonly GenericGF field; - private readonly int[] coefficients; - - /// - /// Initializes a new instance of the class. - /// - /// the {@link GenericGF} instance representing the field to use - /// to perform computations - /// coefficients as ints representing elements of GF(size), arranged - /// from most significant (highest-power term) coefficient to least significant - /// if argument is null or empty, - /// or if leading coefficient is 0 and this is not a - /// constant polynomial (that is, it is not the monomial "0") - internal GenericGFPoly(GenericGF field, int[] coefficients) - { - if (coefficients.Length == 0) - { - throw new ArgumentException(); - } - this.field = field; - int coefficientsLength = coefficients.Length; - if (coefficientsLength > 1 && coefficients[0] == 0) - { - // Leading term must be non-zero for anything except the constant polynomial "0" - int firstNonZero = 1; - while (firstNonZero < coefficientsLength && coefficients[firstNonZero] == 0) - { - firstNonZero++; - } - if (firstNonZero == coefficientsLength) - { - this.coefficients = field.Zero.coefficients; - } - else - { - this.coefficients = new int[coefficientsLength - firstNonZero]; - Array.Copy(coefficients, - firstNonZero, - this.coefficients, - 0, - this.coefficients.Length); - } - } - else - { - this.coefficients = coefficients; - } - } - - internal int[] Coefficients - { - get { return coefficients; } - } - - /// - /// degree of this polynomial - /// - internal int Degree - { - get - { - return coefficients.Length - 1; - } - } - - /// - /// Gets a value indicating whether this is zero. - /// - /// true iff this polynomial is the monomial "0" - internal bool isZero - { - get { return coefficients[0] == 0; } - } - - /// - /// coefficient of x^degree term in this polynomial - /// - /// The degree. - /// coefficient of x^degree term in this polynomial - internal int getCoefficient(int degree) - { - return coefficients[coefficients.Length - 1 - degree]; - } - - /// - /// evaluation of this polynomial at a given point - /// - /// A. - /// evaluation of this polynomial at a given point - internal int evaluateAt(int a) - { - int result = 0; - if (a == 0) - { - // Just return the x^0 coefficient - return getCoefficient(0); - } - int size = coefficients.Length; - if (a == 1) - { - // Just the sum of the coefficients - foreach (var coefficient in coefficients) - { - result = GenericGF.addOrSubtract(result, coefficient); - } - return result; - } - result = coefficients[0]; - for (int i = 1; i < size; i++) - { - result = GenericGF.addOrSubtract(field.multiply(a, result), coefficients[i]); - } - return result; - } - - internal GenericGFPoly addOrSubtract(GenericGFPoly other) - { - if (field != other.field) - { - throw new ArgumentException("GenericGFPolys do not have same GenericGF field"); - } - if (isZero) - { - return other; - } - if (other.isZero) - { - return this; - } - - int[] smallerCoefficients = this.coefficients; - int[] largerCoefficients = other.coefficients; - if (smallerCoefficients.Length > largerCoefficients.Length) - { - int[] temp = smallerCoefficients; - smallerCoefficients = largerCoefficients; - largerCoefficients = temp; - } - int[] sumDiff = new int[largerCoefficients.Length]; - int lengthDiff = largerCoefficients.Length - smallerCoefficients.Length; - // Copy high-order terms only found in higher-degree polynomial's coefficients - Array.Copy(largerCoefficients, 0, sumDiff, 0, lengthDiff); - - for (int i = lengthDiff; i < largerCoefficients.Length; i++) - { - sumDiff[i] = GenericGF.addOrSubtract(smallerCoefficients[i - lengthDiff], largerCoefficients[i]); - } - - return new GenericGFPoly(field, sumDiff); - } - - internal GenericGFPoly multiply(GenericGFPoly other) - { - if (field != other.field) - { - throw new ArgumentException("GenericGFPolys do not have same GenericGF field"); - } - if (isZero || other.isZero) - { - return field.Zero; - } - int[] aCoefficients = this.coefficients; - int aLength = aCoefficients.Length; - int[] bCoefficients = other.coefficients; - int bLength = bCoefficients.Length; - int[] product = new int[aLength + bLength - 1]; - for (int i = 0; i < aLength; i++) - { - int aCoeff = aCoefficients[i]; - for (int j = 0; j < bLength; j++) - { - product[i + j] = GenericGF.addOrSubtract(product[i + j], - field.multiply(aCoeff, bCoefficients[j])); - } - } - return new GenericGFPoly(field, product); - } - - internal GenericGFPoly multiply(int scalar) - { - if (scalar == 0) - { - return field.Zero; - } - if (scalar == 1) - { - return this; - } - int size = coefficients.Length; - int[] product = new int[size]; - for (int i = 0; i < size; i++) - { - product[i] = field.multiply(coefficients[i], scalar); - } - return new GenericGFPoly(field, product); - } - - internal GenericGFPoly multiplyByMonomial(int degree, int coefficient) - { - if (degree < 0) - { - throw new ArgumentException(); - } - if (coefficient == 0) - { - return field.Zero; - } - int size = coefficients.Length; - int[] product = new int[size + degree]; - for (int i = 0; i < size; i++) - { - product[i] = field.multiply(coefficients[i], coefficient); - } - return new GenericGFPoly(field, product); - } - - internal GenericGFPoly[] divide(GenericGFPoly other) - { - if (field != other.field) - { - throw new ArgumentException("GenericGFPolys do not have same GenericGF field"); - } - if (other.isZero) - { - throw new ArgumentException("Divide by 0"); - } - - GenericGFPoly quotient = field.Zero; - GenericGFPoly remainder = this; - - int denominatorLeadingTerm = other.getCoefficient(other.Degree); - int inverseDenominatorLeadingTerm = field.inverse(denominatorLeadingTerm); - - while (remainder.Degree >= other.Degree && !remainder.isZero) - { - int degreeDifference = remainder.Degree - other.Degree; - int scale = field.multiply(remainder.getCoefficient(remainder.Degree), inverseDenominatorLeadingTerm); - GenericGFPoly term = other.multiplyByMonomial(degreeDifference, scale); - GenericGFPoly iterationQuotient = field.buildMonomial(degreeDifference, scale); - quotient = quotient.addOrSubtract(iterationQuotient); - remainder = remainder.addOrSubtract(term); - } - - return new GenericGFPoly[] { quotient, remainder }; - } - - public override String ToString() - { - StringBuilder result = new StringBuilder(8 * Degree); - for (int degree = Degree; degree >= 0; degree--) - { - int coefficient = getCoefficient(degree); - if (coefficient != 0) - { - if (coefficient < 0) - { - result.Append(" - "); - coefficient = -coefficient; - } - else - { - if (result.Length > 0) - { - result.Append(" + "); - } - } - if (degree == 0 || coefficient != 1) - { - int alphaPower = field.log(coefficient); - if (alphaPower == 0) - { - result.Append('1'); - } - else if (alphaPower == 1) - { - result.Append('a'); - } - else - { - result.Append("a^"); - result.Append(alphaPower); - } - } - if (degree != 0) - { - if (degree == 1) - { - result.Append('x'); - } - else - { - result.Append("x^"); - result.Append(degree); - } - } - } - } - return result.ToString(); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonDecoder.cs b/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonDecoder.cs deleted file mode 100755 index 1030a56d9..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonDecoder.cs +++ /dev/null @@ -1,227 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.Common.ReedSolomon -{ - ///

Implements Reed-Solomon decoding, as the name implies.

- /// - ///

The algorithm will not be explained here, but the following references were helpful - /// in creating this implementation:

- /// - /// - /// - ///

Much credit is due to William Rucklidge since portions of this code are an indirect - /// port of his C++ Reed-Solomon implementation.

- /// - ///
- /// Sean Owen - /// William Rucklidge - /// sanfordsquires - public sealed class ReedSolomonDecoder - { - private readonly GenericGF field; - - public ReedSolomonDecoder(GenericGF field) - { - this.field = field; - } - - /// - ///

Decodes given set of received codewords, which include both data and error-correction - /// codewords. Really, this means it uses Reed-Solomon to detect and correct errors, in-place, - /// in the input.

- ///
- /// data and error-correction codewords - /// number of error-correction codewords available - /// false: decoding fails - public bool decode(int[] received, int twoS) - { - var poly = new GenericGFPoly(field, received); - var syndromeCoefficients = new int[twoS]; - var noError = true; - for (var i = 0; i < twoS; i++) - { - var eval = poly.evaluateAt(field.exp(i + field.GeneratorBase)); - syndromeCoefficients[syndromeCoefficients.Length - 1 - i] = eval; - if (eval != 0) - { - noError = false; - } - } - if (noError) - { - return true; - } - var syndrome = new GenericGFPoly(field, syndromeCoefficients); - - var sigmaOmega = runEuclideanAlgorithm(field.buildMonomial(twoS, 1), syndrome, twoS); - if (sigmaOmega == null) - return false; - - var sigma = sigmaOmega[0]; - var errorLocations = findErrorLocations(sigma); - if (errorLocations == null) - return false; - - var omega = sigmaOmega[1]; - var errorMagnitudes = findErrorMagnitudes(omega, errorLocations); - for (var i = 0; i < errorLocations.Length; i++) - { - var position = received.Length - 1 - field.log(errorLocations[i]); - if (position < 0) - { - // throw new ReedSolomonException("Bad error location"); - return false; - } - received[position] = GenericGF.addOrSubtract(received[position], errorMagnitudes[i]); - } - - return true; - } - - internal GenericGFPoly[] runEuclideanAlgorithm(GenericGFPoly a, GenericGFPoly b, int R) - { - // Assume a's degree is >= b's - if (a.Degree < b.Degree) - { - GenericGFPoly temp = a; - a = b; - b = temp; - } - - GenericGFPoly rLast = a; - GenericGFPoly r = b; - GenericGFPoly tLast = field.Zero; - GenericGFPoly t = field.One; - - // Run Euclidean algorithm until r's degree is less than R/2 - while (r.Degree >= R / 2) - { - GenericGFPoly rLastLast = rLast; - GenericGFPoly tLastLast = tLast; - rLast = r; - tLast = t; - - // Divide rLastLast by rLast, with quotient in q and remainder in r - if (rLast.isZero) - { - // Oops, Euclidean algorithm already terminated? - // throw new ReedSolomonException("r_{i-1} was zero"); - return null; - } - r = rLastLast; - GenericGFPoly q = field.Zero; - int denominatorLeadingTerm = rLast.getCoefficient(rLast.Degree); - int dltInverse = field.inverse(denominatorLeadingTerm); - while (r.Degree >= rLast.Degree && !r.isZero) - { - int degreeDiff = r.Degree - rLast.Degree; - int scale = field.multiply(r.getCoefficient(r.Degree), dltInverse); - q = q.addOrSubtract(field.buildMonomial(degreeDiff, scale)); - r = r.addOrSubtract(rLast.multiplyByMonomial(degreeDiff, scale)); - } - - t = q.multiply(tLast).addOrSubtract(tLastLast); - - if (r.Degree >= rLast.Degree) - { - // throw new IllegalStateException("Division algorithm failed to reduce polynomial?"); - return null; - } - } - - int sigmaTildeAtZero = t.getCoefficient(0); - if (sigmaTildeAtZero == 0) - { - // throw new ReedSolomonException("sigmaTilde(0) was zero"); - return null; - } - - int inverse = field.inverse(sigmaTildeAtZero); - GenericGFPoly sigma = t.multiply(inverse); - GenericGFPoly omega = r.multiply(inverse); - return new GenericGFPoly[] { sigma, omega }; - } - - private int[] findErrorLocations(GenericGFPoly errorLocator) - { - // This is a direct application of Chien's search - int numErrors = errorLocator.Degree; - if (numErrors == 1) - { - // shortcut - return new int[] { errorLocator.getCoefficient(1) }; - } - int[] result = new int[numErrors]; - int e = 0; - for (int i = 1; i < field.Size && e < numErrors; i++) - { - if (errorLocator.evaluateAt(i) == 0) - { - result[e] = field.inverse(i); - e++; - } - } - if (e != numErrors) - { - // throw new ReedSolomonException("Error locator degree does not match number of roots"); - return null; - } - return result; - } - - private int[] findErrorMagnitudes(GenericGFPoly errorEvaluator, int[] errorLocations) - { - // This is directly applying Forney's Formula - int s = errorLocations.Length; - int[] result = new int[s]; - for (int i = 0; i < s; i++) - { - int xiInverse = field.inverse(errorLocations[i]); - int denominator = 1; - for (int j = 0; j < s; j++) - { - if (i != j) - { - //denominator = field.multiply(denominator, - // GenericGF.addOrSubtract(1, field.multiply(errorLocations[j], xiInverse))); - // Above should work but fails on some Apple and Linux JDKs due to a Hotspot bug. - // Below is a funny-looking workaround from Steven Parkes - int term = field.multiply(errorLocations[j], xiInverse); - int termPlus1 = (term & 0x1) == 0 ? term | 1 : term & ~1; - denominator = field.multiply(denominator, termPlus1); - - // removed in java version, not sure if this is right - // denominator = field.multiply(denominator, GenericGF.addOrSubtract(1, field.multiply(errorLocations[j], xiInverse))); - } - } - result[i] = field.multiply(errorEvaluator.evaluateAt(xiInverse), field.inverse(denominator)); - if (field.GeneratorBase != 0) - { - result[i] = field.multiply(result[i], xiInverse); - } - } - return result; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonEncoder.cs b/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonEncoder.cs deleted file mode 100755 index 78aca71df..000000000 --- a/shadowsocks-csharp/3rd/zxing/common/reedsolomon/ReedSolomonEncoder.cs +++ /dev/null @@ -1,84 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using System; -using System.Collections.Generic; - -namespace ZXing.Common.ReedSolomon -{ - /// - /// Implements Reed-Solomon encoding, as the name implies. - /// - /// Sean Owen - /// William Rucklidge - public sealed class ReedSolomonEncoder - { - private readonly GenericGF field; - private readonly IList cachedGenerators; - - public ReedSolomonEncoder(GenericGF field) - { - this.field = field; - this.cachedGenerators = new List(); - cachedGenerators.Add(new GenericGFPoly(field, new int[] { 1 })); - } - - private GenericGFPoly buildGenerator(int degree) - { - if (degree >= cachedGenerators.Count) - { - var lastGenerator = cachedGenerators[cachedGenerators.Count - 1]; - for (int d = cachedGenerators.Count; d <= degree; d++) - { - var nextGenerator = lastGenerator.multiply(new GenericGFPoly(field, new int[] { 1, field.exp(d - 1 + field.GeneratorBase) })); - cachedGenerators.Add(nextGenerator); - lastGenerator = nextGenerator; - } - } - return cachedGenerators[degree]; - } - - public void encode(int[] toEncode, int ecBytes) - { - if (ecBytes == 0) - { - throw new ArgumentException("No error correction bytes"); - } - var dataBytes = toEncode.Length - ecBytes; - if (dataBytes <= 0) - { - throw new ArgumentException("No data bytes provided"); - } - - var generator = buildGenerator(ecBytes); - var infoCoefficients = new int[dataBytes]; - Array.Copy(toEncode, 0, infoCoefficients, 0, dataBytes); - - var info = new GenericGFPoly(field, infoCoefficients); - info = info.multiplyByMonomial(ecBytes, 1); - - var remainder = info.divide(generator)[1]; - var coefficients = remainder.Coefficients; - var numZeroCoefficients = ecBytes - coefficients.Length; - for (var i = 0; i < numZeroCoefficients; i++) - { - toEncode[dataBytes + i] = 0; - } - - Array.Copy(coefficients, 0, toEncode, dataBytes + numZeroCoefficients, coefficients.Length); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/QRCodeReader.cs b/shadowsocks-csharp/3rd/zxing/qrcode/QRCodeReader.cs deleted file mode 100755 index 597797bc0..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/QRCodeReader.cs +++ /dev/null @@ -1,255 +0,0 @@ -/* - * Copyright 2007 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. - */ - -using System; -using System.Collections.Generic; - -using ZXing.Common; -using ZXing.QrCode.Internal; - -namespace ZXing.QrCode -{ - /// - /// This implementation can detect and decode QR Codes in an image. - /// Sean Owen - /// - public class QRCodeReader - { - private static readonly ResultPoint[] NO_POINTS = new ResultPoint[0]; - - private readonly Decoder decoder = new Decoder(); - - /// - /// Gets the decoder. - /// - /// - protected Decoder getDecoder() - { - return decoder; - } - - /// - /// Locates and decodes a QR code in an image. - /// - /// a String representing the content encoded by the QR code - /// - public Result decode(BinaryBitmap image) - { - return decode(image, null); - } - - /// - /// Locates and decodes a barcode in some format within an image. This method also accepts - /// hints, each possibly associated to some data, which may help the implementation decode. - /// - /// image of barcode to decode - /// passed as a from - /// to arbitrary data. The - /// meaning of the data depends upon the hint type. The implementation may or may not do - /// anything with these hints. - /// - /// String which the barcode encodes - /// - public Result decode(BinaryBitmap image, IDictionary hints) - { - DecoderResult decoderResult; - ResultPoint[] points; - if (image == null || image.BlackMatrix == null) - { - // something is wrong with the image - return null; - } - if (hints != null && hints.ContainsKey(DecodeHintType.PURE_BARCODE)) - { - var bits = extractPureBits(image.BlackMatrix); - if (bits == null) - return null; - decoderResult = decoder.decode(bits, hints); - points = NO_POINTS; - } - else - { - var detectorResult = new Detector(image.BlackMatrix).detect(hints); - if (detectorResult == null) - return null; - decoderResult = decoder.decode(detectorResult.Bits, hints); - points = detectorResult.Points; - } - if (decoderResult == null) - return null; - - // If the code was mirrored: swap the bottom-left and the top-right points. - var data = decoderResult.Other as QRCodeDecoderMetaData; - if (data != null) - { - data.applyMirroredCorrection(points); - } - - var result = new Result(decoderResult.Text, decoderResult.RawBytes, points, BarcodeFormat.QR_CODE); - var byteSegments = decoderResult.ByteSegments; - if (byteSegments != null) - { - result.putMetadata(ResultMetadataType.BYTE_SEGMENTS, byteSegments); - } - var ecLevel = decoderResult.ECLevel; - if (ecLevel != null) - { - result.putMetadata(ResultMetadataType.ERROR_CORRECTION_LEVEL, ecLevel); - } - if (decoderResult.StructuredAppend) - { - result.putMetadata(ResultMetadataType.STRUCTURED_APPEND_SEQUENCE, decoderResult.StructuredAppendSequenceNumber); - result.putMetadata(ResultMetadataType.STRUCTURED_APPEND_PARITY, decoderResult.StructuredAppendParity); - } - return result; - } - - /// - /// Resets any internal state the implementation has after a decode, to prepare it - /// for reuse. - /// - public void reset() - { - // do nothing - } - - /// - /// This method detects a code in a "pure" image -- that is, pure monochrome image - /// which contains only an unrotated, unskewed, image of a code, with some white border - /// around it. This is a specialized method that works exceptionally fast in this special - /// case. - /// - /// - /// - private static BitMatrix extractPureBits(BitMatrix image) - { - int[] leftTopBlack = image.getTopLeftOnBit(); - int[] rightBottomBlack = image.getBottomRightOnBit(); - if (leftTopBlack == null || rightBottomBlack == null) - { - return null; - } - - float moduleSize; - if (!QRCodeReader.moduleSize(leftTopBlack, image, out moduleSize)) - return null; - - int top = leftTopBlack[1]; - int bottom = rightBottomBlack[1]; - int left = leftTopBlack[0]; - int right = rightBottomBlack[0]; - - // Sanity check! - if (left >= right || top >= bottom) - { - return null; - } - - if (bottom - top != right - left) - { - // Special case, where bottom-right module wasn't black so we found something else in the last row - // Assume it's a square, so use height as the width - right = left + (bottom - top); - } - - int matrixWidth = (int)Math.Round((right - left + 1) / moduleSize); - int matrixHeight = (int)Math.Round((bottom - top + 1) / moduleSize); - if (matrixWidth <= 0 || matrixHeight <= 0) - { - return null; - } - if (matrixHeight != matrixWidth) - { - // Only possibly decode square regions - return null; - } - - // Push in the "border" by half the module width so that we start - // sampling in the middle of the module. Just in case the image is a - // little off, this will help recover. - int nudge = (int)(moduleSize / 2.0f); - top += nudge; - left += nudge; - - // But careful that this does not sample off the edge - int nudgedTooFarRight = left + (int)((matrixWidth - 1) * moduleSize) - (right - 1); - if (nudgedTooFarRight > 0) - { - if (nudgedTooFarRight > nudge) - { - // Neither way fits; abort - return null; - } - left -= nudgedTooFarRight; - } - int nudgedTooFarDown = top + (int)((matrixHeight - 1) * moduleSize) - (bottom - 1); - if (nudgedTooFarDown > 0) - { - if (nudgedTooFarDown > nudge) - { - // Neither way fits; abort - return null; - } - top -= nudgedTooFarDown; - } - - // Now just read off the bits - BitMatrix bits = new BitMatrix(matrixWidth, matrixHeight); - for (int y = 0; y < matrixHeight; y++) - { - int iOffset = top + (int)(y * moduleSize); - for (int x = 0; x < matrixWidth; x++) - { - if (image[left + (int)(x * moduleSize), iOffset]) - { - bits[x, y] = true; - } - } - } - return bits; - } - - private static bool moduleSize(int[] leftTopBlack, BitMatrix image, out float msize) - { - int height = image.Height; - int width = image.Width; - int x = leftTopBlack[0]; - int y = leftTopBlack[1]; - bool inBlack = true; - int transitions = 0; - while (x < width && y < height) - { - if (inBlack != image[x, y]) - { - if (++transitions == 5) - { - break; - } - inBlack = !inBlack; - } - x++; - y++; - } - if (x == width || y == height) - { - msize = 0.0f; - return false; - } - msize = (x - leftTopBlack[0]) / 7.0f; - return true; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/BitMatrixParser.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/BitMatrixParser.cs deleted file mode 100755 index 6a328faad..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/BitMatrixParser.cs +++ /dev/null @@ -1,281 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - /// Sean Owen - sealed class BitMatrixParser - { - private readonly BitMatrix bitMatrix; - private Version parsedVersion; - private FormatInformation parsedFormatInfo; - private bool mirrored; - - /// {@link BitMatrix} to parse - /// ReaderException if dimension is not >= 21 and 1 mod 4 - internal static BitMatrixParser createBitMatrixParser(BitMatrix bitMatrix) - { - int dimension = bitMatrix.Height; - if (dimension < 21 || (dimension & 0x03) != 1) - { - return null; - } - return new BitMatrixParser(bitMatrix); - } - - private BitMatrixParser(BitMatrix bitMatrix) - { - // Should only be called from createBitMatrixParser with the important checks before - this.bitMatrix = bitMatrix; - } - - ///

Reads format information from one of its two locations within the QR Code.

- /// - ///
- /// {@link FormatInformation} encapsulating the QR Code's format info - /// - /// ReaderException if both format information locations cannot be parsed as - /// the valid encoding of format information - /// - internal FormatInformation readFormatInformation() - { - if (parsedFormatInfo != null) - { - return parsedFormatInfo; - } - - // Read top-left format info bits - int formatInfoBits1 = 0; - for (int i = 0; i < 6; i++) - { - formatInfoBits1 = copyBit(i, 8, formatInfoBits1); - } - // .. and skip a bit in the timing pattern ... - formatInfoBits1 = copyBit(7, 8, formatInfoBits1); - formatInfoBits1 = copyBit(8, 8, formatInfoBits1); - formatInfoBits1 = copyBit(8, 7, formatInfoBits1); - // .. and skip a bit in the timing pattern ... - for (int j = 5; j >= 0; j--) - { - formatInfoBits1 = copyBit(8, j, formatInfoBits1); - } - // Read the top-right/bottom-left pattern too - int dimension = bitMatrix.Height; - int formatInfoBits2 = 0; - int jMin = dimension - 7; - for (int j = dimension - 1; j >= jMin; j--) - { - formatInfoBits2 = copyBit(8, j, formatInfoBits2); - } - for (int i = dimension - 8; i < dimension; i++) - { - formatInfoBits2 = copyBit(i, 8, formatInfoBits2); - } - - parsedFormatInfo = FormatInformation.decodeFormatInformation(formatInfoBits1, formatInfoBits2); - if (parsedFormatInfo != null) - { - return parsedFormatInfo; - } - return null; - } - - ///

Reads version information from one of its two locations within the QR Code.

- /// - ///
- /// {@link Version} encapsulating the QR Code's version - /// - /// ReaderException if both version information locations cannot be parsed as - /// the valid encoding of version information - /// - internal Version readVersion() - { - if (parsedVersion != null) - { - return parsedVersion; - } - - int dimension = bitMatrix.Height; - - int provisionalVersion = (dimension - 17) >> 2; - if (provisionalVersion <= 6) - { - return Version.getVersionForNumber(provisionalVersion); - } - - // Read top-right version info: 3 wide by 6 tall - int versionBits = 0; - int ijMin = dimension - 11; - for (int j = 5; j >= 0; j--) - { - for (int i = dimension - 9; i >= ijMin; i--) - { - versionBits = copyBit(i, j, versionBits); - } - } - - parsedVersion = Version.decodeVersionInformation(versionBits); - if (parsedVersion != null && parsedVersion.DimensionForVersion == dimension) - { - return parsedVersion; - } - - // Hmm, failed. Try bottom left: 6 wide by 3 tall - versionBits = 0; - for (int i = 5; i >= 0; i--) - { - for (int j = dimension - 9; j >= ijMin; j--) - { - versionBits = copyBit(i, j, versionBits); - } - } - - parsedVersion = Version.decodeVersionInformation(versionBits); - if (parsedVersion != null && parsedVersion.DimensionForVersion == dimension) - { - return parsedVersion; - } - return null; - } - - private int copyBit(int i, int j, int versionBits) - { - bool bit = mirrored ? bitMatrix[j, i] : bitMatrix[i, j]; - return bit ? (versionBits << 1) | 0x1 : versionBits << 1; - } - - ///

Reads the bits in the {@link BitMatrix} representing the finder pattern in the - /// correct order in order to reconstruct the codewords bytes contained within the - /// QR Code.

- /// - ///
- /// bytes encoded within the QR Code - /// - /// ReaderException if the exact number of bytes expected is not read - internal byte[] readCodewords() - { - FormatInformation formatInfo = readFormatInformation(); - if (formatInfo == null) - return null; - Version version = readVersion(); - if (version == null) - return null; - - // Get the data mask for the format used in this QR Code. This will exclude - // some bits from reading as we wind through the bit matrix. - DataMask dataMask = DataMask.forReference(formatInfo.DataMask); - int dimension = bitMatrix.Height; - dataMask.unmaskBitMatrix(bitMatrix, dimension); - - BitMatrix functionPattern = version.buildFunctionPattern(); - - bool readingUp = true; - byte[] result = new byte[version.TotalCodewords]; - int resultOffset = 0; - int currentByte = 0; - int bitsRead = 0; - // Read columns in pairs, from right to left - for (int j = dimension - 1; j > 0; j -= 2) - { - if (j == 6) - { - // Skip whole column with vertical alignment pattern; - // saves time and makes the other code proceed more cleanly - j--; - } - // Read alternatingly from bottom to top then top to bottom - for (int count = 0; count < dimension; count++) - { - int i = readingUp ? dimension - 1 - count : count; - for (int col = 0; col < 2; col++) - { - // Ignore bits covered by the function pattern - if (!functionPattern[j - col, i]) - { - // Read a bit - bitsRead++; - currentByte <<= 1; - if (bitMatrix[j - col, i]) - { - currentByte |= 1; - } - // If we've made a whole byte, save it off - if (bitsRead == 8) - { - result[resultOffset++] = (byte)currentByte; - bitsRead = 0; - currentByte = 0; - } - } - } - } - readingUp ^= true; // readingUp = !readingUp; // switch directions - } - if (resultOffset != version.TotalCodewords) - { - return null; - } - return result; - } - - /** - * Revert the mask removal done while reading the code words. The bit matrix should revert to its original state. - */ - internal void remask() - { - if (parsedFormatInfo == null) - { - return; // We have no format information, and have no data mask - } - DataMask dataMask = DataMask.forReference(parsedFormatInfo.DataMask); - int dimension = bitMatrix.Height; - dataMask.unmaskBitMatrix(bitMatrix, dimension); - } - - /** - * Prepare the parser for a mirrored operation. - * This flag has effect only on the {@link #readFormatInformation()} and the - * {@link #readVersion()}. Before proceeding with {@link #readCodewords()} the - * {@link #mirror()} method should be called. - * - * @param mirror Whether to read version and format information mirrored. - */ - internal void setMirror(bool mirror) - { - parsedVersion = null; - parsedFormatInfo = null; - mirrored = mirror; - } - - /** Mirror the bit matrix in order to attempt a second reading. */ - internal void mirror() - { - for (int x = 0; x < bitMatrix.Width; x++) - { - for (int y = x + 1; y < bitMatrix.Height; y++) - { - if (bitMatrix[x, y] != bitMatrix[y, x]) - { - bitMatrix.flip(y, x); - bitMatrix.flip(x, y); - } - } - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataBlock.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataBlock.cs deleted file mode 100755 index 5860fe6a1..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataBlock.cs +++ /dev/null @@ -1,146 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.QrCode.Internal -{ - ///

Encapsulates a block of data within a QR Code. QR Codes may split their data into - /// multiple blocks, each of which is a unit of data and error-correction codewords. Each - /// is represented by an instance of this class.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - internal sealed class DataBlock - { - private readonly int numDataCodewords; - private readonly byte[] codewords; - - private DataBlock(int numDataCodewords, byte[] codewords) - { - this.numDataCodewords = numDataCodewords; - this.codewords = codewords; - } - - ///

When QR Codes use multiple data blocks, they are actually interleaved. - /// That is, the first byte of data block 1 to n is written, then the second bytes, and so on. This - /// method will separate the data into original blocks.

- /// - ///
- /// bytes as read directly from the QR Code - /// - /// version of the QR Code - /// - /// error-correction level of the QR Code - /// - /// {@link DataBlock}s containing original bytes, "de-interleaved" from representation in the - /// QR Code - /// - internal static DataBlock[] getDataBlocks(byte[] rawCodewords, Version version, ErrorCorrectionLevel ecLevel) - { - - if (rawCodewords.Length != version.TotalCodewords) - { - throw new System.ArgumentException(); - } - - // Figure out the number and size of data blocks used by this version and - // error correction level - Version.ECBlocks ecBlocks = version.getECBlocksForLevel(ecLevel); - - // First count the total number of data blocks - int totalBlocks = 0; - Version.ECB[] ecBlockArray = ecBlocks.getECBlocks(); - foreach (var ecBlock in ecBlockArray) - { - totalBlocks += ecBlock.Count; - } - - // Now establish DataBlocks of the appropriate size and number of data codewords - DataBlock[] result = new DataBlock[totalBlocks]; - int numResultBlocks = 0; - foreach (var ecBlock in ecBlockArray) - { - for (int i = 0; i < ecBlock.Count; i++) - { - int numDataCodewords = ecBlock.DataCodewords; - int numBlockCodewords = ecBlocks.ECCodewordsPerBlock + numDataCodewords; - result[numResultBlocks++] = new DataBlock(numDataCodewords, new byte[numBlockCodewords]); - } - } - - // All blocks have the same amount of data, except that the last n - // (where n may be 0) have 1 more byte. Figure out where these start. - int shorterBlocksTotalCodewords = result[0].codewords.Length; - int longerBlocksStartAt = result.Length - 1; - while (longerBlocksStartAt >= 0) - { - int numCodewords = result[longerBlocksStartAt].codewords.Length; - if (numCodewords == shorterBlocksTotalCodewords) - { - break; - } - longerBlocksStartAt--; - } - longerBlocksStartAt++; - - int shorterBlocksNumDataCodewords = shorterBlocksTotalCodewords - ecBlocks.ECCodewordsPerBlock; - // The last elements of result may be 1 element longer; - // first fill out as many elements as all of them have - int rawCodewordsOffset = 0; - for (int i = 0; i < shorterBlocksNumDataCodewords; i++) - { - for (int j = 0; j < numResultBlocks; j++) - { - result[j].codewords[i] = rawCodewords[rawCodewordsOffset++]; - } - } - // Fill out the last data block in the longer ones - for (int j = longerBlocksStartAt; j < numResultBlocks; j++) - { - result[j].codewords[shorterBlocksNumDataCodewords] = rawCodewords[rawCodewordsOffset++]; - } - // Now add in error correction blocks - int max = result[0].codewords.Length; - for (int i = shorterBlocksNumDataCodewords; i < max; i++) - { - for (int j = 0; j < numResultBlocks; j++) - { - int iOffset = j < longerBlocksStartAt ? i : i + 1; - result[j].codewords[iOffset] = rawCodewords[rawCodewordsOffset++]; - } - } - return result; - } - - internal int NumDataCodewords - { - get - { - return numDataCodewords; - } - } - - internal byte[] Codewords - { - get - { - return codewords; - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataMask.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataMask.cs deleted file mode 100755 index a6ac93e65..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DataMask.cs +++ /dev/null @@ -1,165 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - ///

Encapsulates data masks for the data bits in a QR code, per ISO 18004:2006 6.8. Implementations - /// of this class can un-mask a raw BitMatrix. For simplicity, they will unmask the entire BitMatrix, - /// including areas used for finder patterns, timing patterns, etc. These areas should be unused - /// after the point they are unmasked anyway.

- /// - ///

Note that the diagram in section 6.8.1 is misleading since it indicates that i is column position - /// and j is row position. In fact, as the text says, i is row position and j is column position.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - abstract class DataMask - { - /// See ISO 18004:2006 6.8.1 - private static readonly DataMask[] DATA_MASKS = new DataMask[] - { - new DataMask000(), - new DataMask001(), - new DataMask010(), - new DataMask011(), - new DataMask100(), - new DataMask101(), - new DataMask110(), - new DataMask111() - }; - - private DataMask() - { - } - - ///

Implementations of this method reverse the data masking process applied to a QR Code and - /// make its bits ready to read.

- /// - ///
- /// representation of QR Code bits - /// - /// dimension of QR Code, represented by bits, being unmasked - /// - internal void unmaskBitMatrix(BitMatrix bits, int dimension) - { - for (int i = 0; i < dimension; i++) - { - for (int j = 0; j < dimension; j++) - { - if (isMasked(i, j)) - { - bits.flip(j, i); - } - } - } - } - - internal abstract bool isMasked(int i, int j); - - /// a value between 0 and 7 indicating one of the eight possible - /// data mask patterns a QR Code may use - /// - /// {@link DataMask} encapsulating the data mask pattern - /// - internal static DataMask forReference(int reference) - { - if (reference < 0 || reference > 7) - { - throw new System.ArgumentException(); - } - return DATA_MASKS[reference]; - } - - /// 000: mask bits for which (x + y) mod 2 == 0 - private sealed class DataMask000 : DataMask - { - internal override bool isMasked(int i, int j) - { - return ((i + j) & 0x01) == 0; - } - } - - /// 001: mask bits for which x mod 2 == 0 - private sealed class DataMask001 : DataMask - { - internal override bool isMasked(int i, int j) - { - return (i & 0x01) == 0; - } - } - - /// 010: mask bits for which y mod 3 == 0 - private sealed class DataMask010 : DataMask - { - internal override bool isMasked(int i, int j) - { - return j % 3 == 0; - } - } - - /// 011: mask bits for which (x + y) mod 3 == 0 - private sealed class DataMask011 : DataMask - { - internal override bool isMasked(int i, int j) - { - return (i + j) % 3 == 0; - } - } - - /// 100: mask bits for which (x/2 + y/3) mod 2 == 0 - private sealed class DataMask100 : DataMask - { - internal override bool isMasked(int i, int j) - { - return ((((int)((uint)i >> 1)) + (j / 3)) & 0x01) == 0; - } - } - - /// 101: mask bits for which xy mod 2 + xy mod 3 == 0 - private sealed class DataMask101 : DataMask - { - internal override bool isMasked(int i, int j) - { - int temp = i * j; - return (temp & 0x01) + (temp % 3) == 0; - } - } - - /// 110: mask bits for which (xy mod 2 + xy mod 3) mod 2 == 0 - private sealed class DataMask110 : DataMask - { - internal override bool isMasked(int i, int j) - { - int temp = i * j; - return (((temp & 0x01) + (temp % 3)) & 0x01) == 0; - } - } - - /// 111: mask bits for which ((x+y)mod 2 + xy mod 3) mod 2 == 0 - private sealed class DataMask111 : DataMask - { - internal override bool isMasked(int i, int j) - { - return ((((i + j) & 0x01) + ((i * j) % 3)) & 0x01) == 0; - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DecodedBitStreamParser.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DecodedBitStreamParser.cs deleted file mode 100755 index 189fb41f0..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/DecodedBitStreamParser.cs +++ /dev/null @@ -1,514 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; -using System.Text; - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - ///

QR Codes can encode text as bits in one of several modes, and can use multiple modes - /// in one QR Code. This class decodes the bits back into text.

- /// - ///

See ISO 18004:2006, 6.4.3 - 6.4.7

- /// Sean Owen - ///
- internal static class DecodedBitStreamParser - { - /// - /// See ISO 18004:2006, 6.4.4 Table 5 - /// - private static readonly char[] ALPHANUMERIC_CHARS = { - '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', - 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', - 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', - ' ', '$', '%', '*', '+', '-', '.', '/', ':' - }; - private const int GB2312_SUBSET = 1; - - internal static DecoderResult decode(byte[] bytes, - Version version, - ErrorCorrectionLevel ecLevel, - IDictionary hints) - { - var bits = new BitSource(bytes); - var result = new StringBuilder(50); - var byteSegments = new List(1); - var symbolSequence = -1; - var parityData = -1; - - try - { - // CharacterSetECI currentCharacterSetECI = null; - bool fc1InEffect = false; - Mode mode; - do - { - // While still another segment to read... - if (bits.available() < 4) - { - // OK, assume we're done. Really, a TERMINATOR mode should have been recorded here - mode = Mode.TERMINATOR; - } - else - { - try - { - mode = Mode.forBits(bits.readBits(4)); // mode is encoded by 4 bits - } - catch (ArgumentException) - { - return null; - } - } - if (mode != Mode.TERMINATOR) - { - if (mode == Mode.FNC1_FIRST_POSITION || mode == Mode.FNC1_SECOND_POSITION) - { - // We do little with FNC1 except alter the parsed result a bit according to the spec - fc1InEffect = true; - } - else if (mode == Mode.STRUCTURED_APPEND) - { - if (bits.available() < 16) - { - return null; - } - // not really supported; but sequence number and parity is added later to the result metadata - // Read next 8 bits (symbol sequence #) and 8 bits (parity data), then continue - symbolSequence = bits.readBits(8); - parityData = bits.readBits(8); - } - else if (mode == Mode.ECI) - { - /* - // Count doesn't apply to ECI - int value = parseECIValue(bits); - currentCharacterSetECI = CharacterSetECI.getCharacterSetECIByValue(value); - if (currentCharacterSetECI == null) - { - return null; - } - * */ - } - else - { - // First handle Hanzi mode which does not start with character count - if (mode == Mode.HANZI) - { - //chinese mode contains a sub set indicator right after mode indicator - int subset = bits.readBits(4); - int countHanzi = bits.readBits(mode.getCharacterCountBits(version)); - if (subset == GB2312_SUBSET) - { - if (!decodeHanziSegment(bits, result, countHanzi)) - return null; - } - } - else - { - // "Normal" QR code modes: - // How many characters will follow, encoded in this mode? - int count = bits.readBits(mode.getCharacterCountBits(version)); - if (mode == Mode.NUMERIC) - { - if (!decodeNumericSegment(bits, result, count)) - return null; - } - else if (mode == Mode.ALPHANUMERIC) - { - if (!decodeAlphanumericSegment(bits, result, count, fc1InEffect)) - return null; - } - else if (mode == Mode.BYTE) - { - if (!decodeByteSegment(bits, result, count, byteSegments, hints)) - return null; - } - else if (mode == Mode.KANJI) - { - if (!decodeKanjiSegment(bits, result, count)) - return null; - } - else - { - return null; - } - } - } - } - } while (mode != Mode.TERMINATOR); - } - catch (ArgumentException) - { - // from readBits() calls - return null; - } - -#if WindowsCE - var resultString = result.ToString().Replace("\n", "\r\n"); -#else - var resultString = result.ToString().Replace("\r\n", "\n").Replace("\n", Environment.NewLine); -#endif - return new DecoderResult(bytes, - resultString, - byteSegments.Count == 0 ? null : byteSegments, - ecLevel == null ? null : ecLevel.ToString(), - symbolSequence, parityData); - } - - /// - /// See specification GBT 18284-2000 - /// - /// The bits. - /// The result. - /// The count. - /// - private static bool decodeHanziSegment(BitSource bits, - StringBuilder result, - int count) - { - // Don't crash trying to read more bits than we have available. - if (count * 13 > bits.available()) - { - return false; - } - - // Each character will require 2 bytes. Read the characters as 2-byte pairs - // and decode as GB2312 afterwards - byte[] buffer = new byte[2 * count]; - int offset = 0; - while (count > 0) - { - // Each 13 bits encodes a 2-byte character - int twoBytes = bits.readBits(13); - int assembledTwoBytes = ((twoBytes / 0x060) << 8) | (twoBytes % 0x060); - if (assembledTwoBytes < 0x003BF) - { - // In the 0xA1A1 to 0xAAFE range - assembledTwoBytes += 0x0A1A1; - } - else - { - // In the 0xB0A1 to 0xFAFE range - assembledTwoBytes += 0x0A6A1; - } - buffer[offset] = (byte)((assembledTwoBytes >> 8) & 0xFF); - buffer[offset + 1] = (byte)(assembledTwoBytes & 0xFF); - offset += 2; - count--; - } - - try - { - result.Append(Encoding.GetEncoding(StringUtils.GB2312).GetString(buffer, 0, buffer.Length)); - } -#if (WINDOWS_PHONE70 || WINDOWS_PHONE71 || SILVERLIGHT4 || SILVERLIGHT5 || NETFX_CORE || MONOANDROID || MONOTOUCH) - catch (ArgumentException) - { - try - { - // Silverlight only supports a limited number of character sets, trying fallback to UTF-8 - result.Append(Encoding.GetEncoding("UTF-8").GetString(buffer, 0, buffer.Length)); - } - catch (Exception) - { - return false; - } - } -#endif - catch (Exception) - { - return false; - } - - return true; - } - - private static bool decodeKanjiSegment(BitSource bits, - StringBuilder result, - int count) - { - // Don't crash trying to read more bits than we have available. - if (count * 13 > bits.available()) - { - return false; - } - - // Each character will require 2 bytes. Read the characters as 2-byte pairs - // and decode as Shift_JIS afterwards - byte[] buffer = new byte[2 * count]; - int offset = 0; - while (count > 0) - { - // Each 13 bits encodes a 2-byte character - int twoBytes = bits.readBits(13); - int assembledTwoBytes = ((twoBytes / 0x0C0) << 8) | (twoBytes % 0x0C0); - if (assembledTwoBytes < 0x01F00) - { - // In the 0x8140 to 0x9FFC range - assembledTwoBytes += 0x08140; - } - else - { - // In the 0xE040 to 0xEBBF range - assembledTwoBytes += 0x0C140; - } - buffer[offset] = (byte)(assembledTwoBytes >> 8); - buffer[offset + 1] = (byte)assembledTwoBytes; - offset += 2; - count--; - } - // Shift_JIS may not be supported in some environments: - try - { - result.Append(Encoding.GetEncoding(StringUtils.SHIFT_JIS).GetString(buffer, 0, buffer.Length)); - } -#if (WINDOWS_PHONE70 || WINDOWS_PHONE71 || SILVERLIGHT4 || SILVERLIGHT5 || NETFX_CORE || MONOANDROID || MONOTOUCH) - catch (ArgumentException) - { - try - { - // Silverlight only supports a limited number of character sets, trying fallback to UTF-8 - result.Append(Encoding.GetEncoding("UTF-8").GetString(buffer, 0, buffer.Length)); - } - catch (Exception) - { - return false; - } - } -#endif - catch (Exception) - { - return false; - } - return true; - } - - private static bool decodeByteSegment(BitSource bits, - StringBuilder result, - int count, - IList byteSegments, - IDictionary hints) - { - // Don't crash trying to read more bits than we have available. - if (count << 3 > bits.available()) - { - return false; - } - - byte[] readBytes = new byte[count]; - for (int i = 0; i < count; i++) - { - readBytes[i] = (byte)bits.readBits(8); - } - String encoding; - encoding = StringUtils.guessEncoding(readBytes, hints); - - try - { - result.Append(Encoding.GetEncoding(encoding).GetString(readBytes, 0, readBytes.Length)); - } -#if (WINDOWS_PHONE70 || WINDOWS_PHONE71 || SILVERLIGHT4 || SILVERLIGHT5 || NETFX_CORE || MONOANDROID || MONOTOUCH) - catch (ArgumentException) - { - try - { - // Silverlight only supports a limited number of character sets, trying fallback to UTF-8 - result.Append(Encoding.GetEncoding("UTF-8").GetString(readBytes, 0, readBytes.Length)); - } - catch (Exception) - { - return false; - } - } -#endif -#if WindowsCE - catch (PlatformNotSupportedException) - { - try - { - // WindowsCE doesn't support all encodings. But it is device depended. - // So we try here the some different ones - if (encoding == "ISO-8859-1") - { - result.Append(Encoding.GetEncoding(1252).GetString(readBytes, 0, readBytes.Length)); - } - else - { - result.Append(Encoding.GetEncoding("UTF-8").GetString(readBytes, 0, readBytes.Length)); - } - } - catch (Exception) - { - return false; - } - } -#endif - catch (Exception) - { - return false; - } - byteSegments.Add(readBytes); - - return true; - } - - private static char toAlphaNumericChar(int value) - { - if (value >= ALPHANUMERIC_CHARS.Length) - { - //throw FormatException.Instance; - } - return ALPHANUMERIC_CHARS[value]; - } - - private static bool decodeAlphanumericSegment(BitSource bits, - StringBuilder result, - int count, - bool fc1InEffect) - { - // Read two characters at a time - int start = result.Length; - while (count > 1) - { - if (bits.available() < 11) - { - return false; - } - int nextTwoCharsBits = bits.readBits(11); - result.Append(toAlphaNumericChar(nextTwoCharsBits / 45)); - result.Append(toAlphaNumericChar(nextTwoCharsBits % 45)); - count -= 2; - } - if (count == 1) - { - // special case: one character left - if (bits.available() < 6) - { - return false; - } - result.Append(toAlphaNumericChar(bits.readBits(6))); - } - - // See section 6.4.8.1, 6.4.8.2 - if (fc1InEffect) - { - // We need to massage the result a bit if in an FNC1 mode: - for (int i = start; i < result.Length; i++) - { - if (result[i] == '%') - { - if (i < result.Length - 1 && result[i + 1] == '%') - { - // %% is rendered as % - result.Remove(i + 1, 1); - } - else - { - // In alpha mode, % should be converted to FNC1 separator 0x1D - result.Remove(i, 1); - result.Insert(i, new[] { (char)0x1D }); - } - } - } - } - - return true; - } - - private static bool decodeNumericSegment(BitSource bits, - StringBuilder result, - int count) - { - // Read three digits at a time - while (count >= 3) - { - // Each 10 bits encodes three digits - if (bits.available() < 10) - { - return false; - } - int threeDigitsBits = bits.readBits(10); - if (threeDigitsBits >= 1000) - { - return false; - } - result.Append(toAlphaNumericChar(threeDigitsBits / 100)); - result.Append(toAlphaNumericChar((threeDigitsBits / 10) % 10)); - result.Append(toAlphaNumericChar(threeDigitsBits % 10)); - - count -= 3; - } - if (count == 2) - { - // Two digits left over to read, encoded in 7 bits - if (bits.available() < 7) - { - return false; - } - int twoDigitsBits = bits.readBits(7); - if (twoDigitsBits >= 100) - { - return false; - } - result.Append(toAlphaNumericChar(twoDigitsBits / 10)); - result.Append(toAlphaNumericChar(twoDigitsBits % 10)); - } - else if (count == 1) - { - // One digit left over to read - if (bits.available() < 4) - { - return false; - } - int digitBits = bits.readBits(4); - if (digitBits >= 10) - { - return false; - } - result.Append(toAlphaNumericChar(digitBits)); - } - - return true; - } - - private static int parseECIValue(BitSource bits) - { - int firstByte = bits.readBits(8); - if ((firstByte & 0x80) == 0) - { - // just one byte - return firstByte & 0x7F; - } - if ((firstByte & 0xC0) == 0x80) - { - // two bytes - int secondByte = bits.readBits(8); - return ((firstByte & 0x3F) << 8) | secondByte; - } - if ((firstByte & 0xE0) == 0xC0) - { - // three bytes - int secondThirdBytes = bits.readBits(16); - return ((firstByte & 0x1F) << 16) | secondThirdBytes; - } - throw new ArgumentException("Bad ECI bits starting with byte " + firstByte); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Decoder.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Decoder.cs deleted file mode 100755 index a5ec86457..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Decoder.cs +++ /dev/null @@ -1,195 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System.Collections.Generic; - -using ZXing.Common; -using ZXing.Common.ReedSolomon; - -namespace ZXing.QrCode.Internal -{ - /// - ///

The main class which implements QR Code decoding -- as opposed to locating and extracting - /// the QR Code from an image.

- ///
- /// - /// Sean Owen - /// - public sealed class Decoder - { - private readonly ReedSolomonDecoder rsDecoder; - - /// - /// Initializes a new instance of the class. - /// - public Decoder() - { - rsDecoder = new ReedSolomonDecoder(GenericGF.QR_CODE_FIELD_256); - } - - /// - ///

Convenience method that can decode a QR Code represented as a 2D array of booleans. - /// "true" is taken to mean a black module.

- ///
- /// booleans representing white/black QR Code modules - /// The hints. - /// - /// text and bytes encoded within the QR Code - /// - public DecoderResult decode(bool[][] image, IDictionary hints) - { - var dimension = image.Length; - var bits = new BitMatrix(dimension); - for (int i = 0; i < dimension; i++) - { - for (int j = 0; j < dimension; j++) - { - bits[j, i] = image[i][j]; - } - } - return decode(bits, hints); - } - - /// - ///

Decodes a QR Code represented as a {@link BitMatrix}. A 1 or "true" is taken to mean a black module.

- ///
- /// booleans representing white/black QR Code modules - /// The hints. - /// - /// text and bytes encoded within the QR Code - /// - public DecoderResult decode(BitMatrix bits, IDictionary hints) - { - // Construct a parser and read version, error-correction level - var parser = BitMatrixParser.createBitMatrixParser(bits); - if (parser == null) - return null; - - var result = decode(parser, hints); - if (result == null) - { - // Revert the bit matrix - parser.remask(); - - // Will be attempting a mirrored reading of the version and format info. - parser.setMirror(true); - - // Preemptively read the version. - var version = parser.readVersion(); - if (version == null) - return null; - - // Preemptively read the format information. - var formatinfo = parser.readFormatInformation(); - if (formatinfo == null) - return null; - - /* - * Since we're here, this means we have successfully detected some kind - * of version and format information when mirrored. This is a good sign, - * that the QR code may be mirrored, and we should try once more with a - * mirrored content. - */ - // Prepare for a mirrored reading. - parser.mirror(); - - result = decode(parser, hints); - - if (result != null) - { - // Success! Notify the caller that the code was mirrored. - result.Other = new QRCodeDecoderMetaData(true); - } - } - - return result; - } - - private DecoderResult decode(BitMatrixParser parser, IDictionary hints) - { - Version version = parser.readVersion(); - if (version == null) - return null; - var formatinfo = parser.readFormatInformation(); - if (formatinfo == null) - return null; - ErrorCorrectionLevel ecLevel = formatinfo.ErrorCorrectionLevel; - - // Read codewords - byte[] codewords = parser.readCodewords(); - if (codewords == null) - return null; - // Separate into data blocks - DataBlock[] dataBlocks = DataBlock.getDataBlocks(codewords, version, ecLevel); - - // Count total number of data bytes - int totalBytes = 0; - foreach (var dataBlock in dataBlocks) - { - totalBytes += dataBlock.NumDataCodewords; - } - byte[] resultBytes = new byte[totalBytes]; - int resultOffset = 0; - - // Error-correct and copy data blocks together into a stream of bytes - foreach (var dataBlock in dataBlocks) - { - byte[] codewordBytes = dataBlock.Codewords; - int numDataCodewords = dataBlock.NumDataCodewords; - if (!correctErrors(codewordBytes, numDataCodewords)) - return null; - for (int i = 0; i < numDataCodewords; i++) - { - resultBytes[resultOffset++] = codewordBytes[i]; - } - } - - // Decode the contents of that stream of bytes - return DecodedBitStreamParser.decode(resultBytes, version, ecLevel, hints); - } - - /// - ///

Given data and error-correction codewords received, possibly corrupted by errors, attempts to - /// correct the errors in-place using Reed-Solomon error correction.

- ///
- /// data and error correction codewords - /// number of codewords that are data bytes - /// - private bool correctErrors(byte[] codewordBytes, int numDataCodewords) - { - int numCodewords = codewordBytes.Length; - // First read into an array of ints - int[] codewordsInts = new int[numCodewords]; - for (int i = 0; i < numCodewords; i++) - { - codewordsInts[i] = codewordBytes[i] & 0xFF; - } - int numECCodewords = codewordBytes.Length - numDataCodewords; - - if (!rsDecoder.decode(codewordsInts, numECCodewords)) - return false; - - // Copy back into array of bytes -- only need to worry about the bytes that were data - // We don't care about errors in the error-correction codewords - for (int i = 0; i < numDataCodewords; i++) - { - codewordBytes[i] = (byte)codewordsInts[i]; - } - - return true; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/ErrorCorrectionLevel.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/ErrorCorrectionLevel.cs deleted file mode 100755 index f3b493474..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/ErrorCorrectionLevel.cs +++ /dev/null @@ -1,109 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - /// - ///

See ISO 18004:2006, 6.5.1. This enum encapsulates the four error correction levels - /// defined by the QR code standard.

- ///
- /// Sean Owen - public sealed class ErrorCorrectionLevel - { - /// L = ~7% correction - public static readonly ErrorCorrectionLevel L = new ErrorCorrectionLevel(0, 0x01, "L"); - /// M = ~15% correction - public static readonly ErrorCorrectionLevel M = new ErrorCorrectionLevel(1, 0x00, "M"); - /// Q = ~25% correction - public static readonly ErrorCorrectionLevel Q = new ErrorCorrectionLevel(2, 0x03, "Q"); - /// H = ~30% correction - public static readonly ErrorCorrectionLevel H = new ErrorCorrectionLevel(3, 0x02, "H"); - - private static readonly ErrorCorrectionLevel[] FOR_BITS = new [] { M, L, H, Q }; - - private readonly int bits; - - private ErrorCorrectionLevel(int ordinal, int bits, String name) - { - this.ordinal_Renamed_Field = ordinal; - this.bits = bits; - this.name = name; - } - - /// - /// Gets the bits. - /// - public int Bits - { - get - { - return bits; - } - } - - /// - /// Gets the name. - /// - public String Name - { - get - { - return name; - } - } - - private readonly int ordinal_Renamed_Field; - private readonly String name; - - /// - /// Ordinals this instance. - /// - /// - public int ordinal() - { - return ordinal_Renamed_Field; - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - return name; - } - - /// - /// Fors the bits. - /// - /// int containing the two bits encoding a QR Code's error correction level - /// - /// representing the encoded error correction level - /// - public static ErrorCorrectionLevel forBits(int bits) - { - if (bits < 0 || bits >= FOR_BITS.Length) - { - throw new ArgumentException(); - } - return FOR_BITS[bits]; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/FormatInformation.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/FormatInformation.cs deleted file mode 100755 index 88b5045e1..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/FormatInformation.cs +++ /dev/null @@ -1,197 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - - ///

Encapsulates a QR Code's format information, including the data mask used and - /// error correction level.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - /// - /// - /// - /// - sealed class FormatInformation - { - private const int FORMAT_INFO_MASK_QR = 0x5412; - - /// See ISO 18004:2006, Annex C, Table C.1 - private static readonly int[][] FORMAT_INFO_DECODE_LOOKUP = new int[][] - { - new [] { 0x5412, 0x00 }, - new [] { 0x5125, 0x01 }, - new [] { 0x5E7C, 0x02 }, - new [] { 0x5B4B, 0x03 }, - new [] { 0x45F9, 0x04 }, - new [] { 0x40CE, 0x05 }, - new [] { 0x4F97, 0x06 }, - new [] { 0x4AA0, 0x07 }, - new [] { 0x77C4, 0x08 }, - new [] { 0x72F3, 0x09 }, - new [] { 0x7DAA, 0x0A }, - new [] { 0x789D, 0x0B }, - new [] { 0x662F, 0x0C }, - new [] { 0x6318, 0x0D }, - new [] { 0x6C41, 0x0E }, - new [] { 0x6976, 0x0F }, - new [] { 0x1689, 0x10 }, - new [] { 0x13BE, 0x11 }, - new [] { 0x1CE7, 0x12 }, - new [] { 0x19D0, 0x13 }, - new [] { 0x0762, 0x14 }, - new [] { 0x0255, 0x15 }, - new [] { 0x0D0C, 0x16 }, - new [] { 0x083B, 0x17 }, - new [] { 0x355F, 0x18 }, - new [] { 0x3068, 0x19 }, - new [] { 0x3F31, 0x1A }, - new [] { 0x3A06, 0x1B }, - new [] { 0x24B4, 0x1C }, - new [] { 0x2183, 0x1D }, - new [] { 0x2EDA, 0x1E }, - new [] { 0x2BED, 0x1F } - }; - - /// Offset i holds the number of 1 bits in the binary representation of i - private static readonly int[] BITS_SET_IN_HALF_BYTE = new [] - { 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4 }; - - private readonly ErrorCorrectionLevel errorCorrectionLevel; - private readonly byte dataMask; - - private FormatInformation(int formatInfo) - { - // Bits 3,4 - errorCorrectionLevel = ErrorCorrectionLevel.forBits((formatInfo >> 3) & 0x03); - // Bottom 3 bits - dataMask = (byte)(formatInfo & 0x07); - } - - internal static int numBitsDiffering(int a, int b) - { - a ^= b; // a now has a 1 bit exactly where its bit differs with b's - // Count bits set quickly with a series of lookups: - return BITS_SET_IN_HALF_BYTE[a & 0x0F] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 4)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 8)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 12)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 16)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 20)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 24)) & 0x0F)] + - BITS_SET_IN_HALF_BYTE[(((int)((uint)a >> 28)) & 0x0F)]; - } - - /// - /// Decodes the format information. - /// - /// format info indicator, with mask still applied - /// The masked format info2. - /// - /// information about the format it specifies, or null - /// if doesn't seem to match any known pattern - /// - internal static FormatInformation decodeFormatInformation(int maskedFormatInfo1, int maskedFormatInfo2) - { - FormatInformation formatInfo = doDecodeFormatInformation(maskedFormatInfo1, maskedFormatInfo2); - if (formatInfo != null) - { - return formatInfo; - } - // Should return null, but, some QR codes apparently - // do not mask this info. Try again by actually masking the pattern - // first - return doDecodeFormatInformation(maskedFormatInfo1 ^ FORMAT_INFO_MASK_QR, - maskedFormatInfo2 ^ FORMAT_INFO_MASK_QR); - } - - private static FormatInformation doDecodeFormatInformation(int maskedFormatInfo1, int maskedFormatInfo2) - { - // Find the int in FORMAT_INFO_DECODE_LOOKUP with fewest bits differing - int bestDifference = Int32.MaxValue; - int bestFormatInfo = 0; - foreach (var decodeInfo in FORMAT_INFO_DECODE_LOOKUP) - { - int targetInfo = decodeInfo[0]; - if (targetInfo == maskedFormatInfo1 || targetInfo == maskedFormatInfo2) - { - // Found an exact match - return new FormatInformation(decodeInfo[1]); - } - int bitsDifference = numBitsDiffering(maskedFormatInfo1, targetInfo); - if (bitsDifference < bestDifference) - { - bestFormatInfo = decodeInfo[1]; - bestDifference = bitsDifference; - } - if (maskedFormatInfo1 != maskedFormatInfo2) - { - // also try the other option - bitsDifference = numBitsDiffering(maskedFormatInfo2, targetInfo); - if (bitsDifference < bestDifference) - { - bestFormatInfo = decodeInfo[1]; - bestDifference = bitsDifference; - } - } - } - // Hamming distance of the 32 masked codes is 7, by construction, so <= 3 bits - // differing means we found a match - if (bestDifference <= 3) - { - return new FormatInformation(bestFormatInfo); - } - return null; - } - - internal ErrorCorrectionLevel ErrorCorrectionLevel - { - get - { - return errorCorrectionLevel; - } - } - - internal byte DataMask - { - get - { - return dataMask; - } - } - - public override int GetHashCode() - { - return (errorCorrectionLevel.ordinal() << 3) | dataMask; - } - - public override bool Equals(Object o) - { - if (!(o is FormatInformation)) - { - return false; - } - var other = (FormatInformation)o; - return errorCorrectionLevel == other.errorCorrectionLevel && dataMask == other.dataMask; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Mode.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Mode.cs deleted file mode 100755 index 548ea6d7e..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Mode.cs +++ /dev/null @@ -1,179 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - /// - ///

See ISO 18004:2006, 6.4.1, Tables 2 and 3. This enum encapsulates the various modes in which - /// data can be encoded to bits in the QR code standard.

- ///
- /// Sean Owen - public sealed class Mode - { - /// - /// Gets the name. - /// - public String Name - { - get - { - return name; - } - } - - // No, we can't use an enum here. J2ME doesn't support it. - - /// - /// - /// - public static readonly Mode TERMINATOR = new Mode(new int[] { 0, 0, 0 }, 0x00, "TERMINATOR"); // Not really a mode... - /// - /// - /// - public static readonly Mode NUMERIC = new Mode(new int[] { 10, 12, 14 }, 0x01, "NUMERIC"); - /// - /// - /// - public static readonly Mode ALPHANUMERIC = new Mode(new int[] { 9, 11, 13 }, 0x02, "ALPHANUMERIC"); - /// - /// - /// - public static readonly Mode STRUCTURED_APPEND = new Mode(new int[] { 0, 0, 0 }, 0x03, "STRUCTURED_APPEND"); // Not supported - /// - /// - /// - public static readonly Mode BYTE = new Mode(new int[] { 8, 16, 16 }, 0x04, "BYTE"); - /// - /// - /// - public static readonly Mode ECI = new Mode(null, 0x07, "ECI"); // character counts don't apply - /// - /// - /// - public static readonly Mode KANJI = new Mode(new int[] { 8, 10, 12 }, 0x08, "KANJI"); - /// - /// - /// - public static readonly Mode FNC1_FIRST_POSITION = new Mode(null, 0x05, "FNC1_FIRST_POSITION"); - /// - /// - /// - public static readonly Mode FNC1_SECOND_POSITION = new Mode(null, 0x09, "FNC1_SECOND_POSITION"); - /// See GBT 18284-2000; "Hanzi" is a transliteration of this mode name. - public static readonly Mode HANZI = new Mode(new int[] { 8, 10, 12 }, 0x0D, "HANZI"); - - private readonly int[] characterCountBitsForVersions; - private readonly int bits; - private readonly String name; - - private Mode(int[] characterCountBitsForVersions, int bits, System.String name) - { - this.characterCountBitsForVersions = characterCountBitsForVersions; - this.bits = bits; - this.name = name; - } - - /// - /// Fors the bits. - /// - /// four bits encoding a QR Code data mode - /// - /// encoded by these bits - /// - /// if bits do not correspond to a known mode - public static Mode forBits(int bits) - { - switch (bits) - { - case 0x0: - return TERMINATOR; - case 0x1: - return NUMERIC; - case 0x2: - return ALPHANUMERIC; - case 0x3: - return STRUCTURED_APPEND; - case 0x4: - return BYTE; - case 0x5: - return FNC1_FIRST_POSITION; - case 0x7: - return ECI; - case 0x8: - return KANJI; - case 0x9: - return FNC1_SECOND_POSITION; - case 0xD: - // 0xD is defined in GBT 18284-2000, may not be supported in foreign country - return HANZI; - default: - throw new ArgumentException(); - } - } - - /// version in question - /// - /// number of bits used, in this QR Code symbol {@link Version}, to encode the - /// count of characters that will follow encoded in this {@link Mode} - /// - public int getCharacterCountBits(Version version) - { - if (characterCountBitsForVersions == null) - { - throw new ArgumentException("Character count doesn't apply to this mode"); - } - int number = version.VersionNumber; - int offset; - if (number <= 9) - { - offset = 0; - } - else if (number <= 26) - { - offset = 1; - } - else - { - offset = 2; - } - return characterCountBitsForVersions[offset]; - } - - /// - /// Gets the bits. - /// - public int Bits - { - get - { - return bits; - } - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - return name; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/QRCodeDecoderMetaData.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/QRCodeDecoderMetaData.cs deleted file mode 100755 index cc059aa91..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/QRCodeDecoderMetaData.cs +++ /dev/null @@ -1,60 +0,0 @@ -/* - * 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. - */ - -namespace ZXing.QrCode.Internal -{ - /// - /// Meta-data container for QR Code decoding. Instances of this class may be used to convey information back to the - /// decoding caller. Callers are expected to process this. - /// - public sealed class QRCodeDecoderMetaData - { - private readonly bool mirrored; - - /// - /// Initializes a new instance of the class. - /// - /// if set to true [mirrored]. - public QRCodeDecoderMetaData(bool mirrored) - { - this.mirrored = mirrored; - } - - /// - /// true if the QR Code was mirrored. - /// - public bool IsMirrored - { - get { return mirrored; } - } - - /// - /// Apply the result points' order correction due to mirroring. - /// - /// Array of points to apply mirror correction to. - public void applyMirroredCorrection(ResultPoint[] points) - { - if (!mirrored || points == null || points.Length < 3) - { - return; - } - ResultPoint bottomLeft = points[0]; - points[0] = points[2]; - points[2] = bottomLeft; - // No need to 'fix' top-left and alignment pattern. - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Version.cs b/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Version.cs deleted file mode 100755 index e619933d9..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/decoder/Version.cs +++ /dev/null @@ -1,424 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - /// - /// See ISO 18004:2006 Annex D - /// - /// Sean Owen - public sealed class Version - { - /// See ISO 18004:2006 Annex D. - /// Element i represents the raw version bits that specify version i + 7 - /// - private static readonly int[] VERSION_DECODE_INFO = new[] - { - 0x07C94, 0x085BC, 0x09A99, 0x0A4D3, 0x0BBF6, - 0x0C762, 0x0D847, 0x0E60D, 0x0F928, 0x10B78, - 0x1145D, 0x12A17, 0x13532, 0x149A6, 0x15683, - 0x168C9, 0x177EC, 0x18EC4, 0x191E1, 0x1AFAB, - 0x1B08E, 0x1CC1A, 0x1D33F, 0x1ED75, 0x1F250, - 0x209D5, 0x216F0, 0x228BA, 0x2379F, 0x24B0B, - 0x2542E, 0x26A64, 0x27541, 0x28C69 - }; - - private static readonly Version[] VERSIONS = buildVersions(); - - private readonly int versionNumber; - private readonly int[] alignmentPatternCenters; - private readonly ECBlocks[] ecBlocks; - private readonly int totalCodewords; - - private Version(int versionNumber, int[] alignmentPatternCenters, params ECBlocks[] ecBlocks) - { - this.versionNumber = versionNumber; - this.alignmentPatternCenters = alignmentPatternCenters; - this.ecBlocks = ecBlocks; - int total = 0; - int ecCodewords = ecBlocks[0].ECCodewordsPerBlock; - ECB[] ecbArray = ecBlocks[0].getECBlocks(); - foreach (var ecBlock in ecbArray) - { - total += ecBlock.Count * (ecBlock.DataCodewords + ecCodewords); - } - this.totalCodewords = total; - } - - /// - /// Gets the version number. - /// - public int VersionNumber - { - get - { - return versionNumber; - } - - } - - /// - /// Gets the alignment pattern centers. - /// - public int[] AlignmentPatternCenters - { - get - { - return alignmentPatternCenters; - } - - } - - /// - /// Gets the total codewords. - /// - public int TotalCodewords - { - get - { - return totalCodewords; - } - - } - - /// - /// Gets the dimension for version. - /// - public int DimensionForVersion - { - get - { - return 17 + 4 * versionNumber; - } - - } - - /// - /// Gets the EC blocks for level. - /// - /// The ec level. - /// - public ECBlocks getECBlocksForLevel(ErrorCorrectionLevel ecLevel) - { - return ecBlocks[ecLevel.ordinal()]; - } - - ///

Deduces version information purely from QR Code dimensions.

- /// - ///
- /// dimension in modules - /// - /// for a QR Code of that dimension or null - public static Version getProvisionalVersionForDimension(int dimension) - { - if (dimension % 4 != 1) - { - return null; - } - try - { - return getVersionForNumber((dimension - 17) >> 2); - } - catch (ArgumentException) - { - return null; - } - } - - /// - /// Gets the version for number. - /// - /// The version number. - /// - public static Version getVersionForNumber(int versionNumber) - { - if (versionNumber < 1 || versionNumber > 40) - { - throw new ArgumentException(); - } - return VERSIONS[versionNumber - 1]; - } - - internal static Version decodeVersionInformation(int versionBits) - { - int bestDifference = Int32.MaxValue; - int bestVersion = 0; - for (int i = 0; i < VERSION_DECODE_INFO.Length; i++) - { - int targetVersion = VERSION_DECODE_INFO[i]; - // Do the version info bits match exactly? done. - if (targetVersion == versionBits) - { - return getVersionForNumber(i + 7); - } - // Otherwise see if this is the closest to a real version info bit string - // we have seen so far - int bitsDifference = FormatInformation.numBitsDiffering(versionBits, targetVersion); - if (bitsDifference < bestDifference) - { - bestVersion = i + 7; - bestDifference = bitsDifference; - } - } - // We can tolerate up to 3 bits of error since no two version info codewords will - // differ in less than 8 bits. - if (bestDifference <= 3) - { - return getVersionForNumber(bestVersion); - } - // If we didn't find a close enough match, fail - return null; - } - - /// See ISO 18004:2006 Annex E - internal BitMatrix buildFunctionPattern() - { - int dimension = DimensionForVersion; - BitMatrix bitMatrix = new BitMatrix(dimension); - - // Top left finder pattern + separator + format - bitMatrix.setRegion(0, 0, 9, 9); - // Top right finder pattern + separator + format - bitMatrix.setRegion(dimension - 8, 0, 8, 9); - // Bottom left finder pattern + separator + format - bitMatrix.setRegion(0, dimension - 8, 9, 8); - - // Alignment patterns - int max = alignmentPatternCenters.Length; - for (int x = 0; x < max; x++) - { - int i = alignmentPatternCenters[x] - 2; - for (int y = 0; y < max; y++) - { - if ((x == 0 && (y == 0 || y == max - 1)) || (x == max - 1 && y == 0)) - { - // No alignment patterns near the three finder paterns - continue; - } - bitMatrix.setRegion(alignmentPatternCenters[y] - 2, i, 5, 5); - } - } - - // Vertical timing pattern - bitMatrix.setRegion(6, 9, 1, dimension - 17); - // Horizontal timing pattern - bitMatrix.setRegion(9, 6, dimension - 17, 1); - - if (versionNumber > 6) - { - // Version info, top right - bitMatrix.setRegion(dimension - 11, 0, 3, 6); - // Version info, bottom left - bitMatrix.setRegion(0, dimension - 11, 6, 3); - } - - return bitMatrix; - } - - ///

Encapsulates a set of error-correction blocks in one symbol version. Most versions will - /// use blocks of differing sizes within one version, so, this encapsulates the parameters for - /// each set of blocks. It also holds the number of error-correction codewords per block since it - /// will be the same across all blocks within one version.

- ///
- public sealed class ECBlocks - { - private readonly int ecCodewordsPerBlock; - private readonly ECB[] ecBlocks; - - internal ECBlocks(int ecCodewordsPerBlock, params ECB[] ecBlocks) - { - this.ecCodewordsPerBlock = ecCodewordsPerBlock; - this.ecBlocks = ecBlocks; - } - - /// - /// Gets the EC codewords per block. - /// - public int ECCodewordsPerBlock - { - get - { - return ecCodewordsPerBlock; - } - } - - /// - /// Gets the num blocks. - /// - public int NumBlocks - { - get - { - int total = 0; - foreach (var ecBlock in ecBlocks) - { - total += ecBlock.Count; - } - return total; - } - } - - /// - /// Gets the total EC codewords. - /// - public int TotalECCodewords - { - get - { - return ecCodewordsPerBlock * NumBlocks; - } - } - - /// - /// Gets the EC blocks. - /// - /// - public ECB[] getECBlocks() - { - return ecBlocks; - } - } - - ///

Encapsualtes the parameters for one error-correction block in one symbol version. - /// This includes the number of data codewords, and the number of times a block with these - /// parameters is used consecutively in the QR code version's format.

- ///
- public sealed class ECB - { - private readonly int count; - private readonly int dataCodewords; - - internal ECB(int count, int dataCodewords) - { - this.count = count; - this.dataCodewords = dataCodewords; - } - - /// - /// Gets the count. - /// - public int Count - { - get - { - return count; - } - - } - /// - /// Gets the data codewords. - /// - public int DataCodewords - { - get - { - return dataCodewords; - } - - } - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - return Convert.ToString(versionNumber); - } - - /// See ISO 18004:2006 6.5.1 Table 9 - private static Version[] buildVersions() - { - return new Version[]{ - new Version(1, new int[]{}, - new ECBlocks(7, new ECB(1, 19)), - new ECBlocks(10, new ECB(1, 16)), - new ECBlocks(13, new ECB(1, 13)), - new ECBlocks(17, new ECB(1, 9))), - new Version(2, new int[]{6, 18}, - new ECBlocks(10, new ECB(1, 34)), - new ECBlocks(16, new ECB(1, 28)), - new ECBlocks(22, new ECB(1, 22)), - new ECBlocks(28, new ECB(1, 16))), - new Version(3, new int[]{6, 22}, - new ECBlocks(15, new ECB(1, 55)), - new ECBlocks(26, new ECB(1, 44)), - new ECBlocks(18, new ECB(2, 17)), - new ECBlocks(22, new ECB(2, 13))), - new Version(4, new int[]{6, 26}, - new ECBlocks(20, new ECB(1, 80)), - new ECBlocks(18, new ECB(2, 32)), - new ECBlocks(26, new ECB(2, 24)), - new ECBlocks(16, new ECB(4, 9))), - new Version(5, new int[]{6, 30}, - new ECBlocks(26, new ECB(1, 108)), - new ECBlocks(24, new ECB(2, 43)), - new ECBlocks(18, new ECB(2, 15), - new ECB(2, 16)), - new ECBlocks(22, new ECB(2, 11), - new ECB(2, 12))), - new Version(6, new int[]{6, 34}, - new ECBlocks(18, new ECB(2, 68)), - new ECBlocks(16, new ECB(4, 27)), - new ECBlocks(24, new ECB(4, 19)), - new ECBlocks(28, new ECB(4, 15))), - new Version(7, new int[]{6, 22, 38}, - new ECBlocks(20, new ECB(2, 78)), - new ECBlocks(18, new ECB(4, 31)), - new ECBlocks(18, new ECB(2, 14), - new ECB(4, 15)), - new ECBlocks(26, new ECB(4, 13), - new ECB(1, 14))), - new Version(8, new int[]{6, 24, 42}, - new ECBlocks(24, new ECB(2, 97)), - new ECBlocks(22, new ECB(2, 38), - new ECB(2, 39)), - new ECBlocks(22, new ECB(4, 18), - new ECB(2, 19)), - new ECBlocks(26, new ECB(4, 14), - new ECB(2, 15))), - new Version(9, new int[]{6, 26, 46}, - new ECBlocks(30, new ECB(2, 116)), - new ECBlocks(22, new ECB(3, 36), - new ECB(2, 37)), - new ECBlocks(20, new ECB(4, 16), - new ECB(4, 17)), - new ECBlocks(24, new ECB(4, 12), - new ECB(4, 13))), - new Version(10, new int[]{6, 28, 50}, - new ECBlocks(18, new ECB(2, 68), - new ECB(2, 69)), - new ECBlocks(26, new ECB(4, 43), - new ECB(1, 44)), - new ECBlocks(24, new ECB(6, 19), - new ECB(2, 20)), - new ECBlocks(28, new ECB(6, 15), - new ECB(2, 16))), - new Version(11, new int[]{6, 30, 54}, new ECBlocks(20, new ECB(4, 81)), - new ECBlocks(30, new ECB(1, 50), new ECB(4, 51)), new ECBlocks(28, new ECB(4, 22), new ECB(4, 23)), new ECBlocks(24, new ECB(3, 12), new ECB(8, 13))), new Version(12, new int[]{6, 32, 58}, new ECBlocks(24, new ECB(2, 92), new ECB(2, 93)), new ECBlocks(22, new ECB(6, 36), new ECB(2, 37)), new ECBlocks(26, new ECB(4, 20), new ECB(6, 21)), new ECBlocks(28, new ECB(7, 14), new ECB(4, 15))), new Version(13, new int[]{6, 34, 62}, new ECBlocks(26, new ECB(4, 107)), new ECBlocks(22, new ECB(8, 37), new ECB(1, 38)), new ECBlocks(24, new ECB(8, 20), new ECB(4, 21)), new ECBlocks(22, new ECB(12, 11), new ECB(4, 12))), new Version(14, new int[]{6, 26, 46, 66}, new ECBlocks(30, new ECB(3, 115), new ECB(1, 116)), new ECBlocks(24, new ECB(4, 40), new ECB(5, 41)), new ECBlocks(20, new ECB(11, 16), new ECB(5, 17)), new ECBlocks(24, new ECB(11, 12), new ECB(5, 13))), new Version(15, new int[]{6, 26, 48, 70}, new ECBlocks(22, new ECB(5, 87), new ECB(1, 88)), new ECBlocks(24, new ECB(5, 41), new ECB(5, 42)), new ECBlocks(30, new ECB(5, 24), new ECB(7, 25)), new ECBlocks(24, new ECB(11, 12), new ECB(7, 13))), new Version(16, new int[]{6, 26, 50, 74}, new ECBlocks(24, new ECB(5, 98), new ECB(1, 99)), new ECBlocks(28, new ECB(7, 45), new ECB(3, 46)), new ECBlocks(24, new ECB(15, 19), new ECB(2, 20)), new ECBlocks(30, new ECB(3, 15), new ECB(13, 16))), new Version(17, new int[]{6, 30, 54, 78}, new ECBlocks(28, new ECB(1, 107), new ECB(5, 108)), new ECBlocks(28, new ECB(10, 46), new ECB(1, 47)), new ECBlocks(28, new ECB(1, 22), new ECB(15, 23)), new ECBlocks(28, new ECB(2, 14), new ECB(17, 15))), new Version(18, new int[]{6, 30, 56, 82}, new ECBlocks(30, new ECB(5, 120), new ECB(1, 121)), new ECBlocks(26, new ECB(9, 43), new ECB(4, 44)), new ECBlocks(28, new ECB(17, 22), new ECB(1, 23)), new ECBlocks(28, new ECB(2, 14), new ECB(19, 15))), new Version(19, new int[]{6, 30, 58, 86}, new ECBlocks(28, new ECB(3, 113), new ECB(4, 114)), new ECBlocks(26, new ECB(3, 44), new ECB(11, 45)), new ECBlocks(26, new ECB(17, 21), - new ECB(4, 22)), new ECBlocks(26, new ECB(9, 13), new ECB(16, 14))), new Version(20, new int[]{6, 34, 62, 90}, new ECBlocks(28, new ECB(3, 107), new ECB(5, 108)), new ECBlocks(26, new ECB(3, 41), new ECB(13, 42)), new ECBlocks(30, new ECB(15, 24), new ECB(5, 25)), new ECBlocks(28, new ECB(15, 15), new ECB(10, 16))), new Version(21, new int[]{6, 28, 50, 72, 94}, new ECBlocks(28, new ECB(4, 116), new ECB(4, 117)), new ECBlocks(26, new ECB(17, 42)), new ECBlocks(28, new ECB(17, 22), new ECB(6, 23)), new ECBlocks(30, new ECB(19, 16), new ECB(6, 17))), new Version(22, new int[]{6, 26, 50, 74, 98}, new ECBlocks(28, new ECB(2, 111), new ECB(7, 112)), new ECBlocks(28, new ECB(17, 46)), new ECBlocks(30, new ECB(7, 24), new ECB(16, 25)), new ECBlocks(24, new ECB(34, 13))), new Version(23, new int[]{6, 30, 54, 74, 102}, new ECBlocks(30, new ECB(4, 121), new ECB(5, 122)), new ECBlocks(28, new ECB(4, 47), new ECB(14, 48)), new ECBlocks(30, new ECB(11, 24), new ECB(14, 25)), new ECBlocks(30, new ECB(16, 15), new ECB(14, 16))), new Version(24, new int[]{6, 28, 54, 80, 106}, new ECBlocks(30, new ECB(6, 117), new ECB(4, 118)), new ECBlocks(28, new ECB(6, 45), new ECB(14, 46)), new ECBlocks(30, new ECB(11, 24), new ECB(16, 25)), new ECBlocks(30, new ECB(30, 16), new ECB(2, 17))), new Version(25, new int[]{6, 32, 58, 84, 110}, new ECBlocks(26, new ECB(8, 106), new ECB(4, 107)), new ECBlocks(28, new ECB(8, 47), new ECB(13, 48)), new ECBlocks(30, new ECB(7, 24), new ECB(22, 25)), new ECBlocks(30, new ECB(22, 15), new ECB(13, 16))), new Version(26, new int[]{6, 30, 58, 86, 114}, new ECBlocks(28, new ECB(10, 114), new ECB(2, 115)), new ECBlocks(28, new ECB(19, 46), new ECB(4, 47)), new ECBlocks(28, new ECB(28, 22), new ECB(6, 23)), new ECBlocks(30, new ECB(33, 16), new ECB(4, 17))), new Version(27, new int[]{6, 34, 62, 90, 118}, new ECBlocks(30, new ECB(8, 122), new ECB(4, 123)), new ECBlocks(28, new ECB(22, 45), new ECB(3, 46)), new ECBlocks(30, new ECB(8, 23), new ECB(26, 24)), new ECBlocks(30, new ECB(12, 15), - new ECB(28, 16))), new Version(28, new int[]{6, 26, 50, 74, 98, 122}, new ECBlocks(30, new ECB(3, 117), new ECB(10, 118)), new ECBlocks(28, new ECB(3, 45), new ECB(23, 46)), new ECBlocks(30, new ECB(4, 24), new ECB(31, 25)), new ECBlocks(30, new ECB(11, 15), new ECB(31, 16))), new Version(29, new int[]{6, 30, 54, 78, 102, 126}, new ECBlocks(30, new ECB(7, 116), new ECB(7, 117)), new ECBlocks(28, new ECB(21, 45), new ECB(7, 46)), new ECBlocks(30, new ECB(1, 23), new ECB(37, 24)), new ECBlocks(30, new ECB(19, 15), new ECB(26, 16))), new Version(30, new int[]{6, 26, 52, 78, 104, 130}, new ECBlocks(30, new ECB(5, 115), new ECB(10, 116)), new ECBlocks(28, new ECB(19, 47), new ECB(10, 48)), new ECBlocks(30, new ECB(15, 24), new ECB(25, 25)), new ECBlocks(30, new ECB(23, 15), new ECB(25, 16))), new Version(31, new int[]{6, 30, 56, 82, 108, 134}, new ECBlocks(30, new ECB(13, 115), new ECB(3, 116)), new ECBlocks(28, new ECB(2, 46), new ECB(29, 47)), new ECBlocks(30, new ECB(42, 24), new ECB(1, 25)), new ECBlocks(30, new ECB(23, 15), new ECB(28, 16))), new Version(32, new int[]{6, 34, 60, 86, 112, 138}, new ECBlocks(30, new ECB(17, 115)), new ECBlocks(28, new ECB(10, 46), new ECB(23, 47)), new ECBlocks(30, new ECB(10, 24), new ECB(35, 25)), new ECBlocks(30, new ECB(19, 15), new ECB(35, 16))), new Version(33, new int[]{6, 30, 58, 86, 114, 142}, new ECBlocks(30, new ECB(17, 115), new ECB(1, 116)), new ECBlocks(28, new ECB(14, 46), new ECB(21, 47)), new ECBlocks(30, new ECB(29, 24), new ECB(19, 25)), new ECBlocks(30, new ECB(11, 15), new ECB(46, 16))), new Version(34, new int[]{6, 34, 62, 90, 118, 146}, new ECBlocks(30, new ECB(13, 115), new ECB(6, 116)), new ECBlocks(28, new ECB(14, 46), new ECB(23, 47)), new ECBlocks(30, new ECB(44, 24), new ECB(7, 25)), new ECBlocks(30, new ECB(59, 16), new ECB(1, 17))), new Version(35, new int[]{6, 30, 54, 78, 102, 126, 150}, new ECBlocks(30, new ECB(12, 121), new ECB(7, 122)), new ECBlocks(28, new ECB(12, 47), new ECB(26, 48)), new ECBlocks(30, new ECB(39, 24), new - ECB(14, 25)), new ECBlocks(30, new ECB(22, 15), new ECB(41, 16))), new Version(36, new int[]{6, 24, 50, 76, 102, 128, 154}, new ECBlocks(30, new ECB(6, 121), new ECB(14, 122)), new ECBlocks(28, new ECB(6, 47), new ECB(34, 48)), new ECBlocks(30, new ECB(46, 24), new ECB(10, 25)), new ECBlocks(30, new ECB(2, 15), new ECB(64, 16))), new Version(37, new int[]{6, 28, 54, 80, 106, 132, 158}, new ECBlocks(30, new ECB(17, 122), new ECB(4, 123)), new ECBlocks(28, new ECB(29, 46), new ECB(14, 47)), new ECBlocks(30, new ECB(49, 24), new ECB(10, 25)), new ECBlocks(30, new ECB(24, 15), new ECB(46, 16))), new Version(38, new int[]{6, 32, 58, 84, 110, 136, 162}, new ECBlocks(30, new ECB(4, 122), new ECB(18, 123)), new ECBlocks(28, new ECB(13, 46), new ECB(32, 47)), new ECBlocks(30, new ECB(48, 24), new ECB(14, 25)), new ECBlocks(30, new ECB(42, 15), new ECB(32, 16))), new Version(39, new int[]{6, 26, 54, 82, 110, 138, 166}, new ECBlocks(30, new ECB(20, 117), new ECB(4, 118)), new ECBlocks(28, new ECB(40, 47), new ECB(7, 48)), new ECBlocks(30, new ECB(43, 24), new ECB(22, 25)), new ECBlocks(30, new ECB(10, 15), new ECB(67, 16))), new Version(40, new int[]{6, 30, 58, 86, 114, 142, 170}, new ECBlocks(30, new ECB(19, 118), new ECB(6, 119)), new ECBlocks(28, new ECB(18, 47), new ECB(31, 48)), new ECBlocks(30, new ECB(34, 24), new ECB(34, 25)), new ECBlocks(30, new ECB(20, 15), new ECB(61, 16)))}; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPattern.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPattern.cs deleted file mode 100755 index e7dd9460f..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPattern.cs +++ /dev/null @@ -1,68 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - ///

Encapsulates an alignment pattern, which are the smaller square patterns found in - /// all but the simplest QR Codes.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - public sealed class AlignmentPattern : ResultPoint - { - private float estimatedModuleSize; - - internal AlignmentPattern(float posX, float posY, float estimatedModuleSize) - : base(posX, posY) - { - this.estimatedModuleSize = estimatedModuleSize; - } - - ///

Determines if this alignment pattern "about equals" an alignment pattern at the stated - /// position and size -- meaning, it is at nearly the same center with nearly the same size.

- ///
- internal bool aboutEquals(float moduleSize, float i, float j) - { - if (Math.Abs(i - Y) <= moduleSize && Math.Abs(j - X) <= moduleSize) - { - float moduleSizeDiff = Math.Abs(moduleSize - estimatedModuleSize); - return moduleSizeDiff <= 1.0f || moduleSizeDiff <= estimatedModuleSize; - } - return false; - } - - /// - /// Combines this object's current estimate of a finder pattern position and module size - /// with a new estimate. It returns a new {@code FinderPattern} containing an average of the two. - /// - /// The i. - /// The j. - /// New size of the module. - /// - internal AlignmentPattern combineEstimate(float i, float j, float newModuleSize) - { - float combinedX = (X + j) / 2.0f; - float combinedY = (Y + i) / 2.0f; - float combinedModuleSize = (estimatedModuleSize + newModuleSize) / 2.0f; - return new AlignmentPattern(combinedX, combinedY, combinedModuleSize); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPatternFinder.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPatternFinder.cs deleted file mode 100755 index b8cdec5b5..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/AlignmentPatternFinder.cs +++ /dev/null @@ -1,324 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - ///

This class attempts to find alignment patterns in a QR Code. Alignment patterns look like finder - /// patterns but are smaller and appear at regular intervals throughout the image.

- /// - ///

At the moment this only looks for the bottom-right alignment pattern.

- /// - ///

This is mostly a simplified copy of {@link FinderPatternFinder}. It is copied, - /// pasted and stripped down here for maximum performance but does unfortunately duplicate - /// some code.

- /// - ///

This class is thread-safe but not reentrant. Each thread must allocate its own object.

- /// - ///
- /// Sean Owen - /// - /// www.Redivivus.in (suraj.supekar@redivivus.in) - Ported from ZXING Java Source - /// - sealed class AlignmentPatternFinder - { - private readonly BitMatrix image; - private readonly IList possibleCenters; - private readonly int startX; - private readonly int startY; - private readonly int width; - private readonly int height; - private readonly float moduleSize; - private readonly int[] crossCheckStateCount; - private readonly ResultPointCallback resultPointCallback; - - ///

Creates a finder that will look in a portion of the whole image.

- /// - ///
- /// image to search - /// - /// left column from which to start searching - /// - /// top row from which to start searching - /// - /// width of region to search - /// - /// height of region to search - /// - /// estimated module size so far - /// - internal AlignmentPatternFinder(BitMatrix image, int startX, int startY, int width, int height, float moduleSize, ResultPointCallback resultPointCallback) - { - this.image = image; - this.possibleCenters = new List(5); - this.startX = startX; - this.startY = startY; - this.width = width; - this.height = height; - this.moduleSize = moduleSize; - this.crossCheckStateCount = new int[3]; - this.resultPointCallback = resultPointCallback; - } - - ///

This method attempts to find the bottom-right alignment pattern in the image. It is a bit messy since - /// it's pretty performance-critical and so is written to be fast foremost.

- /// - ///
- /// {@link AlignmentPattern} if found - /// - internal AlignmentPattern find() - { - int startX = this.startX; - int height = this.height; - int maxJ = startX + width; - int middleI = startY + (height >> 1); - // We are looking for black/white/black modules in 1:1:1 ratio; - // this tracks the number of black/white/black modules seen so far - int[] stateCount = new int[3]; - for (int iGen = 0; iGen < height; iGen++) - { - // Search from middle outwards - int i = middleI + ((iGen & 0x01) == 0 ? ((iGen + 1) >> 1) : -((iGen + 1) >> 1)); - stateCount[0] = 0; - stateCount[1] = 0; - stateCount[2] = 0; - int j = startX; - // Burn off leading white pixels before anything else; if we start in the middle of - // a white run, it doesn't make sense to count its length, since we don't know if the - // white run continued to the left of the start point - while (j < maxJ && !image[j, i]) - { - j++; - } - int currentState = 0; - while (j < maxJ) - { - if (image[j, i]) - { - // Black pixel - if (currentState == 1) - { - // Counting black pixels - stateCount[currentState]++; - } - else - { - // Counting white pixels - if (currentState == 2) - { - // A winner? - if (foundPatternCross(stateCount)) - { - // Yes - AlignmentPattern confirmed = handlePossibleCenter(stateCount, i, j); - if (confirmed != null) - { - return confirmed; - } - } - stateCount[0] = stateCount[2]; - stateCount[1] = 1; - stateCount[2] = 0; - currentState = 1; - } - else - { - stateCount[++currentState]++; - } - } - } - else - { - // White pixel - if (currentState == 1) - { - // Counting black pixels - currentState++; - } - stateCount[currentState]++; - } - j++; - } - if (foundPatternCross(stateCount)) - { - AlignmentPattern confirmed = handlePossibleCenter(stateCount, i, maxJ); - if (confirmed != null) - { - return confirmed; - } - } - } - - // Hmm, nothing we saw was observed and confirmed twice. If we had - // any guess at all, return it. - if (possibleCenters.Count != 0) - { - return possibleCenters[0]; - } - - return null; - } - - /// Given a count of black/white/black pixels just seen and an end position, - /// figures the location of the center of this black/white/black run. - /// - private static float? centerFromEnd(int[] stateCount, int end) - { - var result = (end - stateCount[2]) - stateCount[1] / 2.0f; - if (Single.IsNaN(result)) - return null; - return result; - } - - /// count of black/white/black pixels just read - /// - /// true iff the proportions of the counts is close enough to the 1/1/1 ratios - /// used by alignment patterns to be considered a match - /// - private bool foundPatternCross(int[] stateCount) - { - float maxVariance = moduleSize / 2.0f; - for (int i = 0; i < 3; i++) - { - if (Math.Abs(moduleSize - stateCount[i]) >= maxVariance) - { - return false; - } - } - return true; - } - - /// - ///

After a horizontal scan finds a potential alignment pattern, this method - /// "cross-checks" by scanning down vertically through the center of the possible - /// alignment pattern to see if the same proportion is detected.

- ///
- /// row where an alignment pattern was detected - /// center of the section that appears to cross an alignment pattern - /// maximum reasonable number of modules that should be - /// observed in any reading state, based on the results of the horizontal scan - /// The original state count total. - /// - /// vertical center of alignment pattern, or null if not found - /// - private float? crossCheckVertical(int startI, int centerJ, int maxCount, int originalStateCountTotal) - { - int maxI = image.Height; - int[] stateCount = crossCheckStateCount; - stateCount[0] = 0; - stateCount[1] = 0; - stateCount[2] = 0; - - // Start counting up from center - int i = startI; - while (i >= 0 && image[centerJ, i] && stateCount[1] <= maxCount) - { - stateCount[1]++; - i--; - } - // If already too many modules in this state or ran off the edge: - if (i < 0 || stateCount[1] > maxCount) - { - return null; - } - while (i >= 0 && !image[centerJ, i] && stateCount[0] <= maxCount) - { - stateCount[0]++; - i--; - } - if (stateCount[0] > maxCount) - { - return null; - } - - // Now also count down from center - i = startI + 1; - while (i < maxI && image[centerJ, i] && stateCount[1] <= maxCount) - { - stateCount[1]++; - i++; - } - if (i == maxI || stateCount[1] > maxCount) - { - return null; - } - while (i < maxI && !image[centerJ, i] && stateCount[2] <= maxCount) - { - stateCount[2]++; - i++; - } - if (stateCount[2] > maxCount) - { - return null; - } - - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2]; - if (5 * Math.Abs(stateCountTotal - originalStateCountTotal) >= 2 * originalStateCountTotal) - { - return null; - } - - return foundPatternCross(stateCount) ? centerFromEnd(stateCount, i) : null; - } - - ///

This is called when a horizontal scan finds a possible alignment pattern. It will - /// cross check with a vertical scan, and if successful, will see if this pattern had been - /// found on a previous horizontal scan. If so, we consider it confirmed and conclude we have - /// found the alignment pattern.

- /// - ///
- /// reading state module counts from horizontal scan - /// - /// row where alignment pattern may be found - /// - /// end of possible alignment pattern in row - /// - /// {@link AlignmentPattern} if we have found the same pattern twice, or null if not - /// - private AlignmentPattern handlePossibleCenter(int[] stateCount, int i, int j) - { - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2]; - float? centerJ = centerFromEnd(stateCount, j); - if (centerJ == null) - return null; - float? centerI = crossCheckVertical(i, (int)centerJ, 2 * stateCount[1], stateCountTotal); - if (centerI != null) - { - float estimatedModuleSize = (stateCount[0] + stateCount[1] + stateCount[2]) / 3.0f; - foreach (var center in possibleCenters) - { - // Look for about the same center and module size: - if (center.aboutEquals(estimatedModuleSize, centerI.Value, centerJ.Value)) - { - return center.combineEstimate(centerI.Value, centerJ.Value, estimatedModuleSize); - } - } - // Hadn't found this before; save it - var point = new AlignmentPattern(centerJ.Value, centerI.Value, estimatedModuleSize); - possibleCenters.Add(point); - if (resultPointCallback != null) - { - resultPointCallback(point); - } - } - return null; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/Detector.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/Detector.cs deleted file mode 100755 index 7ae8e3db3..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/Detector.cs +++ /dev/null @@ -1,429 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -using ZXing.Common; -using ZXing.Common.Detector; - -namespace ZXing.QrCode.Internal -{ - /// - ///

Encapsulates logic that can detect a QR Code in an image, even if the QR Code - /// is rotated or skewed, or partially obscured.

- ///
- /// Sean Owen - public class Detector - { - private readonly BitMatrix image; - private ResultPointCallback resultPointCallback; - - /// - /// Initializes a new instance of the class. - /// - /// The image. - public Detector(BitMatrix image) - { - this.image = image; - } - - /// - /// Gets the image. - /// - virtual protected internal BitMatrix Image - { - get - { - return image; - } - } - - /// - /// Gets the result point callback. - /// - virtual protected internal ResultPointCallback ResultPointCallback - { - get - { - return resultPointCallback; - } - } - - /// - ///

Detects a QR Code in an image, simply.

- ///
- /// - /// encapsulating results of detecting a QR Code - /// - public virtual DetectorResult detect() - { - return detect(null); - } - - /// - ///

Detects a QR Code in an image, simply.

- ///
- /// optional hints to detector - /// - /// encapsulating results of detecting a QR Code - /// - public virtual DetectorResult detect(IDictionary hints) - { - resultPointCallback = hints == null || !hints.ContainsKey(DecodeHintType.NEED_RESULT_POINT_CALLBACK) ? null : (ResultPointCallback)hints[DecodeHintType.NEED_RESULT_POINT_CALLBACK]; - - FinderPatternFinder finder = new FinderPatternFinder(image, resultPointCallback); - FinderPatternInfo info = finder.find(hints); - if (info == null) - return null; - - return processFinderPatternInfo(info); - } - - /// - /// Processes the finder pattern info. - /// - /// The info. - /// - protected internal virtual DetectorResult processFinderPatternInfo(FinderPatternInfo info) - { - FinderPattern topLeft = info.TopLeft; - FinderPattern topRight = info.TopRight; - FinderPattern bottomLeft = info.BottomLeft; - - float moduleSize = calculateModuleSize(topLeft, topRight, bottomLeft); - if (moduleSize < 1.0f) - { - return null; - } - int dimension; - if (!computeDimension(topLeft, topRight, bottomLeft, moduleSize, out dimension)) - return null; - Internal.Version provisionalVersion = Internal.Version.getProvisionalVersionForDimension(dimension); - if (provisionalVersion == null) - return null; - int modulesBetweenFPCenters = provisionalVersion.DimensionForVersion - 7; - - AlignmentPattern alignmentPattern = null; - // Anything above version 1 has an alignment pattern - if (provisionalVersion.AlignmentPatternCenters.Length > 0) - { - - // Guess where a "bottom right" finder pattern would have been - float bottomRightX = topRight.X - topLeft.X + bottomLeft.X; - float bottomRightY = topRight.Y - topLeft.Y + bottomLeft.Y; - - // Estimate that alignment pattern is closer by 3 modules - // from "bottom right" to known top left location - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - float correctionToTopLeft = 1.0f - 3.0f / (float)modulesBetweenFPCenters; - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int estAlignmentX = (int)(topLeft.X + correctionToTopLeft * (bottomRightX - topLeft.X)); - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int estAlignmentY = (int)(topLeft.Y + correctionToTopLeft * (bottomRightY - topLeft.Y)); - - // Kind of arbitrary -- expand search radius before giving up - for (int i = 4; i <= 16; i <<= 1) - { - alignmentPattern = findAlignmentInRegion(moduleSize, estAlignmentX, estAlignmentY, (float)i); - if (alignmentPattern == null) - continue; - break; - } - // If we didn't find alignment pattern... well try anyway without it - } - - PerspectiveTransform transform = createTransform(topLeft, topRight, bottomLeft, alignmentPattern, dimension); - - BitMatrix bits = sampleGrid(image, transform, dimension); - if (bits == null) - return null; - - ResultPoint[] points; - if (alignmentPattern == null) - { - points = new ResultPoint[] { bottomLeft, topLeft, topRight }; - } - else - { - points = new ResultPoint[] { bottomLeft, topLeft, topRight, alignmentPattern }; - } - return new DetectorResult(bits, points); - } - - private static PerspectiveTransform createTransform(ResultPoint topLeft, ResultPoint topRight, ResultPoint bottomLeft, ResultPoint alignmentPattern, int dimension) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - float dimMinusThree = (float)dimension - 3.5f; - float bottomRightX; - float bottomRightY; - float sourceBottomRightX; - float sourceBottomRightY; - if (alignmentPattern != null) - { - bottomRightX = alignmentPattern.X; - bottomRightY = alignmentPattern.Y; - sourceBottomRightX = sourceBottomRightY = dimMinusThree - 3.0f; - } - else - { - // Don't have an alignment pattern, just make up the bottom-right point - bottomRightX = (topRight.X - topLeft.X) + bottomLeft.X; - bottomRightY = (topRight.Y - topLeft.Y) + bottomLeft.Y; - sourceBottomRightX = sourceBottomRightY = dimMinusThree; - } - - return PerspectiveTransform.quadrilateralToQuadrilateral( - 3.5f, - 3.5f, - dimMinusThree, - 3.5f, - sourceBottomRightX, - sourceBottomRightY, - 3.5f, - dimMinusThree, - topLeft.X, - topLeft.Y, - topRight.X, - topRight.Y, - bottomRightX, - bottomRightY, - bottomLeft.X, - bottomLeft.Y); - } - - private static BitMatrix sampleGrid(BitMatrix image, PerspectiveTransform transform, int dimension) - { - GridSampler sampler = GridSampler.Instance; - return sampler.sampleGrid(image, dimension, dimension, transform); - } - - ///

Computes the dimension (number of modules on a size) of the QR Code based on the position - /// of the finder patterns and estimated module size.

- ///
- private static bool computeDimension(ResultPoint topLeft, ResultPoint topRight, ResultPoint bottomLeft, float moduleSize, out int dimension) - { - int tltrCentersDimension = MathUtils.round(ResultPoint.distance(topLeft, topRight) / moduleSize); - int tlblCentersDimension = MathUtils.round(ResultPoint.distance(topLeft, bottomLeft) / moduleSize); - dimension = ((tltrCentersDimension + tlblCentersDimension) >> 1) + 7; - switch (dimension & 0x03) - { - // mod 4 - case 0: - dimension++; - break; - // 1? do nothing - case 2: - dimension--; - break; - case 3: - return true; - } - return true; - } - - ///

Computes an average estimated module size based on estimated derived from the positions - /// of the three finder patterns.

- ///
- protected internal virtual float calculateModuleSize(ResultPoint topLeft, ResultPoint topRight, ResultPoint bottomLeft) - { - // Take the average - return (calculateModuleSizeOneWay(topLeft, topRight) + calculateModuleSizeOneWay(topLeft, bottomLeft)) / 2.0f; - } - - ///

Estimates module size based on two finder patterns -- it uses - /// {@link #sizeOfBlackWhiteBlackRunBothWays(int, int, int, int)} to figure the - /// width of each, measuring along the axis between their centers.

- ///
- private float calculateModuleSizeOneWay(ResultPoint pattern, ResultPoint otherPattern) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - float moduleSizeEst1 = sizeOfBlackWhiteBlackRunBothWays((int)pattern.X, (int)pattern.Y, (int)otherPattern.X, (int)otherPattern.Y); - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - float moduleSizeEst2 = sizeOfBlackWhiteBlackRunBothWays((int)otherPattern.X, (int)otherPattern.Y, (int)pattern.X, (int)pattern.Y); - if (Single.IsNaN(moduleSizeEst1)) - { - return moduleSizeEst2 / 7.0f; - } - if (Single.IsNaN(moduleSizeEst2)) - { - return moduleSizeEst1 / 7.0f; - } - // Average them, and divide by 7 since we've counted the width of 3 black modules, - // and 1 white and 1 black module on either side. Ergo, divide sum by 14. - return (moduleSizeEst1 + moduleSizeEst2) / 14.0f; - } - - /// See {@link #sizeOfBlackWhiteBlackRun(int, int, int, int)}; computes the total width of - /// a finder pattern by looking for a black-white-black run from the center in the direction - /// of another point (another finder pattern center), and in the opposite direction too. - /// - private float sizeOfBlackWhiteBlackRunBothWays(int fromX, int fromY, int toX, int toY) - { - - float result = sizeOfBlackWhiteBlackRun(fromX, fromY, toX, toY); - - // Now count other way -- don't run off image though of course - float scale = 1.0f; - int otherToX = fromX - (toX - fromX); - if (otherToX < 0) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - scale = (float)fromX / (float)(fromX - otherToX); - otherToX = 0; - } - else if (otherToX >= image.Width) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - scale = (float)(image.Width - 1 - fromX) / (float)(otherToX - fromX); - otherToX = image.Width - 1; - } - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int otherToY = (int)(fromY - (toY - fromY) * scale); - - scale = 1.0f; - if (otherToY < 0) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - scale = (float)fromY / (float)(fromY - otherToY); - otherToY = 0; - } - else if (otherToY >= image.Height) - { - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - scale = (float)(image.Height - 1 - fromY) / (float)(otherToY - fromY); - otherToY = image.Height - 1; - } - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - otherToX = (int)(fromX + (otherToX - fromX) * scale); - - result += sizeOfBlackWhiteBlackRun(fromX, fromY, otherToX, otherToY); - return result - 1.0f; // -1 because we counted the middle pixel twice - } - - ///

This method traces a line from a point in the image, in the direction towards another point. - /// It begins in a black region, and keeps going until it finds white, then black, then white again. - /// It reports the distance from the start to this point.

- /// - ///

This is used when figuring out how wide a finder pattern is, when the finder pattern - /// may be skewed or rotated.

- ///
- private float sizeOfBlackWhiteBlackRun(int fromX, int fromY, int toX, int toY) - { - // Mild variant of Bresenham's algorithm; - // see http://en.wikipedia.org/wiki/Bresenham's_line_algorithm - bool steep = Math.Abs(toY - fromY) > Math.Abs(toX - fromX); - if (steep) - { - int temp = fromX; - fromX = fromY; - fromY = temp; - temp = toX; - toX = toY; - toY = temp; - } - - int dx = Math.Abs(toX - fromX); - int dy = Math.Abs(toY - fromY); - int error = -dx >> 1; - int xstep = fromX < toX ? 1 : -1; - int ystep = fromY < toY ? 1 : -1; - - // In black pixels, looking for white, first or second time. - int state = 0; - // Loop up until x == toX, but not beyond - int xLimit = toX + xstep; - for (int x = fromX, y = fromY; x != xLimit; x += xstep) - { - int realX = steep ? y : x; - int realY = steep ? x : y; - - // Does current pixel mean we have moved white to black or vice versa? - // Scanning black in state 0,2 and white in state 1, so if we find the wrong - // color, advance to next state or end if we are in state 2 already - if ((state == 1) == image[realX, realY]) - { - if (state == 2) - { - return MathUtils.distance(x, y, fromX, fromY); - } - state++; - } - error += dy; - if (error > 0) - { - if (y == toY) - { - - - break; - } - y += ystep; - error -= dx; - } - } - // Found black-white-black; give the benefit of the doubt that the next pixel outside the image - // is "white" so this last point at (toX+xStep,toY) is the right ending. This is really a - // small approximation; (toX+xStep,toY+yStep) might be really correct. Ignore this. - if (state == 2) - { - return MathUtils.distance(toX + xstep, toY, fromX, fromY); - } - // else we didn't find even black-white-black; no estimate is really possible - return Single.NaN; - - } - - /// - ///

Attempts to locate an alignment pattern in a limited region of the image, which is - /// guessed to contain it. This method uses {@link AlignmentPattern}.

- ///
- /// estimated module size so far - /// x coordinate of center of area probably containing alignment pattern - /// y coordinate of above - /// number of pixels in all directions to search from the center - /// - /// if found, or null otherwise - /// - protected AlignmentPattern findAlignmentInRegion(float overallEstModuleSize, int estAlignmentX, int estAlignmentY, float allowanceFactor) - { - // Look for an alignment pattern (3 modules in size) around where it - // should be - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - int allowance = (int)(allowanceFactor * overallEstModuleSize); - int alignmentAreaLeftX = Math.Max(0, estAlignmentX - allowance); - int alignmentAreaRightX = Math.Min(image.Width - 1, estAlignmentX + allowance); - if (alignmentAreaRightX - alignmentAreaLeftX < overallEstModuleSize * 3) - { - return null; - } - - int alignmentAreaTopY = Math.Max(0, estAlignmentY - allowance); - int alignmentAreaBottomY = Math.Min(image.Height - 1, estAlignmentY + allowance); - - var alignmentFinder = new AlignmentPatternFinder( - image, - alignmentAreaLeftX, - alignmentAreaTopY, - alignmentAreaRightX - alignmentAreaLeftX, - alignmentAreaBottomY - alignmentAreaTopY, - overallEstModuleSize, - resultPointCallback); - - return alignmentFinder.find(); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPattern.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPattern.cs deleted file mode 100755 index 80469bf7f..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPattern.cs +++ /dev/null @@ -1,107 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - /// - ///

Encapsulates a finder pattern, which are the three square patterns found in - /// the corners of QR Codes. It also encapsulates a count of similar finder patterns, - /// as a convenience to the finder's bookkeeping.

- ///
- /// Sean Owen - public sealed class FinderPattern : ResultPoint - { - private readonly float estimatedModuleSize; - private int count; - - internal FinderPattern(float posX, float posY, float estimatedModuleSize) - : this(posX, posY, estimatedModuleSize, 1) - { - this.estimatedModuleSize = estimatedModuleSize; - this.count = 1; - } - - internal FinderPattern(float posX, float posY, float estimatedModuleSize, int count) - : base(posX, posY) - { - this.estimatedModuleSize = estimatedModuleSize; - this.count = count; - } - - /// - /// Gets the size of the estimated module. - /// - /// - /// The size of the estimated module. - /// - public float EstimatedModuleSize - { - get - { - return estimatedModuleSize; - } - } - - internal int Count - { - get - { - return count; - } - } - - /* - internal void incrementCount() - { - this.count++; - } - */ - - ///

Determines if this finder pattern "about equals" a finder pattern at the stated - /// position and size -- meaning, it is at nearly the same center with nearly the same size.

- ///
- internal bool aboutEquals(float moduleSize, float i, float j) - { - if (Math.Abs(i - Y) <= moduleSize && Math.Abs(j - X) <= moduleSize) - { - float moduleSizeDiff = Math.Abs(moduleSize - estimatedModuleSize); - return moduleSizeDiff <= 1.0f || moduleSizeDiff <= estimatedModuleSize; - - } - return false; - } - - /// - /// Combines this object's current estimate of a finder pattern position and module size - /// with a new estimate. It returns a new {@code FinderPattern} containing a weighted average - /// based on count. - /// - /// The i. - /// The j. - /// New size of the module. - /// - internal FinderPattern combineEstimate(float i, float j, float newModuleSize) - { - int combinedCount = count + 1; - float combinedX = (count * X + j) / combinedCount; - float combinedY = (count * Y + i) / combinedCount; - float combinedModuleSize = (count * estimatedModuleSize + newModuleSize) / combinedCount; - return new FinderPattern(combinedX, combinedY, combinedModuleSize, combinedCount); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternFinder.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternFinder.cs deleted file mode 100755 index 7b4c5113f..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternFinder.cs +++ /dev/null @@ -1,808 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -using System; -using System.Collections.Generic; - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - /// - ///

This class attempts to find finder patterns in a QR Code. Finder patterns are the square - /// markers at three corners of a QR Code.

- /// - ///

This class is thread-safe but not reentrant. Each thread must allocate its own object. - ///

- /// Sean Owen - public class FinderPatternFinder - { - private const int CENTER_QUORUM = 2; - /// - /// 1 pixel/module times 3 modules/center - /// - protected internal const int MIN_SKIP = 3; - /// - /// support up to version 10 for mobile clients - /// - protected internal const int MAX_MODULES = 57; - private const int INTEGER_MATH_SHIFT = 8; - - private readonly BitMatrix image; - private List possibleCenters; - private bool hasSkipped; - private readonly int[] crossCheckStateCount; - private readonly ResultPointCallback resultPointCallback; - - /// - ///

Creates a finder that will search the image for three finder patterns.

- ///
- /// image to search - public FinderPatternFinder(BitMatrix image) - : this(image, null) - { - } - - /// - /// Initializes a new instance of the class. - /// - /// The image. - /// The result point callback. - public FinderPatternFinder(BitMatrix image, ResultPointCallback resultPointCallback) - { - this.image = image; - this.possibleCenters = new List(); - this.crossCheckStateCount = new int[5]; - this.resultPointCallback = resultPointCallback; - } - - /// - /// Gets the image. - /// - virtual protected internal BitMatrix Image - { - get - { - return image; - } - } - - /// - /// Gets the possible centers. - /// - virtual protected internal List PossibleCenters - { - get - { - return possibleCenters; - } - } - - internal virtual FinderPatternInfo find(IDictionary hints) - { - bool tryHarder = hints != null && hints.ContainsKey(DecodeHintType.TRY_HARDER); - bool pureBarcode = hints != null && hints.ContainsKey(DecodeHintType.PURE_BARCODE); - int maxI = image.Height; - int maxJ = image.Width; - // We are looking for black/white/black/white/black modules in - // 1:1:3:1:1 ratio; this tracks the number of such modules seen so far - - // Let's assume that the maximum version QR Code we support takes up 1/4 the height of the - // image, and then account for the center being 3 modules in size. This gives the smallest - // number of pixels the center could be, so skip this often. When trying harder, look for all - // QR versions regardless of how dense they are. - int iSkip = (3 * maxI) / (4 * MAX_MODULES); - if (iSkip < MIN_SKIP || tryHarder) - { - iSkip = MIN_SKIP; - } - - bool done = false; - int[] stateCount = new int[5]; - for (int i = iSkip - 1; i < maxI && !done; i += iSkip) - { - // Get a row of black/white values - stateCount[0] = 0; - stateCount[1] = 0; - stateCount[2] = 0; - stateCount[3] = 0; - stateCount[4] = 0; - int currentState = 0; - for (int j = 0; j < maxJ; j++) - { - if (image[j, i]) - { - // Black pixel - if ((currentState & 1) == 1) - { - // Counting white pixels - currentState++; - } - stateCount[currentState]++; - } - else - { - // White pixel - if ((currentState & 1) == 0) - { - // Counting black pixels - if (currentState == 4) - { - // A winner? - if (foundPatternCross(stateCount)) - { - // Yes - bool confirmed = handlePossibleCenter(stateCount, i, j, pureBarcode); - if (confirmed) - { - // Start examining every other line. Checking each line turned out to be too - // expensive and didn't improve performance. - iSkip = 2; - if (hasSkipped) - { - done = haveMultiplyConfirmedCenters(); - } - else - { - int rowSkip = findRowSkip(); - if (rowSkip > stateCount[2]) - { - // Skip rows between row of lower confirmed center - // and top of presumed third confirmed center - // but back up a bit to get a full chance of detecting - // it, entire width of center of finder pattern - - // Skip by rowSkip, but back off by stateCount[2] (size of last center - // of pattern we saw) to be conservative, and also back off by iSkip which - // is about to be re-added - i += rowSkip - stateCount[2] - iSkip; - j = maxJ - 1; - } - } - } - else - { - stateCount[0] = stateCount[2]; - stateCount[1] = stateCount[3]; - stateCount[2] = stateCount[4]; - stateCount[3] = 1; - stateCount[4] = 0; - currentState = 3; - continue; - } - // Clear state to start looking again - currentState = 0; - stateCount[0] = 0; - stateCount[1] = 0; - stateCount[2] = 0; - stateCount[3] = 0; - stateCount[4] = 0; - } - else - { - // No, shift counts back by two - stateCount[0] = stateCount[2]; - stateCount[1] = stateCount[3]; - stateCount[2] = stateCount[4]; - stateCount[3] = 1; - stateCount[4] = 0; - currentState = 3; - } - } - else - { - stateCount[++currentState]++; - } - } - else - { - // Counting white pixels - stateCount[currentState]++; - } - } - } - if (foundPatternCross(stateCount)) - { - bool confirmed = handlePossibleCenter(stateCount, i, maxJ, pureBarcode); - if (confirmed) - { - iSkip = stateCount[0]; - if (hasSkipped) - { - // Found a third one - done = haveMultiplyConfirmedCenters(); - } - } - } - } - - FinderPattern[] patternInfo = selectBestPatterns(); - if (patternInfo == null) - return null; - - ResultPoint.orderBestPatterns(patternInfo); - - return new FinderPatternInfo(patternInfo); - } - - /// Given a count of black/white/black/white/black pixels just seen and an end position, - /// figures the location of the center of this run. - /// - private static float? centerFromEnd(int[] stateCount, int end) - { - var result = (end - stateCount[4] - stateCount[3]) - stateCount[2] / 2.0f; - if (Single.IsNaN(result)) - return null; - return result; - } - - /// count of black/white/black/white/black pixels just read - /// - /// true iff the proportions of the counts is close enough to the 1/1/3/1/1 ratios - /// used by finder patterns to be considered a match - /// - protected internal static bool foundPatternCross(int[] stateCount) - { - int totalModuleSize = 0; - for (int i = 0; i < 5; i++) - { - int count = stateCount[i]; - if (count == 0) - { - return false; - } - totalModuleSize += count; - } - if (totalModuleSize < 7) - { - return false; - } - int moduleSize = (totalModuleSize << INTEGER_MATH_SHIFT) / 7; - int maxVariance = moduleSize / 2; - // Allow less than 50% variance from 1-1-3-1-1 proportions - return Math.Abs(moduleSize - (stateCount[0] << INTEGER_MATH_SHIFT)) < maxVariance && - Math.Abs(moduleSize - (stateCount[1] << INTEGER_MATH_SHIFT)) < maxVariance && - Math.Abs(3 * moduleSize - (stateCount[2] << INTEGER_MATH_SHIFT)) < 3 * maxVariance && - Math.Abs(moduleSize - (stateCount[3] << INTEGER_MATH_SHIFT)) < maxVariance && - Math.Abs(moduleSize - (stateCount[4] << INTEGER_MATH_SHIFT)) < maxVariance; - } - - private int[] CrossCheckStateCount - { - get - { - crossCheckStateCount[0] = 0; - crossCheckStateCount[1] = 0; - crossCheckStateCount[2] = 0; - crossCheckStateCount[3] = 0; - crossCheckStateCount[4] = 0; - return crossCheckStateCount; - } - } - - /// - /// After a vertical and horizontal scan finds a potential finder pattern, this method - /// "cross-cross-cross-checks" by scanning down diagonally through the center of the possible - /// finder pattern to see if the same proportion is detected. - /// - /// row where a finder pattern was detected - /// center of the section that appears to cross a finder pattern - /// maximum reasonable number of modules that should be observed in any reading state, based on the results of the horizontal scan - /// The original state count total. - /// true if proportions are withing expected limits - private bool crossCheckDiagonal(int startI, int centerJ, int maxCount, int originalStateCountTotal) - { - int maxI = image.Height; - int maxJ = image.Width; - int[] stateCount = CrossCheckStateCount; - - // Start counting up, left from center finding black center mass - int i = 0; - while (startI - i >= 0 && image[centerJ - i, startI - i]) - { - stateCount[2]++; - i++; - } - - if ((startI - i < 0) || (centerJ - i < 0)) - { - return false; - } - - // Continue up, left finding white space - while ((startI - i >= 0) && (centerJ - i >= 0) && !image[centerJ - i, startI - i] && stateCount[1] <= maxCount) - { - stateCount[1]++; - i++; - } - - // If already too many modules in this state or ran off the edge: - if ((startI - i < 0) || (centerJ - i < 0) || stateCount[1] > maxCount) - { - return false; - } - - // Continue up, left finding black border - while ((startI - i >= 0) && (centerJ - i >= 0) && image[centerJ - i, startI - i] && stateCount[0] <= maxCount) - { - stateCount[0]++; - i++; - } - if (stateCount[0] > maxCount) - { - return false; - } - - // Now also count down, right from center - i = 1; - while ((startI + i < maxI) && (centerJ + i < maxJ) && image[centerJ + i, startI + i]) - { - stateCount[2]++; - i++; - } - - // Ran off the edge? - if ((startI + i >= maxI) || (centerJ + i >= maxJ)) - { - return false; - } - - while ((startI + i < maxI) && (centerJ + i < maxJ) && !image[centerJ + i, startI + i] && stateCount[3] < maxCount) - { - stateCount[3]++; - i++; - } - - if ((startI + i >= maxI) || (centerJ + i >= maxJ) || stateCount[3] >= maxCount) - { - return false; - } - - while ((startI + i < maxI) && (centerJ + i < maxJ) && image[centerJ + i, startI + i] && stateCount[4] < maxCount) - { - stateCount[4]++; - i++; - } - - if (stateCount[4] >= maxCount) - { - return false; - } - - // If we found a finder-pattern-like section, but its size is more than 100% different than - // the original, assume it's a false positive - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] + stateCount[4]; - return Math.Abs(stateCountTotal - originalStateCountTotal) < 2*originalStateCountTotal && - foundPatternCross(stateCount); - } - - /// - ///

After a horizontal scan finds a potential finder pattern, this method - /// "cross-checks" by scanning down vertically through the center of the possible - /// finder pattern to see if the same proportion is detected.

- ///
- /// row where a finder pattern was detected - /// center of the section that appears to cross a finder pattern - /// maximum reasonable number of modules that should be - /// observed in any reading state, based on the results of the horizontal scan - /// The original state count total. - /// - /// vertical center of finder pattern, or null if not found - /// - private float? crossCheckVertical(int startI, int centerJ, int maxCount, int originalStateCountTotal) - { - int maxI = image.Height; - int[] stateCount = CrossCheckStateCount; - - // Start counting up from center - int i = startI; - while (i >= 0 && image[centerJ, i]) - { - stateCount[2]++; - i--; - } - if (i < 0) - { - return null; - } - while (i >= 0 && !image[centerJ, i] && stateCount[1] <= maxCount) - { - stateCount[1]++; - i--; - } - // If already too many modules in this state or ran off the edge: - if (i < 0 || stateCount[1] > maxCount) - { - return null; - } - while (i >= 0 && image[centerJ, i] && stateCount[0] <= maxCount) - { - stateCount[0]++; - i--; - } - if (stateCount[0] > maxCount) - { - return null; - } - - // Now also count down from center - i = startI + 1; - while (i < maxI && image[centerJ, i]) - { - stateCount[2]++; - i++; - } - if (i == maxI) - { - return null; - } - while (i < maxI && !image[centerJ, i] && stateCount[3] < maxCount) - { - stateCount[3]++; - i++; - } - if (i == maxI || stateCount[3] >= maxCount) - { - return null; - } - while (i < maxI && image[centerJ, i] && stateCount[4] < maxCount) - { - stateCount[4]++; - i++; - } - if (stateCount[4] >= maxCount) - { - return null; - } - - // If we found a finder-pattern-like section, but its size is more than 40% different than - // the original, assume it's a false positive - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] + stateCount[4]; - if (5 * Math.Abs(stateCountTotal - originalStateCountTotal) >= 2 * originalStateCountTotal) - { - return null; - } - - return foundPatternCross(stateCount) ? centerFromEnd(stateCount, i) : null; - } - - ///

Like {@link #crossCheckVertical(int, int, int, int)}, and in fact is basically identical, - /// except it reads horizontally instead of vertically. This is used to cross-cross - /// check a vertical cross check and locate the real center of the alignment pattern.

- ///
- private float? crossCheckHorizontal(int startJ, int centerI, int maxCount, int originalStateCountTotal) - { - int maxJ = image.Width; - int[] stateCount = CrossCheckStateCount; - - int j = startJ; - while (j >= 0 && image[j, centerI]) - { - stateCount[2]++; - j--; - } - if (j < 0) - { - return null; - } - while (j >= 0 && !image[j, centerI] && stateCount[1] <= maxCount) - { - stateCount[1]++; - j--; - } - if (j < 0 || stateCount[1] > maxCount) - { - return null; - } - while (j >= 0 && image[j, centerI] && stateCount[0] <= maxCount) - { - stateCount[0]++; - j--; - } - if (stateCount[0] > maxCount) - { - return null; - } - - j = startJ + 1; - while (j < maxJ && image[j, centerI]) - { - stateCount[2]++; - j++; - } - if (j == maxJ) - { - return null; - } - while (j < maxJ && !image[j, centerI] && stateCount[3] < maxCount) - { - stateCount[3]++; - j++; - } - if (j == maxJ || stateCount[3] >= maxCount) - { - return null; - } - while (j < maxJ && image[j, centerI] && stateCount[4] < maxCount) - { - stateCount[4]++; - j++; - } - if (stateCount[4] >= maxCount) - { - return null; - } - - // If we found a finder-pattern-like section, but its size is significantly different than - // the original, assume it's a false positive - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] + stateCount[4]; - if (5 * Math.Abs(stateCountTotal - originalStateCountTotal) >= originalStateCountTotal) - { - return null; - } - - return foundPatternCross(stateCount) ? centerFromEnd(stateCount, j) : null; - } - - /// - ///

This is called when a horizontal scan finds a possible alignment pattern. It will - /// cross check with a vertical scan, and if successful, will, ah, cross-cross-check - /// with another horizontal scan. This is needed primarily to locate the real horizontal - /// center of the pattern in cases of extreme skew. - /// And then we cross-cross-cross check with another diagonal scan.

- /// If that succeeds the finder pattern location is added to a list that tracks - /// the number of times each location has been nearly-matched as a finder pattern. - /// Each additional find is more evidence that the location is in fact a finder - /// pattern center - ///
- /// reading state module counts from horizontal scan - /// row where finder pattern may be found - /// end of possible finder pattern in row - /// if set to true [pure barcode]. - /// - /// true if a finder pattern candidate was found this time - /// - protected bool handlePossibleCenter(int[] stateCount, int i, int j, bool pureBarcode) - { - int stateCountTotal = stateCount[0] + stateCount[1] + stateCount[2] + stateCount[3] + - stateCount[4]; - float? centerJ = centerFromEnd(stateCount, j); - if (centerJ == null) - return false; - float? centerI = crossCheckVertical(i, (int)centerJ.Value, stateCount[2], stateCountTotal); - if (centerI != null) - { - // Re-cross check - centerJ = crossCheckHorizontal((int)centerJ.Value, (int)centerI.Value, stateCount[2], stateCountTotal); - if (centerJ != null && - (!pureBarcode || crossCheckDiagonal((int) centerI, (int) centerJ, stateCount[2], stateCountTotal))) - { - float estimatedModuleSize = stateCountTotal / 7.0f; - bool found = false; - for (int index = 0; index < possibleCenters.Count; index++) - { - var center = possibleCenters[index]; - // Look for about the same center and module size: - if (center.aboutEquals(estimatedModuleSize, centerI.Value, centerJ.Value)) - { - possibleCenters.RemoveAt(index); - possibleCenters.Insert(index, center.combineEstimate(centerI.Value, centerJ.Value, estimatedModuleSize)); - - found = true; - break; - } - } - if (!found) - { - var point = new FinderPattern(centerJ.Value, centerI.Value, estimatedModuleSize); - - possibleCenters.Add(point); - if (resultPointCallback != null) - { - - resultPointCallback(point); - } - } - return true; - } - } - return false; - } - - /// number of rows we could safely skip during scanning, based on the first - /// two finder patterns that have been located. In some cases their position will - /// allow us to infer that the third pattern must lie below a certain point farther - /// down in the image. - /// - private int findRowSkip() - { - int max = possibleCenters.Count; - if (max <= 1) - { - return 0; - } - ResultPoint firstConfirmedCenter = null; - foreach (var center in possibleCenters) - { - if (center.Count >= CENTER_QUORUM) - { - if (firstConfirmedCenter == null) - { - firstConfirmedCenter = center; - } - else - { - // We have two confirmed centers - // How far down can we skip before resuming looking for the next - // pattern? In the worst case, only the difference between the - // difference in the x / y coordinates of the two centers. - // This is the case where you find top left last. - hasSkipped = true; - //UPGRADE_WARNING: Data types in Visual C# might be different. Verify the accuracy of narrowing conversions. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1042'" - return (int)(Math.Abs(firstConfirmedCenter.X - center.X) - Math.Abs(firstConfirmedCenter.Y - center.Y)) / 2; - } - } - } - return 0; - } - - /// true iff we have found at least 3 finder patterns that have been detected - /// at least {@link #CENTER_QUORUM} times each, and, the estimated module size of the - /// candidates is "pretty similar" - /// - private bool haveMultiplyConfirmedCenters() - { - int confirmedCount = 0; - float totalModuleSize = 0.0f; - int max = possibleCenters.Count; - foreach (var pattern in possibleCenters) - { - if (pattern.Count >= CENTER_QUORUM) - { - confirmedCount++; - totalModuleSize += pattern.EstimatedModuleSize; - } - } - if (confirmedCount < 3) - { - return false; - } - // OK, we have at least 3 confirmed centers, but, it's possible that one is a "false positive" - // and that we need to keep looking. We detect this by asking if the estimated module sizes - // vary too much. We arbitrarily say that when the total deviation from average exceeds - // 5% of the total module size estimates, it's too much. - float average = totalModuleSize / max; - float totalDeviation = 0.0f; - for (int i = 0; i < max; i++) - { - var pattern = possibleCenters[i]; - totalDeviation += Math.Abs(pattern.EstimatedModuleSize - average); - } - return totalDeviation <= 0.05f * totalModuleSize; - } - - /// the 3 best {@link FinderPattern}s from our list of candidates. The "best" are - /// those that have been detected at least {@link #CENTER_QUORUM} times, and whose module - /// size differs from the average among those patterns the least - /// - private FinderPattern[] selectBestPatterns() - { - int startSize = possibleCenters.Count; - if (startSize < 3) - { - // Couldn't find enough finder patterns - return null; - } - - // Filter outlier possibilities whose module size is too different - if (startSize > 3) - { - // But we can only afford to do so if we have at least 4 possibilities to choose from - float totalModuleSize = 0.0f; - float square = 0.0f; - foreach (var center in possibleCenters) - { - float size = center.EstimatedModuleSize; - totalModuleSize += size; - square += size * size; - } - float average = totalModuleSize / startSize; - float stdDev = (float)Math.Sqrt(square / startSize - average * average); - - possibleCenters.Sort(new FurthestFromAverageComparator(average)); - - float limit = Math.Max(0.2f * average, stdDev); - - for (int i = 0; i < possibleCenters.Count && possibleCenters.Count > 3; i++) - { - FinderPattern pattern = possibleCenters[i]; - if (Math.Abs(pattern.EstimatedModuleSize - average) > limit) - { - possibleCenters.RemoveAt(i); - i--; - } - } - } - - if (possibleCenters.Count > 3) - { - // Throw away all but those first size candidate points we found. - - float totalModuleSize = 0.0f; - foreach (var possibleCenter in possibleCenters) - { - totalModuleSize += possibleCenter.EstimatedModuleSize; - } - - float average = totalModuleSize / possibleCenters.Count; - - possibleCenters.Sort(new CenterComparator(average)); - - //possibleCenters.subList(3, possibleCenters.Count).clear(); - possibleCenters = possibleCenters.GetRange(0, 3); - } - - return new[] - { - possibleCenters[0], - possibleCenters[1], - possibleCenters[2] - }; - } - - /// - /// Orders by furthest from average - /// - private sealed class FurthestFromAverageComparator : IComparer - { - private readonly float average; - - public FurthestFromAverageComparator(float f) - { - average = f; - } - - public int Compare(FinderPattern x, FinderPattern y) - { - float dA = Math.Abs(y.EstimatedModuleSize - average); - float dB = Math.Abs(x.EstimatedModuleSize - average); - return dA < dB ? -1 : dA == dB ? 0 : 1; - } - } - - ///

Orders by {@link FinderPattern#getCount()}, descending.

- private sealed class CenterComparator : IComparer - { - private readonly float average; - - public CenterComparator(float f) - { - average = f; - } - - public int Compare(FinderPattern x, FinderPattern y) - { - if (y.Count == x.Count) - { - float dA = Math.Abs(y.EstimatedModuleSize - average); - float dB = Math.Abs(x.EstimatedModuleSize - average); - return dA < dB ? 1 : dA == dB ? 0 : -1; - } - return y.Count - x.Count; - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternInfo.cs b/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternInfo.cs deleted file mode 100755 index 982b755a0..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/detector/FinderPatternInfo.cs +++ /dev/null @@ -1,74 +0,0 @@ -/* -* Copyright 2007 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. -*/ - -namespace ZXing.QrCode.Internal -{ - /// - ///

Encapsulates information about finder patterns in an image, including the location of - /// the three finder patterns, and their estimated module size.

- ///
- /// Sean Owen - public sealed class FinderPatternInfo - { - private readonly FinderPattern bottomLeft; - private readonly FinderPattern topLeft; - private readonly FinderPattern topRight; - - /// - /// Initializes a new instance of the class. - /// - /// The pattern centers. - public FinderPatternInfo(FinderPattern[] patternCenters) - { - this.bottomLeft = patternCenters[0]; - this.topLeft = patternCenters[1]; - this.topRight = patternCenters[2]; - } - - /// - /// Gets the bottom left. - /// - public FinderPattern BottomLeft - { - get - { - return bottomLeft; - } - } - - /// - /// Gets the top left. - /// - public FinderPattern TopLeft - { - get - { - return topLeft; - } - } - - /// - /// Gets the top right. - /// - public FinderPattern TopRight - { - get - { - return topRight; - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/BlockPair.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/BlockPair.cs deleted file mode 100755 index b1afff46b..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/BlockPair.cs +++ /dev/null @@ -1,40 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -namespace ZXing.QrCode.Internal -{ - internal sealed class BlockPair - { - private readonly byte[] dataBytes; - private readonly byte[] errorCorrectionBytes; - - public BlockPair(byte[] data, byte[] errorCorrection) - { - dataBytes = data; - errorCorrectionBytes = errorCorrection; - } - - public byte[] DataBytes - { - get { return dataBytes; } - } - - public byte[] ErrorCorrectionBytes - { - get { return errorCorrectionBytes; } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/ByteMatrix.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/ByteMatrix.cs deleted file mode 100755 index e3d372fdb..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/ByteMatrix.cs +++ /dev/null @@ -1,148 +0,0 @@ -/* - * Copyright 2008 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. - */ - -using System; -using System.Text; - -namespace ZXing.QrCode.Internal -{ - /// - /// JAVAPORT: The original code was a 2D array of ints, but since it only ever gets assigned - /// 0, 1 and 2 I'm going to use less memory and go with bytes. - /// - /// dswitkin@google.com (Daniel Switkin) - public sealed class ByteMatrix - { - private readonly byte[][] bytes; - private readonly int width; - private readonly int height; - - /// - /// Initializes a new instance of the class. - /// - /// The width. - /// The height. - public ByteMatrix(int width, int height) - { - bytes = new byte[height][]; - for (var i = 0; i < height; i++) - bytes[i] = new byte[width]; - this.width = width; - this.height = height; - } - - /// - /// Gets the height. - /// - public int Height - { - get { return height; } - } - - /// - /// Gets the width. - /// - public int Width - { - get { return width; } - } - - /// - /// Gets or sets the with the specified x. - /// - public int this[int x, int y] - { - get { return bytes[y][x]; } - set { bytes[y][x] = (byte)value; } - } - - /// - /// an internal representation as bytes, in row-major order. array[y][x] represents point (x,y) - /// - public byte[][] Array - { - get { return bytes; } - } - - /// - /// Sets the specified x. - /// - /// The x. - /// The y. - /// The value. - public void set(int x, int y, byte value) - { - bytes[y][x] = value; - } - - /// - /// Sets the specified x. - /// - /// The x. - /// The y. - /// if set to true [value]. - public void set(int x, int y, bool value) - { - bytes[y][x] = (byte)(value ? 1 : 0); - } - - /// - /// Clears the specified value. - /// - /// The value. - public void clear(byte value) - { - for (int y = 0; y < height; ++y) - { - for (int x = 0; x < width; ++x) - { - bytes[y][x] = value; - } - } - } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - override public String ToString() - { - var result = new StringBuilder(2 * width * height + 2); - for (int y = 0; y < height; ++y) - { - for (int x = 0; x < width; ++x) - { - switch (bytes[y][x]) - { - case 0: - result.Append(" 0"); - break; - case 1: - result.Append(" 1"); - break; - default: - result.Append(" "); - break; - } - } - result.Append('\n'); - } - return result.ToString(); - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/Encoder.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/Encoder.cs deleted file mode 100755 index dbae7bf3a..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/Encoder.cs +++ /dev/null @@ -1,597 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using System; -using System.Collections.Generic; -using System.Text; - -using ZXing.Common; -using ZXing.Common.ReedSolomon; - -namespace ZXing.QrCode.Internal -{ - /// - /// - /// satorux@google.com (Satoru Takabayashi) - creator - /// dswitkin@google.com (Daniel Switkin) - ported from C++ - public static class Encoder - { - - // The original table is defined in the table 5 of JISX0510:2004 (p.19). - private static readonly int[] ALPHANUMERIC_TABLE = { - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 0x00-0x0f - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // 0x10-0x1f - 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, // 0x20-0x2f - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, // 0x30-0x3f - -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, // 0x40-0x4f - 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, // 0x50-0x5f - }; - - internal static String DEFAULT_BYTE_MODE_ENCODING = "ISO-8859-1"; - - // The mask penalty calculation is complicated. See Table 21 of JISX0510:2004 (p.45) for details. - // Basically it applies four rules and summate all penalties. - private static int calculateMaskPenalty(ByteMatrix matrix) - { - return MaskUtil.applyMaskPenaltyRule1(matrix) - + MaskUtil.applyMaskPenaltyRule2(matrix) - + MaskUtil.applyMaskPenaltyRule3(matrix) - + MaskUtil.applyMaskPenaltyRule4(matrix); - } - - /// - /// Encode "bytes" with the error correction level "ecLevel". The encoding mode will be chosen - /// internally by chooseMode(). On success, store the result in "qrCode". - /// We recommend you to use QRCode.EC_LEVEL_L (the lowest level) for - /// "getECLevel" since our primary use is to show QR code on desktop screens. We don't need very - /// strong error correction for this purpose. - /// Note that there is no way to encode bytes in MODE_KANJI. We might want to add EncodeWithMode() - /// with which clients can specify the encoding mode. For now, we don't need the functionality. - /// - /// The content. - /// The ec level. - public static QRCode encode(String content, ErrorCorrectionLevel ecLevel) - { - return encode(content, ecLevel, null); - } - - /// - /// Encodes the specified content. - /// - /// The content. - /// The ec level. - /// The hints. - /// - public static QRCode encode(String content, - ErrorCorrectionLevel ecLevel, - IDictionary hints) - { - // Determine what character encoding has been specified by the caller, if any -#if !SILVERLIGHT || WINDOWS_PHONE - String encoding = hints == null || !hints.ContainsKey(EncodeHintType.CHARACTER_SET) ? null : (String)hints[EncodeHintType.CHARACTER_SET]; - if (encoding == null) - { - encoding = DEFAULT_BYTE_MODE_ENCODING; - } - bool generateECI = !DEFAULT_BYTE_MODE_ENCODING.Equals(encoding, StringComparison.OrdinalIgnoreCase); -#else - // Silverlight supports only UTF-8 and UTF-16 out-of-the-box - const string encoding = "UTF-8"; - // caller of the method can only control if the ECI segment should be written - // character set is fixed to UTF-8; but some scanners doesn't like the ECI segment - bool generateECI = (hints != null && hints.ContainsKey(EncodeHintType.CHARACTER_SET)); -#endif - - // Pick an encoding mode appropriate for the content. Note that this will not attempt to use - // multiple modes / segments even if that were more efficient. Twould be nice. - Mode mode = chooseMode(content, encoding); - - // This will store the header information, like mode and - // length, as well as "header" segments like an ECI segment. - BitArray headerBits = new BitArray(); - - - // (With ECI in place,) Write the mode marker - appendModeInfo(mode, headerBits); - - // Collect data within the main segment, separately, to count its size if needed. Don't add it to - // main payload yet. - BitArray dataBits = new BitArray(); - appendBytes(content, mode, dataBits, encoding); - - // Hard part: need to know version to know how many bits length takes. But need to know how many - // bits it takes to know version. First we take a guess at version by assuming version will be - // the minimum, 1: - - int provisionalBitsNeeded = headerBits.Size - + mode.getCharacterCountBits(Version.getVersionForNumber(1)) - + dataBits.Size; - Version provisionalVersion = chooseVersion(provisionalBitsNeeded, ecLevel); - - // Use that guess to calculate the right version. I am still not sure this works in 100% of cases. - int bitsNeeded = headerBits.Size - + mode.getCharacterCountBits(provisionalVersion) - + dataBits.Size; - Version version = chooseVersion(bitsNeeded, ecLevel); - - BitArray headerAndDataBits = new BitArray(); - headerAndDataBits.appendBitArray(headerBits); - // Find "length" of main segment and write it - int numLetters = mode == Mode.BYTE ? dataBits.SizeInBytes : content.Length; - appendLengthInfo(numLetters, version, mode, headerAndDataBits); - // Put data together into the overall payload - headerAndDataBits.appendBitArray(dataBits); - - Version.ECBlocks ecBlocks = version.getECBlocksForLevel(ecLevel); - int numDataBytes = version.TotalCodewords - ecBlocks.TotalECCodewords; - - // Terminate the bits properly. - terminateBits(numDataBytes, headerAndDataBits); - - // Interleave data bits with error correction code. - BitArray finalBits = interleaveWithECBytes(headerAndDataBits, - version.TotalCodewords, - numDataBytes, - ecBlocks.NumBlocks); - - QRCode qrCode = new QRCode - { - ECLevel = ecLevel, - Mode = mode, - Version = version - }; - - // Choose the mask pattern and set to "qrCode". - int dimension = version.DimensionForVersion; - ByteMatrix matrix = new ByteMatrix(dimension, dimension); - int maskPattern = chooseMaskPattern(finalBits, ecLevel, version, matrix); - qrCode.MaskPattern = maskPattern; - - // Build the matrix and set it to "qrCode". - MatrixUtil.buildMatrix(finalBits, ecLevel, version, maskPattern, matrix); - qrCode.Matrix = matrix; - - return qrCode; - } - - /// - /// Gets the alphanumeric code. - /// - /// The code. - /// the code point of the table used in alphanumeric mode or - /// -1 if there is no corresponding code in the table. - internal static int getAlphanumericCode(int code) - { - if (code < ALPHANUMERIC_TABLE.Length) - { - return ALPHANUMERIC_TABLE[code]; - } - return -1; - } - - /// - /// Chooses the mode. - /// - /// The content. - /// - public static Mode chooseMode(String content) - { - return chooseMode(content, null); - } - - /// - /// Choose the best mode by examining the content. Note that 'encoding' is used as a hint; - /// if it is Shift_JIS, and the input is only double-byte Kanji, then we return {@link Mode#KANJI}. - /// - /// The content. - /// The encoding. - /// - private static Mode chooseMode(String content, String encoding) - { - return Mode.BYTE; - } - - private static int chooseMaskPattern(BitArray bits, - ErrorCorrectionLevel ecLevel, - Version version, - ByteMatrix matrix) - { - int minPenalty = Int32.MaxValue; // Lower penalty is better. - int bestMaskPattern = -1; - // We try all mask patterns to choose the best one. - for (int maskPattern = 0; maskPattern < QRCode.NUM_MASK_PATTERNS; maskPattern++) - { - - MatrixUtil.buildMatrix(bits, ecLevel, version, maskPattern, matrix); - int penalty = calculateMaskPenalty(matrix); - if (penalty < minPenalty) - { - - minPenalty = penalty; - bestMaskPattern = maskPattern; - } - } - return bestMaskPattern; - } - - private static Version chooseVersion(int numInputBits, ErrorCorrectionLevel ecLevel) - { - // In the following comments, we use numbers of Version 7-H. - for (int versionNum = 1; versionNum <= 40; versionNum++) - { - Version version = Version.getVersionForNumber(versionNum); - // numBytes = 196 - int numBytes = version.TotalCodewords; - // getNumECBytes = 130 - Version.ECBlocks ecBlocks = version.getECBlocksForLevel(ecLevel); - int numEcBytes = ecBlocks.TotalECCodewords; - // getNumDataBytes = 196 - 130 = 66 - int numDataBytes = numBytes - numEcBytes; - int totalInputBytes = (numInputBits + 7) / 8; - if (numDataBytes >= totalInputBytes) - { - return version; - } - } - throw new WriterException("Data too big"); - } - - /// - /// Terminate bits as described in 8.4.8 and 8.4.9 of JISX0510:2004 (p.24). - /// - /// The num data bytes. - /// The bits. - internal static void terminateBits(int numDataBytes, BitArray bits) - { - int capacity = numDataBytes << 3; - if (bits.Size > capacity) - { - throw new WriterException("data bits cannot fit in the QR Code" + bits.Size + " > " + - capacity); - } - for (int i = 0; i < 4 && bits.Size < capacity; ++i) - { - bits.appendBit(false); - } - // Append termination bits. See 8.4.8 of JISX0510:2004 (p.24) for details. - // If the last byte isn't 8-bit aligned, we'll add padding bits. - int numBitsInLastByte = bits.Size & 0x07; - if (numBitsInLastByte > 0) - { - for (int i = numBitsInLastByte; i < 8; i++) - { - bits.appendBit(false); - } - } - // If we have more space, we'll fill the space with padding patterns defined in 8.4.9 (p.24). - int numPaddingBytes = numDataBytes - bits.SizeInBytes; - for (int i = 0; i < numPaddingBytes; ++i) - { - bits.appendBits((i & 0x01) == 0 ? 0xEC : 0x11, 8); - } - if (bits.Size != capacity) - { - throw new WriterException("Bits size does not equal capacity"); - } - } - - /// - /// Get number of data bytes and number of error correction bytes for block id "blockID". Store - /// the result in "numDataBytesInBlock", and "numECBytesInBlock". See table 12 in 8.5.1 of - /// JISX0510:2004 (p.30) - /// - /// The num total bytes. - /// The num data bytes. - /// The num RS blocks. - /// The block ID. - /// The num data bytes in block. - /// The num EC bytes in block. - internal static void getNumDataBytesAndNumECBytesForBlockID(int numTotalBytes, - int numDataBytes, - int numRSBlocks, - int blockID, - int[] numDataBytesInBlock, - int[] numECBytesInBlock) - { - if (blockID >= numRSBlocks) - { - throw new WriterException("Block ID too large"); - } - // numRsBlocksInGroup2 = 196 % 5 = 1 - int numRsBlocksInGroup2 = numTotalBytes % numRSBlocks; - // numRsBlocksInGroup1 = 5 - 1 = 4 - int numRsBlocksInGroup1 = numRSBlocks - numRsBlocksInGroup2; - // numTotalBytesInGroup1 = 196 / 5 = 39 - int numTotalBytesInGroup1 = numTotalBytes / numRSBlocks; - // numTotalBytesInGroup2 = 39 + 1 = 40 - int numTotalBytesInGroup2 = numTotalBytesInGroup1 + 1; - // numDataBytesInGroup1 = 66 / 5 = 13 - int numDataBytesInGroup1 = numDataBytes / numRSBlocks; - // numDataBytesInGroup2 = 13 + 1 = 14 - int numDataBytesInGroup2 = numDataBytesInGroup1 + 1; - // numEcBytesInGroup1 = 39 - 13 = 26 - int numEcBytesInGroup1 = numTotalBytesInGroup1 - numDataBytesInGroup1; - // numEcBytesInGroup2 = 40 - 14 = 26 - int numEcBytesInGroup2 = numTotalBytesInGroup2 - numDataBytesInGroup2; - // Sanity checks. - // 26 = 26 - if (numEcBytesInGroup1 != numEcBytesInGroup2) - { - - throw new WriterException("EC bytes mismatch"); - } - // 5 = 4 + 1. - if (numRSBlocks != numRsBlocksInGroup1 + numRsBlocksInGroup2) - { - - throw new WriterException("RS blocks mismatch"); - } - // 196 = (13 + 26) * 4 + (14 + 26) * 1 - if (numTotalBytes != - ((numDataBytesInGroup1 + numEcBytesInGroup1) * - numRsBlocksInGroup1) + - ((numDataBytesInGroup2 + numEcBytesInGroup2) * - numRsBlocksInGroup2)) - { - throw new WriterException("Total bytes mismatch"); - } - - if (blockID < numRsBlocksInGroup1) - { - - numDataBytesInBlock[0] = numDataBytesInGroup1; - numECBytesInBlock[0] = numEcBytesInGroup1; - } - else - { - - - numDataBytesInBlock[0] = numDataBytesInGroup2; - numECBytesInBlock[0] = numEcBytesInGroup2; - } - } - - /// - /// Interleave "bits" with corresponding error correction bytes. On success, store the result in - /// "result". The interleave rule is complicated. See 8.6 of JISX0510:2004 (p.37) for details. - /// - /// The bits. - /// The num total bytes. - /// The num data bytes. - /// The num RS blocks. - /// - internal static BitArray interleaveWithECBytes(BitArray bits, - int numTotalBytes, - int numDataBytes, - int numRSBlocks) - { - // "bits" must have "getNumDataBytes" bytes of data. - if (bits.SizeInBytes != numDataBytes) - { - - throw new WriterException("Number of bits and data bytes does not match"); - } - - // Step 1. Divide data bytes into blocks and generate error correction bytes for them. We'll - // store the divided data bytes blocks and error correction bytes blocks into "blocks". - int dataBytesOffset = 0; - int maxNumDataBytes = 0; - int maxNumEcBytes = 0; - - // Since, we know the number of reedsolmon blocks, we can initialize the vector with the number. - var blocks = new List(numRSBlocks); - - for (int i = 0; i < numRSBlocks; ++i) - { - - int[] numDataBytesInBlock = new int[1]; - int[] numEcBytesInBlock = new int[1]; - getNumDataBytesAndNumECBytesForBlockID( - numTotalBytes, numDataBytes, numRSBlocks, i, - numDataBytesInBlock, numEcBytesInBlock); - - int size = numDataBytesInBlock[0]; - byte[] dataBytes = new byte[size]; - bits.toBytes(8 * dataBytesOffset, dataBytes, 0, size); - byte[] ecBytes = generateECBytes(dataBytes, numEcBytesInBlock[0]); - blocks.Add(new BlockPair(dataBytes, ecBytes)); - - maxNumDataBytes = Math.Max(maxNumDataBytes, size); - maxNumEcBytes = Math.Max(maxNumEcBytes, ecBytes.Length); - dataBytesOffset += numDataBytesInBlock[0]; - } - if (numDataBytes != dataBytesOffset) - { - - throw new WriterException("Data bytes does not match offset"); - } - - BitArray result = new BitArray(); - - // First, place data blocks. - for (int i = 0; i < maxNumDataBytes; ++i) - { - foreach (BlockPair block in blocks) - { - byte[] dataBytes = block.DataBytes; - if (i < dataBytes.Length) - { - result.appendBits(dataBytes[i], 8); - } - } - } - // Then, place error correction blocks. - for (int i = 0; i < maxNumEcBytes; ++i) - { - foreach (BlockPair block in blocks) - { - byte[] ecBytes = block.ErrorCorrectionBytes; - if (i < ecBytes.Length) - { - result.appendBits(ecBytes[i], 8); - } - } - } - if (numTotalBytes != result.SizeInBytes) - { // Should be same. - throw new WriterException("Interleaving error: " + numTotalBytes + " and " + - result.SizeInBytes + " differ."); - } - - return result; - } - - internal static byte[] generateECBytes(byte[] dataBytes, int numEcBytesInBlock) - { - int numDataBytes = dataBytes.Length; - int[] toEncode = new int[numDataBytes + numEcBytesInBlock]; - for (int i = 0; i < numDataBytes; i++) - { - toEncode[i] = dataBytes[i] & 0xFF; - - } - new ReedSolomonEncoder(GenericGF.QR_CODE_FIELD_256).encode(toEncode, numEcBytesInBlock); - - byte[] ecBytes = new byte[numEcBytesInBlock]; - for (int i = 0; i < numEcBytesInBlock; i++) - { - ecBytes[i] = (byte)toEncode[numDataBytes + i]; - - } - return ecBytes; - } - - /// - /// Append mode info. On success, store the result in "bits". - /// - /// The mode. - /// The bits. - internal static void appendModeInfo(Mode mode, BitArray bits) - { - bits.appendBits(mode.Bits, 4); - } - - - /// - /// Append length info. On success, store the result in "bits". - /// - /// The num letters. - /// The version. - /// The mode. - /// The bits. - internal static void appendLengthInfo(int numLetters, Version version, Mode mode, BitArray bits) - { - int numBits = mode.getCharacterCountBits(version); - if (numLetters >= (1 << numBits)) - { - throw new WriterException(numLetters + " is bigger than " + ((1 << numBits) - 1)); - } - bits.appendBits(numLetters, numBits); - } - - /// - /// Append "bytes" in "mode" mode (encoding) into "bits". On success, store the result in "bits". - /// - /// The content. - /// The mode. - /// The bits. - /// The encoding. - internal static void appendBytes(String content, - Mode mode, - BitArray bits, - String encoding) - { - // TODO: check the purpose of this .Equals(obj) - if (mode == Mode.BYTE) - append8BitBytes(content, bits, encoding); - else - throw new WriterException("Invalid mode: " + mode); - } - - internal static void appendNumericBytes(String content, BitArray bits) - { - int length = content.Length; - - int i = 0; - while (i < length) - { - int num1 = content[i] - '0'; - if (i + 2 < length) - { - // Encode three numeric letters in ten bits. - int num2 = content[i + 1] - '0'; - int num3 = content[i + 2] - '0'; - bits.appendBits(num1 * 100 + num2 * 10 + num3, 10); - i += 3; - } - else if (i + 1 < length) - { - // Encode two numeric letters in seven bits. - int num2 = content[i + 1] - '0'; - bits.appendBits(num1 * 10 + num2, 7); - i += 2; - } - else - { - // Encode one numeric letter in four bits. - bits.appendBits(num1, 4); - i++; - } - } - } - - - internal static void append8BitBytes(String content, BitArray bits, String encoding) - { - byte[] bytes; - try - { - bytes = Encoding.GetEncoding(encoding).GetBytes(content); - } -#if WindowsCE - catch (PlatformNotSupportedException) - { - try - { - // WindowsCE doesn't support all encodings. But it is device depended. - // So we try here the some different ones - if (encoding == "ISO-8859-1") - { - bytes = Encoding.GetEncoding(1252).GetBytes(content); - } - else - { - bytes = Encoding.GetEncoding("UTF-8").GetBytes(content); - } - } - catch (Exception uee) - { - throw new WriterException(uee.Message, uee); - } - } -#endif - catch (Exception uee) - { - throw new WriterException(uee.Message, uee); - } - foreach (byte b in bytes) - { - bits.appendBits(b, 8); - } - } - - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MaskUtil.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MaskUtil.cs deleted file mode 100755 index 24e85cc17..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MaskUtil.cs +++ /dev/null @@ -1,271 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using System; - -namespace ZXing.QrCode.Internal -{ - /// - /// - /// - /// Satoru Takabayashi - /// Daniel Switkin - /// Sean Owen - public static class MaskUtil - { - // Penalty weights from section 6.8.2.1 - private const int N1 = 3; - private const int N2 = 3; - private const int N3 = 40; - private const int N4 = 10; - - /// - /// Apply mask penalty rule 1 and return the penalty. Find repetitive cells with the same color and - /// give penalty to them. Example: 00000 or 11111. - /// - /// The matrix. - /// - public static int applyMaskPenaltyRule1(ByteMatrix matrix) - { - return applyMaskPenaltyRule1Internal(matrix, true) + applyMaskPenaltyRule1Internal(matrix, false); - } - - /// - /// Apply mask penalty rule 2 and return the penalty. Find 2x2 blocks with the same color and give - /// penalty to them. This is actually equivalent to the spec's rule, which is to find MxN blocks and give a - /// penalty proportional to (M-1)x(N-1), because this is the number of 2x2 blocks inside such a block. - /// - /// The matrix. - /// - public static int applyMaskPenaltyRule2(ByteMatrix matrix) - { - int penalty = 0; - var array = matrix.Array; - int width = matrix.Width; - int height = matrix.Height; - for (int y = 0; y < height - 1; y++) - { - for (int x = 0; x < width - 1; x++) - { - int value = array[y][x]; - if (value == array[y][x + 1] && value == array[y + 1][x] && value == array[y + 1][x + 1]) - { - penalty++; - } - } - } - return N2 * penalty; - } - - /// - /// Apply mask penalty rule 3 and return the penalty. Find consecutive cells of 00001011101 or - /// 10111010000, and give penalty to them. If we find patterns like 000010111010000, we give - /// penalties twice (i.e. 40 * 2). - /// - /// The matrix. - /// - public static int applyMaskPenaltyRule3(ByteMatrix matrix) - { - int numPenalties = 0; - byte[][] array = matrix.Array; - int width = matrix.Width; - int height = matrix.Height; - for (int y = 0; y < height; y++) - { - for (int x = 0; x < width; x++) - { - byte[] arrayY = array[y]; // We can at least optimize this access - if (x + 6 < width && - arrayY[x] == 1 && - arrayY[x + 1] == 0 && - arrayY[x + 2] == 1 && - arrayY[x + 3] == 1 && - arrayY[x + 4] == 1 && - arrayY[x + 5] == 0 && - arrayY[x + 6] == 1 && - (isWhiteHorizontal(arrayY, x - 4, x) || isWhiteHorizontal(arrayY, x + 7, x + 11))) - { - numPenalties++; - } - if (y + 6 < height && - array[y][x] == 1 && - array[y + 1][x] == 0 && - array[y + 2][x] == 1 && - array[y + 3][x] == 1 && - array[y + 4][x] == 1 && - array[y + 5][x] == 0 && - array[y + 6][x] == 1 && - (isWhiteVertical(array, x, y - 4, y) || isWhiteVertical(array, x, y + 7, y + 11))) - { - numPenalties++; - } - } - } - return numPenalties * N3; - } - - private static bool isWhiteHorizontal(byte[] rowArray, int from, int to) - { - for (int i = from; i < to; i++) - { - if (i >= 0 && i < rowArray.Length && rowArray[i] == 1) - { - return false; - } - } - return true; - } - - private static bool isWhiteVertical(byte[][] array, int col, int from, int to) - { - for (int i = from; i < to; i++) - { - if (i >= 0 && i < array.Length && array[i][col] == 1) - { - return false; - } - } - return true; - } - - /// - /// Apply mask penalty rule 4 and return the penalty. Calculate the ratio of dark cells and give - /// penalty if the ratio is far from 50%. It gives 10 penalty for 5% distance. - /// - /// The matrix. - /// - public static int applyMaskPenaltyRule4(ByteMatrix matrix) - { - int numDarkCells = 0; - var array = matrix.Array; - int width = matrix.Width; - int height = matrix.Height; - for (int y = 0; y < height; y++) - { - var arrayY = array[y]; - for (int x = 0; x < width; x++) - { - if (arrayY[x] == 1) - { - numDarkCells++; - } - } - } - var numTotalCells = matrix.Height * matrix.Width; - var darkRatio = (double)numDarkCells / numTotalCells; - var fivePercentVariances = (int)(Math.Abs(darkRatio - 0.5) * 20.0); // * 100.0 / 5.0 - return fivePercentVariances * N4; - } - - /// - /// Return the mask bit for "getMaskPattern" at "x" and "y". See 8.8 of JISX0510:2004 for mask - /// pattern conditions. - /// - /// The mask pattern. - /// The x. - /// The y. - /// - public static bool getDataMaskBit(int maskPattern, int x, int y) - { - int intermediate, temp; - switch (maskPattern) - { - - case 0: - intermediate = (y + x) & 0x1; - break; - - case 1: - intermediate = y & 0x1; - break; - - case 2: - intermediate = x % 3; - break; - - case 3: - intermediate = (y + x) % 3; - break; - - case 4: - intermediate = (((int)((uint)y >> 1)) + (x / 3)) & 0x1; - break; - - case 5: - temp = y * x; - intermediate = (temp & 0x1) + (temp % 3); - break; - - case 6: - temp = y * x; - intermediate = (((temp & 0x1) + (temp % 3)) & 0x1); - break; - - case 7: - temp = y * x; - intermediate = (((temp % 3) + ((y + x) & 0x1)) & 0x1); - break; - - default: - throw new ArgumentException("Invalid mask pattern: " + maskPattern); - - } - return intermediate == 0; - } - - /// - /// Helper function for applyMaskPenaltyRule1. We need this for doing this calculation in both - /// vertical and horizontal orders respectively. - /// - /// The matrix. - /// if set to true [is horizontal]. - /// - private static int applyMaskPenaltyRule1Internal(ByteMatrix matrix, bool isHorizontal) - { - int penalty = 0; - int iLimit = isHorizontal ? matrix.Height : matrix.Width; - int jLimit = isHorizontal ? matrix.Width : matrix.Height; - var array = matrix.Array; - for (int i = 0; i < iLimit; i++) - { - int numSameBitCells = 0; - int prevBit = -1; - for (int j = 0; j < jLimit; j++) - { - int bit = isHorizontal ? array[i][j] : array[j][i]; - if (bit == prevBit) - { - numSameBitCells++; - } - else - { - if (numSameBitCells >= 5) - { - penalty += N1 + (numSameBitCells - 5); - } - numSameBitCells = 1; // Include the cell itself. - prevBit = bit; - } - } - if (numSameBitCells >= 5) - { - penalty += N1 + (numSameBitCells - 5); - } - } - return penalty; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MatrixUtil.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MatrixUtil.cs deleted file mode 100755 index 9fcde4e13..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/MatrixUtil.cs +++ /dev/null @@ -1,600 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using ZXing.Common; - -namespace ZXing.QrCode.Internal -{ - /// - /// - /// - /// - /// satorux@google.com (Satoru Takabayashi) - creator - /// - public static class MatrixUtil - { - private static readonly int[][] POSITION_DETECTION_PATTERN = new int[][] - { - new int[] { 1, 1, 1, 1, 1, 1, 1 }, - new int[] { 1, 0, 0, 0, 0, 0, 1 }, - new int[] { 1, 0, 1, 1, 1, 0, 1 }, - new int[] { 1, 0, 1, 1, 1, 0, 1 }, - new int[] { 1, 0, 1, 1, 1, 0, 1 }, - new int[] { 1, 0, 0, 0, 0, 0, 1 }, - new int[] { 1, 1, 1, 1, 1, 1, 1 } - }; - - private static readonly int[][] POSITION_ADJUSTMENT_PATTERN = new int[][] - { - new int[] { 1, 1, 1, 1, 1 }, - new int[] { 1, 0, 0, 0, 1 }, - new int[] { 1, 0, 1, 0, 1 }, - new int[] { 1, 0, 0, 0, 1 }, - new int[] { 1, 1, 1, 1, 1 } - }; - - // From Appendix E. Table 1, JIS0510X:2004 (p 71). The table was double-checked by komatsu. - private static readonly int[][] POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE = new int[][] - { - new int[] { -1, -1, -1, -1, -1, -1, -1 }, - new int[] { 6, 18, -1, -1, -1, -1, -1 }, - new int[] { 6, 22, -1, -1, -1, -1, -1 }, - new int[] { 6, 26, -1, -1, -1, -1, -1 }, - new int[] { 6, 30, -1, -1, -1, -1, -1 }, - new int[] { 6, 34, -1, -1, -1, -1, -1 }, - new int[] { 6, 22, 38, -1, -1, -1, -1 }, - new int[] { 6, 24, 42, -1, -1, -1, -1 }, - new int[] { 6, 26, 46, -1, -1, -1, -1 }, - new int[] { 6, 28, 50, -1, -1, -1, -1 }, - new int[] { 6, 30, 54, -1, -1, -1, -1 }, - new int[] { 6, 32, 58, -1, -1, -1, -1 }, - new int[] { 6, 34, 62, -1, -1, -1, -1 }, - new int[] { 6, 26, 46, 66, -1, -1, -1 }, - new int[] { 6, 26, 48, 70, -1, -1, -1 }, - new int[] { 6, 26, 50, 74, -1, -1, -1 }, - new int[] { 6, 30, 54, 78, -1, -1, -1 }, - new int[] { 6, 30, 56, 82, -1, -1, -1 }, - new int[] { 6, 30, 58, 86, -1, -1, -1 }, - new int[] { 6, 34, 62, 90, -1, -1, -1 }, - new int[] { 6, 28, 50, 72, 94, -1, -1 }, - new int[] { 6, 26, 50, 74, 98, -1, -1 }, - new int[] { 6, 30, 54, 78, 102, -1, -1 }, - new int[] { 6, 28, 54, 80, 106, -1, -1 }, - new int[] { 6, 32, 58, 84, 110, -1, -1 }, - new int[] { 6, 30, 58, 86, 114, -1, -1 }, - new int[] { 6, 34, 62, 90, 118, -1, -1 }, - new int[] { 6, 26, 50, 74, 98, 122, -1 }, - new int[] { 6, 30, 54, 78, 102, 126, -1 }, - new int[] { 6, 26, 52, 78, 104, 130, -1 }, - new int[] { 6, 30, 56, 82, 108, 134, -1 }, - new int[] { 6, 34, 60, 86, 112, 138, -1 }, - new int[] { 6, 30, 58, 86, 114, 142, -1 }, - new int[] { 6, 34, 62, 90, 118, 146, -1 }, - new int[] { 6, 30, 54, 78, 102, 126, 150 }, - new int[] { 6, 24, 50, 76, 102, 128, 154 }, - new int[] { 6, 28, 54, 80, 106, 132, 158 }, - new int[] { 6, 32, 58, 84, 110, 136, 162 }, - new int[] { 6, 26, 54, 82, 110, 138, 166 }, - new int[] { 6, 30, 58, 86, 114, 142, 170 } - }; - - // Type info cells at the left top corner. - private static readonly int[][] TYPE_INFO_COORDINATES = new int[][] - { - new int[] { 8, 0 }, - new int[] { 8, 1 }, - new int[] { 8, 2 }, - new int[] { 8, 3 }, - new int[] { 8, 4 }, - new int[] { 8, 5 }, - new int[] { 8, 7 }, - new int[] { 8, 8 }, - new int[] { 7, 8 }, - new int[] { 5, 8 }, - new int[] { 4, 8 }, - new int[] { 3, 8 }, - new int[] { 2, 8 }, - new int[] { 1, 8 }, - new int[] { 0, 8 } - }; - - // From Appendix D in JISX0510:2004 (p. 67) - private const int VERSION_INFO_POLY = 0x1f25; // 1 1111 0010 0101 - - // From Appendix C in JISX0510:2004 (p.65). - private const int TYPE_INFO_POLY = 0x537; - private const int TYPE_INFO_MASK_PATTERN = 0x5412; - - /// - /// Set all cells to 2. 2 means that the cell is empty (not set yet). - /// - /// JAVAPORT: We shouldn't need to do this at all. The code should be rewritten to begin encoding - /// with the ByteMatrix initialized all to zero. - /// - /// The matrix. - public static void clearMatrix(ByteMatrix matrix) - { - matrix.clear(2); - } - - /// - /// Build 2D matrix of QR Code from "dataBits" with "ecLevel", "version" and "getMaskPattern". On - /// success, store the result in "matrix" and return true. - /// - /// The data bits. - /// The ec level. - /// The version. - /// The mask pattern. - /// The matrix. - public static void buildMatrix(BitArray dataBits, ErrorCorrectionLevel ecLevel, Version version, int maskPattern, ByteMatrix matrix) - { - clearMatrix(matrix); - embedBasicPatterns(version, matrix); - // Type information appear with any version. - embedTypeInfo(ecLevel, maskPattern, matrix); - // Version info appear if version >= 7. - maybeEmbedVersionInfo(version, matrix); - // Data should be embedded at end. - embedDataBits(dataBits, maskPattern, matrix); - } - - /// - /// Embed basic patterns. On success, modify the matrix and return true. - /// The basic patterns are: - /// - Position detection patterns - /// - Timing patterns - /// - Dark dot at the left bottom corner - /// - Position adjustment patterns, if need be - /// - /// The version. - /// The matrix. - public static void embedBasicPatterns(Version version, ByteMatrix matrix) - { - // Let's get started with embedding big squares at corners. - embedPositionDetectionPatternsAndSeparators(matrix); - // Then, embed the dark dot at the left bottom corner. - embedDarkDotAtLeftBottomCorner(matrix); - - // Position adjustment patterns appear if version >= 2. - maybeEmbedPositionAdjustmentPatterns(version, matrix); - // Timing patterns should be embedded after position adj. patterns. - embedTimingPatterns(matrix); - } - - /// - /// Embed type information. On success, modify the matrix. - /// - /// The ec level. - /// The mask pattern. - /// The matrix. - public static void embedTypeInfo(ErrorCorrectionLevel ecLevel, int maskPattern, ByteMatrix matrix) - { - BitArray typeInfoBits = new BitArray(); - makeTypeInfoBits(ecLevel, maskPattern, typeInfoBits); - - for (int i = 0; i < typeInfoBits.Size; ++i) - { - // Place bits in LSB to MSB order. LSB (least significant bit) is the last value in - // "typeInfoBits". - int bit = typeInfoBits[typeInfoBits.Size - 1 - i] ? 1 : 0; - - // Type info bits at the left top corner. See 8.9 of JISX0510:2004 (p.46). - int x1 = TYPE_INFO_COORDINATES[i][0]; - int y1 = TYPE_INFO_COORDINATES[i][1]; - matrix[x1, y1] = bit; - - if (i < 8) - { - // Right top corner. - int x2 = matrix.Width - i - 1; - int y2 = 8; - matrix[x2, y2] = bit; - } - else - { - // Left bottom corner. - int x2 = 8; - int y2 = matrix.Height - 7 + (i - 8); - matrix[x2, y2] = bit; - } - } - } - - /// - /// Embed version information if need be. On success, modify the matrix and return true. - /// See 8.10 of JISX0510:2004 (p.47) for how to embed version information. - /// - /// The version. - /// The matrix. - public static void maybeEmbedVersionInfo(Version version, ByteMatrix matrix) - { - if (version.VersionNumber < 7) - { - // Version info is necessary if version >= 7. - return; // Don't need version info. - } - BitArray versionInfoBits = new BitArray(); - makeVersionInfoBits(version, versionInfoBits); - - int bitIndex = 6 * 3 - 1; // It will decrease from 17 to 0. - for (int i = 0; i < 6; ++i) - { - for (int j = 0; j < 3; ++j) - { - // Place bits in LSB (least significant bit) to MSB order. - var bit = versionInfoBits[bitIndex] ? 1 : 0; - bitIndex--; - // Left bottom corner. - matrix[i, matrix.Height - 11 + j] = bit; - // Right bottom corner. - matrix[matrix.Height - 11 + j, i] = bit; - } - } - } - - /// - /// Embed "dataBits" using "getMaskPattern". On success, modify the matrix and return true. - /// For debugging purposes, it skips masking process if "getMaskPattern" is -1. - /// See 8.7 of JISX0510:2004 (p.38) for how to embed data bits. - /// - /// The data bits. - /// The mask pattern. - /// The matrix. - public static void embedDataBits(BitArray dataBits, int maskPattern, ByteMatrix matrix) - { - int bitIndex = 0; - int direction = -1; - // Start from the right bottom cell. - int x = matrix.Width - 1; - int y = matrix.Height - 1; - while (x > 0) - { - // Skip the vertical timing pattern. - if (x == 6) - { - x -= 1; - } - while (y >= 0 && y < matrix.Height) - { - for (int i = 0; i < 2; ++i) - { - int xx = x - i; - // Skip the cell if it's not empty. - if (!isEmpty(matrix[xx, y])) - { - continue; - } - int bit; - if (bitIndex < dataBits.Size) - { - bit = dataBits[bitIndex] ? 1 : 0; - ++bitIndex; - } - else - { - // Padding bit. If there is no bit left, we'll fill the left cells with 0, as described - // in 8.4.9 of JISX0510:2004 (p. 24). - bit = 0; - } - - // Skip masking if mask_pattern is -1. - if (maskPattern != -1) - { - if (MaskUtil.getDataMaskBit(maskPattern, xx, y)) - { - bit ^= 0x1; - } - } - matrix[xx, y] = bit; - } - y += direction; - } - direction = -direction; // Reverse the direction. - y += direction; - x -= 2; // Move to the left. - } - // All bits should be consumed. - if (bitIndex != dataBits.Size) - { - throw new WriterException("Not all bits consumed: " + bitIndex + '/' + dataBits.Size); - } - } - - /// - /// Return the position of the most significant bit set (to one) in the "value". The most - /// significant bit is position 32. If there is no bit set, return 0. Examples: - /// - findMSBSet(0) => 0 - /// - findMSBSet(1) => 1 - /// - findMSBSet(255) => 8 - /// - /// The value_ renamed. - /// - public static int findMSBSet(int value_Renamed) - { - int numDigits = 0; - while (value_Renamed != 0) - { - value_Renamed = (int)((uint)value_Renamed >> 1); - ++numDigits; - } - return numDigits; - } - - /// - /// Calculate BCH (Bose-Chaudhuri-Hocquenghem) code for "value" using polynomial "poly". The BCH - /// code is used for encoding type information and version information. - /// Example: Calculation of version information of 7. - /// f(x) is created from 7. - /// - 7 = 000111 in 6 bits - /// - f(x) = x^2 + x^2 + x^1 - /// g(x) is given by the standard (p. 67) - /// - g(x) = x^12 + x^11 + x^10 + x^9 + x^8 + x^5 + x^2 + 1 - /// Multiply f(x) by x^(18 - 6) - /// - f'(x) = f(x) * x^(18 - 6) - /// - f'(x) = x^14 + x^13 + x^12 - /// Calculate the remainder of f'(x) / g(x) - /// x^2 - /// __________________________________________________ - /// g(x) )x^14 + x^13 + x^12 - /// x^14 + x^13 + x^12 + x^11 + x^10 + x^7 + x^4 + x^2 - /// -------------------------------------------------- - /// x^11 + x^10 + x^7 + x^4 + x^2 - /// - /// The remainder is x^11 + x^10 + x^7 + x^4 + x^2 - /// Encode it in binary: 110010010100 - /// The return value is 0xc94 (1100 1001 0100) - /// - /// Since all coefficients in the polynomials are 1 or 0, we can do the calculation by bit - /// operations. We don't care if cofficients are positive or negative. - /// - /// The value. - /// The poly. - /// - public static int calculateBCHCode(int value, int poly) - { - // If poly is "1 1111 0010 0101" (version info poly), msbSetInPoly is 13. We'll subtract 1 - // from 13 to make it 12. - int msbSetInPoly = findMSBSet(poly); - value <<= msbSetInPoly - 1; - // Do the division business using exclusive-or operations. - while (findMSBSet(value) >= msbSetInPoly) - { - value ^= poly << (findMSBSet(value) - msbSetInPoly); - } - // Now the "value" is the remainder (i.e. the BCH code) - return value; - } - - /// - /// Make bit vector of type information. On success, store the result in "bits" and return true. - /// Encode error correction level and mask pattern. See 8.9 of - /// JISX0510:2004 (p.45) for details. - /// - /// The ec level. - /// The mask pattern. - /// The bits. - public static void makeTypeInfoBits(ErrorCorrectionLevel ecLevel, int maskPattern, BitArray bits) - { - if (!QRCode.isValidMaskPattern(maskPattern)) - { - throw new WriterException("Invalid mask pattern"); - } - int typeInfo = (ecLevel.Bits << 3) | maskPattern; - bits.appendBits(typeInfo, 5); - - int bchCode = calculateBCHCode(typeInfo, TYPE_INFO_POLY); - bits.appendBits(bchCode, 10); - - BitArray maskBits = new BitArray(); - maskBits.appendBits(TYPE_INFO_MASK_PATTERN, 15); - bits.xor(maskBits); - - if (bits.Size != 15) - { - // Just in case. - throw new WriterException("should not happen but we got: " + bits.Size); - } - } - - /// - /// Make bit vector of version information. On success, store the result in "bits" and return true. - /// See 8.10 of JISX0510:2004 (p.45) for details. - /// - /// The version. - /// The bits. - public static void makeVersionInfoBits(Version version, BitArray bits) - { - bits.appendBits(version.VersionNumber, 6); - int bchCode = calculateBCHCode(version.VersionNumber, VERSION_INFO_POLY); - bits.appendBits(bchCode, 12); - - if (bits.Size != 18) - { - // Just in case. - throw new WriterException("should not happen but we got: " + bits.Size); - } - } - - /// - /// Check if "value" is empty. - /// - /// The value. - /// - /// true if the specified value is empty; otherwise, false. - /// - private static bool isEmpty(int value) - { - return value == 2; - } - - private static void embedTimingPatterns(ByteMatrix matrix) - { - // -8 is for skipping position detection patterns (size 7), and two horizontal/vertical - // separation patterns (size 1). Thus, 8 = 7 + 1. - for (int i = 8; i < matrix.Width - 8; ++i) - { - int bit = (i + 1) % 2; - // Horizontal line. - if (isEmpty(matrix[i, 6])) - { - matrix[i, 6] = bit; - } - // Vertical line. - if (isEmpty(matrix[6, i])) - { - matrix[6, i] = bit; - } - } - } - - /// - /// Embed the lonely dark dot at left bottom corner. JISX0510:2004 (p.46) - /// - /// The matrix. - private static void embedDarkDotAtLeftBottomCorner(ByteMatrix matrix) - { - if (matrix[8, matrix.Height - 8] == 0) - { - throw new WriterException(); - } - matrix[8, matrix.Height - 8] = 1; - } - - private static void embedHorizontalSeparationPattern(int xStart, int yStart, ByteMatrix matrix) - { - for (int x = 0; x < 8; ++x) - { - if (!isEmpty(matrix[xStart + x, yStart])) - { - throw new WriterException(); - } - matrix[xStart + x, yStart] = 0; - } - } - - private static void embedVerticalSeparationPattern(int xStart, int yStart, ByteMatrix matrix) - { - for (int y = 0; y < 7; ++y) - { - if (!isEmpty(matrix[xStart, yStart + y])) - { - throw new WriterException(); - } - matrix[xStart, yStart + y] = 0; - } - } - - /// - /// Note that we cannot unify the function with embedPositionDetectionPattern() despite they are - /// almost identical, since we cannot write a function that takes 2D arrays in different sizes in - /// C/C++. We should live with the fact. - /// - /// The x start. - /// The y start. - /// The matrix. - private static void embedPositionAdjustmentPattern(int xStart, int yStart, ByteMatrix matrix) - { - for (int y = 0; y < 5; ++y) - { - for (int x = 0; x < 5; ++x) - { - matrix[xStart + x, yStart + y] = POSITION_ADJUSTMENT_PATTERN[y][x]; - } - } - } - - private static void embedPositionDetectionPattern(int xStart, int yStart, ByteMatrix matrix) - { - for (int y = 0; y < 7; ++y) - { - for (int x = 0; x < 7; ++x) - { - matrix[xStart + x, yStart + y] = POSITION_DETECTION_PATTERN[y][x]; - } - } - } - - /// - /// Embed position detection patterns and surrounding vertical/horizontal separators. - /// - /// The matrix. - private static void embedPositionDetectionPatternsAndSeparators(ByteMatrix matrix) - { - // Embed three big squares at corners. - int pdpWidth = POSITION_DETECTION_PATTERN[0].Length; - // Left top corner. - embedPositionDetectionPattern(0, 0, matrix); - // Right top corner. - embedPositionDetectionPattern(matrix.Width - pdpWidth, 0, matrix); - // Left bottom corner. - embedPositionDetectionPattern(0, matrix.Width - pdpWidth, matrix); - - // Embed horizontal separation patterns around the squares. - const int hspWidth = 8; - // Left top corner. - embedHorizontalSeparationPattern(0, hspWidth - 1, matrix); - // Right top corner. - embedHorizontalSeparationPattern(matrix.Width - hspWidth, hspWidth - 1, matrix); - // Left bottom corner. - embedHorizontalSeparationPattern(0, matrix.Width - hspWidth, matrix); - - // Embed vertical separation patterns around the squares. - const int vspSize = 7; - // Left top corner. - embedVerticalSeparationPattern(vspSize, 0, matrix); - // Right top corner. - embedVerticalSeparationPattern(matrix.Height - vspSize - 1, 0, matrix); - // Left bottom corner. - embedVerticalSeparationPattern(vspSize, matrix.Height - vspSize, matrix); - } - - /// - /// Embed position adjustment patterns if need be. - /// - /// The version. - /// The matrix. - private static void maybeEmbedPositionAdjustmentPatterns(Version version, ByteMatrix matrix) - { - if (version.VersionNumber < 2) - { - // The patterns appear if version >= 2 - return; - } - int index = version.VersionNumber - 1; - int[] coordinates = POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE[index]; - int numCoordinates = POSITION_ADJUSTMENT_PATTERN_COORDINATE_TABLE[index].Length; - for (int i = 0; i < numCoordinates; ++i) - { - for (int j = 0; j < numCoordinates; ++j) - { - int y = coordinates[i]; - int x = coordinates[j]; - if (x == -1 || y == -1) - { - continue; - } - // If the cell is unset, we embed the position adjustment pattern here. - if (isEmpty(matrix[x, y])) - { - // -2 is necessary since the x/y coordinates point to the center of the pattern, not the - // left top corner. - embedPositionAdjustmentPattern(x - 2, y - 2, matrix); - } - } - } - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/QRCode.cs b/shadowsocks-csharp/3rd/zxing/qrcode/encoder/QRCode.cs deleted file mode 100755 index 90d10bf5b..000000000 --- a/shadowsocks-csharp/3rd/zxing/qrcode/encoder/QRCode.cs +++ /dev/null @@ -1,125 +0,0 @@ -/* -* Copyright 2008 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. -*/ - -using System; -using System.Text; - -namespace ZXing.QrCode.Internal -{ - /// satorux@google.com (Satoru Takabayashi) - creator - /// dswitkin@google.com (Daniel Switkin) - ported from C++ - public sealed class QRCode - { - /// - /// - /// - public static int NUM_MASK_PATTERNS = 8; - - /// - /// Initializes a new instance of the class. - /// - public QRCode() - { - MaskPattern = -1; - } - - /// - /// Gets or sets the mode. - /// - /// - /// The mode. - /// - public Mode Mode { get; set; } - - /// - /// Gets or sets the EC level. - /// - /// - /// The EC level. - /// - public ErrorCorrectionLevel ECLevel { get; set; } - - /// - /// Gets or sets the version. - /// - /// - /// The version. - /// - public Version Version { get; set; } - - /// - /// Gets or sets the mask pattern. - /// - /// - /// The mask pattern. - /// - public int MaskPattern { get; set; } - - /// - /// Gets or sets the matrix. - /// - /// - /// The matrix. - /// - public ByteMatrix Matrix { get; set; } - - /// - /// Returns a that represents this instance. - /// - /// - /// A that represents this instance. - /// - public override String ToString() - { - var result = new StringBuilder(200); - result.Append("<<\n"); - result.Append(" mode: "); - result.Append(Mode); - result.Append("\n ecLevel: "); - result.Append(ECLevel); - result.Append("\n version: "); - if (Version == null) - result.Append("null"); - else - result.Append(Version); - result.Append("\n maskPattern: "); - result.Append(MaskPattern); - if (Matrix == null) - { - result.Append("\n matrix: null\n"); - } - else - { - result.Append("\n matrix:\n"); - result.Append(Matrix.ToString()); - } - result.Append(">>\n"); - return result.ToString(); - } - - /// - /// Check if "mask_pattern" is valid. - /// - /// The mask pattern. - /// - /// true if [is valid mask pattern] [the specified mask pattern]; otherwise, false. - /// - public static bool isValidMaskPattern(int maskPattern) - { - return maskPattern >= 0 && maskPattern < NUM_MASK_PATTERNS; - } - } -} \ No newline at end of file diff --git a/shadowsocks-csharp/Data/libsscrypto.dll.gz b/shadowsocks-csharp/Data/libsscrypto.dll.gz index 41f0d4b8113ec972bb8f5f9f164096469e4d0427..e4285f4c8135677522f593099af97f8c8f75a2e1 100755 GIT binary patch literal 140908 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

82qZFdT{n{Z_h&9|}%$hpKJHud~8287%~ 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 z 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

x4+Tdl7mpi{EokW)I3h+1GuO(q;>w;>n){JE~ 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 z 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 Od;I|klBvJ|NCW`N4@(^Y literal 79596 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ð-wr=SbMS`l3?&L)TT&X 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⩔dTauZbqj2!fgkwyd_j0M_af$t)K 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

S@~IR^T3Q+L}HNuE$+1a!ecDgSa0Qn-cgP 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 literal 55391 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 diff --git a/shadowsocks-csharp/Data/sysproxy64.exe.gz b/shadowsocks-csharp/Data/sysproxy64.exe.gz index d0b5b59d5a2f9087bbba47e720e6fdecd5b0d85b..c5ff36af391832b09710ea138375632cc984dd32 100644 GIT binary patch literal 61784 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 literal 61079 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 - + + \ No newline at end of file diff --git a/shadowsocks-csharp/shadowsocks-csharp.csproj b/shadowsocks-csharp/shadowsocks-csharp.csproj index 11b1f6f55..2b5971422 100644 --- a/shadowsocks-csharp/shadowsocks-csharp.csproj +++ b/shadowsocks-csharp/shadowsocks-csharp.csproj @@ -72,9 +72,8 @@ - - 3rd\Newtonsoft.Json.9.0.1\lib\net45\Newtonsoft.Json.dll - True + + 3rd\Newtonsoft.Json.10.0.1\lib\net45\Newtonsoft.Json.dll @@ -86,60 +85,14 @@ + + 3rd\ZXing.Net.0.15.0\lib\net461\zxing.dll + + + 3rd\ZXing.Net.0.15.0\lib\net461\zxing.presentation.dll + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/shadowsocks-windows.sln b/shadowsocks-windows.sln index bb7f2978d..4e8f72ff3 100644 --- a/shadowsocks-windows.sln +++ b/shadowsocks-windows.sln @@ -1,32 +1,32 @@ - -Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio 14 -VisualStudioVersion = 14.0.24720.0 -MinimumVisualStudioVersion = 10.0.40219.1 -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "shadowsocks-csharp", "shadowsocks-csharp\shadowsocks-csharp.csproj", "{8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}" -EndProject -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "test", "test\test.csproj", "{45913187-0685-4903-B250-DCEF0479CD86}" - ProjectSection(ProjectDependencies) = postProject - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062} = {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062} - EndProjectSection -EndProject -Global - GlobalSection(SolutionConfigurationPlatforms) = preSolution - Debug|x86 = Debug|x86 - Release|x86 = Release|x86 - EndGlobalSection - GlobalSection(ProjectConfigurationPlatforms) = postSolution - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.ActiveCfg = Debug|x86 - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.Build.0 = Debug|x86 - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.Deploy.0 = Debug|x86 - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Release|x86.ActiveCfg = Release|x86 - {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Release|x86.Build.0 = Release|x86 - {45913187-0685-4903-B250-DCEF0479CD86}.Debug|x86.ActiveCfg = Debug|x86 - {45913187-0685-4903-B250-DCEF0479CD86}.Debug|x86.Build.0 = Debug|x86 - {45913187-0685-4903-B250-DCEF0479CD86}.Release|x86.ActiveCfg = Release|x86 - {45913187-0685-4903-B250-DCEF0479CD86}.Release|x86.Build.0 = Release|x86 - EndGlobalSection - GlobalSection(SolutionProperties) = preSolution - HideSolutionNode = FALSE - EndGlobalSection -EndGlobal + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio 15 +VisualStudioVersion = 15.0.26228.10 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "shadowsocks-csharp", "shadowsocks-csharp\shadowsocks-csharp.csproj", "{8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "test", "test\test.csproj", "{45913187-0685-4903-B250-DCEF0479CD86}" + ProjectSection(ProjectDependencies) = postProject + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062} = {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062} + EndProjectSection +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|x86 = Debug|x86 + Release|x86 = Release|x86 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.ActiveCfg = Debug|x86 + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.Build.0 = Debug|x86 + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Debug|x86.Deploy.0 = Debug|x86 + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Release|x86.ActiveCfg = Release|x86 + {8C02D2F7-7CDB-4D55-9F25-CD03EF4AA062}.Release|x86.Build.0 = Release|x86 + {45913187-0685-4903-B250-DCEF0479CD86}.Debug|x86.ActiveCfg = Debug|x86 + {45913187-0685-4903-B250-DCEF0479CD86}.Debug|x86.Build.0 = Debug|x86 + {45913187-0685-4903-B250-DCEF0479CD86}.Release|x86.ActiveCfg = Release|x86 + {45913187-0685-4903-B250-DCEF0479CD86}.Release|x86.Build.0 = Release|x86 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection +EndGlobal diff --git a/test/packages.config b/test/packages.config new file mode 100644 index 000000000..a32f7c2d7 --- /dev/null +++ b/test/packages.config @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/test/test.csproj b/test/test.csproj index 8ea4949b7..654a9afa5 100755 --- a/test/test.csproj +++ b/test/test.csproj @@ -37,7 +37,6 @@ ..\shadowsocks-csharp\3rd\GlobalHotKey.1.1.0\lib\GlobalHotKey.dll - True @@ -64,6 +63,9 @@ shadowsocks-csharp + + +