PHP と Baidu Map API を使用してタクシー軌跡表示機能を実装するチュートリアル
要約:
このチュートリアルでは、PHP と Baidu Map API を使用してタクシー軌跡表示機能を実装する方法を紹介します。 Baidu Maps の JavaScript API を使用して地図を描画し、PHP を通じてデータベースからタクシーの軌跡データを取得します。最終的には、各タクシーの移動軌跡を表示し、いくつかのインタラクティブ機能を追加する予定です。
データベースの作成
まず、タクシー軌跡データを保存するデータベース テーブルを作成する必要があります。各タクシーの経度、緯度、タイムスタンプのデータを保存する必要があるとします。 「tracks」という名前のテーブルを作成し、次のフィールドを追加します。
CREATE TABLE `tracks` ( `id` INT(11) UNSIGNED AUTO_INCREMENT PRIMARY KEY, `car_id` INT(11) NOT NULL, `lng` DOUBLE NOT NULL, `lat` DOUBLE NOT NULL, `timestamp` INT(11) NOT NULL );
テスト データの挿入
以降の表示軌跡のために、前の手順で作成したデータベース テーブルにテスト データを挿入します。例:
INSERT INTO `tracks` (`car_id`, `lng`, `lat`, `timestamp`) VALUES (1, 116.404, 39.915, 1600000000), (1, 116.406, 39.920, 1600000100), ...
PHP スクリプトの作成
「map.php」という名前の PHP スクリプトを作成して、データベースから軌跡データを取得し、フロントエンドに返します。次のコードを「map.php」に追加します。
<?php // 连接到数据库 $servername = "localhost"; $username = "root"; $password = "password"; $dbname = "your_database"; $conn = new mysqli($servername, $username, $password, $dbname); if ($conn->connect_error) { die("Connection failed: " . $conn->connect_error); } // 获取轨迹数据 $carId = $_GET['car_id']; // 从前端获取参数 $sql = "SELECT * FROM tracks WHERE car_id = $carId"; // 假设每辆出租车有一个唯一的ID $result = $conn->query($sql); $tracks = []; if ($result->num_rows > 0) { while($row = $result->fetch_assoc()) { $tracks[] = $row; } } else { echo "No tracks found."; } // 返回JSON格式的轨迹数据 header('Content-Type: application/json'); echo json_encode($tracks); $conn->close(); ?>
HTML ページの作成
地図と軌跡データを表示する「index.html」という名前の HTML ページを作成します。次のコードを「index.html」に追加します。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>出租车轨迹展示</title> <style> #map { width: 100%; height: 500px; } </style> </head> <body> <div id="map"></div> <script src="http://api.map.baidu.com/api?v=2.0&ak=your_api_key"></script> <script> var map = new BMap.Map("map"); map.centerAndZoom(new BMap.Point(116.404, 39.915), 14); // 获取轨迹数据 var carId = 1; // 假设需要展示的出租车ID为1 var xhr = new XMLHttpRequest(); xhr.open("GET", "map.php?car_id=" + carId, true); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { var tracks = JSON.parse(xhr.responseText); // 绘制轨迹 var path = tracks.map(function (track) { return new BMap.Point(track.lng, track.lat); }); var polyline = new BMap.Polyline(path, {strokeColor: "blue", strokeWeight: 3, strokeOpacity: 0.5}); map.addOverlay(polyline); } }; xhr.send(); </script> </body> </html>
概要:
このチュートリアルでは、PHP と Baidu Map API を使用してタクシー軌跡表示機能を実装する方法を紹介します。 PHPを使用してデータベースから軌跡データを取得し、Baidu MapsのJavaScript APIを使用して地図と軌跡を描画することで、各タクシーの移動軌跡を動的に表示できます。タクシー マーカー、リアルタイムの軌跡更新、その他の機能の追加など、実際のニーズに基づいてさらに最適化および拡張できます。
以上がPHPとBaidu Map APIを利用してタクシー軌跡表示機能を実装するチュートリアルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。