public void Pattern_01() { const int WIDTH = 21, HEIGHT = 21; QRMatrix matrix = new QRMatrix(WIDTH, HEIGHT); matrix.Fill(2); matrix.AddBasicPatterns(QRVersion.GetVersionByNumber(1)); string expected = "1 1 1 1 1 1 1 0 0 1 1 1 1 1 1 1\r\n" + "1 0 0 0 0 0 1 0 0 1 0 0 0 0 0 1\r\n" + "1 0 1 1 1 0 1 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 0 1 0 1 1 1 0 1\r\n" + "1 0 0 0 0 0 1 0 0 1 0 0 0 0 0 1\r\n" + "1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 1 1 1 1 1 1\r\n" + "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + " 1 \r\n" + " 0 \r\n" + " 1 \r\n" + " 0 \r\n" + " 1 \r\n" + "0 0 0 0 0 0 0 0 1 \r\n" + "1 1 1 1 1 1 1 0 \r\n" + "1 0 0 0 0 0 1 0 \r\n" + "1 0 1 1 1 0 1 0 \r\n" + "1 0 1 1 1 0 1 0 \r\n" + "1 0 1 1 1 0 1 0 \r\n" + "1 0 0 0 0 0 1 0 \r\n" + "1 1 1 1 1 1 1 0 "; Assert.AreEqual(expected, matrix.ToString()); }
public void VersionInfo() { const int WIDTH = 21, HEIGHT = 21; // Version info bits = 000111 110010 010100 // Actually, version 7 QR Code has 45x45 matrix but we use 21x21 here // since 45x45 matrix is too big to depict. QRMatrix matrix = new QRMatrix(WIDTH, HEIGHT); matrix.AddVersionInfoIfRequired(QRVersion.GetVersionByNumber(7)); string expected = " 0 0 1 \r\n" + " 0 1 0 \r\n" + " 0 1 0 \r\n" + " 0 1 1 \r\n" + " 1 1 1 \r\n" + " 0 0 0 \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + "0 0 0 0 1 0 \r\n" + "0 1 1 1 1 0 \r\n" + "1 0 0 1 1 0 \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " "; Assert.AreEqual(expected, matrix.ToString()); }
public void TypeInfo() { const int WIDTH = 21, HEIGHT = 21; // Type info bits = 100000011001110. QRMatrix matrix = new QRMatrix(WIDTH, HEIGHT); matrix.AddTypeInfo(QRCorrectionLevel.M, 5); string expected = " 0 \r\n" + " 1 \r\n" + " 1 \r\n" + " 1 \r\n" + " 0 \r\n" + " 0 \r\n" + " \r\n" + " 1 \r\n" + "1 0 0 0 0 0 0 1 1 1 0 0 1 1 1 0\r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " \r\n" + " 0 \r\n" + " 0 \r\n" + " 0 \r\n" + " 0 \r\n" + " 0 \r\n" + " 0 \r\n" + " 1 "; Assert.AreEqual(expected, matrix.ToString()); }
public void BuildMatrix() { const int WIDTH = 21, HEIGHT = 21; // From http://www.swetake.com/qr/qr7.html int[] ints = { 32, 65, 205, 69, 41, 220, 46, 128, 236, 42, 159, 74, 221, 244, 169, 239, 150, 138, 70, 237, 85, 224, 96, 74, 219, 61 }; BitList bits = new BitList(); foreach (int i in ints) { bits.AppendBits(i, 8); } QRMatrix matrix = new QRMatrix(WIDTH, HEIGHT); matrix.FormMatrix(bits, QRCorrectionLevel.H, QRVersion.GetVersionByNumber(1), 3); string expected = "1 1 1 1 1 1 1 0 0 1 1 0 0 0 1 1 1 1 1 1 1\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1\r\n" + "1 0 1 1 1 0 1 0 0 0 0 1 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 0 1 1 0 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 1 1 0 0 1 0 1 0 1 1 1 0 1\r\n" + "1 0 0 0 0 0 1 0 0 0 1 1 1 0 1 0 0 0 0 0 1\r\n" + "1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 1 1 1 1 1 1\r\n" + "0 0 0 0 0 0 0 0 1 1 0 1 1 0 0 0 0 0 0 0 0\r\n" + "0 0 1 1 0 0 1 1 1 0 0 1 1 1 1 0 1 0 0 0 0\r\n" + "1 0 1 0 1 0 0 0 0 0 1 1 1 0 0 1 0 1 1 1 0\r\n" + "1 1 1 1 0 1 1 0 1 0 1 1 1 0 0 1 1 1 0 1 0\r\n" + "1 0 1 0 1 1 0 1 1 1 0 0 1 1 1 0 0 1 0 1 0\r\n" + "0 0 1 0 0 1 1 1 0 0 0 0 0 0 1 0 1 1 1 1 1\r\n" + "0 0 0 0 0 0 0 0 1 1 0 1 0 0 0 0 0 1 0 1 1\r\n" + "1 1 1 1 1 1 1 0 1 1 1 1 0 0 0 0 1 0 1 1 0\r\n" + "1 0 0 0 0 0 1 0 0 0 0 1 0 1 1 1 0 0 0 0 0\r\n" + "1 0 1 1 1 0 1 0 0 1 0 0 1 1 0 0 1 0 0 1 1\r\n" + "1 0 1 1 1 0 1 0 1 1 0 1 0 0 0 0 0 1 1 1 0\r\n" + "1 0 1 1 1 0 1 0 1 1 1 1 0 0 0 0 1 1 1 0 0\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 0 1 0 0\r\n" + "1 1 1 1 1 1 1 0 0 0 1 1 1 1 1 0 1 0 0 1 0"; Assert.AreEqual(expected, matrix.ToString()); }
public void DataBits() { const int WIDTH = 21, HEIGHT = 21; //System.Diagnostics.Debugger.Launch(); // Cells other than basic patterns should be filled with zero. QRMatrix matrix = new QRMatrix(WIDTH, HEIGHT); matrix.AddBasicPatterns(QRVersion.GetVersionByNumber(1)); BitList bits = new BitList(); matrix.InsertDataBits(bits, -1); string expected = "1 1 1 1 1 1 1 0 0 0 0 0 0 0 1 1 1 1 1 1 1\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 1 0 1 1 1 0 1\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 1 0 1 1 1 0 1\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1\r\n" + "1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 1 1 1 1 1 1\r\n" + "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 0 1 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0\r\n" + "1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0"; Assert.AreEqual(expected, matrix.ToString()); }