Passed
Push — main ( a3ac80...14e9ad )
by Frank
02:23
created

MercatorProjection   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
wmc 7
eloc 11
c 2
b 0
f 0
dl 0
loc 34
ccs 15
cts 15
cp 1
rs 10

5 Methods

Rating   Name   Duplication   Size   Complexity  
A getMaxX() 0 3 1
A getMaxLatitude() 0 3 1
A getX() 0 3 1
A getMaxY() 0 3 1
A getY() 0 12 3
1
<?php
2
declare(strict_types=1);
3
4
namespace PrinsFrank\PhpGeoSVG\Projection;
5
6
use PrinsFrank\PhpGeoSVG\Geometry\Position\Position;
7
8
class MercatorProjection implements Projection
9
{
10 1
    public function getX(Position $position): float
11
    {
12 1
        return ($position->longitude + 180) * (Position::TOTAL_LONGITUDE * .5 / 360);
13
    }
14
15 1
    public function getY(Position $position): float
16
    {
17 1
        $latitude = $position->latitude;
18 1
        if ($latitude > $this->getMaxLatitude() - 0.001) {
19 1
            $latitude = $this->getMaxLatitude() - 0.001;
20
        }
21
22 1
        if ($latitude < (-$this->getMaxLatitude()) + 0.001) {
23 1
            $latitude = (-$this->getMaxLatitude()) + 0.001;
24
        }
25
26 1
        return (Position::TOTAL_LATITUDE / 2) - (Position::TOTAL_LONGITUDE * .5 * log(tan((M_PI / 4) + (($latitude*M_PI / 180) / 2))) / (2 * M_PI));
27
    }
28
29 1
    public function getMaxX(): float
30
    {
31 1
        return Position::TOTAL_LONGITUDE * .5;
32
    }
33
34 1
    public function getMaxY(): float
35
    {
36 1
        return Position::TOTAL_LATITUDE;
37
    }
38
39 1
    public function getMaxLatitude(): float
40
    {
41 1
        return 85;
42
    }
43
}
44