@@ -15,7 +15,7 @@ discard block |
||
| 15 | 15 | /** |
| 16 | 16 | * @see https://github.com/mourner/simplify-js |
| 17 | 17 | */ |
| 18 | -class PolylineSimplifyer{ |
|
| 18 | +class PolylineSimplifyer { |
|
| 19 | 19 | |
| 20 | 20 | protected array $coords; |
| 21 | 21 | |
@@ -24,17 +24,17 @@ discard block |
||
| 24 | 24 | * |
| 25 | 25 | * @throws \chillerlan\GeoJSON\GeoJSONException |
| 26 | 26 | */ |
| 27 | - public function __construct(array $polylineCoords){ |
|
| 27 | + public function __construct(array $polylineCoords) { |
|
| 28 | 28 | |
| 29 | - if(count($polylineCoords) < 2){ |
|
| 29 | + if (count($polylineCoords) < 2) { |
|
| 30 | 30 | throw new GeoJSONException('not enough points'); |
| 31 | 31 | } |
| 32 | 32 | |
| 33 | 33 | $this->coords = array_values($polylineCoords); |
| 34 | 34 | |
| 35 | - foreach($this->coords as $i => $coord){ |
|
| 35 | + foreach ($this->coords as $i => $coord) { |
|
| 36 | 36 | |
| 37 | - if(!is_array($coord) || count($coord) < 2){ |
|
| 37 | + if (!is_array($coord) || count($coord) < 2) { |
|
| 38 | 38 | throw new GeoJSONException('invalid coords found'); |
| 39 | 39 | } |
| 40 | 40 | |
@@ -62,16 +62,16 @@ discard block |
||
| 62 | 62 | $point = null; |
| 63 | 63 | $len = count($this->coords); |
| 64 | 64 | |
| 65 | - for($i = 1; $i < $len; $i++){ |
|
| 65 | + for ($i = 1; $i < $len; $i++) { |
|
| 66 | 66 | $point = $this->coords[$i]; |
| 67 | 67 | |
| 68 | - if($this->getSqDist($point, $prevPoint) > $sqTolerance){ |
|
| 68 | + if ($this->getSqDist($point, $prevPoint) > $sqTolerance) { |
|
| 69 | 69 | $newPoints[] = $point; |
| 70 | 70 | $prevPoint = $point; |
| 71 | 71 | } |
| 72 | 72 | } |
| 73 | 73 | |
| 74 | - if($prevPoint !== $point){ |
|
| 74 | + if ($prevPoint !== $point) { |
|
| 75 | 75 | $newPoints[] = $point; |
| 76 | 76 | } |
| 77 | 77 | |
@@ -102,20 +102,20 @@ discard block |
||
| 102 | 102 | |
| 103 | 103 | $markers[$first] = $markers[$last] = 1; |
| 104 | 104 | |
| 105 | - while($last){ |
|
| 105 | + while ($last) { |
|
| 106 | 106 | |
| 107 | 107 | $maxSqDist = 0; |
| 108 | 108 | |
| 109 | - for($i = $first + 1; $i < $last; $i++){ |
|
| 109 | + for ($i = $first + 1; $i < $last; $i++) { |
|
| 110 | 110 | $sqDist = $this->getSqSegDist($points[$i], $points[$first], $points[$last]); |
| 111 | 111 | |
| 112 | - if($sqDist > $maxSqDist){ |
|
| 112 | + if ($sqDist > $maxSqDist) { |
|
| 113 | 113 | $index = $i; |
| 114 | 114 | $maxSqDist = $sqDist; |
| 115 | 115 | } |
| 116 | 116 | } |
| 117 | 117 | |
| 118 | - if($maxSqDist > $sqTolerance){ |
|
| 118 | + if ($maxSqDist > $sqTolerance) { |
|
| 119 | 119 | $markers[$index] = 1; |
| 120 | 120 | array_push($stack, $first, $index, $index, $last); |
| 121 | 121 | } |
@@ -124,8 +124,8 @@ discard block |
||
| 124 | 124 | $first = array_pop($stack); |
| 125 | 125 | } |
| 126 | 126 | |
| 127 | - foreach($points as $i => $point){ |
|
| 128 | - if($markers[$i]){ |
|
| 127 | + foreach ($points as $i => $point) { |
|
| 128 | + if ($markers[$i]) { |
|
| 129 | 129 | $newPoints[] = $point; |
| 130 | 130 | } |
| 131 | 131 | } |
@@ -142,16 +142,16 @@ discard block |
||
| 142 | 142 | $dx = $p2[0] - $x; |
| 143 | 143 | $dy = $p2[1] - $y; |
| 144 | 144 | |
| 145 | - if((int)$dx !== 0 || (int)$dy !== 0){ |
|
| 145 | + if ((int) $dx !== 0 || (int) $dy !== 0) { |
|
| 146 | 146 | |
| 147 | 147 | $t = (($p[0] - $x) * $dx + ($p[1] - $y) * $dy) / ($dx * $dx + $dy * $dy); |
| 148 | 148 | |
| 149 | - if($t > 1){ |
|
| 149 | + if ($t > 1) { |
|
| 150 | 150 | $x = $p2[0]; |
| 151 | 151 | $y = $p2[1]; |
| 152 | 152 | |
| 153 | 153 | } |
| 154 | - elseif($t > 0){ |
|
| 154 | + elseif ($t > 0) { |
|
| 155 | 155 | $x += $dx * $t; |
| 156 | 156 | $y += $dy * $t; |
| 157 | 157 | } |
@@ -15,7 +15,7 @@ discard block |
||
| 15 | 15 | /** |
| 16 | 16 | * @see https://www.rfc-editor.org/rfc/rfc7946#section-3.3 |
| 17 | 17 | */ |
| 18 | -class FeatureCollection extends GeoJSONAbstract{ |
|
| 18 | +class FeatureCollection extends GeoJSONAbstract { |
|
| 19 | 19 | |
| 20 | 20 | /** @var \chillerlan\GeoJSON\Feature[] */ |
| 21 | 21 | protected array $features = []; |
@@ -25,9 +25,9 @@ discard block |
||
| 25 | 25 | * |
| 26 | 26 | * @param \chillerlan\GeoJSON\Feature[]|null $features |
| 27 | 27 | */ |
| 28 | - public function __construct(iterable $features = null){ |
|
| 28 | + public function __construct(iterable $features = null) { |
|
| 29 | 29 | |
| 30 | - if(!empty($features)){ |
|
| 30 | + if (!empty($features)) { |
|
| 31 | 31 | $this->addFeatures($features); |
| 32 | 32 | } |
| 33 | 33 | |
@@ -47,8 +47,8 @@ discard block |
||
| 47 | 47 | */ |
| 48 | 48 | public function addFeatures(iterable $features):FeatureCollection{ |
| 49 | 49 | |
| 50 | - foreach($features as $feature){ |
|
| 51 | - if($feature instanceof Feature){ |
|
| 50 | + foreach ($features as $feature) { |
|
| 51 | + if ($feature instanceof Feature) { |
|
| 52 | 52 | $this->addFeature($feature); |
| 53 | 53 | } |
| 54 | 54 | } |
@@ -71,7 +71,7 @@ discard block |
||
| 71 | 71 | public function toArray():array{ |
| 72 | 72 | $arr = ['type' => 'FeatureCollection']; |
| 73 | 73 | |
| 74 | - if(!empty($this->bbox)){ |
|
| 74 | + if (!empty($this->bbox)) { |
|
| 75 | 75 | $arr['bbox'] = $this->bbox; |
| 76 | 76 | } |
| 77 | 77 | |
@@ -17,7 +17,7 @@ discard block |
||
| 17 | 17 | /** |
| 18 | 18 | * @see https://www.rfc-editor.org/rfc/rfc7946#section-3.2 |
| 19 | 19 | */ |
| 20 | -class Feature extends GeoJSONAbstract{ |
|
| 20 | +class Feature extends GeoJSONAbstract { |
|
| 21 | 21 | |
| 22 | 22 | public const types = [ |
| 23 | 23 | 'Point', |
@@ -44,18 +44,18 @@ discard block |
||
| 44 | 44 | * |
| 45 | 45 | * @throws \chillerlan\GeoJSON\GeoJSONException |
| 46 | 46 | */ |
| 47 | - public function __construct(array $coords = null, string $type = null, $id = null){ |
|
| 47 | + public function __construct(array $coords = null, string $type = null, $id = null) { |
|
| 48 | 48 | |
| 49 | - if($coords !== null){ |
|
| 49 | + if ($coords !== null) { |
|
| 50 | 50 | |
| 51 | - if($type === null){ |
|
| 51 | + if ($type === null) { |
|
| 52 | 52 | throw new GeoJSONException('got coords but no feature type'); |
| 53 | 53 | } |
| 54 | 54 | |
| 55 | 55 | $this->setGeometry($coords, $type); |
| 56 | 56 | } |
| 57 | 57 | |
| 58 | - if($id !== null){ |
|
| 58 | + if ($id !== null) { |
|
| 59 | 59 | $this->setID($id); |
| 60 | 60 | } |
| 61 | 61 | |
@@ -66,11 +66,11 @@ discard block |
||
| 66 | 66 | */ |
| 67 | 67 | public function setGeometry(array $coords, string $type):Feature{ |
| 68 | 68 | |
| 69 | - if(empty($coords)){ |
|
| 69 | + if (empty($coords)) { |
|
| 70 | 70 | throw new GeoJSONException('invalid coords array'); |
| 71 | 71 | } |
| 72 | 72 | |
| 73 | - if(!in_array($type, $this::types, true)){ |
|
| 73 | + if (!in_array($type, $this::types, true)) { |
|
| 74 | 74 | throw new GeoJSONException('invalid geometry type'); |
| 75 | 75 | } |
| 76 | 76 | |
@@ -96,7 +96,7 @@ discard block |
||
| 96 | 96 | */ |
| 97 | 97 | public function setID($id):Feature{ |
| 98 | 98 | |
| 99 | - if(!is_string($id) && !is_int($id)){ |
|
| 99 | + if (!is_string($id) && !is_int($id)) { |
|
| 100 | 100 | throw new GeoJSONException('invalid id'); |
| 101 | 101 | } |
| 102 | 102 | |
@@ -110,7 +110,7 @@ discard block |
||
| 110 | 110 | */ |
| 111 | 111 | public function toArray():array{ |
| 112 | 112 | |
| 113 | - if(empty($this->coords) || empty($this->type)){ |
|
| 113 | + if (empty($this->coords) || empty($this->type)) { |
|
| 114 | 114 | throw new GeoJSONException('invalid feature'); |
| 115 | 115 | } |
| 116 | 116 | |
@@ -122,15 +122,15 @@ discard block |
||
| 122 | 122 | ] |
| 123 | 123 | ]; |
| 124 | 124 | |
| 125 | - if(!empty($this->bbox)){ |
|
| 125 | + if (!empty($this->bbox)) { |
|
| 126 | 126 | $arr['bbox'] = $this->bbox; |
| 127 | 127 | } |
| 128 | 128 | |
| 129 | - if(!empty($this->properties)){ |
|
| 129 | + if (!empty($this->properties)) { |
|
| 130 | 130 | $arr['properties'] = $this->properties; |
| 131 | 131 | } |
| 132 | 132 | |
| 133 | - if(!empty($this->id)){ |
|
| 133 | + if (!empty($this->id)) { |
|
| 134 | 134 | $arr['properties']['id'] = $this->id; // leaflet |
| 135 | 135 | # $arr['id'] = $this->id; // GMaps |
| 136 | 136 | } |