Passed
Pull Request — master (#1)
by Mark
04:28
created
conf/metadata.php 1 patch
Indentation   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -22,72 +22,72 @@
 block discarded – undo
22 22
  */
23 23
 
24 24
 $meta['enableOSM']                = array(
25
-    'onoff'
25
+	'onoff'
26 26
 );
27 27
 $meta['enableStamen']             = array(
28
-    'onoff'
28
+	'onoff'
29 29
 );
30 30
 $meta['enableGoogle']             = array(
31
-    'onoff'
31
+	'onoff'
32 32
 );
33 33
 $meta['googleAPIkey']             = array(
34
-    'string'
34
+	'string'
35 35
 );
36 36
 $meta['enableBing']               = array(
37
-    'onoff'
37
+	'onoff'
38 38
 );
39 39
 $meta['bingAPIKey']               = array(
40
-    'string'
40
+	'string'
41 41
 );
42 42
 $meta['tfApiKey']                 = array(
43
-    'string'
43
+	'string'
44 44
 );
45 45
 $meta['iconUrlOverload']          = array(
46
-    'string'
46
+	'string'
47 47
 );
48 48
 $meta['enableA11y']               = array(
49
-    'onoff'
49
+	'onoff'
50 50
 );
51 51
 $meta['optionStaticMapGenerator'] = array(
52
-    'multichoice', '_choices' => array('local', 'remote')
52
+	'multichoice', '_choices' => array('local', 'remote')
53 53
 );
54 54
 $meta['autoZoomMap']              = array(
55
-    'onoff'
55
+	'onoff'
56 56
 );
57 57
 $meta ['displayformat']           = array(
58
-    'multichoice', '_choices' => array('DD', 'DMS')
58
+	'multichoice', '_choices' => array('DD', 'DMS')
59 59
 );
60 60
 
61 61
 $meta ['default_width']         = array(
62
-    'string'
62
+	'string'
63 63
 );
64 64
 $meta ['default_height']        = array(
65
-    'string'
65
+	'string'
66 66
 );
67 67
 $meta ['default_zoom']          = array(
68
-    'string'
68
+	'string'
69 69
 );
70 70
 $meta ['default_autozoom']      = array(
71
-    'onoff'
71
+	'onoff'
72 72
 );
73 73
 $meta ['default_statusbar']     = array(
74
-    'onoff'
74
+	'onoff'
75 75
 );
76 76
 $meta ['default_toolbar']       = array(
77
-    'onoff'
77
+	'onoff'
78 78
 );
79 79
 $meta ['default_controls']      = array(
80
-    'onoff'
80
+	'onoff'
81 81
 );
82 82
 $meta ['default_poihoverstyle'] = array(
83
-    'onoff'
83
+	'onoff'
84 84
 );
85 85
 $meta ['default_kmlfile']       = array(
86
-    'string'
86
+	'string'
87 87
 );
88 88
 $meta ['default_gpxfile']       = array(
89
-    'string'
89
+	'string'
90 90
 );
91 91
 $meta ['default_geojsonfile']   = array(
92
-    'string'
92
+	'string'
93 93
 );
Please login to merge, or discard this patch.
StaticMap.php 3 patches
Indentation   +699 added lines, -699 removed lines patch added patch discarded remove patch
@@ -27,703 +27,703 @@
 block discarded – undo
27 27
  *
28 28
  */
29 29
 class StaticMap {
30
-    // this should probably not be changed
31
-    var $doc = '';
32
-
33
-    // the final output
34
-    protected $tileSize = 256;
35
-    protected $tileInfo = array(
36
-        // OSM sources
37
-        'openstreetmap' => array(
38
-            'txt'  => '(c) OpenStreetMap CC-BY-SA',
39
-            'logo' => 'osm_logo.png',
40
-            'url'  => 'https://tile.openstreetmap.org/{Z}/{X}/{Y}.png'
41
-        ),
42
-        // OCM sources
43
-        'cycle'         => array(
44
-            'txt'  => 'OpenCycleMap tiles',
45
-            'logo' => 'cycle_logo.png',
46
-            'url'  => 'https://tile.thunderforest.com/cycle/{Z}/{X}/{Y}.png?apikey='
47
-        ),
48
-        'transport'     => array(
49
-            'txt'  => 'OpenCycleMap tiles',
50
-            'logo' => 'cycle_logo.png',
51
-            'url'  => 'https://tile.thunderforest.com/transport/{Z}/{X}/{Y}.png?apikey='
52
-        ),
53
-        'landscape'     => array(
54
-            'txt'  => 'OpenCycleMap tiles',
55
-            'logo' => 'cycle_logo.png',
56
-            'url'  => 'https://tile.thunderforest.com/landscape/{Z}/{X}/{Y}.png?apikey='
57
-        ),
58
-        'outdoors'      => array(
59
-            'txt'  => 'OpenCycleMap tiles',
60
-            'logo' => 'cycle_logo.png',
61
-            'url'  => 'https://tile.thunderforest.com/outdoors/{Z}/{X}/{Y}.png?apikey='
62
-        ),
63
-        'toner-lite'    => array(
64
-            'txt'  => 'Stamen tiles',
65
-            'logo' => 'stamen.png',
66
-            'url'  => 'http://tile.stamen.com/toner-lite/{Z}/{X}/{Y}.png'
67
-        ),
68
-        'terrain'       => array(
69
-            'txt'  => 'Stamen tiles',
70
-            'logo' => 'stamen.png',
71
-            'url'  => 'http://tile.stamen.com/terrain/{Z}/{X}/{Y}.png'
72
-        )
73
-        //,
74
-        // 'piste'=>array(
75
-        // 'txt'=>'OpenPisteMap tiles',
76
-        // 'logo'=>'piste_logo.png',
77
-        // 'url'=>''),
78
-        // 'sea'=>array(
79
-        // 'txt'=>'OpenSeaMap tiles',
80
-        // 'logo'=>'sea_logo.png',
81
-        // 'url'=>''),
82
-        // H&B sources
83
-        //			'hikeandbike' => array (
84
-        //					'txt' => 'Hike & Bike Map',
85
-        //					'logo' => 'hnb_logo.png',
86
-        //					//'url' => 'http://toolserver.org/tiles/hikebike/{Z}/{X}/{Y}.png'
87
-        //					//moved to: https://www.toolserver.org/tiles/hikebike/12/2105/1388.png
88
-        //					'url' => 'http://c.tiles.wmflabs.org/hikebike/{Z}/{X}/{Y}.png'
89
-        //			)
90
-    );
91
-    protected $tileDefaultSrc = 'openstreetmap';
92
-
93
-    // set up markers
94
-    protected $markerPrototypes = array(
95
-        // found at http://www.mapito.net/map-marker-icons.html
96
-        // these are 17x19 px with a pointer at the bottom left
97
-        'lightblue' => array(
98
-            'regex'        => '/^lightblue([0-9]+)$/',
99
-            'extension'    => '.png',
100
-            'shadow'       => false,
101
-            'offsetImage'  => '0,-19',
102
-            'offsetShadow' => false
103
-        ),
104
-        // openlayers std markers are 21x25px with shadow
105
-        'ol-marker' => array(
106
-            'regex'        => '/^marker(|-blue|-gold|-green|-red)+$/',
107
-            'extension'    => '.png',
108
-            'shadow'       => 'marker_shadow.png',
109
-            'offsetImage'  => '-10,-25',
110
-            'offsetShadow' => '-1,-13'
111
-        ),
112
-        // these are 16x16 px
113
-        'ww_icon'   => array(
114
-            'regex'        => '/ww_\S+$/',
115
-            'extension'    => '.png',
116
-            'shadow'       => false,
117
-            'offsetImage'  => '-8,-8',
118
-            'offsetShadow' => false
119
-        ),
120
-        // assume these are 16x16 px
121
-        'rest'      => array(
122
-            'regex'        => '/^(?!lightblue([0-9]+)$)(?!(ww_\S+$))(?!marker(|-blue|-gold|-green|-red)+$)(.*)/',
123
-            'extension'    => '.png',
124
-            'shadow'       => 'marker_shadow.png',
125
-            'offsetImage'  => '-8,-8',
126
-            'offsetShadow' => '-1,-1'
127
-        )
128
-    );
129
-    protected $centerX, $centerY, $offsetX, $offsetY, $image;
130
-    protected $zoom, $lat, $lon, $width, $height, $markers, $maptype, $kmlFileName, $gpxFileName, $geojsonFileName,
131
-        $autoZoomExtent, $apikey;
132
-    protected $tileCacheBaseDir, $mapCacheBaseDir, $mediaBaseDir;
133
-    protected $useTileCache = true;
134
-    protected $mapCacheID = '';
135
-    protected $mapCacheFile = '';
136
-    protected $mapCacheExtension = 'png';
137
-
138
-    /**
139
-     * Constructor.
140
-     *
141
-     * @param float   $lat
142
-     *            Latitude (x) of center of map
143
-     * @param float   $lon
144
-     *            Longitude (y) of center of map
145
-     * @param int     $zoom
146
-     *            Zoomlevel
147
-     * @param int     $width
148
-     *            Width in pixels
149
-     * @param int     $height
150
-     *            Height in pixels
151
-     * @param string  $maptype
152
-     *            Name of the map
153
-     * @param mixed   $markers
154
-     *            array of markers
155
-     * @param string  $gpx
156
-     *            GPX filename
157
-     * @param string  $kml
158
-     *            KML filename
159
-     * @param string  $mediaDir
160
-     *            Directory to store/cache maps
161
-     * @param string  $tileCacheBaseDir
162
-     *            Directory to cache map tiles
163
-     * @param boolean $autoZoomExtent
164
-     *            Wheter or not to override zoom/lat/lon and zoom to the extent of gpx/kml and markers
165
-     * @param apikey
166
-     *            Some service require a key to access
167
-     */
168
-    public function __construct($lat, $lon, $zoom, $width, $height, $maptype, $markers, $gpx, $kml, $geojson,
169
-                                $mediaDir, $tileCacheBaseDir, $autoZoomExtent = true, $apikey = '') {
170
-        $this->zoom   = $zoom;
171
-        $this->lat    = $lat;
172
-        $this->lon    = $lon;
173
-        $this->width  = $width;
174
-        $this->height = $height;
175
-        // validate + set maptype
176
-        $this->maptype = $this->tileDefaultSrc;
177
-        if(array_key_exists($maptype, $this->tileInfo)) {
178
-            $this->maptype = $maptype;
179
-        }
180
-        $this->markers          = $markers;
181
-        $this->kmlFileName      = $kml;
182
-        $this->gpxFileName      = $gpx;
183
-        $this->geojsonFileName  = $geojson;
184
-        $this->mediaBaseDir     = $mediaDir;
185
-        $this->tileCacheBaseDir = $tileCacheBaseDir . '/olmaptiles';
186
-        $this->useTileCache     = $this->tileCacheBaseDir !== '';
187
-        $this->mapCacheBaseDir  = $mediaDir . '/olmapmaps';
188
-        $this->autoZoomExtent   = $autoZoomExtent;
189
-        $this->apikey           = $apikey;
190
-    }
191
-
192
-    /**
193
-     * get the map, this may return a reference to a cached copy.
194
-     *
195
-     * @return string url relative to media dir
196
-     */
197
-    public function getMap() {
198
-        try {
199
-            if($this->autoZoomExtent) {
200
-                $this->autoZoom();
201
-            }
202
-        } catch(Exception $e) {
203
-            dbglog($e);
204
-        }
205
-
206
-        // use map cache, so check cache for map
207
-        if(!$this->checkMapCache()) {
208
-            // map is not in cache, needs to be build
209
-            $this->makeMap();
210
-            $this->mkdir_recursive(dirname($this->mapCacheIDToFilename()), 0777);
211
-            imagepng($this->image, $this->mapCacheIDToFilename(), 9);
212
-        }
213
-        $this->doc = $this->mapCacheIDToFilename();
214
-        // make url relative to media dir
215
-        return str_replace($this->mediaBaseDir, '', $this->doc);
216
-    }
217
-
218
-    /**
219
-     * Calculate the lat/lon/zoom values to make sure that all of the markers and gpx/kml are on the map.
220
-     * can throw an error like
221
-     * "Fatal error: Uncaught Exception: Cannot create a collection with non-geometries in
222
-     * D:\www\wild-water.nl\www\dokuwiki\lib\plugins\geophp\geoPHP\lib\geometry\Collection.class.php:29"
223
-     *
224
-     * @param float $paddingFactor
225
-     *            buffer constant to enlarge (>1.0) the zoom level
226
-     */
227
-    private function autoZoom($paddingFactor = 1.0) {
228
-        $geoms    = array();
229
-        $geoms [] = new Point ($this->lon, $this->lat);
230
-        if(!empty ($this->markers)) {
231
-            foreach($this->markers as $marker) {
232
-                $geoms [] = new Point ($marker ['lon'], $marker ['lat']);
233
-            }
234
-        }
235
-        $g = false;
236
-        if(file_exists($this->kmlFileName)) {
237
-            $g = geoPHP::load(file_get_contents($this->kmlFileName), 'kml');
238
-            if($g !== false) {
239
-                $geoms [] = $g;
240
-            }
241
-        }
242
-        if(file_exists($this->gpxFileName)) {
243
-            $g = geoPHP::load(file_get_contents($this->gpxFileName), 'gpx');
244
-            if($g !== false) {
245
-                $geoms [] = $g;
246
-            }
247
-        }
248
-        if(file_exists($this->geojsonFileName)) {
249
-            $g = geoPHP::load(file_get_contents($this->geojsonFileName), 'geojson');
250
-            if($g !== false) {
251
-                $geoms [] = $g;
252
-            }
253
-        }
254
-
255
-        if(count($geoms) <= 1) {
256
-            dbglog($geoms, "StaticMap::autoZoom: Skip setting autozoom options");
257
-            return;
258
-        }
259
-
260
-        $geom     = new GeometryCollection ($geoms);
261
-        $centroid = $geom->centroid();
262
-        $bbox     = $geom->getBBox();
263
-
264
-        // determine vertical resolution, this depends on the distance from the equator
265
-        // $vy00 = log(tan(M_PI*(0.25 + $centroid->getY()/360)));
266
-        $vy0 = log(tan(M_PI * (0.25 + $bbox ['miny'] / 360)));
267
-        $vy1 = log(tan(M_PI * (0.25 + $bbox ['maxy'] / 360)));
268
-        dbglog("StaticMap::autoZoom: vertical resolution: $vy0, $vy1");
269
-        $zoomFactorPowered  = ($this->height / 2) / (40.7436654315252 * ($vy1 - $vy0));
270
-        $resolutionVertical = 360 / ($zoomFactorPowered * $this->tileSize);
271
-        // determine horizontal resolution
272
-        $resolutionHorizontal = ($bbox ['maxx'] - $bbox ['minx']) / $this->width;
273
-        $resolution           = max($resolutionHorizontal, $resolutionVertical) * $paddingFactor;
274
-        $zoom                 = log(360 / ($resolution * $this->tileSize), 2);
275
-
276
-        if(is_finite($zoom) && $zoom < 15 && $zoom > 2) {
277
-            $this->zoom = floor($zoom);
278
-        }
279
-        $this->lon = $centroid->getX();
280
-        $this->lat = $centroid->getY();
281
-        dbglog("StaticMap::autoZoom: Set autozoom options to: z: $this->zoom, lon: $this->lon, lat: $this->lat");
282
-    }
283
-
284
-    public function checkMapCache() {
285
-        $this->mapCacheID = md5($this->serializeParams());
286
-        $filename         = $this->mapCacheIDToFilename();
287
-        if(file_exists($filename))
288
-            return true;
289
-    }
290
-
291
-    public function serializeParams() {
292
-        return join(
293
-            "&", array(
294
-                   $this->zoom,
295
-                   $this->lat,
296
-                   $this->lon,
297
-                   $this->width,
298
-                   $this->height,
299
-                   serialize($this->markers),
300
-                   $this->maptype,
301
-                   $this->kmlFileName,
302
-                   $this->gpxFileName,
303
-                   $this->geojsonFileName
304
-               )
305
-        );
306
-    }
307
-
308
-    public function mapCacheIDToFilename() {
309
-        if(!$this->mapCacheFile) {
310
-            $this->mapCacheFile = $this->mapCacheBaseDir . "/" . $this->maptype . "/" . $this->zoom . "/cache_"
311
-                . substr($this->mapCacheID, 0, 2) . "/" . substr($this->mapCacheID, 2, 2)
312
-                . "/" . substr($this->mapCacheID, 4);
313
-        }
314
-        return $this->mapCacheFile . "." . $this->mapCacheExtension;
315
-    }
316
-
317
-    /**
318
-     * make the map.
319
-     */
320
-    public function makeMap() {
321
-        $this->initCoords();
322
-        $this->createBaseMap();
323
-        if(!empty ($this->markers))
324
-            $this->placeMarkers();
325
-        if(file_exists($this->kmlFileName))
326
-            $this->drawKML();
327
-        if(file_exists($this->gpxFileName))
328
-            $this->drawGPX();
329
-        if(file_exists($this->geojsonFileName))
330
-            $this->drawGeojson();
331
-
332
-        $this->drawCopyright();
333
-    }
334
-
335
-    /**
336
-     */
337
-    public function initCoords() {
338
-        $this->centerX = $this->lonToTile($this->lon, $this->zoom);
339
-        $this->centerY = $this->latToTile($this->lat, $this->zoom);
340
-        $this->offsetX = floor((floor($this->centerX) - $this->centerX) * $this->tileSize);
341
-        $this->offsetY = floor((floor($this->centerY) - $this->centerY) * $this->tileSize);
342
-    }
343
-
344
-    /**
345
-     *
346
-     * @param number $long
347
-     * @param number $zoom
348
-     * @return number
349
-     */
350
-    public function lonToTile($long, $zoom) {
351
-        return (($long + 180) / 360) * pow(2, $zoom);
352
-    }
353
-
354
-    /**
355
-     *
356
-     * @param number $lat
357
-     * @param number $zoom
358
-     * @return float|int
359
-     */
360
-    public function latToTile($lat, $zoom) {
361
-        return (1 - log(tan($lat * pi() / 180) + 1 / cos($lat * M_PI / 180)) / M_PI) / 2 * pow(2, $zoom);
362
-    }
363
-
364
-    /**
365
-     * make basemap image.
366
-     */
367
-    public function createBaseMap() {
368
-        $this->image   = imagecreatetruecolor($this->width, $this->height);
369
-        $startX        = floor($this->centerX - ($this->width / $this->tileSize) / 2);
370
-        $startY        = floor($this->centerY - ($this->height / $this->tileSize) / 2);
371
-        $endX          = ceil($this->centerX + ($this->width / $this->tileSize) / 2);
372
-        $endY          = ceil($this->centerY + ($this->height / $this->tileSize) / 2);
373
-        $this->offsetX = -floor(($this->centerX - floor($this->centerX)) * $this->tileSize);
374
-        $this->offsetY = -floor(($this->centerY - floor($this->centerY)) * $this->tileSize);
375
-        $this->offsetX += floor($this->width / 2);
376
-        $this->offsetY += floor($this->height / 2);
377
-        $this->offsetX += floor($startX - floor($this->centerX)) * $this->tileSize;
378
-        $this->offsetY += floor($startY - floor($this->centerY)) * $this->tileSize;
379
-
380
-        for($x = $startX; $x <= $endX; $x++) {
381
-            for($y = $startY; $y <= $endY; $y++) {
382
-                $url = str_replace(
383
-                    array(
384
-                        '{Z}',
385
-                        '{X}',
386
-                        '{Y}'
387
-                    ), array(
388
-                        $this->zoom,
389
-                        $x,
390
-                        $y
391
-                    ), $this->tileInfo [$this->maptype] ['url']
392
-                );
393
-                $url .= $this->apikey;
394
-
395
-                $tileData = $this->fetchTile($url);
396
-                if($tileData) {
397
-                    $tileImage = imagecreatefromstring($tileData);
398
-                } else {
399
-                    $tileImage = imagecreate($this->tileSize, $this->tileSize);
400
-                    $color     = imagecolorallocate($tileImage, 255, 255, 255);
401
-                    @imagestring($tileImage, 1, 127, 127, 'err', $color);
402
-                }
403
-                $destX = ($x - $startX) * $this->tileSize + $this->offsetX;
404
-                $destY = ($y - $startY) * $this->tileSize + $this->offsetY;
405
-                dbglog($this->tileSize, "imagecopy tile into image: $destX, $destY");
406
-                imagecopy(
407
-                    $this->image, $tileImage, $destX, $destY, 0, 0, $this->tileSize,
408
-                    $this->tileSize
409
-                );
410
-            }
411
-        }
412
-    }
413
-
414
-    /**
415
-     * Fetch a tile and (if configured) store it in the cache.
416
-     *
417
-     * @param string $url
418
-     */
419
-    public function fetchTile($url) {
420
-        if($this->useTileCache && ($cached = $this->checkTileCache($url)))
421
-            return $cached;
422
-
423
-        $_UA = 'Mozilla/4.0 (compatible; DokuWikiSpatial HTTP Client; ' . PHP_OS . ')';
424
-        if(function_exists("curl_init")) {
425
-            // use cUrl
426
-            $ch = curl_init();
427
-            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
428
-            curl_setopt($ch, CURLOPT_USERAGENT, $_UA);
429
-            curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10);
430
-            curl_setopt($ch, CURLOPT_URL, $url);
431
-            $tile = curl_exec($ch);
432
-            curl_close($ch);
433
-        } else {
434
-            // use file_get_contents
435
-            global $conf;
436
-            $opts    = array(
437
-                'http' => array(
438
-                    'method'          => "GET",
439
-                    'header'          => "Accept-language: en\r\n" . "User-Agent: $_UA\r\n" . "accept: image/png\r\n",
440
-                    'proxy'           => "tcp://" . $conf ['proxy'] ['host'] . ":" . $conf ['proxy'] ['port'],
441
-                    'request_fulluri' => true
442
-                )
443
-            );
444
-            $context = stream_context_create($opts);
445
-            $tile    = file_get_contents($url, false, $context);
446
-        }
447
-        if($tile && $this->useTileCache) {
448
-            $this->writeTileToCache($url, $tile);
449
-        }
450
-        return $tile;
451
-    }
452
-
453
-    /**
454
-     *
455
-     * @param string $url
456
-     */
457
-    public function checkTileCache($url) {
458
-        $filename = $this->tileUrlToFilename($url);
459
-        if(file_exists($filename)) {
460
-            return file_get_contents($filename);
461
-        }
462
-    }
463
-
464
-    /**
465
-     *
466
-     * @param string $url
467
-     * @return string
468
-     */
469
-    public function tileUrlToFilename($url) {
470
-        return $this->tileCacheBaseDir . "/" . str_replace(
471
-                array(
472
-                    'http://'
473
-                ), '', $url
474
-            );
475
-    }
476
-
477
-    /**
478
-     * Write a tile into the cache.
479
-     *
480
-     * @param string $url
481
-     * @param mixed  $data
482
-     */
483
-    public function writeTileToCache($url, $data) {
484
-        $filename = $this->tileUrlToFilename($url);
485
-        $this->mkdir_recursive(dirname($filename), 0777);
486
-        file_put_contents($filename, $data);
487
-    }
488
-
489
-    /**
490
-     * Recursively create the directory.
491
-     *
492
-     * @param string $pathname
493
-     *            The directory path.
494
-     * @param int    $mode
495
-     *            File access mode. For more information on modes, read the details on the chmod manpage.
496
-     */
497
-    public function mkdir_recursive($pathname, $mode) {
498
-        is_dir(dirname($pathname)) || $this->mkdir_recursive(dirname($pathname), $mode);
499
-        return is_dir($pathname) || @mkdir($pathname, $mode);
500
-    }
501
-
502
-    /**
503
-     * Place markers on the map and number them in the same order as they are listed in the html.
504
-     */
505
-    public function placeMarkers() {
506
-        $count         = 0;
507
-        $color         = imagecolorallocate($this->image, 0, 0, 0);
508
-        $bgcolor       = imagecolorallocate($this->image, 200, 200, 200);
509
-        $markerBaseDir = dirname(__FILE__) . '/icons';
510
-        // loop thru marker array
511
-        foreach($this->markers as $marker) {
512
-            // set some local variables
513
-            $markerLat  = $marker ['lat'];
514
-            $markerLon  = $marker ['lon'];
515
-            $markerType = $marker ['type'];
516
-            // clear variables from previous loops
517
-            $markerFilename = '';
518
-            $markerShadow   = '';
519
-            $matches        = false;
520
-            // check for marker type, get settings from markerPrototypes
521
-            if($markerType) {
522
-                foreach($this->markerPrototypes as $markerPrototype) {
523
-                    if(preg_match($markerPrototype ['regex'], $markerType, $matches)) {
524
-                        $markerFilename = $matches [0] . $markerPrototype ['extension'];
525
-                        if($markerPrototype ['offsetImage']) {
526
-                            list ($markerImageOffsetX, $markerImageOffsetY) = explode(
527
-                                ",",
528
-                                $markerPrototype ['offsetImage']
529
-                            );
530
-                        }
531
-                        $markerShadow = $markerPrototype ['shadow'];
532
-                        if($markerShadow) {
533
-                            list ($markerShadowOffsetX, $markerShadowOffsetY) = explode(
534
-                                ",",
535
-                                $markerPrototype ['offsetShadow']
536
-                            );
537
-                        }
538
-                    }
539
-                }
540
-            }
541
-            // create img resource
542
-            if(file_exists($markerBaseDir . '/' . $markerFilename)) {
543
-                $markerImg = imagecreatefrompng($markerBaseDir . '/' . $markerFilename);
544
-            } else {
545
-                $markerImg = imagecreatefrompng($markerBaseDir . '/marker.png');
546
-            }
547
-            // check for shadow + create shadow recource
548
-            if($markerShadow && file_exists($markerBaseDir . '/' . $markerShadow)) {
549
-                $markerShadowImg = imagecreatefrompng($markerBaseDir . '/' . $markerShadow);
550
-            }
551
-            // calc position
552
-            $destX = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($markerLon, $this->zoom)));
553
-            $destY = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($markerLat, $this->zoom)));
554
-            // copy shadow on basemap
555
-            if($markerShadow && $markerShadowImg) {
556
-                imagecopy($this->image, $markerShadowImg, $destX + intval($markerShadowOffsetX), $destY + intval($markerShadowOffsetY), 0, 0, imagesx($markerShadowImg), imagesy($markerShadowImg));
557
-            }
558
-            // copy marker on basemap above shadow
559
-            imagecopy($this->image, $markerImg, $destX + intval($markerImageOffsetX), $destY + intval($markerImageOffsetY), 0, 0, imagesx($markerImg), imagesy($markerImg));
560
-            // add label
561
-            imagestring($this->image, 3, $destX - imagesx($markerImg) + 1, $destY + intval($markerImageOffsetY) + 1, ++$count, $bgcolor);
562
-            imagestring($this->image, 3, $destX - imagesx($markerImg), $destY + intval($markerImageOffsetY), $count, $color);
563
-        }
564
-    }
565
-
566
-    /**
567
-     * Draw kml trace on the map.
568
-     */
569
-    public function drawKML() {
570
-        // TODO get colour from kml node (not currently supported in geoPHP)
571
-        $col     = imagecolorallocatealpha($this->image, 255, 0, 0, .4 * 127);
572
-        $kmlgeom = geoPHP::load(file_get_contents($this->kmlFileName), 'kml');
573
-        $this->drawGeometry($kmlgeom, $col);
574
-    }
575
-
576
-    /**
577
-     * Draw geometry or geometry collection on the map.
578
-     *
579
-     * @param Geometry $geom
580
-     * @param int      $colour
581
-     *            drawing colour
582
-     */
583
-    private function drawGeometry($geom, $colour) {
584
-        if(empty($geom)) return;
585
-
586
-        switch($geom->geometryType()) {
587
-            case 'GeometryCollection' :
588
-                // recursively draw part of the collection
589
-                for($i = 1; $i < $geom->numGeometries() + 1; $i++) {
590
-                    $_geom = $geom->geometryN($i);
591
-                    $this->drawGeometry($_geom, $colour);
592
-                }
593
-                break;
594
-            case 'MultiPolygon' :
595
-            case 'MultiLineString' :
596
-            case 'MultiPoint' :
597
-                // TODO implement / do nothing
598
-                break;
599
-            case 'Polygon' :
600
-                $this->drawPolygon($geom, $colour);
601
-                break;
602
-            case 'LineString' :
603
-                $this->drawLineString($geom, $colour);
604
-                break;
605
-            case 'Point' :
606
-                $this->drawPoint($geom, $colour);
607
-                break;
608
-            default :
609
-                // draw nothing
610
-                break;
611
-        }
612
-    }
613
-
614
-    /**
615
-     * Draw a polygon on the map.
616
-     *
617
-     * @param Polygon $polygon
618
-     * @param int     $colour
619
-     *            drawing colour
620
-     */
621
-    private function drawPolygon($polygon, $colour) {
622
-        // TODO implementation of drawing holes,
623
-        // maybe draw the polygon to an in-memory image and use imagecopy, draw polygon in col., draw holes in bgcol?
624
-
625
-        // print_r('Polygon:<br />');
626
-        // print_r($polygon);
627
-        $extPoints = array();
628
-        // extring is a linestring actually..
629
-        $extRing = $polygon->exteriorRing();
630
-
631
-        for($i = 1; $i < $extRing->numGeometries(); $i++) {
632
-            $p1           = $extRing->geometryN($i);
633
-            $x            = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p1->x(), $this->zoom)));
634
-            $y            = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p1->y(), $this->zoom)));
635
-            $extPoints [] = $x;
636
-            $extPoints [] = $y;
637
-        }
638
-        // print_r('points:('.($i-1).')<br />');
639
-        // print_r($extPoints);
640
-        // imagepolygon ($this->image, $extPoints, $i-1, $colour );
641
-        imagefilledpolygon($this->image, $extPoints, $i - 1, $colour);
642
-    }
643
-
644
-    /**
645
-     * Draw a line on the map.
646
-     *
647
-     * @param LineString $line
648
-     * @param int        $colour
649
-     *            drawing colour
650
-     */
651
-    private function drawLineString($line, $colour) {
652
-        imagesetthickness($this->image, 2);
653
-        for($p = 1; $p < $line->numGeometries(); $p++) {
654
-            // get first pair of points
655
-            $p1 = $line->geometryN($p);
656
-            $p2 = $line->geometryN($p + 1);
657
-            // translate to paper space
658
-            $x1 = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p1->x(), $this->zoom)));
659
-            $y1 = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p1->y(), $this->zoom)));
660
-            $x2 = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p2->x(), $this->zoom)));
661
-            $y2 = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p2->y(), $this->zoom)));
662
-            // draw to image
663
-            imageline($this->image, $x1, $y1, $x2, $y2, $colour);
664
-        }
665
-        imagesetthickness($this->image, 1);
666
-    }
667
-
668
-    /**
669
-     * Draw a point on the map.
670
-     *
671
-     * @param Point $point
672
-     * @param int   $colour
673
-     *            drawing colour
674
-     */
675
-    private function drawPoint($point, $colour) {
676
-        imagesetthickness($this->image, 2);
677
-        // translate to paper space
678
-        $cx = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($point->x(), $this->zoom)));
679
-        $cy = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($point->y(), $this->zoom)));
680
-        $r  = 5;
681
-        // draw to image
682
-        // imageellipse($this->image, $cx, $cy,$r, $r, $colour);
683
-        imagefilledellipse($this->image, $cx, $cy, $r, $r, $colour);
684
-        // don't use imageellipse because the imagesetthickness function has
685
-        // no effect. So the better workaround is to use imagearc.
686
-        imagearc($this->image, $cx, $cy, $r, $r, 0, 359, $colour);
687
-        imagesetthickness($this->image, 1);
688
-    }
689
-
690
-    /**
691
-     * Draw gpx trace on the map.
692
-     */
693
-    public function drawGPX() {
694
-        $col     = imagecolorallocatealpha($this->image, 0, 0, 255, .4 * 127);
695
-        $gpxgeom = geoPHP::load(file_get_contents($this->gpxFileName), 'gpx');
696
-        $this->drawGeometry($gpxgeom, $col);
697
-    }
698
-
699
-    /**
700
-     * Draw geojson on the map.
701
-     */
702
-    public function drawGeojson() {
703
-        $col     = imagecolorallocatealpha($this->image, 255, 0, 255, .4 * 127);
704
-        $gpxgeom = geoPHP::load(file_get_contents($this->geojsonFileName), 'json');
705
-        $this->drawGeometry($gpxgeom, $col);
706
-    }
707
-
708
-    /**
709
-     * add copyright and origin notice and icons to the map.
710
-     */
711
-    public function drawCopyright() {
712
-        $logoBaseDir = dirname(__FILE__) . '/' . 'logo/';
713
-        $logoImg     = imagecreatefrompng($logoBaseDir . $this->tileInfo ['openstreetmap'] ['logo']);
714
-        $textcolor   = imagecolorallocate($this->image, 0, 0, 0);
715
-        $bgcolor     = imagecolorallocate($this->image, 200, 200, 200);
716
-
717
-        imagecopy($this->image, $logoImg, 0, imagesy($this->image) - imagesy($logoImg), 0, 0, imagesx($logoImg), imagesy($logoImg));
718
-        imagestring($this->image, 1, imagesx($logoImg) + 2, imagesy($this->image) - imagesy($logoImg) + 1, $this->tileInfo ['openstreetmap'] ['txt'], $bgcolor);
719
-        imagestring($this->image, 1, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($logoImg), $this->tileInfo ['openstreetmap'] ['txt'], $textcolor);
720
-
721
-        // additional tile source info, ie. who created/hosted the tiles
722
-        if($this->maptype != 'openstreetmap') {
723
-            $iconImg = imagecreatefrompng($logoBaseDir . $this->tileInfo [$this->maptype] ['logo']);
724
-            imagecopy($this->image, $iconImg, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($iconImg), 0, 0, imagesx($iconImg), imagesy($iconImg));
725
-            imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 4, imagesy($this->image) - ceil(imagesy($logoImg) / 2) + 1, $this->tileInfo [$this->maptype] ['txt'], $bgcolor);
726
-            imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 3, imagesy($this->image) - ceil(imagesy($logoImg) / 2), $this->tileInfo [$this->maptype] ['txt'], $textcolor);
727
-        }
728
-    }
30
+	// this should probably not be changed
31
+	var $doc = '';
32
+
33
+	// the final output
34
+	protected $tileSize = 256;
35
+	protected $tileInfo = array(
36
+		// OSM sources
37
+		'openstreetmap' => array(
38
+			'txt'  => '(c) OpenStreetMap CC-BY-SA',
39
+			'logo' => 'osm_logo.png',
40
+			'url'  => 'https://tile.openstreetmap.org/{Z}/{X}/{Y}.png'
41
+		),
42
+		// OCM sources
43
+		'cycle'         => array(
44
+			'txt'  => 'OpenCycleMap tiles',
45
+			'logo' => 'cycle_logo.png',
46
+			'url'  => 'https://tile.thunderforest.com/cycle/{Z}/{X}/{Y}.png?apikey='
47
+		),
48
+		'transport'     => array(
49
+			'txt'  => 'OpenCycleMap tiles',
50
+			'logo' => 'cycle_logo.png',
51
+			'url'  => 'https://tile.thunderforest.com/transport/{Z}/{X}/{Y}.png?apikey='
52
+		),
53
+		'landscape'     => array(
54
+			'txt'  => 'OpenCycleMap tiles',
55
+			'logo' => 'cycle_logo.png',
56
+			'url'  => 'https://tile.thunderforest.com/landscape/{Z}/{X}/{Y}.png?apikey='
57
+		),
58
+		'outdoors'      => array(
59
+			'txt'  => 'OpenCycleMap tiles',
60
+			'logo' => 'cycle_logo.png',
61
+			'url'  => 'https://tile.thunderforest.com/outdoors/{Z}/{X}/{Y}.png?apikey='
62
+		),
63
+		'toner-lite'    => array(
64
+			'txt'  => 'Stamen tiles',
65
+			'logo' => 'stamen.png',
66
+			'url'  => 'http://tile.stamen.com/toner-lite/{Z}/{X}/{Y}.png'
67
+		),
68
+		'terrain'       => array(
69
+			'txt'  => 'Stamen tiles',
70
+			'logo' => 'stamen.png',
71
+			'url'  => 'http://tile.stamen.com/terrain/{Z}/{X}/{Y}.png'
72
+		)
73
+		//,
74
+		// 'piste'=>array(
75
+		// 'txt'=>'OpenPisteMap tiles',
76
+		// 'logo'=>'piste_logo.png',
77
+		// 'url'=>''),
78
+		// 'sea'=>array(
79
+		// 'txt'=>'OpenSeaMap tiles',
80
+		// 'logo'=>'sea_logo.png',
81
+		// 'url'=>''),
82
+		// H&B sources
83
+		//			'hikeandbike' => array (
84
+		//					'txt' => 'Hike & Bike Map',
85
+		//					'logo' => 'hnb_logo.png',
86
+		//					//'url' => 'http://toolserver.org/tiles/hikebike/{Z}/{X}/{Y}.png'
87
+		//					//moved to: https://www.toolserver.org/tiles/hikebike/12/2105/1388.png
88
+		//					'url' => 'http://c.tiles.wmflabs.org/hikebike/{Z}/{X}/{Y}.png'
89
+		//			)
90
+	);
91
+	protected $tileDefaultSrc = 'openstreetmap';
92
+
93
+	// set up markers
94
+	protected $markerPrototypes = array(
95
+		// found at http://www.mapito.net/map-marker-icons.html
96
+		// these are 17x19 px with a pointer at the bottom left
97
+		'lightblue' => array(
98
+			'regex'        => '/^lightblue([0-9]+)$/',
99
+			'extension'    => '.png',
100
+			'shadow'       => false,
101
+			'offsetImage'  => '0,-19',
102
+			'offsetShadow' => false
103
+		),
104
+		// openlayers std markers are 21x25px with shadow
105
+		'ol-marker' => array(
106
+			'regex'        => '/^marker(|-blue|-gold|-green|-red)+$/',
107
+			'extension'    => '.png',
108
+			'shadow'       => 'marker_shadow.png',
109
+			'offsetImage'  => '-10,-25',
110
+			'offsetShadow' => '-1,-13'
111
+		),
112
+		// these are 16x16 px
113
+		'ww_icon'   => array(
114
+			'regex'        => '/ww_\S+$/',
115
+			'extension'    => '.png',
116
+			'shadow'       => false,
117
+			'offsetImage'  => '-8,-8',
118
+			'offsetShadow' => false
119
+		),
120
+		// assume these are 16x16 px
121
+		'rest'      => array(
122
+			'regex'        => '/^(?!lightblue([0-9]+)$)(?!(ww_\S+$))(?!marker(|-blue|-gold|-green|-red)+$)(.*)/',
123
+			'extension'    => '.png',
124
+			'shadow'       => 'marker_shadow.png',
125
+			'offsetImage'  => '-8,-8',
126
+			'offsetShadow' => '-1,-1'
127
+		)
128
+	);
129
+	protected $centerX, $centerY, $offsetX, $offsetY, $image;
130
+	protected $zoom, $lat, $lon, $width, $height, $markers, $maptype, $kmlFileName, $gpxFileName, $geojsonFileName,
131
+		$autoZoomExtent, $apikey;
132
+	protected $tileCacheBaseDir, $mapCacheBaseDir, $mediaBaseDir;
133
+	protected $useTileCache = true;
134
+	protected $mapCacheID = '';
135
+	protected $mapCacheFile = '';
136
+	protected $mapCacheExtension = 'png';
137
+
138
+	/**
139
+	 * Constructor.
140
+	 *
141
+	 * @param float   $lat
142
+	 *            Latitude (x) of center of map
143
+	 * @param float   $lon
144
+	 *            Longitude (y) of center of map
145
+	 * @param int     $zoom
146
+	 *            Zoomlevel
147
+	 * @param int     $width
148
+	 *            Width in pixels
149
+	 * @param int     $height
150
+	 *            Height in pixels
151
+	 * @param string  $maptype
152
+	 *            Name of the map
153
+	 * @param mixed   $markers
154
+	 *            array of markers
155
+	 * @param string  $gpx
156
+	 *            GPX filename
157
+	 * @param string  $kml
158
+	 *            KML filename
159
+	 * @param string  $mediaDir
160
+	 *            Directory to store/cache maps
161
+	 * @param string  $tileCacheBaseDir
162
+	 *            Directory to cache map tiles
163
+	 * @param boolean $autoZoomExtent
164
+	 *            Wheter or not to override zoom/lat/lon and zoom to the extent of gpx/kml and markers
165
+	 * @param apikey
166
+	 *            Some service require a key to access
167
+	 */
168
+	public function __construct($lat, $lon, $zoom, $width, $height, $maptype, $markers, $gpx, $kml, $geojson,
169
+								$mediaDir, $tileCacheBaseDir, $autoZoomExtent = true, $apikey = '') {
170
+		$this->zoom   = $zoom;
171
+		$this->lat    = $lat;
172
+		$this->lon    = $lon;
173
+		$this->width  = $width;
174
+		$this->height = $height;
175
+		// validate + set maptype
176
+		$this->maptype = $this->tileDefaultSrc;
177
+		if(array_key_exists($maptype, $this->tileInfo)) {
178
+			$this->maptype = $maptype;
179
+		}
180
+		$this->markers          = $markers;
181
+		$this->kmlFileName      = $kml;
182
+		$this->gpxFileName      = $gpx;
183
+		$this->geojsonFileName  = $geojson;
184
+		$this->mediaBaseDir     = $mediaDir;
185
+		$this->tileCacheBaseDir = $tileCacheBaseDir . '/olmaptiles';
186
+		$this->useTileCache     = $this->tileCacheBaseDir !== '';
187
+		$this->mapCacheBaseDir  = $mediaDir . '/olmapmaps';
188
+		$this->autoZoomExtent   = $autoZoomExtent;
189
+		$this->apikey           = $apikey;
190
+	}
191
+
192
+	/**
193
+	 * get the map, this may return a reference to a cached copy.
194
+	 *
195
+	 * @return string url relative to media dir
196
+	 */
197
+	public function getMap() {
198
+		try {
199
+			if($this->autoZoomExtent) {
200
+				$this->autoZoom();
201
+			}
202
+		} catch(Exception $e) {
203
+			dbglog($e);
204
+		}
205
+
206
+		// use map cache, so check cache for map
207
+		if(!$this->checkMapCache()) {
208
+			// map is not in cache, needs to be build
209
+			$this->makeMap();
210
+			$this->mkdir_recursive(dirname($this->mapCacheIDToFilename()), 0777);
211
+			imagepng($this->image, $this->mapCacheIDToFilename(), 9);
212
+		}
213
+		$this->doc = $this->mapCacheIDToFilename();
214
+		// make url relative to media dir
215
+		return str_replace($this->mediaBaseDir, '', $this->doc);
216
+	}
217
+
218
+	/**
219
+	 * Calculate the lat/lon/zoom values to make sure that all of the markers and gpx/kml are on the map.
220
+	 * can throw an error like
221
+	 * "Fatal error: Uncaught Exception: Cannot create a collection with non-geometries in
222
+	 * D:\www\wild-water.nl\www\dokuwiki\lib\plugins\geophp\geoPHP\lib\geometry\Collection.class.php:29"
223
+	 *
224
+	 * @param float $paddingFactor
225
+	 *            buffer constant to enlarge (>1.0) the zoom level
226
+	 */
227
+	private function autoZoom($paddingFactor = 1.0) {
228
+		$geoms    = array();
229
+		$geoms [] = new Point ($this->lon, $this->lat);
230
+		if(!empty ($this->markers)) {
231
+			foreach($this->markers as $marker) {
232
+				$geoms [] = new Point ($marker ['lon'], $marker ['lat']);
233
+			}
234
+		}
235
+		$g = false;
236
+		if(file_exists($this->kmlFileName)) {
237
+			$g = geoPHP::load(file_get_contents($this->kmlFileName), 'kml');
238
+			if($g !== false) {
239
+				$geoms [] = $g;
240
+			}
241
+		}
242
+		if(file_exists($this->gpxFileName)) {
243
+			$g = geoPHP::load(file_get_contents($this->gpxFileName), 'gpx');
244
+			if($g !== false) {
245
+				$geoms [] = $g;
246
+			}
247
+		}
248
+		if(file_exists($this->geojsonFileName)) {
249
+			$g = geoPHP::load(file_get_contents($this->geojsonFileName), 'geojson');
250
+			if($g !== false) {
251
+				$geoms [] = $g;
252
+			}
253
+		}
254
+
255
+		if(count($geoms) <= 1) {
256
+			dbglog($geoms, "StaticMap::autoZoom: Skip setting autozoom options");
257
+			return;
258
+		}
259
+
260
+		$geom     = new GeometryCollection ($geoms);
261
+		$centroid = $geom->centroid();
262
+		$bbox     = $geom->getBBox();
263
+
264
+		// determine vertical resolution, this depends on the distance from the equator
265
+		// $vy00 = log(tan(M_PI*(0.25 + $centroid->getY()/360)));
266
+		$vy0 = log(tan(M_PI * (0.25 + $bbox ['miny'] / 360)));
267
+		$vy1 = log(tan(M_PI * (0.25 + $bbox ['maxy'] / 360)));
268
+		dbglog("StaticMap::autoZoom: vertical resolution: $vy0, $vy1");
269
+		$zoomFactorPowered  = ($this->height / 2) / (40.7436654315252 * ($vy1 - $vy0));
270
+		$resolutionVertical = 360 / ($zoomFactorPowered * $this->tileSize);
271
+		// determine horizontal resolution
272
+		$resolutionHorizontal = ($bbox ['maxx'] - $bbox ['minx']) / $this->width;
273
+		$resolution           = max($resolutionHorizontal, $resolutionVertical) * $paddingFactor;
274
+		$zoom                 = log(360 / ($resolution * $this->tileSize), 2);
275
+
276
+		if(is_finite($zoom) && $zoom < 15 && $zoom > 2) {
277
+			$this->zoom = floor($zoom);
278
+		}
279
+		$this->lon = $centroid->getX();
280
+		$this->lat = $centroid->getY();
281
+		dbglog("StaticMap::autoZoom: Set autozoom options to: z: $this->zoom, lon: $this->lon, lat: $this->lat");
282
+	}
283
+
284
+	public function checkMapCache() {
285
+		$this->mapCacheID = md5($this->serializeParams());
286
+		$filename         = $this->mapCacheIDToFilename();
287
+		if(file_exists($filename))
288
+			return true;
289
+	}
290
+
291
+	public function serializeParams() {
292
+		return join(
293
+			"&", array(
294
+				   $this->zoom,
295
+				   $this->lat,
296
+				   $this->lon,
297
+				   $this->width,
298
+				   $this->height,
299
+				   serialize($this->markers),
300
+				   $this->maptype,
301
+				   $this->kmlFileName,
302
+				   $this->gpxFileName,
303
+				   $this->geojsonFileName
304
+			   )
305
+		);
306
+	}
307
+
308
+	public function mapCacheIDToFilename() {
309
+		if(!$this->mapCacheFile) {
310
+			$this->mapCacheFile = $this->mapCacheBaseDir . "/" . $this->maptype . "/" . $this->zoom . "/cache_"
311
+				. substr($this->mapCacheID, 0, 2) . "/" . substr($this->mapCacheID, 2, 2)
312
+				. "/" . substr($this->mapCacheID, 4);
313
+		}
314
+		return $this->mapCacheFile . "." . $this->mapCacheExtension;
315
+	}
316
+
317
+	/**
318
+	 * make the map.
319
+	 */
320
+	public function makeMap() {
321
+		$this->initCoords();
322
+		$this->createBaseMap();
323
+		if(!empty ($this->markers))
324
+			$this->placeMarkers();
325
+		if(file_exists($this->kmlFileName))
326
+			$this->drawKML();
327
+		if(file_exists($this->gpxFileName))
328
+			$this->drawGPX();
329
+		if(file_exists($this->geojsonFileName))
330
+			$this->drawGeojson();
331
+
332
+		$this->drawCopyright();
333
+	}
334
+
335
+	/**
336
+	 */
337
+	public function initCoords() {
338
+		$this->centerX = $this->lonToTile($this->lon, $this->zoom);
339
+		$this->centerY = $this->latToTile($this->lat, $this->zoom);
340
+		$this->offsetX = floor((floor($this->centerX) - $this->centerX) * $this->tileSize);
341
+		$this->offsetY = floor((floor($this->centerY) - $this->centerY) * $this->tileSize);
342
+	}
343
+
344
+	/**
345
+	 *
346
+	 * @param number $long
347
+	 * @param number $zoom
348
+	 * @return number
349
+	 */
350
+	public function lonToTile($long, $zoom) {
351
+		return (($long + 180) / 360) * pow(2, $zoom);
352
+	}
353
+
354
+	/**
355
+	 *
356
+	 * @param number $lat
357
+	 * @param number $zoom
358
+	 * @return float|int
359
+	 */
360
+	public function latToTile($lat, $zoom) {
361
+		return (1 - log(tan($lat * pi() / 180) + 1 / cos($lat * M_PI / 180)) / M_PI) / 2 * pow(2, $zoom);
362
+	}
363
+
364
+	/**
365
+	 * make basemap image.
366
+	 */
367
+	public function createBaseMap() {
368
+		$this->image   = imagecreatetruecolor($this->width, $this->height);
369
+		$startX        = floor($this->centerX - ($this->width / $this->tileSize) / 2);
370
+		$startY        = floor($this->centerY - ($this->height / $this->tileSize) / 2);
371
+		$endX          = ceil($this->centerX + ($this->width / $this->tileSize) / 2);
372
+		$endY          = ceil($this->centerY + ($this->height / $this->tileSize) / 2);
373
+		$this->offsetX = -floor(($this->centerX - floor($this->centerX)) * $this->tileSize);
374
+		$this->offsetY = -floor(($this->centerY - floor($this->centerY)) * $this->tileSize);
375
+		$this->offsetX += floor($this->width / 2);
376
+		$this->offsetY += floor($this->height / 2);
377
+		$this->offsetX += floor($startX - floor($this->centerX)) * $this->tileSize;
378
+		$this->offsetY += floor($startY - floor($this->centerY)) * $this->tileSize;
379
+
380
+		for($x = $startX; $x <= $endX; $x++) {
381
+			for($y = $startY; $y <= $endY; $y++) {
382
+				$url = str_replace(
383
+					array(
384
+						'{Z}',
385
+						'{X}',
386
+						'{Y}'
387
+					), array(
388
+						$this->zoom,
389
+						$x,
390
+						$y
391
+					), $this->tileInfo [$this->maptype] ['url']
392
+				);
393
+				$url .= $this->apikey;
394
+
395
+				$tileData = $this->fetchTile($url);
396
+				if($tileData) {
397
+					$tileImage = imagecreatefromstring($tileData);
398
+				} else {
399
+					$tileImage = imagecreate($this->tileSize, $this->tileSize);
400
+					$color     = imagecolorallocate($tileImage, 255, 255, 255);
401
+					@imagestring($tileImage, 1, 127, 127, 'err', $color);
402
+				}
403
+				$destX = ($x - $startX) * $this->tileSize + $this->offsetX;
404
+				$destY = ($y - $startY) * $this->tileSize + $this->offsetY;
405
+				dbglog($this->tileSize, "imagecopy tile into image: $destX, $destY");
406
+				imagecopy(
407
+					$this->image, $tileImage, $destX, $destY, 0, 0, $this->tileSize,
408
+					$this->tileSize
409
+				);
410
+			}
411
+		}
412
+	}
413
+
414
+	/**
415
+	 * Fetch a tile and (if configured) store it in the cache.
416
+	 *
417
+	 * @param string $url
418
+	 */
419
+	public function fetchTile($url) {
420
+		if($this->useTileCache && ($cached = $this->checkTileCache($url)))
421
+			return $cached;
422
+
423
+		$_UA = 'Mozilla/4.0 (compatible; DokuWikiSpatial HTTP Client; ' . PHP_OS . ')';
424
+		if(function_exists("curl_init")) {
425
+			// use cUrl
426
+			$ch = curl_init();
427
+			curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
428
+			curl_setopt($ch, CURLOPT_USERAGENT, $_UA);
429
+			curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 10);
430
+			curl_setopt($ch, CURLOPT_URL, $url);
431
+			$tile = curl_exec($ch);
432
+			curl_close($ch);
433
+		} else {
434
+			// use file_get_contents
435
+			global $conf;
436
+			$opts    = array(
437
+				'http' => array(
438
+					'method'          => "GET",
439
+					'header'          => "Accept-language: en\r\n" . "User-Agent: $_UA\r\n" . "accept: image/png\r\n",
440
+					'proxy'           => "tcp://" . $conf ['proxy'] ['host'] . ":" . $conf ['proxy'] ['port'],
441
+					'request_fulluri' => true
442
+				)
443
+			);
444
+			$context = stream_context_create($opts);
445
+			$tile    = file_get_contents($url, false, $context);
446
+		}
447
+		if($tile && $this->useTileCache) {
448
+			$this->writeTileToCache($url, $tile);
449
+		}
450
+		return $tile;
451
+	}
452
+
453
+	/**
454
+	 *
455
+	 * @param string $url
456
+	 */
457
+	public function checkTileCache($url) {
458
+		$filename = $this->tileUrlToFilename($url);
459
+		if(file_exists($filename)) {
460
+			return file_get_contents($filename);
461
+		}
462
+	}
463
+
464
+	/**
465
+	 *
466
+	 * @param string $url
467
+	 * @return string
468
+	 */
469
+	public function tileUrlToFilename($url) {
470
+		return $this->tileCacheBaseDir . "/" . str_replace(
471
+				array(
472
+					'http://'
473
+				), '', $url
474
+			);
475
+	}
476
+
477
+	/**
478
+	 * Write a tile into the cache.
479
+	 *
480
+	 * @param string $url
481
+	 * @param mixed  $data
482
+	 */
483
+	public function writeTileToCache($url, $data) {
484
+		$filename = $this->tileUrlToFilename($url);
485
+		$this->mkdir_recursive(dirname($filename), 0777);
486
+		file_put_contents($filename, $data);
487
+	}
488
+
489
+	/**
490
+	 * Recursively create the directory.
491
+	 *
492
+	 * @param string $pathname
493
+	 *            The directory path.
494
+	 * @param int    $mode
495
+	 *            File access mode. For more information on modes, read the details on the chmod manpage.
496
+	 */
497
+	public function mkdir_recursive($pathname, $mode) {
498
+		is_dir(dirname($pathname)) || $this->mkdir_recursive(dirname($pathname), $mode);
499
+		return is_dir($pathname) || @mkdir($pathname, $mode);
500
+	}
501
+
502
+	/**
503
+	 * Place markers on the map and number them in the same order as they are listed in the html.
504
+	 */
505
+	public function placeMarkers() {
506
+		$count         = 0;
507
+		$color         = imagecolorallocate($this->image, 0, 0, 0);
508
+		$bgcolor       = imagecolorallocate($this->image, 200, 200, 200);
509
+		$markerBaseDir = dirname(__FILE__) . '/icons';
510
+		// loop thru marker array
511
+		foreach($this->markers as $marker) {
512
+			// set some local variables
513
+			$markerLat  = $marker ['lat'];
514
+			$markerLon  = $marker ['lon'];
515
+			$markerType = $marker ['type'];
516
+			// clear variables from previous loops
517
+			$markerFilename = '';
518
+			$markerShadow   = '';
519
+			$matches        = false;
520
+			// check for marker type, get settings from markerPrototypes
521
+			if($markerType) {
522
+				foreach($this->markerPrototypes as $markerPrototype) {
523
+					if(preg_match($markerPrototype ['regex'], $markerType, $matches)) {
524
+						$markerFilename = $matches [0] . $markerPrototype ['extension'];
525
+						if($markerPrototype ['offsetImage']) {
526
+							list ($markerImageOffsetX, $markerImageOffsetY) = explode(
527
+								",",
528
+								$markerPrototype ['offsetImage']
529
+							);
530
+						}
531
+						$markerShadow = $markerPrototype ['shadow'];
532
+						if($markerShadow) {
533
+							list ($markerShadowOffsetX, $markerShadowOffsetY) = explode(
534
+								",",
535
+								$markerPrototype ['offsetShadow']
536
+							);
537
+						}
538
+					}
539
+				}
540
+			}
541
+			// create img resource
542
+			if(file_exists($markerBaseDir . '/' . $markerFilename)) {
543
+				$markerImg = imagecreatefrompng($markerBaseDir . '/' . $markerFilename);
544
+			} else {
545
+				$markerImg = imagecreatefrompng($markerBaseDir . '/marker.png');
546
+			}
547
+			// check for shadow + create shadow recource
548
+			if($markerShadow && file_exists($markerBaseDir . '/' . $markerShadow)) {
549
+				$markerShadowImg = imagecreatefrompng($markerBaseDir . '/' . $markerShadow);
550
+			}
551
+			// calc position
552
+			$destX = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($markerLon, $this->zoom)));
553
+			$destY = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($markerLat, $this->zoom)));
554
+			// copy shadow on basemap
555
+			if($markerShadow && $markerShadowImg) {
556
+				imagecopy($this->image, $markerShadowImg, $destX + intval($markerShadowOffsetX), $destY + intval($markerShadowOffsetY), 0, 0, imagesx($markerShadowImg), imagesy($markerShadowImg));
557
+			}
558
+			// copy marker on basemap above shadow
559
+			imagecopy($this->image, $markerImg, $destX + intval($markerImageOffsetX), $destY + intval($markerImageOffsetY), 0, 0, imagesx($markerImg), imagesy($markerImg));
560
+			// add label
561
+			imagestring($this->image, 3, $destX - imagesx($markerImg) + 1, $destY + intval($markerImageOffsetY) + 1, ++$count, $bgcolor);
562
+			imagestring($this->image, 3, $destX - imagesx($markerImg), $destY + intval($markerImageOffsetY), $count, $color);
563
+		}
564
+	}
565
+
566
+	/**
567
+	 * Draw kml trace on the map.
568
+	 */
569
+	public function drawKML() {
570
+		// TODO get colour from kml node (not currently supported in geoPHP)
571
+		$col     = imagecolorallocatealpha($this->image, 255, 0, 0, .4 * 127);
572
+		$kmlgeom = geoPHP::load(file_get_contents($this->kmlFileName), 'kml');
573
+		$this->drawGeometry($kmlgeom, $col);
574
+	}
575
+
576
+	/**
577
+	 * Draw geometry or geometry collection on the map.
578
+	 *
579
+	 * @param Geometry $geom
580
+	 * @param int      $colour
581
+	 *            drawing colour
582
+	 */
583
+	private function drawGeometry($geom, $colour) {
584
+		if(empty($geom)) return;
585
+
586
+		switch($geom->geometryType()) {
587
+			case 'GeometryCollection' :
588
+				// recursively draw part of the collection
589
+				for($i = 1; $i < $geom->numGeometries() + 1; $i++) {
590
+					$_geom = $geom->geometryN($i);
591
+					$this->drawGeometry($_geom, $colour);
592
+				}
593
+				break;
594
+			case 'MultiPolygon' :
595
+			case 'MultiLineString' :
596
+			case 'MultiPoint' :
597
+				// TODO implement / do nothing
598
+				break;
599
+			case 'Polygon' :
600
+				$this->drawPolygon($geom, $colour);
601
+				break;
602
+			case 'LineString' :
603
+				$this->drawLineString($geom, $colour);
604
+				break;
605
+			case 'Point' :
606
+				$this->drawPoint($geom, $colour);
607
+				break;
608
+			default :
609
+				// draw nothing
610
+				break;
611
+		}
612
+	}
613
+
614
+	/**
615
+	 * Draw a polygon on the map.
616
+	 *
617
+	 * @param Polygon $polygon
618
+	 * @param int     $colour
619
+	 *            drawing colour
620
+	 */
621
+	private function drawPolygon($polygon, $colour) {
622
+		// TODO implementation of drawing holes,
623
+		// maybe draw the polygon to an in-memory image and use imagecopy, draw polygon in col., draw holes in bgcol?
624
+
625
+		// print_r('Polygon:<br />');
626
+		// print_r($polygon);
627
+		$extPoints = array();
628
+		// extring is a linestring actually..
629
+		$extRing = $polygon->exteriorRing();
630
+
631
+		for($i = 1; $i < $extRing->numGeometries(); $i++) {
632
+			$p1           = $extRing->geometryN($i);
633
+			$x            = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p1->x(), $this->zoom)));
634
+			$y            = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p1->y(), $this->zoom)));
635
+			$extPoints [] = $x;
636
+			$extPoints [] = $y;
637
+		}
638
+		// print_r('points:('.($i-1).')<br />');
639
+		// print_r($extPoints);
640
+		// imagepolygon ($this->image, $extPoints, $i-1, $colour );
641
+		imagefilledpolygon($this->image, $extPoints, $i - 1, $colour);
642
+	}
643
+
644
+	/**
645
+	 * Draw a line on the map.
646
+	 *
647
+	 * @param LineString $line
648
+	 * @param int        $colour
649
+	 *            drawing colour
650
+	 */
651
+	private function drawLineString($line, $colour) {
652
+		imagesetthickness($this->image, 2);
653
+		for($p = 1; $p < $line->numGeometries(); $p++) {
654
+			// get first pair of points
655
+			$p1 = $line->geometryN($p);
656
+			$p2 = $line->geometryN($p + 1);
657
+			// translate to paper space
658
+			$x1 = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p1->x(), $this->zoom)));
659
+			$y1 = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p1->y(), $this->zoom)));
660
+			$x2 = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p2->x(), $this->zoom)));
661
+			$y2 = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p2->y(), $this->zoom)));
662
+			// draw to image
663
+			imageline($this->image, $x1, $y1, $x2, $y2, $colour);
664
+		}
665
+		imagesetthickness($this->image, 1);
666
+	}
667
+
668
+	/**
669
+	 * Draw a point on the map.
670
+	 *
671
+	 * @param Point $point
672
+	 * @param int   $colour
673
+	 *            drawing colour
674
+	 */
675
+	private function drawPoint($point, $colour) {
676
+		imagesetthickness($this->image, 2);
677
+		// translate to paper space
678
+		$cx = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($point->x(), $this->zoom)));
679
+		$cy = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($point->y(), $this->zoom)));
680
+		$r  = 5;
681
+		// draw to image
682
+		// imageellipse($this->image, $cx, $cy,$r, $r, $colour);
683
+		imagefilledellipse($this->image, $cx, $cy, $r, $r, $colour);
684
+		// don't use imageellipse because the imagesetthickness function has
685
+		// no effect. So the better workaround is to use imagearc.
686
+		imagearc($this->image, $cx, $cy, $r, $r, 0, 359, $colour);
687
+		imagesetthickness($this->image, 1);
688
+	}
689
+
690
+	/**
691
+	 * Draw gpx trace on the map.
692
+	 */
693
+	public function drawGPX() {
694
+		$col     = imagecolorallocatealpha($this->image, 0, 0, 255, .4 * 127);
695
+		$gpxgeom = geoPHP::load(file_get_contents($this->gpxFileName), 'gpx');
696
+		$this->drawGeometry($gpxgeom, $col);
697
+	}
698
+
699
+	/**
700
+	 * Draw geojson on the map.
701
+	 */
702
+	public function drawGeojson() {
703
+		$col     = imagecolorallocatealpha($this->image, 255, 0, 255, .4 * 127);
704
+		$gpxgeom = geoPHP::load(file_get_contents($this->geojsonFileName), 'json');
705
+		$this->drawGeometry($gpxgeom, $col);
706
+	}
707
+
708
+	/**
709
+	 * add copyright and origin notice and icons to the map.
710
+	 */
711
+	public function drawCopyright() {
712
+		$logoBaseDir = dirname(__FILE__) . '/' . 'logo/';
713
+		$logoImg     = imagecreatefrompng($logoBaseDir . $this->tileInfo ['openstreetmap'] ['logo']);
714
+		$textcolor   = imagecolorallocate($this->image, 0, 0, 0);
715
+		$bgcolor     = imagecolorallocate($this->image, 200, 200, 200);
716
+
717
+		imagecopy($this->image, $logoImg, 0, imagesy($this->image) - imagesy($logoImg), 0, 0, imagesx($logoImg), imagesy($logoImg));
718
+		imagestring($this->image, 1, imagesx($logoImg) + 2, imagesy($this->image) - imagesy($logoImg) + 1, $this->tileInfo ['openstreetmap'] ['txt'], $bgcolor);
719
+		imagestring($this->image, 1, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($logoImg), $this->tileInfo ['openstreetmap'] ['txt'], $textcolor);
720
+
721
+		// additional tile source info, ie. who created/hosted the tiles
722
+		if($this->maptype != 'openstreetmap') {
723
+			$iconImg = imagecreatefrompng($logoBaseDir . $this->tileInfo [$this->maptype] ['logo']);
724
+			imagecopy($this->image, $iconImg, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($iconImg), 0, 0, imagesx($iconImg), imagesy($iconImg));
725
+			imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 4, imagesy($this->image) - ceil(imagesy($logoImg) / 2) + 1, $this->tileInfo [$this->maptype] ['txt'], $bgcolor);
726
+			imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 3, imagesy($this->image) - ceil(imagesy($logoImg) / 2), $this->tileInfo [$this->maptype] ['txt'], $textcolor);
727
+		}
728
+	}
729 729
 }
Please login to merge, or discard this patch.
Spacing   +65 added lines, -65 removed lines patch added patch discarded remove patch
@@ -18,7 +18,7 @@  discard block
 block discarded – undo
18 18
  * See the License for the specific language governing permissions and
19 19
  * limitations under the License.
20 20
  */
21
-include_once(realpath(dirname(__FILE__)) . '/../geophp/geoPHP/geoPHP.inc');
21
+include_once(realpath(dirname(__FILE__)).'/../geophp/geoPHP/geoPHP.inc');
22 22
 
23 23
 /**
24 24
  *
@@ -174,7 +174,7 @@  discard block
 block discarded – undo
174 174
         $this->height = $height;
175 175
         // validate + set maptype
176 176
         $this->maptype = $this->tileDefaultSrc;
177
-        if(array_key_exists($maptype, $this->tileInfo)) {
177
+        if (array_key_exists($maptype, $this->tileInfo)) {
178 178
             $this->maptype = $maptype;
179 179
         }
180 180
         $this->markers          = $markers;
@@ -182,9 +182,9 @@  discard block
 block discarded – undo
182 182
         $this->gpxFileName      = $gpx;
183 183
         $this->geojsonFileName  = $geojson;
184 184
         $this->mediaBaseDir     = $mediaDir;
185
-        $this->tileCacheBaseDir = $tileCacheBaseDir . '/olmaptiles';
185
+        $this->tileCacheBaseDir = $tileCacheBaseDir.'/olmaptiles';
186 186
         $this->useTileCache     = $this->tileCacheBaseDir !== '';
187
-        $this->mapCacheBaseDir  = $mediaDir . '/olmapmaps';
187
+        $this->mapCacheBaseDir  = $mediaDir.'/olmapmaps';
188 188
         $this->autoZoomExtent   = $autoZoomExtent;
189 189
         $this->apikey           = $apikey;
190 190
     }
@@ -196,15 +196,15 @@  discard block
 block discarded – undo
196 196
      */
