116 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
declare(strict_types = 1);
 | 
						|
 | 
						|
namespace BaconQrCodeTest\Common;
 | 
						|
 | 
						|
use BaconQrCode\Common\BitArray;
 | 
						|
use BaconQrCode\Common\BitMatrix;
 | 
						|
use PHPUnit\Framework\TestCase;
 | 
						|
 | 
						|
class BitMatrixTest extends TestCase
 | 
						|
{
 | 
						|
    public function testGetSet() : void
 | 
						|
    {
 | 
						|
        $matrix = new BitMatrix(33);
 | 
						|
        $this->assertEquals(33, $matrix->getHeight());
 | 
						|
 | 
						|
        for ($y = 0; $y < 33; ++$y) {
 | 
						|
            for ($x = 0; $x < 33; ++$x) {
 | 
						|
                if ($y * $x % 3 === 0) {
 | 
						|
                    $matrix->set($x, $y);
 | 
						|
                }
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        for ($y = 0; $y < 33; $y++) {
 | 
						|
            for ($x = 0; $x < 33; ++$x) {
 | 
						|
                $this->assertSame(0 === $x * $y % 3, $matrix->get($x, $y));
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function testSetRegion() : void
 | 
						|
    {
 | 
						|
        $matrix = new BitMatrix(5);
 | 
						|
        $matrix->setRegion(1, 1, 3, 3);
 | 
						|
 | 
						|
        for ($y = 0; $y < 5; ++$y) {
 | 
						|
            for ($x = 0; $x < 5; ++$x) {
 | 
						|
                $this->assertSame($y >= 1 && $y <= 3 && $x >= 1 && $x <= 3, $matrix->get($x, $y));
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function testRectangularMatrix() : void
 | 
						|
    {
 | 
						|
        $matrix = new BitMatrix(75, 20);
 | 
						|
        $this->assertSame(75, $matrix->getWidth());
 | 
						|
        $this->assertSame(20, $matrix->getHeight());
 | 
						|
 | 
						|
        $matrix->set(10, 0);
 | 
						|
        $matrix->set(11, 1);
 | 
						|
        $matrix->set(50, 2);
 | 
						|
        $matrix->set(51, 3);
 | 
						|
        $matrix->flip(74, 4);
 | 
						|
        $matrix->flip(0, 5);
 | 
						|
 | 
						|
        $this->assertTrue($matrix->get(10, 0));
 | 
						|
        $this->assertTrue($matrix->get(11, 1));
 | 
						|
        $this->assertTrue($matrix->get(50, 2));
 | 
						|
        $this->assertTrue($matrix->get(51, 3));
 | 
						|
        $this->assertTrue($matrix->get(74, 4));
 | 
						|
        $this->assertTrue($matrix->get(0, 5));
 | 
						|
 | 
						|
        $matrix->flip(50, 2);
 | 
						|
        $matrix->flip(51, 3);
 | 
						|
 | 
						|
        $this->assertFalse($matrix->get(50, 2));
 | 
						|
        $this->assertFalse($matrix->get(51, 3));
 | 
						|
    }
 | 
						|
 | 
						|
    public function testRectangularSetRegion() : void
 | 
						|
    {
 | 
						|
        $matrix = new BitMatrix(320, 240);
 | 
						|
        $this->assertSame(320, $matrix->getWidth());
 | 
						|
        $this->assertSame(240, $matrix->getHeight());
 | 
						|
 | 
						|
        $matrix->setRegion(105, 22, 80, 12);
 | 
						|
 | 
						|
        for ($y = 0; $y < 240; ++$y) {
 | 
						|
            for ($x = 0; $x < 320; ++$x) {
 | 
						|
                $this->assertEquals($y >= 22 && $y < 34 && $x >= 105 && $x < 185, $matrix->get($x, $y));
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    public function testGetRow() : void
 | 
						|
    {
 | 
						|
        $matrix = new BitMatrix(102, 5);
 | 
						|
 | 
						|
        for ($x = 0; $x < 102; ++$x) {
 | 
						|
            if (0 === ($x & 3)) {
 | 
						|
                $matrix->set($x, 2);
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        $array1 = $matrix->getRow(2, null);
 | 
						|
        $this->assertSame(102, $array1->getSize());
 | 
						|
 | 
						|
        $array2 = new BitArray(60);
 | 
						|
        $array2 = $matrix->getRow(2, $array2);
 | 
						|
        $this->assertSame(102, $array2->getSize());
 | 
						|
 | 
						|
        $array3 = new BitArray(200);
 | 
						|
        $array3 = $matrix->getRow(2, $array3);
 | 
						|
        $this->assertSame(200, $array3->getSize());
 | 
						|
 | 
						|
        for ($x = 0; $x < 102; ++$x) {
 | 
						|
            $on = (0 === ($x & 3));
 | 
						|
 | 
						|
            $this->assertSame($on, $array1->get($x));
 | 
						|
            $this->assertSame($on, $array2->get($x));
 | 
						|
            $this->assertSame($on, $array3->get($x));
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |