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));
|
||
|
}
|
||
|
}
|
||
|
}
|