197 197
     public function getMap() {
198 198
         try {
199
-            if($this->autoZoomExtent) {
199
+            if ($this->autoZoomExtent) {
200 200
                 $this->autoZoom();
201 201
             }
202
-        } catch(Exception $e) {
202
+        } catch (Exception $e) {
203 203
             dbglog($e);
204 204
         }
205 205
 
206 206
         // use map cache, so check cache for map
207
-        if(!$this->checkMapCache()) {
207
+        if (!$this->checkMapCache()) {
208 208
             // map is not in cache, needs to be build
209 209
             $this->makeMap();
210 210
             $this->mkdir_recursive(dirname($this->mapCacheIDToFilename()), 0777);
@@ -226,38 +226,38 @@  discard block
 block discarded – undo
226 226
      */
227 227
     private function autoZoom($paddingFactor = 1.0) {
228 228
         $geoms    = array();
229
-        $geoms [] = new Point ($this->lon, $this->lat);
230
-        if(!empty ($this->markers)) {
231
-            foreach($this->markers as $marker) {
232
-                $geoms [] = new Point ($marker ['lon'], $marker ['lat']);
229
+        $geoms [] = new Point($this->lon, $this->lat);
230
+        if (!empty ($this->markers)) {
231
+            foreach ($this->markers as $marker) {
232
+                $geoms [] = new Point($marker ['lon'], $marker ['lat']);
233 233
             }
234 234
         }
235 235
         $g = false;
236
-        if(file_exists($this->kmlFileName)) {
236
+        if (file_exists($this->kmlFileName)) {
237 237
             $g = geoPHP::load(file_get_contents($this->kmlFileName), 'kml');
238
-            if($g !== false) {
238
+            if ($g !== false) {
239 239
                 $geoms [] = $g;
240 240
             }
241 241
         }
242
-        if(file_exists($this->gpxFileName)) {
242
+        if (file_exists($this->gpxFileName)) {
243 243
             $g = geoPHP::load(file_get_contents($this->gpxFileName), 'gpx');
244
-            if($g !== false) {
244
+            if ($g !== false) {
245 245
                 $geoms [] = $g;
246 246
             }
247 247
         }
248
-        if(file_exists($this->geojsonFileName)) {
248
+        if (file_exists($this->geojsonFileName)) {
249 249
             $g = geoPHP::load(file_get_contents($this->geojsonFileName), 'geojson');
250
-            if($g !== false) {
250
+            if ($g !== false) {
251 251
                 $geoms [] = $g;
252 252
             }
253 253
         }
254 254
 
255
-        if(count($geoms) <= 1) {
255
+        if (count($geoms) <= 1) {
256 256
             dbglog($geoms, "StaticMap::autoZoom: Skip setting autozoom options");
257 257
             return;
258 258
         }
259 259
 
260
-        $geom     = new GeometryCollection ($geoms);
260
+        $geom     = new GeometryCollection($geoms);
261 261
         $centroid = $geom->centroid();
262 262
         $bbox     = $geom->getBBox();
263 263
 
@@ -273,7 +273,7 @@  discard block
 block discarded – undo
273 273
         $resolution           = max($resolutionHorizontal, $resolutionVertical) * $paddingFactor;
274 274
         $zoom                 = log(360 / ($resolution * $this->tileSize), 2);
275 275
 
276
-        if(is_finite($zoom) && $zoom < 15 && $zoom > 2) {
276
+        if (is_finite($zoom) && $zoom < 15 && $zoom > 2) {
277 277
             $this->zoom = floor($zoom);
278 278
         }
279 279
         $this->lon = $centroid->getX();
@@ -284,7 +284,7 @@  discard block
 block discarded – undo
284 284
     public function checkMapCache() {
285 285
         $this->mapCacheID = md5($this->serializeParams());
286 286
         $filename         = $this->mapCacheIDToFilename();
287
-        if(file_exists($filename))
287
+        if (file_exists($filename))
288 288
             return true;
289 289
     }
290 290
 
@@ -306,12 +306,12 @@  discard block
 block discarded – undo
306 306
     }
307 307
 
308 308
     public function mapCacheIDToFilename() {
309
-        if(!$this->mapCacheFile) {
310
-            $this->mapCacheFile = $this->mapCacheBaseDir . "/" . $this->maptype . "/" . $this->zoom . "/cache_"
311
-                . substr($this->mapCacheID, 0, 2) . "/" . substr($this->mapCacheID, 2, 2)
312
-                . "/" . substr($this->mapCacheID, 4);
309
+        if (!$this->mapCacheFile) {
310
+            $this->mapCacheFile = $this->mapCacheBaseDir."/".$this->maptype."/".$this->zoom."/cache_"
311
+                . substr($this->mapCacheID, 0, 2)."/".substr($this->mapCacheID, 2, 2)
312
+                . "/".substr($this->mapCacheID, 4);
313 313
         }
314
-        return $this->mapCacheFile . "." . $this->mapCacheExtension;
314
+        return $this->mapCacheFile.".".$this->mapCacheExtension;
315 315
     }
316 316
 
317 317
     /**
@@ -320,13 +320,13 @@  discard block
 block discarded – undo
320 320
     public function makeMap() {
321 321
         $this->initCoords();
322 322
         $this->createBaseMap();
323
-        if(!empty ($this->markers))
323
+        if (!empty ($this->markers))
324 324
             $this->placeMarkers();
325
-        if(file_exists($this->kmlFileName))
325
+        if (file_exists($this->kmlFileName))
326 326
             $this->drawKML();
327
-        if(file_exists($this->gpxFileName))
327
+        if (file_exists($this->gpxFileName))
328 328
             $this->drawGPX();
329
-        if(file_exists($this->geojsonFileName))
329
+        if (file_exists($this->geojsonFileName))
330 330
             $this->drawGeojson();
331 331
 
332 332
         $this->drawCopyright();
@@ -377,8 +377,8 @@  discard block
 block discarded – undo
377 377
         $this->offsetX += floor($startX - floor($this->centerX)) * $this->tileSize;
378 378
         $this->offsetY += floor($startY - floor($this->centerY)) * $this->tileSize;
379 379
 
380
-        for($x = $startX; $x <= $endX; $x++) {
381
-            for($y = $startY; $y <= $endY; $y++) {
380
+        for ($x = $startX; $x <= $endX; $x++) {
381
+            for ($y = $startY; $y <= $endY; $y++) {
382 382
                 $url = str_replace(
383 383
                     array(
384 384
                         '{Z}',
@@ -393,7 +393,7 @@  discard block
 block discarded – undo
393 393
                 $url .= $this->apikey;
394 394
 
395 395
                 $tileData = $this->fetchTile($url);
396
-                if($tileData) {
396
+                if ($tileData) {
397 397
                     $tileImage = imagecreatefromstring($tileData);
398 398
                 } else {
399 399
                     $tileImage = imagecreate($this->tileSize, $this->tileSize);
@@ -417,11 +417,11 @@  discard block
 block discarded – undo
417 417
      * @param string $url
418 418
      */
419 419
     public function fetchTile($url) {
420
-        if($this->useTileCache && ($cached = $this->checkTileCache($url)))
420
+        if ($this->useTileCache && ($cached = $this->checkTileCache($url)))
421 421
             return $cached;
422 422
 
423
-        $_UA = 'Mozilla/4.0 (compatible; DokuWikiSpatial HTTP Client; ' . PHP_OS . ')';
424
-        if(function_exists("curl_init")) {
423
+        $_UA = 'Mozilla/4.0 (compatible; DokuWikiSpatial HTTP Client; '.PHP_OS.')';
424
+        if (function_exists("curl_init")) {
425 425
             // use cUrl
426 426
             $ch = curl_init();
427 427
             curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
@@ -433,18 +433,18 @@  discard block
 block discarded – undo
433 433
         } else {
434 434
             // use file_get_contents
435 435
             global $conf;
436
-            $opts    = array(
436
+            $opts = array(
437 437
                 'http' => array(
438 438
                     'method'          => "GET",
439
-                    'header'          => "Accept-language: en\r\n" . "User-Agent: $_UA\r\n" . "accept: image/png\r\n",
440
-                    'proxy'           => "tcp://" . $conf ['proxy'] ['host'] . ":" . $conf ['proxy'] ['port'],
439
+                    'header'          => "Accept-language: en\r\n"."User-Agent: $_UA\r\n"."accept: image/png\r\n",
440
+                    'proxy'           => "tcp://".$conf ['proxy'] ['host'].":".$conf ['proxy'] ['port'],
441 441
                     'request_fulluri' => true
442 442
                 )
443 443
             );
444 444
             $context = stream_context_create($opts);
445 445
             $tile    = file_get_contents($url, false, $context);
446 446
         }
447
-        if($tile && $this->useTileCache) {
447
+        if ($tile && $this->useTileCache) {
448 448
             $this->writeTileToCache($url, $tile);
449 449
         }
450 450
         return $tile;
@@ -456,7 +456,7 @@  discard block
 block discarded – undo
456 456
      */
457 457
     public function checkTileCache($url) {
458 458
         $filename = $this->tileUrlToFilename($url);
459
-        if(file_exists($filename)) {
459
+        if (file_exists($filename)) {
460 460
             return file_get_contents($filename);
461 461
         }
462 462
     }
@@ -467,7 +467,7 @@  discard block
 block discarded – undo
467 467
      * @return string
468 468
      */
469 469
     public function tileUrlToFilename($url) {
470
-        return $this->tileCacheBaseDir . "/" . str_replace(
470
+        return $this->tileCacheBaseDir."/".str_replace(
471 471
                 array(
472 472
                     'http://'
473 473
                 ), '', $url
@@ -506,9 +506,9 @@  discard block
 block discarded – undo
506 506
         $count         = 0;
507 507
         $color         = imagecolorallocate($this->image, 0, 0, 0);
508 508
         $bgcolor       = imagecolorallocate($this->image, 200, 200, 200);
509
-        $markerBaseDir = dirname(__FILE__) . '/icons';
509
+        $markerBaseDir = dirname(__FILE__).'/icons';
510 510
         // loop thru marker array
511
-        foreach($this->markers as $marker) {
511
+        foreach ($this->markers as $marker) {
512 512
             // set some local variables
513 513
             $markerLat  = $marker ['lat'];
514 514
             $markerLon  = $marker ['lon'];
@@ -518,18 +518,18 @@  discard block
 block discarded – undo
518 518
             $markerShadow   = '';
519 519
             $matches        = false;
520 520
             // check for marker type, get settings from markerPrototypes
521
-            if($markerType) {
522
-                foreach($this->markerPrototypes as $markerPrototype) {
523
-                    if(preg_match($markerPrototype ['regex'], $markerType, $matches)) {
524
-                        $markerFilename = $matches [0] . $markerPrototype ['extension'];
525
-                        if($markerPrototype ['offsetImage']) {
521
+            if ($markerType) {
522
+                foreach ($this->markerPrototypes as $markerPrototype) {
523
+                    if (preg_match($markerPrototype ['regex'], $markerType, $matches)) {
524
+                        $markerFilename = $matches [0].$markerPrototype ['extension'];
525
+                        if ($markerPrototype ['offsetImage']) {
526 526
                             list ($markerImageOffsetX, $markerImageOffsetY) = explode(
527 527
                                 ",",
528 528
                                 $markerPrototype ['offsetImage']
529 529
                             );
530 530
                         }
531 531
                         $markerShadow = $markerPrototype ['shadow'];
532
-                        if($markerShadow) {
532
+                        if ($markerShadow) {
533 533
                             list ($markerShadowOffsetX, $markerShadowOffsetY) = explode(
534 534
                                 ",",
535 535
                                 $markerPrototype ['offsetShadow']
@@ -539,20 +539,20 @@  discard block
 block discarded – undo
539 539
                 }
540 540
             }
541 541
             // create img resource
542
-            if(file_exists($markerBaseDir . '/' . $markerFilename)) {
543
-                $markerImg = imagecreatefrompng($markerBaseDir . '/' . $markerFilename);
542
+            if (file_exists($markerBaseDir.'/'.$markerFilename)) {
543
+                $markerImg = imagecreatefrompng($markerBaseDir.'/'.$markerFilename);
544 544
             } else {
545
-                $markerImg = imagecreatefrompng($markerBaseDir . '/marker.png');
545
+                $markerImg = imagecreatefrompng($markerBaseDir.'/marker.png');
546 546
             }
547 547
             // check for shadow + create shadow recource
548
-            if($markerShadow && file_exists($markerBaseDir . '/' . $markerShadow)) {
549
-                $markerShadowImg = imagecreatefrompng($markerBaseDir . '/' . $markerShadow);
548
+            if ($markerShadow && file_exists($markerBaseDir.'/'.$markerShadow)) {
549
+                $markerShadowImg = imagecreatefrompng($markerBaseDir.'/'.$markerShadow);
550 550
             }
551 551
             // calc position
552 552
             $destX = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($markerLon, $this->zoom)));
553 553
             $destY = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($markerLat, $this->zoom)));
554 554
             // copy shadow on basemap
555
-            if($markerShadow && $markerShadowImg) {
555
+            if ($markerShadow && $markerShadowImg) {
556 556
                 imagecopy($this->image, $markerShadowImg, $destX + intval($markerShadowOffsetX), $destY + intval($markerShadowOffsetY), 0, 0, imagesx($markerShadowImg), imagesy($markerShadowImg));
557 557
             }
558 558
             // copy marker on basemap above shadow
@@ -581,12 +581,12 @@  discard block
 block discarded – undo
581 581
      *            drawing colour
582 582
      */
583 583
     private function drawGeometry($geom, $colour) {
584
-        if(empty($geom)) return;
584
+        if (empty($geom)) return;
585 585
 
586
-        switch($geom->geometryType()) {
586
+        switch ($geom->geometryType()) {
587 587
             case 'GeometryCollection' :
588 588
                 // recursively draw part of the collection
589
-                for($i = 1; $i < $geom->numGeometries() + 1; $i++) {
589
+                for ($i = 1; $i < $geom->numGeometries() + 1; $i++) {
590 590
                     $_geom = $geom->geometryN($i);
591 591
                     $this->drawGeometry($_geom, $colour);
592 592
                 }
@@ -628,7 +628,7 @@  discard block
 block discarded – undo
628 628
         // extring is a linestring actually..
629 629
         $extRing = $polygon->exteriorRing();
630 630
 
631
-        for($i = 1; $i < $extRing->numGeometries(); $i++) {
631
+        for ($i = 1; $i < $extRing->numGeometries(); $i++) {
632 632
             $p1           = $extRing->geometryN($i);
633 633
             $x            = floor(($this->width / 2) - $this->tileSize * ($this->centerX - $this->lonToTile($p1->x(), $this->zoom)));
634 634
             $y            = floor(($this->height / 2) - $this->tileSize * ($this->centerY - $this->latToTile($p1->y(), $this->zoom)));
@@ -650,7 +650,7 @@  discard block
 block discarded – undo
650 650
      */
651 651
     private function drawLineString($line, $colour) {
652 652
         imagesetthickness($this->image, 2);
653
-        for($p = 1; $p < $line->numGeometries(); $p++) {
653
+        for ($p = 1; $p < $line->numGeometries(); $p++) {
654 654
             // get first pair of points
655 655
             $p1 = $line->geometryN($p);
656 656
             $p2 = $line->geometryN($p + 1);
@@ -709,8 +709,8 @@  discard block
 block discarded – undo
709 709
      * add copyright and origin notice and icons to the map.
710 710
      */
711 711
     public function drawCopyright() {
712
-        $logoBaseDir = dirname(__FILE__) . '/' . 'logo/';
713
-        $logoImg     = imagecreatefrompng($logoBaseDir . $this->tileInfo ['openstreetmap'] ['logo']);
712
+        $logoBaseDir = dirname(__FILE__).'/'.'logo/';
713
+        $logoImg     = imagecreatefrompng($logoBaseDir.$this->tileInfo ['openstreetmap'] ['logo']);
714 714
         $textcolor   = imagecolorallocate($this->image, 0, 0, 0);
715 715
         $bgcolor     = imagecolorallocate($this->image, 200, 200, 200);
716 716
 
@@ -719,8 +719,8 @@  discard block
 block discarded – undo
719 719
         imagestring($this->image, 1, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($logoImg), $this->tileInfo ['openstreetmap'] ['txt'], $textcolor);
720 720
 
721 721
         // additional tile source info, ie. who created/hosted the tiles
722
-        if($this->maptype != 'openstreetmap') {
723
-            $iconImg = imagecreatefrompng($logoBaseDir . $this->tileInfo [$this->maptype] ['logo']);
722
+        if ($this->maptype != 'openstreetmap') {
723
+            $iconImg = imagecreatefrompng($logoBaseDir.$this->tileInfo [$this->maptype] ['logo']);
724 724
             imagecopy($this->image, $iconImg, imagesx($logoImg) + 1, imagesy($this->image) - imagesy($iconImg), 0, 0, imagesx($iconImg), imagesy($iconImg));
725 725
             imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 4, imagesy($this->image) - ceil(imagesy($logoImg) / 2) + 1, $this->tileInfo [$this->maptype] ['txt'], $bgcolor);
726 726
             imagestring($this->image, 1, imagesx($logoImg) + imagesx($iconImg) + 3, imagesy($this->image) - ceil(imagesy($logoImg) / 2), $this->tileInfo [$this->maptype] ['txt'], $textcolor);
Please login to merge, or discard this patch.
Braces   +21 added lines, -13 removed lines patch added patch discarded remove patch
@@ -284,8 +284,9 @@  discard block
 block discarded – undo
284 284
     public function checkMapCache() {
285 285
         $this->mapCacheID = md5($this->serializeParams());
286 286
         $filename         = $this->mapCacheIDToFilename();
287
-        if(file_exists($filename))
288
-            return true;
287
+        if(file_exists($filename)) {
288
+                    return true;
289
+        }
289 290
     }
290 291
 
291 292
     public function serializeParams() {
@@ -320,14 +321,18 @@  discard block
 block discarded – undo
320 321
     public function makeMap() {
321 322
         $this->initCoords();
322 323
         $this->createBaseMap();
323
-        if(!empty ($this->markers))
324
-            $this->placeMarkers();
325
-        if(file_exists($this->kmlFileName))
326
-            $this->drawKML();
327
-        if(file_exists($this->gpxFileName))
328
-            $this->drawGPX();
329
-        if(file_exists($this->geojsonFileName))
330
-            $this->drawGeojson();
324
+        if(!empty ($this->markers)) {
325
+                    $this->placeMarkers();
326
+        }
327
+        if(file_exists($this->kmlFileName)) {
328
+                    $this->drawKML();
329
+        }
330
+        if(file_exists($this->gpxFileName)) {
331
+                    $this->drawGPX();
332
+        }
333
+        if(file_exists($this->geojsonFileName)) {
334
+                    $this->drawGeojson();
335
+        }
331 336
 
332 337
         $this->drawCopyright();
333 338
     }
@@ -417,8 +422,9 @@  discard block
 block discarded – undo
417 422
      * @param string $url
418 423
      */
419 424
     public function fetchTile($url) {
420
-        if($this->useTileCache && ($cached = $this->checkTileCache($url)))
421
-            return $cached;
425
+        if($this->useTileCache && ($cached = $this->checkTileCache($url))) {
426
+                    return $cached;
427
+        }
422 428
 
423 429
         $_UA = 'Mozilla/4.0 (compatible; DokuWikiSpatial HTTP Client; ' . PHP_OS . ')';
424 430
         if(function_exists("curl_init")) {
@@ -581,7 +587,9 @@  discard block
 block discarded – undo
581 587
      *            drawing colour
582 588
      */
583 589
     private function drawGeometry($geom, $colour) {
584
-        if(empty($geom)) return;
590
+        if(empty($geom)) {
591
+        	return;
592
+        }
585 593
 
586 594
         switch($geom->geometryType()) {
587 595
             case 'GeometryCollection' :
Please login to merge, or discard this patch.
action.php 2 patches
Indentation   +39 added lines, -39 removed lines patch added patch discarded remove patch
@@ -24,46 +24,46 @@
 block discarded – undo
24 24
  */
25 25
 class action_plugin_openlayersmap extends DokuWiki_Action_Plugin {
26 26
 
27
-    /**
28
-     * plugin should use this method to register its handlers with the DokuWiki's event controller
29
-     *
30
-     * @param    $controller DokuWiki's event controller object. Also available as global $EVENT_HANDLER
31
-     */
32
-    public function register(Doku_Event_Handler $controller) {
33
-        $controller->register_hook('TOOLBAR_DEFINE', 'AFTER', $this, 'insertButton', array());
34
-        $controller->register_hook('TPL_METAHEADER_OUTPUT', 'BEFORE', $this, 'insertCSSSniffer');
35
-    }
27
+	/**
28
+	 * plugin should use this method to register its handlers with the DokuWiki's event controller
29
+	 *
30
+	 * @param    $controller DokuWiki's event controller object. Also available as global $EVENT_HANDLER
31
+	 */
32
+	public function register(Doku_Event_Handler $controller) {
33
+		$controller->register_hook('TOOLBAR_DEFINE', 'AFTER', $this, 'insertButton', array());
34
+		$controller->register_hook('TPL_METAHEADER_OUTPUT', 'BEFORE', $this, 'insertCSSSniffer');
35
+	}
36 36
 
37
-    /**
38
-     * Inserts the toolbar button.
39
-     * @param Doku_Event $event the DokuWiki event
40
-     */
41
-    public function insertButton(Doku_Event $event, $param) {
42
-        $strOpen       = '<olmap id="olMapOne" width="550px" height="450px" lat="50.0" ';
43
-        $strOpen       .= 'lon="5.1" zoom="12" statusbar="1" controls="1" poihoverstyle="0" ';
44
-        $strOpen       .= 'baselyr="OpenStreetMap" gpxfile="" kmlfile="" geojsonfile="" summary="" >\n';
45
-        $strOpen       .= '~~ Plugin olmap help.\n';
46
-        $strOpen       .= '~~ Required in the above tag are values for: id (unique on this page), width, heigth.\n';
47
-        $strOpen       .= '~~ Also you will want to enter zoomlevel and lat, lon values that make sense for where you';
48
-        $strOpen       .= '~~ want the map to start.\n\n';
49
-        $strOpen       .= '~~ Below is an example of a POI, you can add as many as you want. ';
50
-        $strOpen       .= '~~ More examples: https://dokuwiki.org/plugin:openlayersmap \n';
51
-        $event->data[] = array(
52
-            'type'   => 'format',
53
-            'title'  => $this->getLang('openlayersmap'),
54
-            'icon'   => '../../plugins/openlayersmap/toolbar/map.png',
55
-            'open'   => $strOpen,
56
-            'sample' => '50.0117,5.1287,-90,.8,marker-green.png,Pont de Barbouillons; Daverdisse \\\\ external link: 
37
+	/**
38
+	 * Inserts the toolbar button.
39
+	 * @param Doku_Event $event the DokuWiki event
40
+	 */
41
+	public function insertButton(Doku_Event $event, $param) {
42
+		$strOpen       = '<olmap id="olMapOne" width="550px" height="450px" lat="50.0" ';
43
+		$strOpen       .= 'lon="5.1" zoom="12" statusbar="1" controls="1" poihoverstyle="0" ';
44
+		$strOpen       .= 'baselyr="OpenStreetMap" gpxfile="" kmlfile="" geojsonfile="" summary="" >\n';
45
+		$strOpen       .= '~~ Plugin olmap help.\n';
46
+		$strOpen       .= '~~ Required in the above tag are values for: id (unique on this page), width, heigth.\n';
47
+		$strOpen       .= '~~ Also you will want to enter zoomlevel and lat, lon values that make sense for where you';
48
+		$strOpen       .= '~~ want the map to start.\n\n';
49
+		$strOpen       .= '~~ Below is an example of a POI, you can add as many as you want. ';
50
+		$strOpen       .= '~~ More examples: https://dokuwiki.org/plugin:openlayersmap \n';
51
+		$event->data[] = array(
52
+			'type'   => 'format',
53
+			'title'  => $this->getLang('openlayersmap'),
54
+			'icon'   => '../../plugins/openlayersmap/toolbar/map.png',
55
+			'open'   => $strOpen,
56
+			'sample' => '50.0117,5.1287,-90,.8,marker-green.png,Pont de Barbouillons; Daverdisse \\\\ external link: 
57 57
                         [[https://test.com|test.com]] \\\\ internal link: [[::start]]\\\\ **DW Formatting** \n',
58
-            'close'  => '</olmap>\n',
59
-        );
60
-    }
58
+			'close'  => '</olmap>\n',
59
+		);
60
+	}
61 61
 
62
-    /** add a snippet of javascript into the head to do a css operation we can check for later on.*/
63
-    public function insertCSSSniffer(Doku_Event $event, $param) {
64
-        $event->data["script"][] = array(
65
-            "type"  => "text/javascript",
66
-            "_data" => "document.documentElement.className += ' olCSSsupported';",
67
-        );
68
-    }
62
+	/** add a snippet of javascript into the head to do a css operation we can check for later on.*/
63
+	public function insertCSSSniffer(Doku_Event $event, $param) {
64
+		$event->data["script"][] = array(
65
+			"type"  => "text/javascript",
66
+			"_data" => "document.documentElement.className += ' olCSSsupported';",
67
+		);
68
+	}
69 69
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -39,7 +39,7 @@
 block discarded – undo
39 39
      * @param Doku_Event $event the DokuWiki event
40 40
      */
41 41
     public function insertButton(Doku_Event $event, $param) {
42
-        $strOpen       = '<olmap id="olMapOne" width="550px" height="450px" lat="50.0" ';
42
+        $strOpen = '<olmap id="olMapOne" width="550px" height="450px" lat="50.0" ';
43 43
         $strOpen       .= 'lon="5.1" zoom="12" statusbar="1" controls="1" poihoverstyle="0" ';
44 44
         $strOpen       .= 'baselyr="OpenStreetMap" gpxfile="" kmlfile="" geojsonfile="" summary="" >\n';
45 45
         $strOpen       .= '~~ Plugin olmap help.\n';
Please login to merge, or discard this patch.
icons/index.php 2 patches
Indentation   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -42,9 +42,9 @@
 block discarded – undo
42 42
 </head>
43 43
 <body>
44 44
 <div class="box"><?php
45
-    foreach(glob('*.png') as $img) {
46
-        echo '<img src="' . $img . '" alt="' . $img . '" title="' . $img . '" /> ';
47
-    }
48
-    ?></div>
45
+	foreach(glob('*.png') as $img) {
46
+		echo '<img src="' . $img . '" alt="' . $img . '" title="' . $img . '" /> ';
47
+	}
48
+	?></div>
49 49
 </body>
50 50
 </html>
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -42,8 +42,8 @@
 block discarded – undo
42 42
 </head>
43 43
 <body>
44 44
 <div class="box"><?php
45
-    foreach(glob('*.png') as $img) {
46
-        echo '<img src="' . $img . '" alt="' . $img . '" title="' . $img . '" /> ';
45
+    foreach (glob('*.png') as $img) {
46
+        echo '<img src="'.$img.'" alt="'.$img.'" title="'.$img.'" /> ';
47 47
     }
48 48
     ?></div>
49 49
 </body>
Please login to merge, or discard this patch.
helper/staticmap.php 2 patches
Indentation   +104 added lines, -104 removed lines patch added patch discarded remove patch
@@ -24,115 +24,115 @@
 block discarded – undo
24 24
  * @author Mark Prins
25 25
  */
26 26
 class helper_plugin_openlayersmap_staticmap extends DokuWiki_Plugin {
27
-    /** maximum width of the resulting image. */
28
-    private $maxWidth = 1024;
29
-    /** maximum heigth of the resulting image. */
30
-    private $maxHeight = 1024;
27
+	/** maximum width of the resulting image. */
28
+	private $maxWidth = 1024;
29
+	/** maximum heigth of the resulting image. */
30
+	private $maxHeight = 1024;
31 31
 
32
-    /**
33
-     * Provide metadata of the public methods of this class.
34
-     *
35
-     * @return array Information to all provided methods.
36
-     */
37
-    public function getMethods(): array {
38
-        $result   = array();
39
-        $result[] = array(
40
-            'name'   => 'getMap',
41
-            'desc'   => 'returns url to the image',
42
-            'params' => array(
43
-                'lat'     => 'float',
44
-                'lon'     => 'float',
45
-                'zoom'    => 'integer',
46
-                'size'    => 'string',
47
-                'maptype' => 'string',
48
-                'markers' => 'string',
49
-                'gpx'     => 'string',
50
-                'kml'     => 'string',
51
-                'geojson' => 'string',
52
-                'apikey'  => 'string'
53
-            ),
54
-            'return' => array('image' => 'string'),
55
-        );
56
-        return $result;
57
-    }
32
+	/**
33
+	 * Provide metadata of the public methods of this class.
34
+	 *
35
+	 * @return array Information to all provided methods.
36
+	 */
37
+	public function getMethods(): array {
38
+		$result   = array();
39
+		$result[] = array(
40
+			'name'   => 'getMap',
41
+			'desc'   => 'returns url to the image',
42
+			'params' => array(
43
+				'lat'     => 'float',
44
+				'lon'     => 'float',
45
+				'zoom'    => 'integer',
46
+				'size'    => 'string',
47
+				'maptype' => 'string',
48
+				'markers' => 'string',
49
+				'gpx'     => 'string',
50
+				'kml'     => 'string',
51
+				'geojson' => 'string',
52
+				'apikey'  => 'string'
53
+			),
54
+			'return' => array('image' => 'string'),
55
+		);
56
+		return $result;
57
+	}
58 58
 
59
-    /**
60
-     * Create the map.
61
-     *
62
-     * @param float  $lat     the latitude of the map's center, eg. 40.714728
63
-     * @param float  $lon     the longitude of the map's center, eg -73.998672
64
-     * @param int    $zoom    the zoom level in the tile cache, eg. 14
65
-     * @param string $size    the size in WxH px, eg. 512x512
66
-     * @param string $maptype the maptype, eg. cycle
67
-     * @param array  $markers associative array of markers, array('lat'=>$lat,'lon'=>$lon,'type'=>$iconStyle),
68
-     *                        eg. array('lat'=>40.702147,'lon'=>-74.015794,'type'=>lightblue1);
69
-     * @param string $gpx     media link
70
-     * @param string $kml     media link
71
-     * @param string $geojson media link
72
-     * @param string $apikey  optional API key eg. for Thunderforest maps
73
-     *
74
-     * @return string
75
-     */
76
-    public function getMap(float $lat, float $lon, int $zoom, string $size, string $maptype, array $markers,
77
-                           string $gpx, string $kml, string $geojson, string $apikey = ''): string {
78
-        global $conf;
79
-        // dbglog($markers,'helper_plugin_openlayersmap_staticmap::getMap: markers :');
59
+	/**
60
+	 * Create the map.
61
+	 *
62
+	 * @param float  $lat     the latitude of the map's center, eg. 40.714728
63
+	 * @param float  $lon     the longitude of the map's center, eg -73.998672
64
+	 * @param int    $zoom    the zoom level in the tile cache, eg. 14
65
+	 * @param string $size    the size in WxH px, eg. 512x512
66
+	 * @param string $maptype the maptype, eg. cycle
67
+	 * @param array  $markers associative array of markers, array('lat'=>$lat,'lon'=>$lon,'type'=>$iconStyle),
68
+	 *                        eg. array('lat'=>40.702147,'lon'=>-74.015794,'type'=>lightblue1);
69
+	 * @param string $gpx     media link
70
+	 * @param string $kml     media link
71
+	 * @param string $geojson media link
72
+	 * @param string $apikey  optional API key eg. for Thunderforest maps
73
+	 *
74
+	 * @return string
75
+	 */
76
+	public function getMap(float $lat, float $lon, int $zoom, string $size, string $maptype, array $markers,
77
+						   string $gpx, string $kml, string $geojson, string $apikey = ''): string {
78
+		global $conf;
79
+		// dbglog($markers,'helper_plugin_openlayersmap_staticmap::getMap: markers :');
80 80
 
81
-        // normalize zoom
82
-        $zoom = $zoom ?: 0;
83
-        if($zoom > 18) {
84
-            $zoom = 18;
85
-        }
86
-        // normalize WxH
87
-        list($width, $height) = explode('x', $size);
88
-        $width = (int) $width;
89
-        if($width > $this->maxWidth) {
90
-            $width = $this->maxWidth;
91
-        }
92
-        $height = (int) $height;
93
-        if($height > $this->maxHeight) {
94
-            $height = $this->maxHeight;
95
-        }
81
+		// normalize zoom
82
+		$zoom = $zoom ?: 0;
83
+		if($zoom > 18) {
84
+			$zoom = 18;
85
+		}
86
+		// normalize WxH
87
+		list($width, $height) = explode('x', $size);
88
+		$width = (int) $width;
89
+		if($width > $this->maxWidth) {
90
+			$width = $this->maxWidth;
91
+		}
92
+		$height = (int) $height;
93
+		if($height > $this->maxHeight) {
94
+			$height = $this->maxHeight;
95
+		}
96 96
 
97
-        // cleanup/validate gpx/kml
98
-        $kml = $this->mediaIdToPath($kml);
99
-        // dbglog($kml,'helper_plugin_openlayersmap_staticmap::getMap: kml file:');
100
-        $gpx = $this->mediaIdToPath($gpx);
101
-        // dbglog($gpx,'helper_plugin_openlayersmap_staticmap::getMap: gpx file:');
102
-        $geojson = $this->mediaIdToPath($geojson);
97
+		// cleanup/validate gpx/kml
98
+		$kml = $this->mediaIdToPath($kml);
99
+		// dbglog($kml,'helper_plugin_openlayersmap_staticmap::getMap: kml file:');
100
+		$gpx = $this->mediaIdToPath($gpx);
101
+		// dbglog($gpx,'helper_plugin_openlayersmap_staticmap::getMap: gpx file:');
102
+		$geojson = $this->mediaIdToPath($geojson);
103 103
 
104
-        // create map
105
-        $map = new StaticMap(
106
-            $lat, $lon, $zoom, $width, $height, $maptype,
107
-            $markers, $gpx, $kml, $geojson, $conf['mediadir'], $conf['cachedir'],
108
-            $this->getConf('autoZoomMap'),
109
-            $apikey
110
-        );
104
+		// create map
105
+		$map = new StaticMap(
106
+			$lat, $lon, $zoom, $width, $height, $maptype,
107
+			$markers, $gpx, $kml, $geojson, $conf['mediadir'], $conf['cachedir'],
108
+			$this->getConf('autoZoomMap'),
109
+			$apikey
110
+		);
111 111
 
112
-        // return the media id url
113
-        // $mediaId = str_replace('/', ':', $map->getMap());
114
-        // if($this->startsWith($mediaId,':')) {
115
-        //     $mediaId = substr($mediaId, 1);
116
-        // }
117
-        // return $mediaId;
118
-        return str_replace('/', ':', $map->getMap());
119
-    }
112
+		// return the media id url
113
+		// $mediaId = str_replace('/', ':', $map->getMap());
114
+		// if($this->startsWith($mediaId,':')) {
115
+		//     $mediaId = substr($mediaId, 1);
116
+		// }
117
+		// return $mediaId;
118
+		return str_replace('/', ':', $map->getMap());
119
+	}
120 120
 
121
-    /**
122
-     * Constructs the path to a file.
123
-     * @param string $id the DW media id
124
-     * @return string the path to the file
125
-     */
126
-    private function mediaIdToPath(string $id): string {
127
-        global $conf;
128
-        if(empty($id)) {
129
-            return "";
130
-        }
131
-        $id = str_replace(array("[[", "]]"), "", $id);
132
-        if((strpos($id, ':') === 0)) {
133
-            $id = substr($id, 1);
134
-        }
135
-        $id = str_replace(":", "/", $id);
136
-        return $conf['mediadir'] . '/' . $id;
137
-    }
121
+	/**
122
+	 * Constructs the path to a file.
123
+	 * @param string $id the DW media id
124
+	 * @return string the path to the file
125
+	 */
126
+	private function mediaIdToPath(string $id): string {
127
+		global $conf;
128
+		if(empty($id)) {
129
+			return "";
130
+		}
131
+		$id = str_replace(array("[[", "]]"), "", $id);
132
+		if((strpos($id, ':') === 0)) {
133
+			$id = substr($id, 1);
134
+		}
135
+		$id = str_replace(":", "/", $id);
136
+		return $conf['mediadir'] . '/' . $id;
137
+	}
138 138
 }
Please login to merge, or discard this patch.
Spacing   +6 added lines, -6 removed lines patch added patch discarded remove patch
@@ -80,17 +80,17 @@  discard block
 block discarded – undo
80 80
 
81 81
         // normalize zoom
82 82
         $zoom = $zoom ?: 0;
83
-        if($zoom > 18) {
83
+        if ($zoom > 18) {
84 84
             $zoom = 18;
85 85
         }
86 86
         // normalize WxH
87 87
         list($width, $height) = explode('x', $size);
88 88
         $width = (int) $width;
89
-        if($width > $this->maxWidth) {
89
+        if ($width > $this->maxWidth) {
90 90
             $width = $this->maxWidth;
91 91
         }
92 92
         $height = (int) $height;
93
-        if($height > $this->maxHeight) {
93
+        if ($height > $this->maxHeight) {
94 94
             $height = $this->maxHeight;
95 95
         }
96 96
 
@@ -125,14 +125,14 @@  discard block
 block discarded – undo
125 125
      */
126 126
     private function mediaIdToPath(string $id): string {
127 127
         global $conf;
128
-        if(empty($id)) {
128
+        if (empty($id)) {
129 129
             return "";
130 130
         }
131 131
         $id = str_replace(array("[[", "]]"), "", $id);
132
-        if((strpos($id, ':') === 0)) {
132
+        if ((strpos($id, ':') === 0)) {
133 133
             $id = substr($id, 1);
134 134
         }
135 135
         $id = str_replace(":", "/", $id);
136
-        return $conf['mediadir'] . '/' . $id;
136
+        return $conf['mediadir'].'/'.$id;
137 137
     }
138 138
 }
Please login to merge, or discard this patch.
_test/general.test.php 2 patches
Indentation   +33 added lines, -33 removed lines patch added patch discarded remove patch
@@ -24,42 +24,42 @@
 block discarded – undo
24 24
  */
25 25
 class general_plugin_openlayersmap_test extends DokuWikiTest {
26 26
 
27
-    protected $pluginsEnabled = array('openlayersmap', 'geophp');
27
+	protected $pluginsEnabled = array('openlayersmap', 'geophp');
28 28
 
29
-    /**
30
-     * Simple test to make sure the plugin.info.txt is in correct format.
31
-     */
32
-    final public function test_plugininfo(): void {
33
-        $file = __DIR__ . '/../plugin.info.txt';
34
-        self::assertFileExists($file);
29
+	/**
30
+	 * Simple test to make sure the plugin.info.txt is in correct format.
31
+	 */
32
+	final public function test_plugininfo(): void {
33
+		$file = __DIR__ . '/../plugin.info.txt';
34
+		self::assertFileExists($file);
35 35
 
36
-        $info = confToHash($file);
36
+		$info = confToHash($file);
37 37
 
38
-        self::assertArrayHasKey('base', $info);
39
-        self::assertArrayHasKey('author', $info);
40
-        self::assertArrayHasKey('email', $info);
41
-        self::assertArrayHasKey('date', $info);
42
-        self::assertArrayHasKey('name', $info);
43
-        self::assertArrayHasKey('desc', $info);
44
-        self::assertArrayHasKey('url', $info);
38
+		self::assertArrayHasKey('base', $info);
39
+		self::assertArrayHasKey('author', $info);
40
+		self::assertArrayHasKey('email', $info);
41
+		self::assertArrayHasKey('date', $info);
42
+		self::assertArrayHasKey('name', $info);
43
+		self::assertArrayHasKey('desc', $info);
44
+		self::assertArrayHasKey('url', $info);
45 45
 
46
-        self::assertEquals('openlayersmap', $info['base']);
47
-        self::assertRegExp('/^https?:\/\//', $info['url']);
48
-        self::assertTrue(mail_isvalid($info['email']));
49
-        self::assertRegExp('/^\d\d\d\d-\d\d-\d\d$/', $info['date']);
50
-        self::assertTrue(false !== strtotime($info['date']));
51
-    }
46
+		self::assertEquals('openlayersmap', $info['base']);
47
+		self::assertRegExp('/^https?:\/\//', $info['url']);
48
+		self::assertTrue(mail_isvalid($info['email']));
49
+		self::assertRegExp('/^\d\d\d\d-\d\d-\d\d$/', $info['date']);
50
+		self::assertTrue(false !== strtotime($info['date']));
51
+	}
52 52
 
53
-    /**
54
-     * test if plugin is loaded.
55
-     */
56
-    final public function test_plugin_openlayersmap_isloaded(): void {
57
-        global $plugin_controller;
58
-        self::assertContains(
59
-            'geophp', $plugin_controller->getList(), "geophp plugin is loaded"
60
-        );
61
-        self::assertContains(
62
-            'openlayersmap', $plugin_controller->getList(), "openlayersmap plugin is loaded"
63
-        );
64
-    }
53
+	/**
54
+	 * test if plugin is loaded.
55
+	 */
56
+	final public function test_plugin_openlayersmap_isloaded(): void {
57
+		global $plugin_controller;
58
+		self::assertContains(
59
+			'geophp', $plugin_controller->getList(), "geophp plugin is loaded"
60
+		);
61
+		self::assertContains(
62
+			'openlayersmap', $plugin_controller->getList(), "openlayersmap plugin is loaded"
63
+		);
64
+	}
65 65
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -30,7 +30,7 @@
 block discarded – undo
30 30
      * Simple test to make sure the plugin.info.txt is in correct format.
31 31
      */
32 32
     final public function test_plugininfo(): void {
33
-        $file = __DIR__ . '/../plugin.info.txt';
33
+        $file = __DIR__.'/../plugin.info.txt';
34 34
         self::assertFileExists($file);
35 35
 
36 36
         $info = confToHash($file);
Please login to merge, or discard this patch.
admin/purge.php 2 patches
Indentation   +86 added lines, -86 removed lines patch added patch discarded remove patch
@@ -24,96 +24,96 @@
 block discarded – undo
24 24
  * @author Mark Prins
25 25
  */
26 26
 class admin_plugin_openlayersmap_purge extends DokuWiki_Admin_Plugin {
27
-    /**
28
-     * (non-PHPdoc)
29
-     * @see DokuWiki_Admin_Plugin::getMenuSort()
30
-     */
31
-    public function getMenuSort(): int {
32
-        return 800;
33
-    }
27
+	/**
28
+	 * (non-PHPdoc)
29
+	 * @see DokuWiki_Admin_Plugin::getMenuSort()
30
+	 */
31
+	public function getMenuSort(): int {
32
+		return 800;
33
+	}
34 34
 
35
-    /**
36
-     * (non-PHPdoc)
37
-     * @see DokuWiki_Admin_Plugin::handle()
38
-     */
39
-    public function handle(): void {
40
-        global $conf;
41
-        if(!isset($_REQUEST['continue']) || !checkSecurityToken()) {
42
-            return;
43
-        }
44
-        if(isset($_REQUEST['purgetiles'])) {
45
-            $path = $conf['cachedir'] . '/olmaptiles';
46
-            if($this->rrmdir($path)) {
47
-                msg($this->getLang('admin_purged_tiles'), 0);
48
-            }
49
-        }
50
-        if(isset($_REQUEST['purgemaps'])) {
51
-            $path = $conf['mediadir'] . '/olmapmaps';
52
-            if($this->rrmdir($path)) {
53
-                msg($this->getLang('admin_purged_maps'), 0);
54
-            }
55
-        }
56
-    }
35
+	/**
36
+	 * (non-PHPdoc)
37
+	 * @see DokuWiki_Admin_Plugin::handle()
38
+	 */
39
+	public function handle(): void {
40
+		global $conf;
41
+		if(!isset($_REQUEST['continue']) || !checkSecurityToken()) {
42
+			return;
43
+		}
44
+		if(isset($_REQUEST['purgetiles'])) {
45
+			$path = $conf['cachedir'] . '/olmaptiles';
46
+			if($this->rrmdir($path)) {
47
+				msg($this->getLang('admin_purged_tiles'), 0);
48
+			}
49
+		}
50
+		if(isset($_REQUEST['purgemaps'])) {
51
+			$path = $conf['mediadir'] . '/olmapmaps';
52
+			if($this->rrmdir($path)) {
53
+				msg($this->getLang('admin_purged_maps'), 0);
54
+			}
55
+		}
56
+	}
57 57
 
58
-    /**
59
-     * Recursively delete the directory.
60
-     * @param string $sDir directory path
61
-     * @return boolean true when succesful
62
-     */
63
-    private function rrmdir(string $sDir): bool {
64
-        if(is_dir($sDir)) {
65
-            dbglog($sDir, 'admin_plugin_openlayersmap_purge::rrmdir: recursively removing path: ');
66
-            $sDir = rtrim($sDir, '/');
67
-            $oDir = dir($sDir);
68
-            while(($sFile = $oDir->read()) !== false) {
69
-                if($sFile !== '.' && $sFile !== '..') {
70
-                    (!is_link("$sDir/$sFile") && is_dir("$sDir/$sFile")) ?
71
-                        $this->rrmdir("$sDir/$sFile") : unlink("$sDir/$sFile");
72
-                }
73
-            }
74
-            $oDir->close();
75
-            rmdir($sDir);
76
-            return true;
77
-        }
78
-        return false;
79
-    }
58
+	/**
59
+	 * Recursively delete the directory.
60
+	 * @param string $sDir directory path
61
+	 * @return boolean true when succesful
62
+	 */
63
+	private function rrmdir(string $sDir): bool {
64
+		if(is_dir($sDir)) {
65
+			dbglog($sDir, 'admin_plugin_openlayersmap_purge::rrmdir: recursively removing path: ');
66
+			$sDir = rtrim($sDir, '/');
67
+			$oDir = dir($sDir);
68
+			while(($sFile = $oDir->read()) !== false) {
69
+				if($sFile !== '.' && $sFile !== '..') {
70
+					(!is_link("$sDir/$sFile") && is_dir("$sDir/$sFile")) ?
71
+						$this->rrmdir("$sDir/$sFile") : unlink("$sDir/$sFile");
72
+				}
73
+			}
74
+			$oDir->close();
75
+			rmdir($sDir);
76
+			return true;
77
+		}
78
+		return false;
79
+	}
80 80
 
81
-    /**
82
-     * (non-PHPdoc)
83
-     * @see DokuWiki_Admin_Plugin::html()
84
-     */
85
-    public function html(): void {
86
-        echo $this->locale_xhtml('admin_intro');
87
-        $form = new Doku_Form(array('id' => 'olmap_purgeform', 'method' => 'post'));
88
-        $form->addHidden('continue', 'go');
81
+	/**
82
+	 * (non-PHPdoc)
83
+	 * @see DokuWiki_Admin_Plugin::html()
84
+	 */
85
+	public function html(): void {
86
+		echo $this->locale_xhtml('admin_intro');
87
+		$form = new Doku_Form(array('id' => 'olmap_purgeform', 'method' => 'post'));
88
+		$form->addHidden('continue', 'go');
89 89
 
90
-        $form->startFieldset($this->getLang('admin_tiles'));
91
-        $form->addElement('<p>');
92
-        $form->addElement(
93
-            '<input id="purgetiles" name="purgetiles" type="checkbox" value="1" class="checkbox" />'
94
-        );
95
-        $form->addElement(
96
-            '<label for="purgetiles" class="label">' . $this->getLang('admin_purge_tiles')
97
-            . '</label>'
98
-        );
99
-        $form->addElement('</p>');
100
-        $form->endFieldset();
90
+		$form->startFieldset($this->getLang('admin_tiles'));
91
+		$form->addElement('<p>');
92
+		$form->addElement(
93
+			'<input id="purgetiles" name="purgetiles" type="checkbox" value="1" class="checkbox" />'
94
+		);
95
+		$form->addElement(
96
+			'<label for="purgetiles" class="label">' . $this->getLang('admin_purge_tiles')
97
+			. '</label>'
98
+		);
99
+		$form->addElement('</p>');
100
+		$form->endFieldset();
101 101
 
102
-        $form->startFieldset($this->getLang('admin_maps'));
103
-        $form->addElement('<p>');
104
-        $form->addElement('<input id="purgemaps" name="purgemaps" type="checkbox" value="1" class="checkbox" />');
105
-        $form->addElement(
106
-            '<label for="purgemaps" class="label">' . $this->getLang('admin_purge_maps') . '</label>'
107
-        );
108
-        $form->addElement('</p>');
109
-        $form->endFieldset();
102
+		$form->startFieldset($this->getLang('admin_maps'));
103
+		$form->addElement('<p>');
104
+		$form->addElement('<input id="purgemaps" name="purgemaps" type="checkbox" value="1" class="checkbox" />');
105
+		$form->addElement(
106
+			'<label for="purgemaps" class="label">' . $this->getLang('admin_purge_maps') . '</label>'
107
+		);
108
+		$form->addElement('</p>');
109
+		$form->endFieldset();
110 110
 
111
-        $form->addElement(
112
-            form_makeButton(
113
-                'submit', 'admin', $this->getLang('admin_submit'),
114
-                array('accesskey' => 'p', 'title' => $this->getLang('admin_submit'))
115
-            )
116
-        );
117
-        $form->printForm();
118
-    }
111
+		$form->addElement(
112
+			form_makeButton(
113
+				'submit', 'admin', $this->getLang('admin_submit'),
114
+				array('accesskey' => 'p', 'title' => $this->getLang('admin_submit'))
115
+			)
116
+		);
117
+		$form->printForm();
118
+	}
119 119
 }
Please login to merge, or discard this patch.
Spacing   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -38,18 +38,18 @@  discard block
 block discarded – undo
38 38
      */
39 39
     public function handle(): void {
40 40
         global $conf;
41
-        if(!isset($_REQUEST['continue']) || !checkSecurityToken()) {
41
+        if (!isset($_REQUEST['continue']) || !checkSecurityToken()) {
42 42
             return;
43 43
         }
44
-        if(isset($_REQUEST['purgetiles'])) {
45
-            $path = $conf['cachedir'] . '/olmaptiles';
46
-            if($this->rrmdir($path)) {
44
+        if (isset($_REQUEST['purgetiles'])) {
45
+            $path = $conf['cachedir'].'/olmaptiles';
46
+            if ($this->rrmdir($path)) {
47 47
                 msg($this->getLang('admin_purged_tiles'), 0);
48 48
             }
49 49
         }
50
-        if(isset($_REQUEST['purgemaps'])) {
51
-            $path = $conf['mediadir'] . '/olmapmaps';
52
-            if($this->rrmdir($path)) {
50
+        if (isset($_REQUEST['purgemaps'])) {
51
+            $path = $conf['mediadir'].'/olmapmaps';
52
+            if ($this->rrmdir($path)) {
53 53
                 msg($this->getLang('admin_purged_maps'), 0);
54 54
             }
55 55
         }
@@ -61,12 +61,12 @@  discard block
 block discarded – undo
61 61
      * @return boolean true when succesful
62 62
      */
63 63
     private function rrmdir(string $sDir): bool {
64
-        if(is_dir($sDir)) {
64
+        if (is_dir($sDir)) {
65 65
             dbglog($sDir, 'admin_plugin_openlayersmap_purge::rrmdir: recursively removing path: ');
66 66
             $sDir = rtrim($sDir, '/');
67 67
             $oDir = dir($sDir);
68
-            while(($sFile = $oDir->read()) !== false) {
69
-                if($sFile !== '.' && $sFile !== '..') {
68
+            while (($sFile = $oDir->read()) !== false) {
69
+                if ($sFile !== '.' && $sFile !== '..') {
70 70
                     (!is_link("$sDir/$sFile") && is_dir("$sDir/$sFile")) ?
71 71
                         $this->rrmdir("$sDir/$sFile") : unlink("$sDir/$sFile");
72 72
                 }
@@ -93,7 +93,7 @@  discard block
 block discarded – undo
93 93
             '<input id="purgetiles" name="purgetiles" type="checkbox" value="1" class="checkbox" />'
94 94
         );
95 95
         $form->addElement(
96
-            '<label for="purgetiles" class="label">' . $this->getLang('admin_purge_tiles')
96
+            '<label for="purgetiles" class="label">'.$this->getLang('admin_purge_tiles')
97 97
             . '</label>'
98 98
         );
99 99
         $form->addElement('</p>');
@@ -103,7 +103,7 @@  discard block
 block discarded – undo
103 103
         $form->addElement('<p>');
104 104
         $form->addElement('<input id="purgemaps" name="purgemaps" type="checkbox" value="1" class="checkbox" />');
105 105
         $form->addElement(
106
-            '<label for="purgemaps" class="label">' . $this->getLang('admin_purge_maps') . '</label>'
106
+            '<label for="purgemaps" class="label">'.$this->getLang('admin_purge_maps').'</label>'
107 107
         );
108 108
         $form->addElement('</p>');
109 109
         $form->endFieldset();
Please login to merge, or discard this patch.
syntax/olmap.php 3 patches
Indentation   +732 added lines, -732 removed lines patch added patch discarded remove patch
@@ -25,108 +25,108 @@  discard block
 block discarded – undo
25 25
  */
26 26
 class syntax_plugin_openlayersmap_olmap extends DokuWiki_Syntax_Plugin {
27 27
 
28
-    /**
29
-     * defaults of the known attributes of the olmap tag.
30
-     */
31
-    private $dflt = array(
32
-        'id'            => 'olmap',
33
-        'width'         => '550px',
34
-        'height'        => '450px',
35
-        'lat'           => 50.0,
36
-        'lon'           => 5.1,
37
-        'zoom'          => 12,
38
-        'autozoom'      => 1,
39
-        'statusbar'     => true,
40
-        'toolbar'       => true,
41
-        'controls'      => true,
42
-        'poihoverstyle' => false,
43
-        'baselyr'       => 'OpenStreetMap',
44
-        'gpxfile'       => '',
45
-        'kmlfile'       => '',
46
-        'geojsonfile'   => '',
47
-        'summary'       => ''
48
-    );
49
-
50
-    /**
51
-     *
52
-     * @see DokuWiki_Syntax_Plugin::getType()
53
-     */
54
-    public function getType(): string {
55
-        return 'substition';
56
-    }
57
-
58
-    /**
59
-     *
60
-     * @see DokuWiki_Syntax_Plugin::getPType()
61
-     */
62
-    public function getPType(): string {
63
-        return 'block';
64
-    }
65
-
66
-    /**
67
-     *
68
-     * @see Doku_Parser_Mode::getSort()
69
-     */
70
-    public function getSort(): int {
71
-        return 901;
72
-    }
73
-
74
-    /**
75
-     *
76
-     * @see Doku_Parser_Mode::connectTo()
77
-     */
78
-    public function connectTo($mode) {
79
-        $this->Lexer->addSpecialPattern(
80
-            '<olmap ?[^>\n]*>.*?</olmap>', $mode,
81
-            'plugin_openlayersmap_olmap'
82
-        );
83
-    }
84
-
85
-    /**
86
-     *
87
-     * @see DokuWiki_Syntax_Plugin::handle()
88
-     */
89
-    public function handle($match, $state, $pos, Doku_Handler $handler): array {
90
-        // break matched cdata into its components
91
-        list ($str_params, $str_points) = explode('>', substr($match, 7, -9), 2);
92
-        // get the lat/lon for adding them to the metadata (used by geotag)
93
-        preg_match('(lat[:|=]\"-?\d*\.?\d*\")', $match, $mainLat);
94
-        preg_match('(lon[:|=]\"-?\d*\.?\d*\")', $match, $mainLon);
95
-        $mainLat = substr($mainLat [0], 5, -1);
96
-        $mainLon = substr($mainLon [0], 5, -1);
97
-        if(!is_numeric($mainLat)) {
98
-            $mainLat = $this->dflt ['lat'];
99
-        }
100
-        if(!is_numeric($mainLon)) {
101
-            $mainLon = $this->dflt ['lon'];
102
-        }
103
-
104
-        $gmap          = $this->extractParams($str_params);
105
-        $overlay       = $this->extractPoints($str_points);
106
-        $_firstimageID = '';
107
-
108
-        $_nocache = false;
109
-        // choose maptype based on the specified tag
110
-        $imgUrl = "{{";
111
-        if(stripos($gmap ['baselyr'], 'google') !== false) {
112
-            // Google
113
-            $imgUrl .= $this->getGoogle($gmap, $overlay);
114
-            $imgUrl .= "&.png";
115
-        } elseif(stripos($gmap ['baselyr'], 'bing') !== false) {
116
-            // Bing
117
-            if(!$this->getConf('bingAPIKey')) {
118
-                // in case there is no Bing api key we'll use OSM
119
-                $_firstimageID = $this->getStaticOSM($gmap, $overlay);
120
-                $imgUrl        .= $_firstimageID;
121
-                if($this->getConf('optionStaticMapGenerator') == 'remote') {
122
-                    $imgUrl .= "&.png";
123
-                }
124
-            } else {
125
-                // seems that Bing doesn't like the DW client, turn off caching
126
-                $_nocache = true;
127
-                $imgUrl   .= $this->getBing($gmap, $overlay) . "&.png";
128
-            }
129
-        } /* elseif (stripos ( $gmap ['baselyr'], 'mapquest' ) !== false) {
28
+	/**
29
+	 * defaults of the known attributes of the olmap tag.
30
+	 */
31
+	private $dflt = array(
32
+		'id'            => 'olmap',
33
+		'width'         => '550px',
34
+		'height'        => '450px',
35
+		'lat'           => 50.0,
36
+		'lon'           => 5.1,
37
+		'zoom'          => 12,
38
+		'autozoom'      => 1,
39
+		'statusbar'     => true,
40
+		'toolbar'       => true,
41
+		'controls'      => true,
42
+		'poihoverstyle' => false,
43
+		'baselyr'       => 'OpenStreetMap',
44
+		'gpxfile'       => '',
45
+		'kmlfile'       => '',
46
+		'geojsonfile'   => '',
47
+		'summary'       => ''
48
+	);
49
+
50
+	/**
51
+	 *
52
+	 * @see DokuWiki_Syntax_Plugin::getType()
53
+	 */
54
+	public function getType(): string {
55
+		return 'substition';
56
+	}
57
+
58
+	/**
59
+	 *
60
+	 * @see DokuWiki_Syntax_Plugin::getPType()
61
+	 */
62
+	public function getPType(): string {
63
+		return 'block';
64
+	}
65
+
66
+	/**
67
+	 *
68
+	 * @see Doku_Parser_Mode::getSort()
69
+	 */
70
+	public function getSort(): int {
71
+		return 901;
72
+	}
73
+
74
+	/**
75
+	 *
76
+	 * @see Doku_Parser_Mode::connectTo()
77
+	 */
78
+	public function connectTo($mode) {
79
+		$this->Lexer->addSpecialPattern(
80
+			'<olmap ?[^>\n]*>.*?</olmap>', $mode,
81
+			'plugin_openlayersmap_olmap'
82
+		);
83
+	}
84
+
85
+	/**
86
+	 *
87
+	 * @see DokuWiki_Syntax_Plugin::handle()
88
+	 */
89
+	public function handle($match, $state, $pos, Doku_Handler $handler): array {
90
+		// break matched cdata into its components
91
+		list ($str_params, $str_points) = explode('>', substr($match, 7, -9), 2);
92
+		// get the lat/lon for adding them to the metadata (used by geotag)
93
+		preg_match('(lat[:|=]\"-?\d*\.?\d*\")', $match, $mainLat);
94
+		preg_match('(lon[:|=]\"-?\d*\.?\d*\")', $match, $mainLon);
95
+		$mainLat = substr($mainLat [0], 5, -1);
96
+		$mainLon = substr($mainLon [0], 5, -1);
97
+		if(!is_numeric($mainLat)) {
98
+			$mainLat = $this->dflt ['lat'];
99
+		}
100
+		if(!is_numeric($mainLon)) {
101
+			$mainLon = $this->dflt ['lon'];
102
+		}
103
+
104
+		$gmap          = $this->extractParams($str_params);
105
+		$overlay       = $this->extractPoints($str_points);
106
+		$_firstimageID = '';
107
+
108
+		$_nocache = false;
109
+		// choose maptype based on the specified tag
110
+		$imgUrl = "{{";
111
+		if(stripos($gmap ['baselyr'], 'google') !== false) {
112
+			// Google
113
+			$imgUrl .= $this->getGoogle($gmap, $overlay);
114
+			$imgUrl .= "&.png";
115
+		} elseif(stripos($gmap ['baselyr'], 'bing') !== false) {
116
+			// Bing
117
+			if(!$this->getConf('bingAPIKey')) {
118
+				// in case there is no Bing api key we'll use OSM
119
+				$_firstimageID = $this->getStaticOSM($gmap, $overlay);
120
+				$imgUrl        .= $_firstimageID;
121
+				if($this->getConf('optionStaticMapGenerator') == 'remote') {
122
+					$imgUrl .= "&.png";
123
+				}
124
+			} else {
125
+				// seems that Bing doesn't like the DW client, turn off caching
126
+				$_nocache = true;
127
+				$imgUrl   .= $this->getBing($gmap, $overlay) . "&.png";
128
+			}
129
+		} /* elseif (stripos ( $gmap ['baselyr'], 'mapquest' ) !== false) {
130 130
             // MapQuest
131 131
             if (! $this->getConf ( 'mapquestAPIKey' )) {
132 132
                 // no API key for MapQuest, use OSM
@@ -140,169 +140,169 @@  discard block
 block discarded – undo
140 140
                 $imgUrl .= "&.png";
141 141
             }
142 142
         } */ else {
143
-            // default OSM
144
-            $_firstimageID = $this->getStaticOSM($gmap, $overlay);
145
-            $imgUrl        .= $_firstimageID;
146
-            if($this->getConf('optionStaticMapGenerator') == 'remote') {
147
-                $imgUrl .= "&.png";
148
-            }
149
-        }
150
-
151
-        // append dw p_render specific params and render
152
-        $imgUrl .= "?" . str_replace("px", "", $gmap ['width']) . "x"
153
-            . str_replace("px", "", $gmap ['height']);
154
-        $imgUrl .= "&nolink";
155
-
156
-        // add nocache option for selected services
157
-        if($_nocache) {
158
-            $imgUrl .= "&nocache";
159
-        }
160
-
161
-        $imgUrl .= " |" . $gmap ['summary'] . " }}";
162
-
163
-        // dbglog($imgUrl,"complete image tags is:");
164
-
165
-        $mapid = $gmap ['id'];
166
-        // create a javascript parameter string for the map
167
-        $param = '';
168
-        foreach($gmap as $key => $val) {
169
-            $param .= is_numeric($val) ? "$key: $val, " : "$key: '" . hsc($val) . "', ";
170
-        }
171
-        if(!empty ($param)) {
172
-            $param = substr($param, 0, -2);
173
-        }
174
-        unset ($gmap ['id']);
175
-
176
-        // create a javascript serialisation of the point data
177
-        $poi      = '';
178
-        $poitable = '';
179
-        $rowId    = 0;
180
-        if(!empty ($overlay)) {
181
-            foreach($overlay as $data) {
182
-                list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
183
-                $rowId++;
184
-                $poi .= ", {lat:$lat,lon:$lon,txt:'$text',angle:$angle,opacity:$opacity,img:'$img',rowId: $rowId}";
185
-
186
-                if($this->getConf('displayformat') === 'DMS') {
187
-                    $lat = $this->convertLat($lat);
188
-                    $lon = $this->convertLon($lon);
189
-                } else {
190
-                    $lat .= 'º';
191
-                    $lon .= 'º';
192
-                }
193
-
194
-                $poitable .= '
143
+			// default OSM
144
+			$_firstimageID = $this->getStaticOSM($gmap, $overlay);
145
+			$imgUrl        .= $_firstimageID;
146
+			if($this->getConf('optionStaticMapGenerator') == 'remote') {
147
+				$imgUrl .= "&.png";
148
+			}
149
+		}
150
+
151
+		// append dw p_render specific params and render
152
+		$imgUrl .= "?" . str_replace("px", "", $gmap ['width']) . "x"
153
+			. str_replace("px", "", $gmap ['height']);
154
+		$imgUrl .= "&nolink";
155
+
156
+		// add nocache option for selected services
157
+		if($_nocache) {
158
+			$imgUrl .= "&nocache";
159
+		}
160
+
161
+		$imgUrl .= " |" . $gmap ['summary'] . " }}";
162
+
163
+		// dbglog($imgUrl,"complete image tags is:");
164
+
165
+		$mapid = $gmap ['id'];
166
+		// create a javascript parameter string for the map
167
+		$param = '';
168
+		foreach($gmap as $key => $val) {
169
+			$param .= is_numeric($val) ? "$key: $val, " : "$key: '" . hsc($val) . "', ";
170
+		}
171
+		if(!empty ($param)) {
172
+			$param = substr($param, 0, -2);
173
+		}
174
+		unset ($gmap ['id']);
175
+
176
+		// create a javascript serialisation of the point data
177
+		$poi      = '';
178
+		$poitable = '';
179
+		$rowId    = 0;
180
+		if(!empty ($overlay)) {
181
+			foreach($overlay as $data) {
182
+				list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
183
+				$rowId++;
184
+				$poi .= ", {lat:$lat,lon:$lon,txt:'$text',angle:$angle,opacity:$opacity,img:'$img',rowId: $rowId}";
185
+
186
+				if($this->getConf('displayformat') === 'DMS') {
187
+					$lat = $this->convertLat($lat);
188
+					$lon = $this->convertLon($lon);
189
+				} else {
190
+					$lat .= 'º';
191
+					$lon .= 'º';
192
+				}
193
+
194
+				$poitable .= '
195 195
                     <tr>
196 196
                     <td class="rowId">' . $rowId . '</td>
197 197
                     <td class="icon"><img src="' . DOKU_BASE . 'lib/plugins/openlayersmap/icons/' . $img . '" alt="'
198
-                    . substr($img, 0, -4) . $this->getlang('alt_legend_poi') . ' " /></td>
198
+					. substr($img, 0, -4) . $this->getlang('alt_legend_poi') . ' " /></td>
199 199
                     <td class="lat" title="' . $this->getLang('olmapPOIlatTitle') . '">' . $lat . '</td>
200 200
                     <td class="lon" title="' . $this->getLang('olmapPOIlonTitle') . '">' . $lon . '</td>
201 201
                     <td class="txt">' . $text . '</td>
202 202
                     </tr>';
203
-            }
204
-            $poi = substr($poi, 2);
205
-        }
206
-        if(!empty ($gmap ['kmlfile'])) {
207
-            $poitable .= '
203
+			}
204
+			$poi = substr($poi, 2);
205
+		}
206
+		if(!empty ($gmap ['kmlfile'])) {
207
+			$poitable .= '
208 208
                     <tr>
209 209
                     <td class="rowId"><img src="' . DOKU_BASE
210
-                . 'lib/plugins/openlayersmap/toolbar/kml_file.png" alt="KML file" /></td>
210
+				. 'lib/plugins/openlayersmap/toolbar/kml_file.png" alt="KML file" /></td>
211 211
                     <td class="icon"><img src="' . DOKU_BASE . 'lib/plugins/openlayersmap/toolbar/kml_line.png" alt="'
212
-                . $this->getlang('alt_legend_kml') . '" /></td>
212
+				. $this->getlang('alt_legend_kml') . '" /></td>
213 213
                     <td class="txt" colspan="3">KML track: ' . $this->getFileName($gmap ['kmlfile']) . '</td>
214 214
                     </tr>';
215
-        }
216
-        if(!empty ($gmap ['gpxfile'])) {
217
-            $poitable .= '
215
+		}
216
+		if(!empty ($gmap ['gpxfile'])) {
217
+			$poitable .= '
218 218
                     <tr>
219 219
                     <td class="rowId"><img src="' . DOKU_BASE
220
-                . 'lib/plugins/openlayersmap/toolbar/gpx_file.png" alt="GPX file" /></td>
220
+				. 'lib/plugins/openlayersmap/toolbar/gpx_file.png" alt="GPX file" /></td>
221 221
                     <td class="icon"><img src="' . DOKU_BASE
222
-                . 'lib/plugins/openlayersmap/toolbar/gpx_line.png" alt="'
223
-                . $this->getlang('alt_legend_gpx') . '" /></td>
222
+				. 'lib/plugins/openlayersmap/toolbar/gpx_line.png" alt="'
223
+				. $this->getlang('alt_legend_gpx') . '" /></td>
224 224
                     <td class="txt" colspan="3">GPX track: ' . $this->getFileName($gmap ['gpxfile']) . '</td>
225 225
                     </tr>';
226
-        }
227
-        if(!empty ($gmap ['geojsonfile'])) {
228
-            $poitable .= '
226
+		}
227
+		if(!empty ($gmap ['geojsonfile'])) {
228
+			$poitable .= '
229 229
                     <tr>
230 230
                     <td class="rowId"><img src="' . DOKU_BASE
231
-                . 'lib/plugins/openlayersmap/toolbar/geojson_file.png" alt="GeoJSON file" /></td>
231
+				. 'lib/plugins/openlayersmap/toolbar/geojson_file.png" alt="GeoJSON file" /></td>
232 232
                     <td class="icon"><img src="' . DOKU_BASE
233
-                . 'lib/plugins/openlayersmap/toolbar/geojson_line.png" alt="'
234
-                . $this->getlang('alt_legend_geojson') . '" /></td>
233
+				. 'lib/plugins/openlayersmap/toolbar/geojson_line.png" alt="'
234
+				. $this->getlang('alt_legend_geojson') . '" /></td>
235 235
                     <td class="txt" colspan="3">GeoJSON track: ' . $this->getFileName($gmap ['geojsonfile']) . '</td>
236 236
                     </tr>';
237
-        }
238
-
239
-        $autozoom = empty ($gmap ['autozoom']) ? $this->getConf('autoZoomMap') : $gmap ['autozoom'];
240
-        $js       = "{mapOpts: {" . $param . ", displayformat: '" . $this->getConf('displayformat')
241
-            . "', autozoom: " . $autozoom . "}, poi: [$poi]};";
242
-        // unescape the json
243
-        $poitable = stripslashes($poitable);
244
-
245
-        return array(
246
-            $mapid,
247
-            $js,
248
-            $mainLat,
249
-            $mainLon,
250
-            $poitable,
251
-            $gmap ['summary'],
252
-            $imgUrl,
253
-            $_firstimageID
254
-        );
255
-    }
256
-
257
-    /**
258
-     * extract parameters for the map from the parameter string
259
-     *
260
-     * @param string $str_params
261
-     *            string of key="value" pairs
262
-     * @return array associative array of parameters key=>value
263
-     */
264
-    private function extractParams(string $str_params): array {
265
-        $param = array();
266
-        preg_match_all('/(\w*)="(.*?)"/us', $str_params, $param, PREG_SET_ORDER);
267
-        // parse match for instructions, break into key value pairs
268
-        $gmap = $this->dflt;
269
-        foreach($gmap as $key => &$value) {
270
-            $defval = $this->getConf('default_' . $key);
271
-            if($defval !== '') {
272
-                $value = $defval;
273
-            }
274
-        }
275
-        unset ($value);
276
-        foreach($param as $kvpair) {
277
-            list ($match, $key, $val) = $kvpair;
278
-            $key = strtolower($key);
279
-            if(isset ($gmap [$key])) {
280
-                if($key == 'summary') {
281
-                    // preserve case for summary field
282
-                    $gmap [$key] = $val;
283
-                } elseif($key == 'id') {
284
-                    // preserve case for id field
285
-                    $gmap [$key] = $val;
286
-                } else {
287
-                    $gmap [$key] = strtolower($val);
288
-                }
289
-            }
290
-        }
291
-        return $gmap;
292
-    }
293
-
294
-    /**
295
-     * extract overlay points for the map from the wiki syntax data
296
-     *
297
-     * @param string $str_points
298
-     *            multi-line string of lat,lon,text triplets
299
-     * @return array multi-dimensional array of lat,lon,text triplets
300
-     */
301
-    private function extractPoints(string $str_points): array {
302
-        $point = array();
303
-        // preg_match_all('/^([+-]?[0-9].*?),\s*([+-]?[0-9].*?),(.*?),(.*?),(.*?),(.*)$/um',
304
-        //      $str_points, $point, PREG_SET_ORDER);
305
-        /*
237
+		}
238
+
239
+		$autozoom = empty ($gmap ['autozoom']) ? $this->getConf('autoZoomMap') : $gmap ['autozoom'];
240
+		$js       = "{mapOpts: {" . $param . ", displayformat: '" . $this->getConf('displayformat')
241
+			. "', autozoom: " . $autozoom . "}, poi: [$poi]};";
242
+		// unescape the json
243
+		$poitable = stripslashes($poitable);
244
+
245
+		return array(
246
+			$mapid,
247
+			$js,
248
+			$mainLat,
249
+			$mainLon,
250
+			$poitable,
251
+			$gmap ['summary'],
252
+			$imgUrl,
253
+			$_firstimageID
254
+		);
255
+	}
256
+
257
+	/**
258
+	 * extract parameters for the map from the parameter string
259
+	 *
260
+	 * @param string $str_params
261
+	 *            string of key="value" pairs
262
+	 * @return array associative array of parameters key=>value
263
+	 */
264
+	private function extractParams(string $str_params): array {
265
+		$param = array();
266
+		preg_match_all('/(\w*)="(.*?)"/us', $str_params, $param, PREG_SET_ORDER);
267
+		// parse match for instructions, break into key value pairs
268
+		$gmap = $this->dflt;
269
+		foreach($gmap as $key => &$value) {
270
+			$defval = $this->getConf('default_' . $key);
271
+			if($defval !== '') {
272
+				$value = $defval;
273
+			}
274
+		}
275
+		unset ($value);
276
+		foreach($param as $kvpair) {
277
+			list ($match, $key, $val) = $kvpair;
278
+			$key = strtolower($key);
279
+			if(isset ($gmap [$key])) {
280
+				if($key == 'summary') {
281
+					// preserve case for summary field
282
+					$gmap [$key] = $val;
283
+				} elseif($key == 'id') {
284
+					// preserve case for id field
285
+					$gmap [$key] = $val;
286
+				} else {
287
+					$gmap [$key] = strtolower($val);
288
+				}
289
+			}
290
+		}
291
+		return $gmap;
292
+	}
293
+
294
+	/**
295
+	 * extract overlay points for the map from the wiki syntax data
296
+	 *
297
+	 * @param string $str_points
298
+	 *            multi-line string of lat,lon,text triplets
299
+	 * @return array multi-dimensional array of lat,lon,text triplets
300
+	 */
301
+	private function extractPoints(string $str_points): array {
302
+		$point = array();
303
+		// preg_match_all('/^([+-]?[0-9].*?),\s*([+-]?[0-9].*?),(.*?),(.*?),(.*?),(.*)$/um',
304
+		//      $str_points, $point, PREG_SET_ORDER);
305
+		/*
306 306
          * group 1: ([+-]?[0-9]+(?:\.[0-9]*)?)
307 307
          * group 2: ([+-]?[0-9]+(?:\.[0-9]*)?)
308 308
          * group 3: (.*?)
@@ -310,104 +310,104 @@  discard block
 block discarded – undo
310 310
          * group 5: (.*?)
311 311
          * group 6: (.*)
312 312
          */
313
-        preg_match_all(
314
-            '/^([+-]?[0-9]+(?:\.[0-9]*)?),\s*([+-]?[0-9]+(?:\.[0-9]*)?),(.*?),(.*?),(.*?),(.*)$/um',
315
-            $str_points, $point, PREG_SET_ORDER
316
-        );
317
-        // create poi array
318
-        $overlay = array();
319
-        foreach($point as $pt) {
320
-            list ($match, $lat, $lon, $angle, $opacity, $img, $text) = $pt;
321
-            $lat     = is_numeric($lat) ? $lat : 0;
322
-            $lon     = is_numeric($lon) ? $lon : 0;
323
-            $angle   = is_numeric($angle) ? $angle : 0;
324
-            $opacity = is_numeric($opacity) ? $opacity : 0.8;
325
-            // TODO validate using exist & set up default img?
326
-            $img  = trim($img);
327
-            $text = p_get_instructions($text);
328
-            // dbg ( $text );
329
-            $text = p_render("xhtml", $text, $info);
330
-            // dbg ( $text );
331
-            $text       = addslashes(str_replace("\n", "", $text));
332
-            $overlay [] = array(
333
-                $lat,
334
-                $lon,
335
-                $text,
336
-                $angle,
337
-                $opacity,
338
-                $img
339
-            );
340
-        }
341
-        return $overlay;
342
-    }
343
-
344
-    /**
345
-     * Create a Google maps static image url w/ the poi.
346
-     *
347
-     * @param array $gmap
348
-     * @param array $overlay
349
-     * @return string
350
-     */
351
-    private function getGoogle(array $gmap, array $overlay): string {
352
-        $sUrl = $this->getConf('iconUrlOverload');
353
-        if(!$sUrl) {
354
-            $sUrl = DOKU_URL;
355
-        }
356
-        switch($gmap ['baselyr']) {
357
-            case 'google hybrid' :
358
-                $maptype = 'hybrid';
359
-                break;
360
-            case 'google sat' :
361
-                $maptype = 'satellite';
362
-                break;
363
-            case 'terrain' :
364
-            case 'google relief' :
365
-                $maptype = 'terrain';
366
-                break;
367
-            case 'google road' :
368
-            default :
369
-                $maptype = 'roadmap';
370
-                break;
371
-        }
372
-        // TODO maybe use viewport / visible instead of center/zoom,
373
-        // see: https://developers.google.com/maps/documentation/staticmaps/index#Viewports
374
-        // http://maps.google.com/maps/api/staticmap?center=51.565690,5.456756&zoom=16&size=600x400&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker.png|label:1|51.565690,5.456756&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker-blue.png|51.566197,5.458966|label:2&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.567177,5.457909|label:3&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.566283,5.457330|label:4&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.565630,5.457695|label:5&sensor=false&format=png&maptype=roadmap
375
-        $imgUrl = "https://maps.googleapis.com/maps/api/staticmap?";
376
-        $imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
377
-            . str_replace("px", "", $gmap ['height']);
378
-        //if (!$this->getConf( 'autoZoomMap')) { // no need for center & zoom params }
379
-        $imgUrl .= "&center=" . $gmap ['lat'] . "," . $gmap ['lon'];
380
-        // max is 21 (== building scale), but that's overkill..
381
-        if($gmap ['zoom'] > 17) {
382
-            $imgUrl .= "&zoom=17";
383
-        } else {
384
-            $imgUrl .= "&zoom=" . $gmap ['zoom'];
385
-        }
386
-        if(!empty ($overlay)) {
387
-            $rowId = 0;
388
-            foreach($overlay as $data) {
389
-                list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
390
-                $imgUrl .= "&markers=icon%3a" . $sUrl . "lib/plugins/openlayersmap/icons/" . $img . "%7c"
391
-                    . $lat . "," . $lon . "%7clabel%3a" . ++$rowId;
392
-            }
393
-        }
394
-        $imgUrl .= "&format=png&maptype=" . $maptype;
395
-        global $conf;
396
-        $imgUrl .= "&language=" . $conf ['lang'];
397
-        if($this->getConf('googleAPIkey')) {
398
-            $imgUrl .= "&key=" . $this->getConf('googleAPIkey');
399
-        }
400
-        // dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getGoogle: Google image url is:');
401
-        return $imgUrl;
402
-    }
403
-
404
-    /**
405
-     * Create a MapQuest static map API image url.
406
-     *
407
-     * @param array $gmap
408
-     * @param array $overlay
409
-     */
410
-    /*
313
+		preg_match_all(
314
+			'/^([+-]?[0-9]+(?:\.[0-9]*)?),\s*([+-]?[0-9]+(?:\.[0-9]*)?),(.*?),(.*?),(.*?),(.*)$/um',
315
+			$str_points, $point, PREG_SET_ORDER
316
+		);
317
+		// create poi array
318
+		$overlay = array();
319
+		foreach($point as $pt) {
320
+			list ($match, $lat, $lon, $angle, $opacity, $img, $text) = $pt;
321
+			$lat     = is_numeric($lat) ? $lat : 0;
322
+			$lon     = is_numeric($lon) ? $lon : 0;
323
+			$angle   = is_numeric($angle) ? $angle : 0;
324
+			$opacity = is_numeric($opacity) ? $opacity : 0.8;
325
+			// TODO validate using exist & set up default img?
326
+			$img  = trim($img);
327
+			$text = p_get_instructions($text);
328
+			// dbg ( $text );
329
+			$text = p_render("xhtml", $text, $info);
330
+			// dbg ( $text );
331
+			$text       = addslashes(str_replace("\n", "", $text));
332
+			$overlay [] = array(
333
+				$lat,
334
+				$lon,
335
+				$text,
336
+				$angle,
337
+				$opacity,
338
+				$img
339
+			);
340
+		}
341
+		return $overlay;
342
+	}
343
+
344
+	/**
345
+	 * Create a Google maps static image url w/ the poi.
346
+	 *
347
+	 * @param array $gmap
348
+	 * @param array $overlay
349
+	 * @return string
350
+	 */
351
+	private function getGoogle(array $gmap, array $overlay): string {
352
+		$sUrl = $this->getConf('iconUrlOverload');
353
+		if(!$sUrl) {
354
+			$sUrl = DOKU_URL;
355
+		}
356
+		switch($gmap ['baselyr']) {
357
+			case 'google hybrid' :
358
+				$maptype = 'hybrid';
359
+				break;
360
+			case 'google sat' :
361
+				$maptype = 'satellite';
362
+				break;
363
+			case 'terrain' :
364
+			case 'google relief' :
365
+				$maptype = 'terrain';
366
+				break;
367
+			case 'google road' :
368
+			default :
369
+				$maptype = 'roadmap';
370
+				break;
371
+		}
372
+		// TODO maybe use viewport / visible instead of center/zoom,
373
+		// see: https://developers.google.com/maps/documentation/staticmaps/index#Viewports
374
+		// http://maps.google.com/maps/api/staticmap?center=51.565690,5.456756&zoom=16&size=600x400&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker.png|label:1|51.565690,5.456756&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker-blue.png|51.566197,5.458966|label:2&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.567177,5.457909|label:3&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.566283,5.457330|label:4&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.565630,5.457695|label:5&sensor=false&format=png&maptype=roadmap
375
+		$imgUrl = "https://maps.googleapis.com/maps/api/staticmap?";
376
+		$imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
377
+			. str_replace("px", "", $gmap ['height']);
378
+		//if (!$this->getConf( 'autoZoomMap')) { // no need for center & zoom params }
379
+		$imgUrl .= "&center=" . $gmap ['lat'] . "," . $gmap ['lon'];
380
+		// max is 21 (== building scale), but that's overkill..
381
+		if($gmap ['zoom'] > 17) {
382
+			$imgUrl .= "&zoom=17";
383
+		} else {
384
+			$imgUrl .= "&zoom=" . $gmap ['zoom'];
385
+		}
386
+		if(!empty ($overlay)) {
387
+			$rowId = 0;
388
+			foreach($overlay as $data) {
389
+				list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
390
+				$imgUrl .= "&markers=icon%3a" . $sUrl . "lib/plugins/openlayersmap/icons/" . $img . "%7c"
391
+					. $lat . "," . $lon . "%7clabel%3a" . ++$rowId;
392
+			}
393
+		}
394
+		$imgUrl .= "&format=png&maptype=" . $maptype;
395
+		global $conf;
396
+		$imgUrl .= "&language=" . $conf ['lang'];
397
+		if($this->getConf('googleAPIkey')) {
398
+			$imgUrl .= "&key=" . $this->getConf('googleAPIkey');
399
+		}
400
+		// dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getGoogle: Google image url is:');
401
+		return $imgUrl;
402
+	}
403
+
404
+	/**
405
+	 * Create a MapQuest static map API image url.
406
+	 *
407
+	 * @param array $gmap
408
+	 * @param array $overlay
409
+	 */
410
+	/*
411 411
    private function _getMapQuest($gmap, $overlay) {
412 412
        $sUrl = $this->getConf ( 'iconUrlOverload' );
413 413
        if (! $sUrl) {
@@ -465,344 +465,344 @@  discard block
 block discarded – undo
465 465
    }
466 466
    */
467 467
 
468
-    /**
469
-     * Create a static OSM map image url w/ the poi from http://staticmap.openstreetmap.de (staticMapLite)
470
-     * use http://staticmap.openstreetmap.de "staticMapLite" or a local version
471
-     *
472
-     * @param array $gmap
473
-     * @param array $overlay
474
-     *
475
-     * @return false|string
476
-     * @todo implementation for http://ojw.dev.openstreetmap.org/StaticMapDev/
477
-     */
478
-    private function getStaticOSM(array $gmap, array $overlay) {
479
-        global $conf;
480
-
481
-        if($this->getConf('optionStaticMapGenerator') == 'local') {
482
-            // using local basemap composer
483
-            if(!$myMap = plugin_load('helper', 'openlayersmap_staticmap')) {
484
-                dbglog(
485
-                    $myMap,
486
-                    'openlayersmap_staticmap plugin is not available for use.'
487
-                );
488
-            }
489
-            if(!$geophp = plugin_load('helper', 'geophp')) {
490
-                dbglog($geophp, 'geophp plugin is not available for use.');
491
-            }
492
-            $size = str_replace("px", "", $gmap ['width']) . "x"
493
-                . str_replace("px", "", $gmap ['height']);
494
-
495
-            $markers = array();
496
-            if(!empty ($overlay)) {
497
-                foreach($overlay as $data) {
498
-                    list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
499
-                    $iconStyle  = substr($img, 0, strlen($img) - 4);
500
-                    $markers [] = array(
501
-                        'lat'  => $lat,
502
-                        'lon'  => $lon,
503
-                        'type' => $iconStyle
504
-                    );
505
-                }
506
-            }
507
-
508
-            $apikey = '';
509
-            switch($gmap ['baselyr']) {
510
-                case 'mapnik' :
511
-                case 'openstreetmap' :
512
-                    $maptype = 'openstreetmap';
513
-                    break;
514
-                case 'transport' :
515
-                    $maptype = 'transport';
516
-                    $apikey  = $this->getConf('tfApiKey');
517
-                    break;
518
-                case 'landscape' :
519
-                    $maptype = 'landscape';
520
-                    $apikey  = $this->getConf('tfApiKey');
521
-                    break;
522
-                case 'outdoors' :
523
-                    $maptype = 'outdoors';
524
-                    $apikey  = $this->getConf('tfApiKey');
525
-                    break;
526
-                case 'cycle map' :
527
-                    $maptype = 'cycle';
528
-                    $apikey  = $this->getConf('tfApiKey');
529
-                    break;
530
-                case 'hike and bike map' :
531
-                    $maptype = 'hikeandbike';
532
-                    break;
533
-                case 'mapquest hybrid' :
534
-                case 'mapquest road' :
535
-                case 'mapquest sat' :
536
-                    $maptype = 'mapquest';
537
-                    break;
538
-                default :
539
-                    $maptype = '';
540
-                    break;
541
-            }
542
-
543
-            $result = $myMap->getMap(
544
-                $gmap ['lat'], $gmap ['lon'], $gmap ['zoom'], $size, $maptype, $markers,
545
-                $gmap ['gpxfile'], $gmap ['kmlfile'], $gmap ['geojsonfile']
546
-            );
547
-        } else {
548
-            // using external basemap composer
549
-
550
-            // https://staticmap.openstreetmap.de/staticmap.php?center=47.000622235634,10
551
-            //.117187497601&zoom=5&size=500x350
552
-            // &markers=48.999812532766,8.3593749976708,lightblue1|43.154850037315,17.499999997306,
553
-            //  lightblue1|49.487527053077,10.820312497573,ltblu-pushpin|47.951071133739,15.917968747369,
554
-            //  ol-marker|47.921629720114,18.027343747285,ol-marker-gold|47.951071133739,19.257812497236,
555
-            //  ol-marker-blue|47.180141361692,19.257812497236,ol-marker-green
556
-            $imgUrl = "https://staticmap.openstreetmap.de/staticmap.php";
557
-            $imgUrl .= "?center=" . $gmap ['lat'] . "," . $gmap ['lon'];
558
-            $imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
559
-                . str_replace("px", "", $gmap ['height']);
560
-
561
-            if($gmap ['zoom'] > 16) {
562
-                // actually this could even be 18, but that seems overkill
563
-                $imgUrl .= "&zoom=16";
564
-            } else {
565
-                $imgUrl .= "&zoom=" . $gmap ['zoom'];
566
-            }
567
-
568
-            if(!empty ($overlay)) {
569
-                $rowId  = 0;
570
-                $imgUrl .= "&markers=";
571
-                foreach($overlay as $data) {
572
-                    list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
573
-                    $rowId++;
574
-                    $iconStyle = "lightblue$rowId";
575
-                    $imgUrl    .= "$lat,$lon,$iconStyle%7c";
576
-                }
577
-                $imgUrl = substr($imgUrl, 0, -3);
578
-            }
579
-
580
-            $result = $imgUrl;
581
-        }
582
-        // dbglog ( $result, 'syntax_plugin_openlayersmap_olmap::getStaticOSM: osm image url is:' );
583
-        return $result;
584
-    }
585
-
586
-    /**
587
-     * Create a Bing maps static image url w/ the poi.
588
-     *
589
-     * @param array $gmap
590
-     * @param array $overlay
591
-     * @return string
592
-     */
593
-    private function getBing(array $gmap, array $overlay): string {
594
-        switch($gmap ['baselyr']) {
595
-            case 've hybrid' :
596
-            case 'bing hybrid' :
597
-                $maptype = 'AerialWithLabels';
598
-                break;
599
-            case 've sat' :
600
-            case 'bing sat' :
601
-                $maptype = 'Aerial';
602
-                break;
603
-            case 've normal' :
604
-            case 've road' :
605
-            case 've' :
606
-            case 'bing road' :
607
-            default :
608
-                $maptype = 'Road';
609
-                break;
610
-        }
611
-        $imgUrl = "https://dev.virtualearth.net/REST/v1/Imagery/Map/" . $maptype;// . "/";
612
-        if($this->getConf('autoZoomMap')) {
613
-            $bbox = $this->calcBBOX($overlay, $gmap ['lat'], $gmap ['lon']);
614
-            //$imgUrl .= "?ma=" . $bbox ['minlat'] . "," . $bbox ['minlon'] . ","
615
-            //          . $bbox ['maxlat'] . "," . $bbox ['maxlon'];
616
-            $imgUrl .= "?ma=" . $bbox ['minlat'] . "%2C" . $bbox ['minlon'] . "%2C" . $bbox ['maxlat']
617
-                . "%2C" . $bbox ['maxlon'];
618
-            $imgUrl .= "&dcl=1";
619
-        }
620
-        if(strpos($imgUrl, "?") === false)
621
-            $imgUrl .= "?";
622
-
623
-        //$imgUrl .= "&ms=" . str_replace ( "px", "", $gmap ['width'] ) . ","
624
-        //          . str_replace ( "px", "", $gmap ['height'] );
625
-        $imgUrl .= "&ms=" . str_replace("px", "", $gmap ['width']) . "%2C"
626
-            . str_replace("px", "", $gmap ['height']);
627
-        $imgUrl .= "&key=" . $this->getConf('bingAPIKey');
628
-        if(!empty ($overlay)) {
629
-            $rowId = 0;
630
-            foreach($overlay as $data) {
631
-                list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
632
-                // TODO icon style lookup, see: http://msdn.microsoft.com/en-us/library/ff701719.aspx for iconStyle
633
-                $iconStyle = 32;
634
-                $rowId++;
635
-                // NOTE: the max number of pushpins is 18! or we have to use POST
636
-                //  (http://msdn.microsoft.com/en-us/library/ff701724.aspx)
637
-                if($rowId == 18) {
638
-                    break;
639
-                }
640
-                //$imgUrl .= "&pp=$lat,$lon;$iconStyle;$rowId";
641
-                $imgUrl .= "&pp=$lat%2C$lon%3B$iconStyle%3B$rowId";
642
-
643
-            }
644
-        }
645
-        global $conf;
646
-        $imgUrl .= "&fmt=png";
647
-        $imgUrl .= "&c=" . $conf ['lang'];
648
-        // dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getBing: bing image url is:');
649
-        return $imgUrl;
650
-    }
651
-
652
-    /**
653
-     * Calculate the minimum bbox for a start location + poi.
654
-     *
655
-     * @param array $overlay
656
-     *            multi-dimensional array of array($lat, $lon, $text, $angle, $opacity, $img)
657
-     * @param float $lat
658
-     *            latitude for map center
659
-     * @param float $lon
660
-     *            longitude for map center
661
-     * @return array :float array describing the mbr and center point
662
-     */
663
-    private function calcBBOX(array $overlay, float $lat, float $lon): array {
664
-        $lats = array($lat);
665
-        $lons = array($lon);
666
-        foreach($overlay as $data) {
667
-            list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
668
-            $lats [] = $lat;
669
-            $lons [] = $lon;
670
-        }
671
-        sort($lats);
672
-        sort($lons);
673
-        // TODO: make edge/wrap around cases work
674
-        $centerlat = $lats [0] + ($lats [count($lats) - 1] - $lats [0]);
675
-        $centerlon = $lons [0] + ($lons [count($lats) - 1] - $lons [0]);
676
-        return array(
677
-            'minlat'    => $lats [0],
678
-            'minlon'    => $lons [0],
679
-            'maxlat'    => $lats [count($lats) - 1],
680
-            'maxlon'    => $lons [count($lats) - 1],
681
-            'centerlat' => $centerlat,
682
-            'centerlon' => $centerlon
683
-        );
684
-    }
685
-
686
-    /**
687
-     * convert latitude in decimal degrees to DMS+hemisphere.
688
-     *
689
-     * @param float $decimaldegrees
690
-     * @return string
691
-     * @todo move this into a shared library
692
-     */
693
-    private function convertLat(float $decimaldegrees): string {
694
-        if(strpos($decimaldegrees, '-') !== false) {
695
-            $latPos = "S";
696
-        } else {
697
-            $latPos = "N";
698
-        }
699
-        $dms = $this->convertDDtoDMS(abs($decimaldegrees));
700
-        return hsc($dms . $latPos);
701
-    }
702
-
703
-    /**
704
-     * Convert decimal degrees to degrees, minutes, seconds format
705
-     *
706
-     * @param float $decimaldegrees
707
-     * @return string dms
708
-     * @todo move this into a shared library
709
-     */
710
-    private function convertDDtoDMS(float $decimaldegrees): string {
711
-        $dms  = floor($decimaldegrees);
712
-        $secs = ($decimaldegrees - $dms) * 3600;
713
-        $min  = floor($secs / 60);
714
-        $sec  = round($secs - ($min * 60), 3);
715
-        $dms  .= 'º' . $min . '\'' . $sec . '"';
716
-        return $dms;
717
-    }
718
-
719
-    /**
720
-     * convert longitude in decimal degrees to DMS+hemisphere.
721
-     *
722
-     * @param float $decimaldegrees
723
-     * @return string
724
-     * @todo move this into a shared library
725
-     */
726
-    private function convertLon(float $decimaldegrees): string {
727
-        if(strpos($decimaldegrees, '-') !== false) {
728
-            $lonPos = "W";
729
-        } else {
730
-            $lonPos = "E";
731
-        }
732
-        $dms = $this->convertDDtoDMS(abs($decimaldegrees));
733
-        return hsc($dms . $lonPos);
734
-    }
735
-
736
-    /**
737
-     * Figures out the base filename of a media path.
738
-     *
739
-     * @param string $mediaLink
740
-     * @return string
741
-     */
742
-    private function getFileName(string $mediaLink): string {
743
-        $mediaLink = str_replace('[[', '', $mediaLink);
744
-        $mediaLink = str_replace(']]', '', $mediaLink);
745
-        $mediaLink = substr($mediaLink, 0, -4);
746
-        $parts     = explode(':', $mediaLink);
747
-        $mediaLink = end($parts);
748
-        return str_replace('_', ' ', $mediaLink);
749
-    }
750
-
751
-    /**
752
-     *
753
-     * @see DokuWiki_Syntax_Plugin::render()
754
-     */
755
-    public function render($format, Doku_Renderer $renderer, $data): bool {
756
-        // set to true after external scripts tags are written
757
-        static $initialised = false;
758
-        // incremented for each map tag in the page source so we can keep track of each map in this page
759
-        static $mapnumber = 0;
760
-
761
-        // dbglog($data, 'olmap::render() data.');
762
-        list ($mapid, $param, $mainLat, $mainLon, $poitable, $poitabledesc, $staticImgUrl, $_firstimage) = $data;
763
-
764
-        if($format == 'xhtml') {
765
-            $olscript     = '';
766
-            $olEnable     = false;
767
-            $gscript      = '';
768
-            $gEnable      = $this->getConf('enableGoogle');
769
-            $stamenEnable = $this->getConf('enableStamen');
770
-            $osmEnable    = $this->getConf('enableOSM');
771
-            $enableBing   = $this->getConf('enableBing');
772
-
773
-            $scriptEnable = '';
774
-            if(!$initialised) {
775
-                $initialised = true;
776
-                // render necessary script tags
777
-                if($gEnable) {
778
-                    $gscript = '<script charset="utf-8" defer="defer" src="//maps.google.com/maps/api/js?v=3.29&amp;key='
779
-                        . $this->getConf('googleAPIkey') . '"></script>';
780
-                }
781
-                $olscript = '<script charset="utf-8" defer="defer" src="' . DOKU_BASE
782
-                    . 'lib/plugins/openlayersmap/lib/OpenLayers.js"></script>';
783
-
784
-                $scriptEnable = '<script defer="defer" charset="utf-8" src="data:text/javascript;base64,';
785
-                $scriptSrc    = $olscript ? 'olEnable = true;' : 'olEnable = false;';
786
-                $scriptSrc    .= 'gEnable = ' . ($gEnable ? 'true' : 'false') . ';';
787
-                $scriptSrc    .= 'osmEnable = ' . ($osmEnable ? 'true' : 'false') . ';';
788
-                $scriptSrc    .= 'stamenEnable = ' . ($stamenEnable ? 'true' : 'false') . ';';
789
-                $scriptSrc    .= 'bEnable = ' . ($enableBing ? 'true' : 'false') . ';';
790
-                $scriptSrc    .= 'bApiKey="' . $this->getConf('bingAPIKey') . '";';
791
-                $scriptSrc    .= 'tfApiKey="' . $this->getConf('tfApiKey') . '";';
792
-                $scriptSrc    .= 'gApiKey="' . $this->getConf('googleAPIkey') . '";';
793
-                $scriptEnable .= base64_encode($scriptSrc);
794
-                $scriptEnable .= '"></script>';
795
-            }
796
-            $renderer->doc .= "$gscript\n$olscript\n$scriptEnable";
797
-            $renderer->doc .= '<div class="olMapHelp">' . $this->locale_xhtml("help") . '</div>';
798
-            if($this->getConf('enableA11y')) {
799
-                $renderer->doc .= '<div id="' . $mapid . '-static" class="olStaticMap">'
800
-                    . p_render($format, p_get_instructions($staticImgUrl), $info) . '</div>';
801
-            }
802
-            $renderer->doc .= '<div id="' . $mapid . '-clearer" class="clearer"><p>&nbsp;</p></div>';
803
-            if($this->getConf('enableA11y')) {
804
-                // render a table of the POI for the print and a11y presentation, it is hidden using javascript
805
-                $renderer->doc .= '<div class="olPOItableSpan" id="' . $mapid . '-table-span">
468
+	/**
469
+	 * Create a static OSM map image url w/ the poi from http://staticmap.openstreetmap.de (staticMapLite)
470
+	 * use http://staticmap.openstreetmap.de "staticMapLite" or a local version
471
+	 *
472
+	 * @param array $gmap
473
+	 * @param array $overlay
474
+	 *
475
+	 * @return false|string
476
+	 * @todo implementation for http://ojw.dev.openstreetmap.org/StaticMapDev/
477
+	 */
478
+	private function getStaticOSM(array $gmap, array $overlay) {
479
+		global $conf;
480
+
481
+		if($this->getConf('optionStaticMapGenerator') == 'local') {
482
+			// using local basemap composer
483
+			if(!$myMap = plugin_load('helper', 'openlayersmap_staticmap')) {
484
+				dbglog(
485
+					$myMap,
486
+					'openlayersmap_staticmap plugin is not available for use.'
487
+				);
488
+			}
489
+			if(!$geophp = plugin_load('helper', 'geophp')) {
490
+				dbglog($geophp, 'geophp plugin is not available for use.');
491
+			}
492
+			$size = str_replace("px", "", $gmap ['width']) . "x"
493
+				. str_replace("px", "", $gmap ['height']);
494
+
495
+			$markers = array();
496
+			if(!empty ($overlay)) {
497
+				foreach($overlay as $data) {
498
+					list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
499
+					$iconStyle  = substr($img, 0, strlen($img) - 4);
500
+					$markers [] = array(
501
+						'lat'  => $lat,
502
+						'lon'  => $lon,
503
+						'type' => $iconStyle
504
+					);
505
+				}
506
+			}
507
+
508
+			$apikey = '';
509
+			switch($gmap ['baselyr']) {
510
+				case 'mapnik' :
511
+				case 'openstreetmap' :
512
+					$maptype = 'openstreetmap';
513
+					break;
514
+				case 'transport' :
515
+					$maptype = 'transport';
516
+					$apikey  = $this->getConf('tfApiKey');
517
+					break;
518
+				case 'landscape' :
519
+					$maptype = 'landscape';
520
+					$apikey  = $this->getConf('tfApiKey');
521
+					break;
522
+				case 'outdoors' :
523
+					$maptype = 'outdoors';
524
+					$apikey  = $this->getConf('tfApiKey');
525
+					break;
526
+				case 'cycle map' :
527
+					$maptype = 'cycle';
528
+					$apikey  = $this->getConf('tfApiKey');
529
+					break;
530
+				case 'hike and bike map' :
531
+					$maptype = 'hikeandbike';
532
+					break;
533
+				case 'mapquest hybrid' :
534
+				case 'mapquest road' :
535
+				case 'mapquest sat' :
536
+					$maptype = 'mapquest';
537
+					break;
538
+				default :
539
+					$maptype = '';
540
+					break;
541
+			}
542
+
543
+			$result = $myMap->getMap(
544
+				$gmap ['lat'], $gmap ['lon'], $gmap ['zoom'], $size, $maptype, $markers,
545
+				$gmap ['gpxfile'], $gmap ['kmlfile'], $gmap ['geojsonfile']
546
+			);
547
+		} else {
548
+			// using external basemap composer
549
+
550
+			// https://staticmap.openstreetmap.de/staticmap.php?center=47.000622235634,10
551
+			//.117187497601&zoom=5&size=500x350
552
+			// &markers=48.999812532766,8.3593749976708,lightblue1|43.154850037315,17.499999997306,
553
+			//  lightblue1|49.487527053077,10.820312497573,ltblu-pushpin|47.951071133739,15.917968747369,
554
+			//  ol-marker|47.921629720114,18.027343747285,ol-marker-gold|47.951071133739,19.257812497236,
555
+			//  ol-marker-blue|47.180141361692,19.257812497236,ol-marker-green
556
+			$imgUrl = "https://staticmap.openstreetmap.de/staticmap.php";
557
+			$imgUrl .= "?center=" . $gmap ['lat'] . "," . $gmap ['lon'];
558
+			$imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
559
+				. str_replace("px", "", $gmap ['height']);
560
+
561
+			if($gmap ['zoom'] > 16) {
562
+				// actually this could even be 18, but that seems overkill
563
+				$imgUrl .= "&zoom=16";
564
+			} else {
565
+				$imgUrl .= "&zoom=" . $gmap ['zoom'];
566
+			}
567
+
568
+			if(!empty ($overlay)) {
569
+				$rowId  = 0;
570
+				$imgUrl .= "&markers=";
571
+				foreach($overlay as $data) {
572
+					list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
573
+					$rowId++;
574
+					$iconStyle = "lightblue$rowId";
575
+					$imgUrl    .= "$lat,$lon,$iconStyle%7c";
576
+				}
577
+				$imgUrl = substr($imgUrl, 0, -3);
578
+			}
579
+
580
+			$result = $imgUrl;
581
+		}
582
+		// dbglog ( $result, 'syntax_plugin_openlayersmap_olmap::getStaticOSM: osm image url is:' );
583
+		return $result;
584
+	}
585
+
586
+	/**
587
+	 * Create a Bing maps static image url w/ the poi.
588
+	 *
589
+	 * @param array $gmap
590
+	 * @param array $overlay
591
+	 * @return string
592
+	 */
593
+	private function getBing(array $gmap, array $overlay): string {
594
+		switch($gmap ['baselyr']) {
595
+			case 've hybrid' :
596
+			case 'bing hybrid' :
597
+				$maptype = 'AerialWithLabels';
598
+				break;
599
+			case 've sat' :
600
+			case 'bing sat' :
601
+				$maptype = 'Aerial';
602
+				break;
603
+			case 've normal' :
604
+			case 've road' :
605
+			case 've' :
606
+			case 'bing road' :
607
+			default :
608
+				$maptype = 'Road';
609
+				break;
610
+		}
611
+		$imgUrl = "https://dev.virtualearth.net/REST/v1/Imagery/Map/" . $maptype;// . "/";
612
+		if($this->getConf('autoZoomMap')) {
613
+			$bbox = $this->calcBBOX($overlay, $gmap ['lat'], $gmap ['lon']);
614
+			//$imgUrl .= "?ma=" . $bbox ['minlat'] . "," . $bbox ['minlon'] . ","
615
+			//          . $bbox ['maxlat'] . "," . $bbox ['maxlon'];
616
+			$imgUrl .= "?ma=" . $bbox ['minlat'] . "%2C" . $bbox ['minlon'] . "%2C" . $bbox ['maxlat']
617
+				. "%2C" . $bbox ['maxlon'];
618
+			$imgUrl .= "&dcl=1";
619
+		}
620
+		if(strpos($imgUrl, "?") === false)
621
+			$imgUrl .= "?";
622
+
623
+		//$imgUrl .= "&ms=" . str_replace ( "px", "", $gmap ['width'] ) . ","
624
+		//          . str_replace ( "px", "", $gmap ['height'] );
625
+		$imgUrl .= "&ms=" . str_replace("px", "", $gmap ['width']) . "%2C"
626
+			. str_replace("px", "", $gmap ['height']);
627
+		$imgUrl .= "&key=" . $this->getConf('bingAPIKey');
628
+		if(!empty ($overlay)) {
629
+			$rowId = 0;
630
+			foreach($overlay as $data) {
631
+				list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
632
+				// TODO icon style lookup, see: http://msdn.microsoft.com/en-us/library/ff701719.aspx for iconStyle
633
+				$iconStyle = 32;
634
+				$rowId++;
635
+				// NOTE: the max number of pushpins is 18! or we have to use POST
636
+				//  (http://msdn.microsoft.com/en-us/library/ff701724.aspx)
637
+				if($rowId == 18) {
638
+					break;
639
+				}
640
+				//$imgUrl .= "&pp=$lat,$lon;$iconStyle;$rowId";
641
+				$imgUrl .= "&pp=$lat%2C$lon%3B$iconStyle%3B$rowId";
642
+
643
+			}
644
+		}
645
+		global $conf;
646
+		$imgUrl .= "&fmt=png";
647
+		$imgUrl .= "&c=" . $conf ['lang'];
648
+		// dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getBing: bing image url is:');
649
+		return $imgUrl;
650
+	}
651
+
652
+	/**
653
+	 * Calculate the minimum bbox for a start location + poi.
654
+	 *
655
+	 * @param array $overlay
656
+	 *            multi-dimensional array of array($lat, $lon, $text, $angle, $opacity, $img)
657
+	 * @param float $lat
658
+	 *            latitude for map center
659
+	 * @param float $lon
660
+	 *            longitude for map center
661
+	 * @return array :float array describing the mbr and center point
662
+	 */
663
+	private function calcBBOX(array $overlay, float $lat, float $lon): array {
664
+		$lats = array($lat);
665
+		$lons = array($lon);
666
+		foreach($overlay as $data) {
667
+			list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
668
+			$lats [] = $lat;
669
+			$lons [] = $lon;
670
+		}
671
+		sort($lats);
672
+		sort($lons);
673
+		// TODO: make edge/wrap around cases work
674
+		$centerlat = $lats [0] + ($lats [count($lats) - 1] - $lats [0]);
675
+		$centerlon = $lons [0] + ($lons [count($lats) - 1] - $lons [0]);
676
+		return array(
677
+			'minlat'    => $lats [0],
678
+			'minlon'    => $lons [0],
679
+			'maxlat'    => $lats [count($lats) - 1],
680
+			'maxlon'    => $lons [count($lats) - 1],
681
+			'centerlat' => $centerlat,
682
+			'centerlon' => $centerlon
683
+		);
684
+	}
685
+
686
+	/**
687
+	 * convert latitude in decimal degrees to DMS+hemisphere.
688
+	 *
689
+	 * @param float $decimaldegrees
690
+	 * @return string
691
+	 * @todo move this into a shared library
692
+	 */
693
+	private function convertLat(float $decimaldegrees): string {
694
+		if(strpos($decimaldegrees, '-') !== false) {
695
+			$latPos = "S";
696
+		} else {
697
+			$latPos = "N";
698
+		}
699
+		$dms = $this->convertDDtoDMS(abs($decimaldegrees));
700
+		return hsc($dms . $latPos);
701
+	}
702
+
703
+	/**
704
+	 * Convert decimal degrees to degrees, minutes, seconds format
705
+	 *
706
+	 * @param float $decimaldegrees
707
+	 * @return string dms
708
+	 * @todo move this into a shared library
709
+	 */
710
+	private function convertDDtoDMS(float $decimaldegrees): string {
711
+		$dms  = floor($decimaldegrees);
712
+		$secs = ($decimaldegrees - $dms) * 3600;
713
+		$min  = floor($secs / 60);
714
+		$sec  = round($secs - ($min * 60), 3);
715
+		$dms  .= 'º' . $min . '\'' . $sec . '"';
716
+		return $dms;
717
+	}
718
+
719
+	/**
720
+	 * convert longitude in decimal degrees to DMS+hemisphere.
721
+	 *
722
+	 * @param float $decimaldegrees
723
+	 * @return string
724
+	 * @todo move this into a shared library
725
+	 */
726
+	private function convertLon(float $decimaldegrees): string {
727
+		if(strpos($decimaldegrees, '-') !== false) {
728
+			$lonPos = "W";
729
+		} else {
730
+			$lonPos = "E";
731
+		}
732
+		$dms = $this->convertDDtoDMS(abs($decimaldegrees));
733
+		return hsc($dms . $lonPos);
734
+	}
735
+
736
+	/**
737
+	 * Figures out the base filename of a media path.
738
+	 *
739
+	 * @param string $mediaLink
740
+	 * @return string
741
+	 */
742
+	private function getFileName(string $mediaLink): string {
743
+		$mediaLink = str_replace('[[', '', $mediaLink);
744
+		$mediaLink = str_replace(']]', '', $mediaLink);
745
+		$mediaLink = substr($mediaLink, 0, -4);
746
+		$parts     = explode(':', $mediaLink);
747
+		$mediaLink = end($parts);
748
+		return str_replace('_', ' ', $mediaLink);
749
+	}
750
+
751
+	/**
752
+	 *
753
+	 * @see DokuWiki_Syntax_Plugin::render()
754
+	 */
755
+	public function render($format, Doku_Renderer $renderer, $data): bool {
756
+		// set to true after external scripts tags are written
757
+		static $initialised = false;
758
+		// incremented for each map tag in the page source so we can keep track of each map in this page
759
+		static $mapnumber = 0;
760
+
761
+		// dbglog($data, 'olmap::render() data.');
762
+		list ($mapid, $param, $mainLat, $mainLon, $poitable, $poitabledesc, $staticImgUrl, $_firstimage) = $data;
763
+
764
+		if($format == 'xhtml') {
765
+			$olscript     = '';
766
+			$olEnable     = false;
767
+			$gscript      = '';
768
+			$gEnable      = $this->getConf('enableGoogle');
769
+			$stamenEnable = $this->getConf('enableStamen');
770
+			$osmEnable    = $this->getConf('enableOSM');
771
+			$enableBing   = $this->getConf('enableBing');
772
+
773
+			$scriptEnable = '';
774
+			if(!$initialised) {
775
+				$initialised = true;
776
+				// render necessary script tags
777
+				if($gEnable) {
778
+					$gscript = '<script charset="utf-8" defer="defer" src="//maps.google.com/maps/api/js?v=3.29&amp;key='
779
+						. $this->getConf('googleAPIkey') . '"></script>';
780
+				}
781
+				$olscript = '<script charset="utf-8" defer="defer" src="' . DOKU_BASE
782
+					. 'lib/plugins/openlayersmap/lib/OpenLayers.js"></script>';
783
+
784
+				$scriptEnable = '<script defer="defer" charset="utf-8" src="data:text/javascript;base64,';
785
+				$scriptSrc    = $olscript ? 'olEnable = true;' : 'olEnable = false;';
786
+				$scriptSrc    .= 'gEnable = ' . ($gEnable ? 'true' : 'false') . ';';
787
+				$scriptSrc    .= 'osmEnable = ' . ($osmEnable ? 'true' : 'false') . ';';
788
+				$scriptSrc    .= 'stamenEnable = ' . ($stamenEnable ? 'true' : 'false') . ';';
789
+				$scriptSrc    .= 'bEnable = ' . ($enableBing ? 'true' : 'false') . ';';
790
+				$scriptSrc    .= 'bApiKey="' . $this->getConf('bingAPIKey') . '";';
791
+				$scriptSrc    .= 'tfApiKey="' . $this->getConf('tfApiKey') . '";';
792
+				$scriptSrc    .= 'gApiKey="' . $this->getConf('googleAPIkey') . '";';
793
+				$scriptEnable .= base64_encode($scriptSrc);
794
+				$scriptEnable .= '"></script>';
795
+			}
796
+			$renderer->doc .= "$gscript\n$olscript\n$scriptEnable";
797
+			$renderer->doc .= '<div class="olMapHelp">' . $this->locale_xhtml("help") . '</div>';
798
+			if($this->getConf('enableA11y')) {
799
+				$renderer->doc .= '<div id="' . $mapid . '-static" class="olStaticMap">'
800
+					. p_render($format, p_get_instructions($staticImgUrl), $info) . '</div>';
801
+			}
802
+			$renderer->doc .= '<div id="' . $mapid . '-clearer" class="clearer"><p>&nbsp;</p></div>';
803
+			if($this->getConf('enableA11y')) {
804
+				// render a table of the POI for the print and a11y presentation, it is hidden using javascript
805
+				$renderer->doc .= '<div class="olPOItableSpan" id="' . $mapid . '-table-span">
806 806
                     <table class="olPOItable" id="' . $mapid . '-table">
807 807
                     <caption class="olPOITblCaption">' . $this->getLang('olmapPOItitle') . '</caption>
808 808
                     <thead class="olPOITblHeader">
@@ -810,62 +810,62 @@  discard block
 block discarded – undo
810 810
                     <th class="rowId" scope="col">id</th>
811 811
                     <th class="icon" scope="col">' . $this->getLang('olmapPOIicon') . '</th>
812 812
                     <th class="lat" scope="col" title="' . $this->getLang('olmapPOIlatTitle') . '">'
813
-                    . $this->getLang('olmapPOIlat') . '</th>
813
+					. $this->getLang('olmapPOIlat') . '</th>
814 814
                     <th class="lon" scope="col" title="' . $this->getLang('olmapPOIlonTitle') . '">'
815
-                    . $this->getLang('olmapPOIlon') . '</th>
815
+					. $this->getLang('olmapPOIlon') . '</th>
816 816
                     <th class="txt" scope="col">' . $this->getLang('olmapPOItxt') . '</th>
817 817
                     </tr>
818 818
                     </thead>';
819
-                if($poitabledesc != '') {
820
-                    $renderer->doc .= '<tfoot class="olPOITblFooter"><tr><td colspan="5">' . $poitabledesc
821
-                        . '</td></tr></tfoot>';
822
-                }
823
-                $renderer->doc .= '<tbody class="olPOITblBody">' . $poitable . '</tbody>
819
+				if($poitabledesc != '') {
820
+					$renderer->doc .= '<tfoot class="olPOITblFooter"><tr><td colspan="5">' . $poitabledesc
821
+						. '</td></tr></tfoot>';
822
+				}
823
+				$renderer->doc .= '<tbody class="olPOITblBody">' . $poitable . '</tbody>
824 824
                     </table></div>';
825
-            }
826
-            // render inline mapscript parts
827
-            $renderer->doc .= '<script charset="utf-8" defer="defer" src="data:text/javascript;base64,';
828
-            $renderer->doc .= base64_encode("olMapData[$mapnumber] = $param");
829
-            $renderer->doc .= '"></script>';
830
-            $mapnumber++;
831
-            return true;
832
-        } elseif($format == 'metadata') {
833
-            if(!(($this->dflt ['lat'] == $mainLat) && ($this->dflt ['lon'] == $mainLon))) {
834
-                // render geo metadata, unless they are the default
835
-                $renderer->meta ['geo'] ['lat'] = $mainLat;
836
-                $renderer->meta ['geo'] ['lon'] = $mainLon;
837
-                if($geophp = plugin_load('helper', 'geophp')) {
838
-                    // if we have the geoPHP helper, add the geohash
839
-
840
-                    // fails with older php versions..
841
-                    // $renderer->meta['geo']['geohash'] = (new Point($mainLon,$mainLat))->out('geohash');
842
-                    $p                                  = new Point ($mainLon, $mainLat);
843
-                    $renderer->meta ['geo'] ['geohash'] = $p->out('geohash');
844
-                }
845
-            }
846
-
847
-            if(($this->getConf('enableA11y')) && (!empty ($_firstimage))) {
848
-                // add map local image into relation/firstimage if not already filled and when it is a local image
849
-
850
-                global $ID;
851
-                $rel = p_get_metadata($ID, 'relation', METADATA_RENDER_USING_CACHE);
852
-                $img = $rel ['firstimage'];
853
-                if(empty ($img) /* || $img == $_firstimage*/) {
854
-                    //dbglog ( $_firstimage,
855
-                    // 'olmap::render#rendering image relation metadata for _firstimage as $img was empty or same.' );
856
-                    // This seems to never work; the firstimage entry in the .meta file is empty
857
-                    // $renderer->meta['relation']['firstimage'] = $_firstimage;
858
-
859
-                    // ... and neither does this; the firstimage entry in the .meta file is empty
860
-                    // $relation = array('relation'=>array('firstimage'=>$_firstimage));
861
-                    // p_set_metadata($ID, $relation, false, false);
862
-
863
-                    // ... this works
864
-                    $renderer->internalmedia($_firstimage, $poitabledesc);
865
-                }
866
-            }
867
-            return true;
868
-        }
869
-        return false;
870
-    }
825
+			}
826
+			// render inline mapscript parts
827
+			$renderer->doc .= '<script charset="utf-8" defer="defer" src="data:text/javascript;base64,';
828
+			$renderer->doc .= base64_encode("olMapData[$mapnumber] = $param");
829
+			$renderer->doc .= '"></script>';
830
+			$mapnumber++;
831
+			return true;
832
+		} elseif($format == 'metadata') {
833
+			if(!(($this->dflt ['lat'] == $mainLat) && ($this->dflt ['lon'] == $mainLon))) {
834
+				// render geo metadata, unless they are the default
835
+				$renderer->meta ['geo'] ['lat'] = $mainLat;
836
+				$renderer->meta ['geo'] ['lon'] = $mainLon;
837
+				if($geophp = plugin_load('helper', 'geophp')) {
838
+					// if we have the geoPHP helper, add the geohash
839
+
840
+					// fails with older php versions..
841
+					// $renderer->meta['geo']['geohash'] = (new Point($mainLon,$mainLat))->out('geohash');
842
+					$p                                  = new Point ($mainLon, $mainLat);
843
+					$renderer->meta ['geo'] ['geohash'] = $p->out('geohash');
844
+				}
845
+			}
846
+
847
+			if(($this->getConf('enableA11y')) && (!empty ($_firstimage))) {
848
+				// add map local image into relation/firstimage if not already filled and when it is a local image
849
+
850
+				global $ID;
851
+				$rel = p_get_metadata($ID, 'relation', METADATA_RENDER_USING_CACHE);
852
+				$img = $rel ['firstimage'];
853
+				if(empty ($img) /* || $img == $_firstimage*/) {
854
+					//dbglog ( $_firstimage,
855
+					// 'olmap::render#rendering image relation metadata for _firstimage as $img was empty or same.' );
856
+					// This seems to never work; the firstimage entry in the .meta file is empty
857
+					// $renderer->meta['relation']['firstimage'] = $_firstimage;
858
+
859
+					// ... and neither does this; the firstimage entry in the .meta file is empty
860
+					// $relation = array('relation'=>array('firstimage'=>$_firstimage));
861
+					// p_set_metadata($ID, $relation, false, false);
862
+
863
+					// ... this works
864
+					$renderer->internalmedia($_firstimage, $poitabledesc);
865
+				}
866
+			}
867
+			return true;
868
+		}
869
+		return false;
870
+	}
871 871
 }
Please login to merge, or discard this patch.
Spacing   +128 added lines, -128 removed lines patch added patch discarded remove patch
@@ -94,10 +94,10 @@  discard block
 block discarded – undo
94 94
         preg_match('(lon[:|=]\"-?\d*\.?\d*\")', $match, $mainLon);
95 95
         $mainLat = substr($mainLat [0], 5, -1);
96 96
         $mainLon = substr($mainLon [0], 5, -1);
97
-        if(!is_numeric($mainLat)) {
97
+        if (!is_numeric($mainLat)) {
98 98
             $mainLat = $this->dflt ['lat'];
99 99
         }
100
-        if(!is_numeric($mainLon)) {
100
+        if (!is_numeric($mainLon)) {
101 101
             $mainLon = $this->dflt ['lon'];
102 102
         }
103 103
 
@@ -108,23 +108,23 @@  discard block
 block discarded – undo
108 108
         $_nocache = false;
109 109
         // choose maptype based on the specified tag
110 110
         $imgUrl = "{{";
111
-        if(stripos($gmap ['baselyr'], 'google') !== false) {
111
+        if (stripos($gmap ['baselyr'], 'google') !== false) {
112 112
             // Google
113 113
             $imgUrl .= $this->getGoogle($gmap, $overlay);
114 114
             $imgUrl .= "&.png";
115
-        } elseif(stripos($gmap ['baselyr'], 'bing') !== false) {
115
+        } elseif (stripos($gmap ['baselyr'], 'bing') !== false) {
116 116
             // Bing
117
-            if(!$this->getConf('bingAPIKey')) {
117
+            if (!$this->getConf('bingAPIKey')) {
118 118
                 // in case there is no Bing api key we'll use OSM
119 119
                 $_firstimageID = $this->getStaticOSM($gmap, $overlay);
120
-                $imgUrl        .= $_firstimageID;
121
-                if($this->getConf('optionStaticMapGenerator') == 'remote') {
120
+                $imgUrl .= $_firstimageID;
121
+                if ($this->getConf('optionStaticMapGenerator') == 'remote') {
122 122
                     $imgUrl .= "&.png";
123 123
                 }
124 124
             } else {
125 125
                 // seems that Bing doesn't like the DW client, turn off caching
126 126
                 $_nocache = true;
127
-                $imgUrl   .= $this->getBing($gmap, $overlay) . "&.png";
127
+                $imgUrl .= $this->getBing($gmap, $overlay)."&.png";
128 128
             }
129 129
         } /* elseif (stripos ( $gmap ['baselyr'], 'mapquest' ) !== false) {
130 130
             // MapQuest
@@ -142,33 +142,33 @@  discard block
 block discarded – undo
142 142
         } */ else {
143 143
             // default OSM
144 144
             $_firstimageID = $this->getStaticOSM($gmap, $overlay);
145
-            $imgUrl        .= $_firstimageID;
146
-            if($this->getConf('optionStaticMapGenerator') == 'remote') {
145
+            $imgUrl .= $_firstimageID;
146
+            if ($this->getConf('optionStaticMapGenerator') == 'remote') {
147 147
                 $imgUrl .= "&.png";
148 148
             }
149 149
         }
150 150
 
151 151
         // append dw p_render specific params and render
152
-        $imgUrl .= "?" . str_replace("px", "", $gmap ['width']) . "x"
152
+        $imgUrl .= "?".str_replace("px", "", $gmap ['width'])."x"
153 153
             . str_replace("px", "", $gmap ['height']);
154 154
         $imgUrl .= "&nolink";
155 155
 
156 156
         // add nocache option for selected services
157
-        if($_nocache) {
157
+        if ($_nocache) {
158 158
             $imgUrl .= "&nocache";
159 159
         }
160 160
 
161
-        $imgUrl .= " |" . $gmap ['summary'] . " }}";
161
+        $imgUrl .= " |".$gmap ['summary']." }}";
162 162
 
163 163
         // dbglog($imgUrl,"complete image tags is:");
164 164
 
165 165
         $mapid = $gmap ['id'];
166 166
         // create a javascript parameter string for the map
167 167
         $param = '';
168
-        foreach($gmap as $key => $val) {
169
-            $param .= is_numeric($val) ? "$key: $val, " : "$key: '" . hsc($val) . "', ";
168
+        foreach ($gmap as $key => $val) {
169
+            $param .= is_numeric($val) ? "$key: $val, " : "$key: '".hsc($val)."', ";
170 170
         }
171
-        if(!empty ($param)) {
171
+        if (!empty ($param)) {
172 172
             $param = substr($param, 0, -2);
173 173
         }
174 174
         unset ($gmap ['id']);
@@ -177,13 +177,13 @@  discard block
 block discarded – undo
177 177
         $poi      = '';
178 178
         $poitable = '';
179 179
         $rowId    = 0;
180
-        if(!empty ($overlay)) {
181
-            foreach($overlay as $data) {
180
+        if (!empty ($overlay)) {
181
+            foreach ($overlay as $data) {
182 182
                 list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
183 183
                 $rowId++;
184 184
                 $poi .= ", {lat:$lat,lon:$lon,txt:'$text',angle:$angle,opacity:$opacity,img:'$img',rowId: $rowId}";
185 185
 
186
-                if($this->getConf('displayformat') === 'DMS') {
186
+                if ($this->getConf('displayformat') === 'DMS') {
187 187
                     $lat = $this->convertLat($lat);
188 188
                     $lon = $this->convertLon($lon);
189 189
                 } else {
@@ -193,52 +193,52 @@  discard block
 block discarded – undo
193 193
 
194 194
                 $poitable .= '
195 195
                     <tr>
196
-                    <td class="rowId">' . $rowId . '</td>
197
-                    <td class="icon"><img src="' . DOKU_BASE . 'lib/plugins/openlayersmap/icons/' . $img . '" alt="'
198
-                    . substr($img, 0, -4) . $this->getlang('alt_legend_poi') . ' " /></td>
199
-                    <td class="lat" title="' . $this->getLang('olmapPOIlatTitle') . '">' . $lat . '</td>
200
-                    <td class="lon" title="' . $this->getLang('olmapPOIlonTitle') . '">' . $lon . '</td>
201
-                    <td class="txt">' . $text . '</td>
196
+                    <td class="rowId">' . $rowId.'</td>
197
+                    <td class="icon"><img src="' . DOKU_BASE.'lib/plugins/openlayersmap/icons/'.$img.'" alt="'
198
+                    . substr($img, 0, -4).$this->getlang('alt_legend_poi').' " /></td>
199
+                    <td class="lat" title="' . $this->getLang('olmapPOIlatTitle').'">'.$lat.'</td>
200
+                    <td class="lon" title="' . $this->getLang('olmapPOIlonTitle').'">'.$lon.'</td>
201
+                    <td class="txt">' . $text.'</td>
202 202
                     </tr>';
203 203
             }
204 204
             $poi = substr($poi, 2);
205 205
         }
206
-        if(!empty ($gmap ['kmlfile'])) {
206
+        if (!empty ($gmap ['kmlfile'])) {
207 207
             $poitable .= '
208 208
                     <tr>
209 209
                     <td class="rowId"><img src="' . DOKU_BASE
210 210
                 . 'lib/plugins/openlayersmap/toolbar/kml_file.png" alt="KML file" /></td>
211
-                    <td class="icon"><img src="' . DOKU_BASE . 'lib/plugins/openlayersmap/toolbar/kml_line.png" alt="'
212
-                . $this->getlang('alt_legend_kml') . '" /></td>
213
-                    <td class="txt" colspan="3">KML track: ' . $this->getFileName($gmap ['kmlfile']) . '</td>
211
+                    <td class="icon"><img src="' . DOKU_BASE.'lib/plugins/openlayersmap/toolbar/kml_line.png" alt="'
212
+                . $this->getlang('alt_legend_kml').'" /></td>
213
+                    <td class="txt" colspan="3">KML track: ' . $this->getFileName($gmap ['kmlfile']).'</td>
214 214
                     </tr>';
215 215
         }
216
-        if(!empty ($gmap ['gpxfile'])) {
216
+        if (!empty ($gmap ['gpxfile'])) {
217 217
             $poitable .= '
218 218
                     <tr>
219 219
                     <td class="rowId"><img src="' . DOKU_BASE
220 220
                 . 'lib/plugins/openlayersmap/toolbar/gpx_file.png" alt="GPX file" /></td>
221 221
                     <td class="icon"><img src="' . DOKU_BASE
222 222
                 . 'lib/plugins/openlayersmap/toolbar/gpx_line.png" alt="'
223
-                . $this->getlang('alt_legend_gpx') . '" /></td>
224
-                    <td class="txt" colspan="3">GPX track: ' . $this->getFileName($gmap ['gpxfile']) . '</td>
223
+                . $this->getlang('alt_legend_gpx').'" /></td>
224
+                    <td class="txt" colspan="3">GPX track: ' . $this->getFileName($gmap ['gpxfile']).'</td>
225 225
                     </tr>';
226 226
         }
227
-        if(!empty ($gmap ['geojsonfile'])) {
227
+        if (!empty ($gmap ['geojsonfile'])) {
228 228
             $poitable .= '
229 229
                     <tr>
230 230
                     <td class="rowId"><img src="' . DOKU_BASE
231 231
                 . 'lib/plugins/openlayersmap/toolbar/geojson_file.png" alt="GeoJSON file" /></td>
232 232
                     <td class="icon"><img src="' . DOKU_BASE
233 233
                 . 'lib/plugins/openlayersmap/toolbar/geojson_line.png" alt="'
234
-                . $this->getlang('alt_legend_geojson') . '" /></td>
235
-                    <td class="txt" colspan="3">GeoJSON track: ' . $this->getFileName($gmap ['geojsonfile']) . '</td>
234
+                . $this->getlang('alt_legend_geojson').'" /></td>
235
+                    <td class="txt" colspan="3">GeoJSON track: ' . $this->getFileName($gmap ['geojsonfile']).'</td>
236 236
                     </tr>';
237 237
         }
238 238
 
239 239
         $autozoom = empty ($gmap ['autozoom']) ? $this->getConf('autoZoomMap') : $gmap ['autozoom'];
240
-        $js       = "{mapOpts: {" . $param . ", displayformat: '" . $this->getConf('displayformat')
241
-            . "', autozoom: " . $autozoom . "}, poi: [$poi]};";
240
+        $js       = "{mapOpts: {".$param.", displayformat: '".$this->getConf('displayformat')
241
+            . "', autozoom: ".$autozoom."}, poi: [$poi]};";
242 242
         // unescape the json
243 243
         $poitable = stripslashes($poitable);
244 244
 
@@ -266,21 +266,21 @@  discard block
 block discarded – undo
266 266
         preg_match_all('/(\w*)="(.*?)"/us', $str_params, $param, PREG_SET_ORDER);
267 267
         // parse match for instructions, break into key value pairs
268 268
         $gmap = $this->dflt;
269
-        foreach($gmap as $key => &$value) {
270
-            $defval = $this->getConf('default_' . $key);
271
-            if($defval !== '') {
269
+        foreach ($gmap as $key => &$value) {
270
+            $defval = $this->getConf('default_'.$key);
271
+            if ($defval !== '') {
272 272
                 $value = $defval;
273 273
             }
274 274
         }
275 275
         unset ($value);
276
-        foreach($param as $kvpair) {
276
+        foreach ($param as $kvpair) {
277 277
             list ($match, $key, $val) = $kvpair;
278 278
             $key = strtolower($key);
279
-            if(isset ($gmap [$key])) {
280
-                if($key == 'summary') {
279
+            if (isset ($gmap [$key])) {
280
+                if ($key == 'summary') {
281 281
                     // preserve case for summary field
282 282
                     $gmap [$key] = $val;
283
-                } elseif($key == 'id') {
283
+                } elseif ($key == 'id') {
284 284
                     // preserve case for id field
285 285
                     $gmap [$key] = $val;
286 286
                 } else {
@@ -316,7 +316,7 @@  discard block
 block discarded – undo
316 316
         );
317 317
         // create poi array
318 318
         $overlay = array();
319
-        foreach($point as $pt) {
319
+        foreach ($point as $pt) {
320 320
             list ($match, $lat, $lon, $angle, $opacity, $img, $text) = $pt;
321 321
             $lat     = is_numeric($lat) ? $lat : 0;
322 322
             $lon     = is_numeric($lon) ? $lon : 0;
@@ -350,10 +350,10 @@  discard block
 block discarded – undo
350 350
      */
351 351
     private function getGoogle(array $gmap, array $overlay): string {
352 352
         $sUrl = $this->getConf('iconUrlOverload');
353
-        if(!$sUrl) {
353
+        if (!$sUrl) {
354 354
             $sUrl = DOKU_URL;
355 355
         }
356
-        switch($gmap ['baselyr']) {
356
+        switch ($gmap ['baselyr']) {
357 357
             case 'google hybrid' :
358 358
                 $maptype = 'hybrid';
359 359
                 break;
@@ -373,29 +373,29 @@  discard block
 block discarded – undo
373 373
         // see: https://developers.google.com/maps/documentation/staticmaps/index#Viewports
374 374
         // http://maps.google.com/maps/api/staticmap?center=51.565690,5.456756&zoom=16&size=600x400&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker.png|label:1|51.565690,5.456756&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/marker-blue.png|51.566197,5.458966|label:2&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.567177,5.457909|label:3&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.566283,5.457330|label:4&markers=icon:http://wild-water.nl/dokuwiki/lib/plugins/openlayersmap/icons/parking.png|51.565630,5.457695|label:5&sensor=false&format=png&maptype=roadmap
375 375
         $imgUrl = "https://maps.googleapis.com/maps/api/staticmap?";
376
-        $imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
376
+        $imgUrl .= "&size=".str_replace("px", "", $gmap ['width'])."x"
377 377
             . str_replace("px", "", $gmap ['height']);
378 378
         //if (!$this->getConf( 'autoZoomMap')) { // no need for center & zoom params }
379
-        $imgUrl .= "&center=" . $gmap ['lat'] . "," . $gmap ['lon'];
379
+        $imgUrl .= "&center=".$gmap ['lat'].",".$gmap ['lon'];
380 380
         // max is 21 (== building scale), but that's overkill..
381
-        if($gmap ['zoom'] > 17) {
381
+        if ($gmap ['zoom'] > 17) {
382 382
             $imgUrl .= "&zoom=17";
383 383
         } else {
384
-            $imgUrl .= "&zoom=" . $gmap ['zoom'];
384
+            $imgUrl .= "&zoom=".$gmap ['zoom'];
385 385
         }
386
-        if(!empty ($overlay)) {
386
+        if (!empty ($overlay)) {
387 387
             $rowId = 0;
388
-            foreach($overlay as $data) {
388
+            foreach ($overlay as $data) {
389 389
                 list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
390
-                $imgUrl .= "&markers=icon%3a" . $sUrl . "lib/plugins/openlayersmap/icons/" . $img . "%7c"
391
-                    . $lat . "," . $lon . "%7clabel%3a" . ++$rowId;
390
+                $imgUrl .= "&markers=icon%3a".$sUrl."lib/plugins/openlayersmap/icons/".$img."%7c"
391
+                    . $lat.",".$lon."%7clabel%3a".++$rowId;
392 392
             }
393 393
         }
394
-        $imgUrl .= "&format=png&maptype=" . $maptype;
394
+        $imgUrl .= "&format=png&maptype=".$maptype;
395 395
         global $conf;
396
-        $imgUrl .= "&language=" . $conf ['lang'];
397
-        if($this->getConf('googleAPIkey')) {
398
-            $imgUrl .= "&key=" . $this->getConf('googleAPIkey');
396
+        $imgUrl .= "&language=".$conf ['lang'];
397
+        if ($this->getConf('googleAPIkey')) {
398
+            $imgUrl .= "&key=".$this->getConf('googleAPIkey');
399 399
         }
400 400
         // dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getGoogle: Google image url is:');
401 401
         return $imgUrl;
@@ -478,23 +478,23 @@  discard block
 block discarded – undo
478 478
     private function getStaticOSM(array $gmap, array $overlay) {
479 479
         global $conf;
480 480
 
481
-        if($this->getConf('optionStaticMapGenerator') == 'local') {
481
+        if ($this->getConf('optionStaticMapGenerator') == 'local') {
482 482
             // using local basemap composer
483
-            if(!$myMap = plugin_load('helper', 'openlayersmap_staticmap')) {
483
+            if (!$myMap = plugin_load('helper', 'openlayersmap_staticmap')) {
484 484
                 dbglog(
485 485
                     $myMap,
486 486
                     'openlayersmap_staticmap plugin is not available for use.'
487 487
                 );
488 488
             }
489
-            if(!$geophp = plugin_load('helper', 'geophp')) {
489
+            if (!$geophp = plugin_load('helper', 'geophp')) {
490 490
                 dbglog($geophp, 'geophp plugin is not available for use.');
491 491
             }
492
-            $size = str_replace("px", "", $gmap ['width']) . "x"
492
+            $size = str_replace("px", "", $gmap ['width'])."x"
493 493
                 . str_replace("px", "", $gmap ['height']);
494 494
 
495 495
             $markers = array();
496
-            if(!empty ($overlay)) {
497
-                foreach($overlay as $data) {
496
+            if (!empty ($overlay)) {
497
+                foreach ($overlay as $data) {
498 498
                     list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
499 499
                     $iconStyle  = substr($img, 0, strlen($img) - 4);
500 500
                     $markers [] = array(
@@ -506,7 +506,7 @@  discard block
 block discarded – undo
506 506
             }
507 507
 
508 508
             $apikey = '';
509
-            switch($gmap ['baselyr']) {
509
+            switch ($gmap ['baselyr']) {
510 510
                 case 'mapnik' :
511 511
                 case 'openstreetmap' :
512 512
                     $maptype = 'openstreetmap';
@@ -554,25 +554,25 @@  discard block
 block discarded – undo
554 554
             //  ol-marker|47.921629720114,18.027343747285,ol-marker-gold|47.951071133739,19.257812497236,
555 555
             //  ol-marker-blue|47.180141361692,19.257812497236,ol-marker-green
556 556
             $imgUrl = "https://staticmap.openstreetmap.de/staticmap.php";
557
-            $imgUrl .= "?center=" . $gmap ['lat'] . "," . $gmap ['lon'];
558
-            $imgUrl .= "&size=" . str_replace("px", "", $gmap ['width']) . "x"
557
+            $imgUrl .= "?center=".$gmap ['lat'].",".$gmap ['lon'];
558
+            $imgUrl .= "&size=".str_replace("px", "", $gmap ['width'])."x"
559 559
                 . str_replace("px", "", $gmap ['height']);
560 560
 
561
-            if($gmap ['zoom'] > 16) {
561
+            if ($gmap ['zoom'] > 16) {
562 562
                 // actually this could even be 18, but that seems overkill
563 563
                 $imgUrl .= "&zoom=16";
564 564
             } else {
565
-                $imgUrl .= "&zoom=" . $gmap ['zoom'];
565
+                $imgUrl .= "&zoom=".$gmap ['zoom'];
566 566
             }
567 567
 
568
-            if(!empty ($overlay)) {
569
-                $rowId  = 0;
568
+            if (!empty ($overlay)) {
569
+                $rowId = 0;
570 570
                 $imgUrl .= "&markers=";
571
-                foreach($overlay as $data) {
571
+                foreach ($overlay as $data) {
572 572
                     list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
573 573
                     $rowId++;
574 574
                     $iconStyle = "lightblue$rowId";
575
-                    $imgUrl    .= "$lat,$lon,$iconStyle%7c";
575
+                    $imgUrl .= "$lat,$lon,$iconStyle%7c";
576 576
                 }
577 577
                 $imgUrl = substr($imgUrl, 0, -3);
578 578
             }
@@ -591,7 +591,7 @@  discard block
 block discarded – undo
591 591
      * @return string
592 592
      */
593 593
     private function getBing(array $gmap, array $overlay): string {
594
-        switch($gmap ['baselyr']) {
594
+        switch ($gmap ['baselyr']) {
595 595
             case 've hybrid' :
596 596
             case 'bing hybrid' :
597 597
                 $maptype = 'AerialWithLabels';
@@ -608,33 +608,33 @@  discard block
 block discarded – undo
608 608
                 $maptype = 'Road';
609 609
                 break;
610 610
         }
611
-        $imgUrl = "https://dev.virtualearth.net/REST/v1/Imagery/Map/" . $maptype;// . "/";
612
-        if($this->getConf('autoZoomMap')) {
611
+        $imgUrl = "https://dev.virtualearth.net/REST/v1/Imagery/Map/".$maptype; // . "/";
612
+        if ($this->getConf('autoZoomMap')) {
613 613
             $bbox = $this->calcBBOX($overlay, $gmap ['lat'], $gmap ['lon']);
614 614
             //$imgUrl .= "?ma=" . $bbox ['minlat'] . "," . $bbox ['minlon'] . ","
615 615
             //          . $bbox ['maxlat'] . "," . $bbox ['maxlon'];
616
-            $imgUrl .= "?ma=" . $bbox ['minlat'] . "%2C" . $bbox ['minlon'] . "%2C" . $bbox ['maxlat']
617
-                . "%2C" . $bbox ['maxlon'];
616
+            $imgUrl .= "?ma=".$bbox ['minlat']."%2C".$bbox ['minlon']."%2C".$bbox ['maxlat']
617
+                . "%2C".$bbox ['maxlon'];
618 618
             $imgUrl .= "&dcl=1";
619 619
         }
620
-        if(strpos($imgUrl, "?") === false)
620
+        if (strpos($imgUrl, "?") === false)
621 621
             $imgUrl .= "?";
622 622
 
623 623
         //$imgUrl .= "&ms=" . str_replace ( "px", "", $gmap ['width'] ) . ","
624 624
         //          . str_replace ( "px", "", $gmap ['height'] );
625
-        $imgUrl .= "&ms=" . str_replace("px", "", $gmap ['width']) . "%2C"
625
+        $imgUrl .= "&ms=".str_replace("px", "", $gmap ['width'])."%2C"
626 626
             . str_replace("px", "", $gmap ['height']);
627
-        $imgUrl .= "&key=" . $this->getConf('bingAPIKey');
628
-        if(!empty ($overlay)) {
627
+        $imgUrl .= "&key=".$this->getConf('bingAPIKey');
628
+        if (!empty ($overlay)) {
629 629
             $rowId = 0;
630
-            foreach($overlay as $data) {
630
+            foreach ($overlay as $data) {
631 631
                 list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
632 632
                 // TODO icon style lookup, see: http://msdn.microsoft.com/en-us/library/ff701719.aspx for iconStyle
633 633
                 $iconStyle = 32;
634 634
                 $rowId++;
635 635
                 // NOTE: the max number of pushpins is 18! or we have to use POST
636 636
                 //  (http://msdn.microsoft.com/en-us/library/ff701724.aspx)
637
-                if($rowId == 18) {
637
+                if ($rowId == 18) {
638 638
                     break;
639 639
                 }
640 640
                 //$imgUrl .= "&pp=$lat,$lon;$iconStyle;$rowId";
@@ -644,7 +644,7 @@  discard block
 block discarded – undo
644 644
         }
645 645
         global $conf;
646 646
         $imgUrl .= "&fmt=png";
647
-        $imgUrl .= "&c=" . $conf ['lang'];
647
+        $imgUrl .= "&c=".$conf ['lang'];
648 648
         // dbglog($imgUrl,'syntax_plugin_openlayersmap_olmap::getBing: bing image url is:');
649 649
         return $imgUrl;
650 650
     }
@@ -663,7 +663,7 @@  discard block
 block discarded – undo
663 663
     private function calcBBOX(array $overlay, float $lat, float $lon): array {
664 664
         $lats = array($lat);
665 665
         $lons = array($lon);
666
-        foreach($overlay as $data) {
666
+        foreach ($overlay as $data) {
667 667
             list ($lat, $lon, $text, $angle, $opacity, $img) = $data;
668 668
             $lats [] = $lat;
669 669
             $lons [] = $lon;
@@ -691,13 +691,13 @@  discard block
 block discarded – undo
691 691
      * @todo move this into a shared library
692 692
      */
693 693
     private function convertLat(float $decimaldegrees): string {
694
-        if(strpos($decimaldegrees, '-') !== false) {
694
+        if (strpos($decimaldegrees, '-') !== false) {
695 695
             $latPos = "S";
696 696
         } else {
697 697
             $latPos = "N";
698 698
         }
699 699
         $dms = $this->convertDDtoDMS(abs($decimaldegrees));
700
-        return hsc($dms . $latPos);
700
+        return hsc($dms.$latPos);
701 701
     }
702 702
 
703 703
     /**
@@ -712,7 +712,7 @@  discard block
 block discarded – undo
712 712
         $secs = ($decimaldegrees - $dms) * 3600;
713 713
         $min  = floor($secs / 60);
714 714
         $sec  = round($secs - ($min * 60), 3);
715
-        $dms  .= 'º' . $min . '\'' . $sec . '"';
715
+        $dms .= 'º'.$min.'\''.$sec.'"';
716 716
         return $dms;
717 717
     }
718 718
 
@@ -724,13 +724,13 @@  discard block
 block discarded – undo
724 724
      * @todo move this into a shared library
725 725
      */
726 726
     private function convertLon(float $decimaldegrees): string {
727
-        if(strpos($decimaldegrees, '-') !== false) {
727
+        if (strpos($decimaldegrees, '-') !== false) {
728 728
             $lonPos = "W";
729 729
         } else {
730 730
             $lonPos = "E";
731 731
         }
732 732
         $dms = $this->convertDDtoDMS(abs($decimaldegrees));
733
-        return hsc($dms . $lonPos);
733
+        return hsc($dms.$lonPos);
734 734
     }
735 735
 
736 736
     /**
@@ -761,7 +761,7 @@  discard block
 block discarded – undo
761 761
         // dbglog($data, 'olmap::render() data.');
762 762
         list ($mapid, $param, $mainLat, $mainLon, $poitable, $poitabledesc, $staticImgUrl, $_firstimage) = $data;
763 763
 
764
-        if($format == 'xhtml') {
764
+        if ($format == 'xhtml') {
765 765
             $olscript     = '';
766 766
             $olEnable     = false;
767 767
             $gscript      = '';
@@ -771,56 +771,56 @@  discard block
 block discarded – undo
771 771
             $enableBing   = $this->getConf('enableBing');
772 772
 
773 773
             $scriptEnable = '';
774
-            if(!$initialised) {
774
+            if (!$initialised) {
775 775
                 $initialised = true;
776 776
                 // render necessary script tags
777
-                if($gEnable) {
777
+                if ($gEnable) {
778 778
                     $gscript = '<script charset="utf-8" defer="defer" src="//maps.google.com/maps/api/js?v=3.29&amp;key='
779
-                        . $this->getConf('googleAPIkey') . '"></script>';
779
+                        . $this->getConf('googleAPIkey').'"></script>';
780 780
                 }
781
-                $olscript = '<script charset="utf-8" defer="defer" src="' . DOKU_BASE
781
+                $olscript = '<script charset="utf-8" defer="defer" src="'.DOKU_BASE
782 782
                     . 'lib/plugins/openlayersmap/lib/OpenLayers.js"></script>';
783 783
 
784 784
                 $scriptEnable = '<script defer="defer" charset="utf-8" src="data:text/javascript;base64,';
785 785
                 $scriptSrc    = $olscript ? 'olEnable = true;' : 'olEnable = false;';
786
-                $scriptSrc    .= 'gEnable = ' . ($gEnable ? 'true' : 'false') . ';';
787
-                $scriptSrc    .= 'osmEnable = ' . ($osmEnable ? 'true' : 'false') . ';';
788
-                $scriptSrc    .= 'stamenEnable = ' . ($stamenEnable ? 'true' : 'false') . ';';
789
-                $scriptSrc    .= 'bEnable = ' . ($enableBing ? 'true' : 'false') . ';';
790
-                $scriptSrc    .= 'bApiKey="' . $this->getConf('bingAPIKey') . '";';
791
-                $scriptSrc    .= 'tfApiKey="' . $this->getConf('tfApiKey') . '";';
792
-                $scriptSrc    .= 'gApiKey="' . $this->getConf('googleAPIkey') . '";';
786
+                $scriptSrc    .= 'gEnable = '.($gEnable ? 'true' : 'false').';';
787
+                $scriptSrc    .= 'osmEnable = '.($osmEnable ? 'true' : 'false').';';
788
+                $scriptSrc    .= 'stamenEnable = '.($stamenEnable ? 'true' : 'false').';';
789
+                $scriptSrc    .= 'bEnable = '.($enableBing ? 'true' : 'false').';';
790
+                $scriptSrc    .= 'bApiKey="'.$this->getConf('bingAPIKey').'";';
791
+                $scriptSrc    .= 'tfApiKey="'.$this->getConf('tfApiKey').'";';
792
+                $scriptSrc    .= 'gApiKey="'.$this->getConf('googleAPIkey').'";';
793 793
                 $scriptEnable .= base64_encode($scriptSrc);
794 794
                 $scriptEnable .= '"></script>';
795 795
             }
796 796
             $renderer->doc .= "$gscript\n$olscript\n$scriptEnable";
797
-            $renderer->doc .= '<div class="olMapHelp">' . $this->locale_xhtml("help") . '</div>';
798
-            if($this->getConf('enableA11y')) {
799
-                $renderer->doc .= '<div id="' . $mapid . '-static" class="olStaticMap">'
800
-                    . p_render($format, p_get_instructions($staticImgUrl), $info) . '</div>';
797
+            $renderer->doc .= '<div class="olMapHelp">'.$this->locale_xhtml("help").'</div>';
798
+            if ($this->getConf('enableA11y')) {
799
+                $renderer->doc .= '<div id="'.$mapid.'-static" class="olStaticMap">'
800
+                    . p_render($format, p_get_instructions($staticImgUrl), $info).'</div>';
801 801
             }
802
-            $renderer->doc .= '<div id="' . $mapid . '-clearer" class="clearer"><p>&nbsp;</p></div>';
803
-            if($this->getConf('enableA11y')) {
802
+            $renderer->doc .= '<div id="'.$mapid.'-clearer" class="clearer"><p>&nbsp;</p></div>';
803
+            if ($this->getConf('enableA11y')) {
804 804
                 // render a table of the POI for the print and a11y presentation, it is hidden using javascript
805
-                $renderer->doc .= '<div class="olPOItableSpan" id="' . $mapid . '-table-span">
806
-                    <table class="olPOItable" id="' . $mapid . '-table">
807
-                    <caption class="olPOITblCaption">' . $this->getLang('olmapPOItitle') . '</caption>
805
+                $renderer->doc .= '<div class="olPOItableSpan" id="'.$mapid.'-table-span">
806
+                    <table class="olPOItable" id="' . $mapid.'-table">
807
+                    <caption class="olPOITblCaption">' . $this->getLang('olmapPOItitle').'</caption>
808 808
                     <thead class="olPOITblHeader">
809 809
                     <tr>
810 810
                     <th class="rowId" scope="col">id</th>
811
-                    <th class="icon" scope="col">' . $this->getLang('olmapPOIicon') . '</th>
812
-                    <th class="lat" scope="col" title="' . $this->getLang('olmapPOIlatTitle') . '">'
813
-                    . $this->getLang('olmapPOIlat') . '</th>
814
-                    <th class="lon" scope="col" title="' . $this->getLang('olmapPOIlonTitle') . '">'
815
-                    . $this->getLang('olmapPOIlon') . '</th>
816
-                    <th class="txt" scope="col">' . $this->getLang('olmapPOItxt') . '</th>
811
+                    <th class="icon" scope="col">' . $this->getLang('olmapPOIicon').'</th>
812
+                    <th class="lat" scope="col" title="' . $this->getLang('olmapPOIlatTitle').'">'
813
+                    . $this->getLang('olmapPOIlat').'</th>
814
+                    <th class="lon" scope="col" title="' . $this->getLang('olmapPOIlonTitle').'">'
815
+                    . $this->getLang('olmapPOIlon').'</th>
816
+                    <th class="txt" scope="col">' . $this->getLang('olmapPOItxt').'</th>
817 817
                     </tr>
818 818
                     </thead>';
819
-                if($poitabledesc != '') {
820
-                    $renderer->doc .= '<tfoot class="olPOITblFooter"><tr><td colspan="5">' . $poitabledesc
819
+                if ($poitabledesc != '') {
820
+                    $renderer->doc .= '<tfoot class="olPOITblFooter"><tr><td colspan="5">'.$poitabledesc
821 821
                         . '</td></tr></tfoot>';
822 822
                 }
823
-                $renderer->doc .= '<tbody class="olPOITblBody">' . $poitable . '</tbody>
823
+                $renderer->doc .= '<tbody class="olPOITblBody">'.$poitable.'</tbody>
824 824
                     </table></div>';
825 825
             }
826 826
             // render inline mapscript parts
@@ -829,28 +829,28 @@  discard block
 block discarded – undo
829 829
             $renderer->doc .= '"></script>';
830 830
             $mapnumber++;
831 831
             return true;
832
-        } elseif($format == 'metadata') {
833
-            if(!(($this->dflt ['lat'] == $mainLat) && ($this->dflt ['lon'] == $mainLon))) {
832
+        } elseif ($format == 'metadata') {
833
+            if (!(($this->dflt ['lat'] == $mainLat) && ($this->dflt ['lon'] == $mainLon))) {
834 834
                 // render geo metadata, unless they are the default
835 835
                 $renderer->meta ['geo'] ['lat'] = $mainLat;
836 836
                 $renderer->meta ['geo'] ['lon'] = $mainLon;
837
-                if($geophp = plugin_load('helper', 'geophp')) {
837
+                if ($geophp = plugin_load('helper', 'geophp')) {
838 838
                     // if we have the geoPHP helper, add the geohash
839 839
 
840 840
                     // fails with older php versions..
841 841
                     // $renderer->meta['geo']['geohash'] = (new Point($mainLon,$mainLat))->out('geohash');
842
-                    $p                                  = new Point ($mainLon, $mainLat);
842
+                    $p                                  = new Point($mainLon, $mainLat);
843 843
                     $renderer->meta ['geo'] ['geohash'] = $p->out('geohash');
844 844
                 }
845 845
             }
846 846
 
847
-            if(($this->getConf('enableA11y')) && (!empty ($_firstimage))) {
847
+            if (($this->getConf('enableA11y')) && (!empty ($_firstimage))) {
848 848
                 // add map local image into relation/firstimage if not already filled and when it is a local image
849 849
 
850 850
                 global $ID;
851 851
                 $rel = p_get_metadata($ID, 'relation', METADATA_RENDER_USING_CACHE);
852 852
                 $img = $rel ['firstimage'];
853
-                if(empty ($img) /* || $img == $_firstimage*/) {
853
+                if (empty ($img) /* || $img == $_firstimage*/) {
854 854
                     //dbglog ( $_firstimage,
855 855
                     // 'olmap::render#rendering image relation metadata for _firstimage as $img was empty or same.' );
856 856
                     // This seems to never work; the firstimage entry in the .meta file is empty
Please login to merge, or discard this patch.
Braces   +3 added lines, -2 removed lines patch added patch discarded remove patch
@@ -617,8 +617,9 @@
 block discarded – undo
617 617
                 . "%2C" . $bbox ['maxlon'];
618 618
             $imgUrl .= "&dcl=1";
619 619
         }
620
-        if(strpos($imgUrl, "?") === false)
621
-            $imgUrl .= "?";
620
+        if(strpos($imgUrl, "?") === false) {
621
+                    $imgUrl .= "?";
622
+        }
622 623
 
623 624
         //$imgUrl .= "&ms=" . str_replace ( "px", "", $gmap ['width'] ) . ","
624 625
         //          . str_replace ( "px", "", $gmap ['height'] );
Please login to merge, or discard this patch.