近年來,Web GIS 技術得到了越來越廣泛的應用,而 Leaflet 作為一款輕量級的開源 JavaScript 地圖庫,已經成為了許多 Web 地圖應用程式的首選。結合 PHP 語言編寫的 Web 應用程式可以方便地在 Web 上展示地圖資訊和地理位置資料。本文將介紹如何使用 PHP 和 Leaflet 建立地圖應用程式。
在開發之前,我們需要準備一些開發工具。首先需要事先安裝好 PHP 開發環境,本文程式碼是基於 PHP7.3.12 版本進行開發。其次,需要下載 Leaflet 函式庫。可以從官網上下載最新版本的庫,或在 GitHub 上取得原始碼。最後,需要選擇一個Web框架來幫助我們快速建立 PHP 開發的 Web 服務。本文我們選擇使用一款 PHP 框架:Lumen。
(1) 建立Lumen專案
我們可以透過 Composer 來安裝 Lumen。在命令列中輸入以下命令(前提是已經安裝好 Composer):
composer create-project --prefer-dist laravel/lumen map-app
該指令將在目前檔案目錄下建立一個名為 map-app 的 Lumen 專案。
(2) 安裝依賴
進入專案根目錄,執行下列指令安裝所需的依賴:
composer install
(3) 整合Leaflet
我們在網站根目錄下建立一個新資料夾(例如「public」),並將下載的Leaflet 庫檔案解壓縮到該資料夾下。在 HTML 頁面中加入以下程式碼來引入 Leaflet 函式庫:
<link rel="stylesheet" href="/public/leaflet/leaflet.css" /> <script type="text/javascript" src="/public/leaflet/leaflet.js"></script>
(4) 定義路由
在 Lumen 框架中,我們通常會使用路由來處理 URL 請求。在 “routes” 目錄下建立一個名為 “web.php” 的文件,定義不同的 URL 對應不同的處理器。例如:
<?php $router->get('/', 'MapController@showMap'); ?>
我們在根目錄下建立一個名為 “MapController.php” 的文件,用於處理不同的 URL 請求。該檔案包含以下方法:
<?php namespace AppHttpControllers; use LaravelLumenRoutingController as BaseController; class MapController extends BaseController { public function showMap() { return view('map'); } } ?>
該方法指定了當使用者存取 “/” URL 時,將對應顯示名為 “map.blade.php” 的 Blade 範本。
(5) 定義 Blade 模板
Blade 是一款極為流行的 PHP 模板引擎,它允許我們使用特定的語法格式來編寫模板檔案。在 “resources/views” 目錄下,我們建立一個名為 “map.blade.php” 的範本檔案。檔案包含以下程式碼:
<!DOCTYPE html> <html> <head> <link rel="stylesheet" href="/public/leaflet/leaflet.css" /> <script src="/public/leaflet/leaflet.js"></script> <style> #mapid { height: 600px; } </style> </head> <body> <div id="mapid"></div> <script> var mymap = L.map('mapid').setView([51.505, -0.09], 13); L.tileLayer('https://api.mapbox.com/styles/v1/{id}/tiles/{z}/{x}/{y}?access_token={accessToken}', { attribution: 'Map data © <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors, ' + '<a href="https://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' + 'Imagery © <a href="https://www.mapbox.com/">Mapbox</a>', maxZoom: 18, id: 'mapbox/streets-v11', tileSize: 512, zoomOffset: -1, accessToken: 'change me' }).addTo(mymap); </script> </body> </html>
這個範本檔案定義了一個地圖的初始位置和縮放等級,使用 Mapbox 提供的街道地圖樣式,其中的「accessToken」需要填寫自己的Mapbox Access Token。在範本檔案中,我們也需要引用在 “public” 資料夾下引入的 Leaflet 庫檔案。
(6) 執行應用程式
現在可以在命令列中輸入以下命令啟動Web 伺服器:
php -S localhost:8000 -t public
在瀏覽器中存取「http://localhost: 8000” 即可看到顯示了地圖的Web 頁面。
透過本文的學習,讀者了解如何使用 PHP 和 Leaflet 建立地圖應用程式。我們學習如何使用 Lumen 框架,如何引入 Leaflet 庫,如何在模板中建立地圖,以及如何啟動 Web 伺服器。讀者可以透過此文初步掌握如何使用 PHP 建立 Web GIS 應用程式。
以上是使用PHP和Leaflet創建地圖應用程式的詳細內容。更多資訊請關注PHP中文網其他相關文章!