Extract CopyrightPrinter.
This commit is contained in:
parent
864f2be68f
commit
06876513e7
42
src/CopyrightPrinter/CopyrightPrinter.php
Normal file
42
src/CopyrightPrinter/CopyrightPrinter.php
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace StaticMapLite\CopyrightPrinter;
|
||||||
|
|
||||||
|
use StaticMapLite\Canvas\CanvasInterface;
|
||||||
|
|
||||||
|
class CopyrightPrinter implements CopyrightPrinterInterface
|
||||||
|
{
|
||||||
|
/** @var string $osmLogo */
|
||||||
|
protected $osmLogo = '../images/osm_logo.png';
|
||||||
|
|
||||||
|
/** @var CanvasInterface $canvas */
|
||||||
|
protected $canvas;
|
||||||
|
|
||||||
|
public function setCanvas(CanvasInterface $canvas): CopyrightPrinterInterface
|
||||||
|
{
|
||||||
|
$this->canvas = $canvas;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function printCopyright(): CopyrightPrinterInterface
|
||||||
|
{
|
||||||
|
$logo = imagecreatefrompng($this->osmLogo);
|
||||||
|
|
||||||
|
$logoWidth = imagesx($logo);
|
||||||
|
$logoHeight = imagesy($logo);
|
||||||
|
|
||||||
|
imagecopy(
|
||||||
|
$this->canvas->getImage(),
|
||||||
|
$logo,
|
||||||
|
imagesx($this->canvas->getImage()) - $logoWidth,
|
||||||
|
imagesy($this->canvas->getImage()) - $logoHeight,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
$logoWidth,
|
||||||
|
$logoHeight
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
}
|
8
src/CopyrightPrinter/CopyrightPrinterInterface.php
Normal file
8
src/CopyrightPrinter/CopyrightPrinterInterface.php
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace StaticMapLite\CopyrightPrinter;
|
||||||
|
|
||||||
|
interface CopyrightPrinterInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
@ -38,9 +38,6 @@ abstract class AbstractPrinter implements PrinterInterface
|
|||||||
/** @var string $tileDefaultSrc */
|
/** @var string $tileDefaultSrc */
|
||||||
protected $tileDefaultSrc = 'mapnik';
|
protected $tileDefaultSrc = 'mapnik';
|
||||||
|
|
||||||
/** @var string $osmLogo */
|
|
||||||
protected $osmLogo = '../images/osm_logo.png';
|
|
||||||
|
|
||||||
/** @var bool $useTileCache */
|
/** @var bool $useTileCache */
|
||||||
protected $useTileCache = true;
|
protected $useTileCache = true;
|
||||||
|
|
||||||
|
@ -4,6 +4,7 @@ namespace StaticMapLite\Printer;
|
|||||||
|
|
||||||
use StaticMapLite\Canvas\Canvas;
|
use StaticMapLite\Canvas\Canvas;
|
||||||
use StaticMapLite\CanvasTilePainter\CanvasTilePainter;
|
use StaticMapLite\CanvasTilePainter\CanvasTilePainter;
|
||||||
|
use StaticMapLite\CopyrightPrinter\CopyrightPrinter;
|
||||||
use StaticMapLite\Element\Marker\AbstractMarker;
|
use StaticMapLite\Element\Marker\AbstractMarker;
|
||||||
use StaticMapLite\Element\Polyline\Polyline;
|
use StaticMapLite\Element\Polyline\Polyline;
|
||||||
use StaticMapLite\ElementPrinter\Marker\ExtraMarkerPrinter;
|
use StaticMapLite\ElementPrinter\Marker\ExtraMarkerPrinter;
|
||||||
@ -88,16 +89,18 @@ class Printer extends AbstractPrinter
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function initCoords()
|
public function initCoords(): Printer
|
||||||
{
|
{
|
||||||
$this->centerX = Util::lonToTile($this->longitude, $this->zoom);
|
$this->centerX = Util::lonToTile($this->longitude, $this->zoom);
|
||||||
$this->centerY = Util::latToTile($this->latitude, $this->zoom);
|
$this->centerY = Util::latToTile($this->latitude, $this->zoom);
|
||||||
|
|
||||||
$this->offsetX = floor((floor($this->centerX) - $this->centerX) * $this->tileSize);
|
$this->offsetX = floor((floor($this->centerX) - $this->centerX) * $this->tileSize);
|
||||||
$this->offsetY = floor((floor($this->centerY) - $this->centerY) * $this->tileSize);
|
$this->offsetY = floor((floor($this->centerY) - $this->centerY) * $this->tileSize);
|
||||||
|
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function createBaseMap()
|
public function createBaseMap(): Printer
|
||||||
{
|
{
|
||||||
$this->canvas = new Canvas(
|
$this->canvas = new Canvas(
|
||||||
$this->width,
|
$this->width,
|
||||||
@ -113,9 +116,11 @@ class Printer extends AbstractPrinter
|
|||||||
->setTileResolver($this->tileResolver)
|
->setTileResolver($this->tileResolver)
|
||||||
->paint()
|
->paint()
|
||||||
;
|
;
|
||||||
|
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function placeMarkers()
|
public function placeMarkers(): Printer
|
||||||
{
|
{
|
||||||
$printer = new ExtraMarkerPrinter();
|
$printer = new ExtraMarkerPrinter();
|
||||||
|
|
||||||
@ -125,9 +130,11 @@ class Printer extends AbstractPrinter
|
|||||||
->paint($this->canvas)
|
->paint($this->canvas)
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function placePolylines()
|
public function placePolylines(): Printer
|
||||||
{
|
{
|
||||||
$printer = new PolylinePrinter();
|
$printer = new PolylinePrinter();
|
||||||
|
|
||||||
@ -138,25 +145,14 @@ class Printer extends AbstractPrinter
|
|||||||
->paint($this->canvas)
|
->paint($this->canvas)
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function copyrightNotice()
|
public function makeMap(): Printer
|
||||||
{
|
|
||||||
$logoImg = imagecreatefrompng($this->osmLogo);
|
|
||||||
imagecopy($this->canvas->getImage(), $logoImg, imagesx($this->canvas->getImage()) - imagesx($logoImg), imagesy($this->canvas->getImage()) - imagesy($logoImg), 0, 0, imagesx($logoImg), imagesy($logoImg));
|
|
||||||
}
|
|
||||||
public function sendHeader()
|
|
||||||
{
|
|
||||||
header('Content-Type: image/png');
|
|
||||||
$expires = 60 * 60 * 24 * 14;
|
|
||||||
header("Pragma: public");
|
|
||||||
header("Cache-Control: maxage=" . $expires);
|
|
||||||
header('Expires: ' . gmdate('D, d M Y H:i:s', time() + $expires) . ' GMT');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function makeMap()
|
|
||||||
{
|
{
|
||||||
$this->initCoords();
|
$this->initCoords();
|
||||||
|
|
||||||
$this->createBaseMap();
|
$this->createBaseMap();
|
||||||
|
|
||||||
if (count($this->polylines)) {
|
if (count($this->polylines)) {
|
||||||
@ -167,9 +163,20 @@ class Printer extends AbstractPrinter
|
|||||||
$this->placeMarkers();
|
$this->placeMarkers();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->osmLogo) {
|
$this->printCopyright();
|
||||||
$this->copyrightNotice();
|
|
||||||
}
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function printCopyright(): Printer
|
||||||
|
{
|
||||||
|
$cp = new CopyrightPrinter();
|
||||||
|
$cp
|
||||||
|
->setCanvas($this->canvas)
|
||||||
|
->printCopyright()
|
||||||
|
;
|
||||||
|
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function showMap()
|
public function showMap()
|
||||||
@ -188,7 +195,6 @@ class Printer extends AbstractPrinter
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// no cache, make map, send headers and deliver png
|
|
||||||
$this->makeMap();
|
$this->makeMap();
|
||||||
|
|
||||||
$output = new ImageOutput();
|
$output = new ImageOutput();
|
||||||
|
@ -74,7 +74,7 @@ if ($polylines) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
print $printer->showMap();
|
$printer->showMap();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user