Rumah >pembangunan bahagian belakang >masalah PHP >Bagaimana untuk menukar latitud dan longitud kepada koordinat piksel menggunakan PHP

Bagaimana untuk menukar latitud dan longitud kepada koordinat piksel menggunakan PHP

PHPz
PHPzasal
2023-04-24 10:51:22761semak imbas

Dengan pembangunan berterusan teknologi Web, semakin banyak tapak web kini membentangkan maklumat melalui peta, dan memaparkan titik label yang sesuai pada peta merupakan isu teknikal yang sangat kritikal. Apabila menggunakan peta untuk memaparkan data, kadangkala kita perlu menukar koordinat longitud dan latitud pada peta kepada koordinat piksel, seperti mencari titik penanda secara automatik pada peta. Oleh itu, dalam artikel ini, kami akan memperkenalkan cara menukar latitud dan longitud kepada koordinat piksel menggunakan PHP.

Apakah koordinat latitud, longitud dan piksel

Sebelum kita mula menerangkan cara menukar latitud dan longitud kepada koordinat piksel, kita perlu memahami konsep asas latitud, longitud dan koordinat piksel? .

Koordinat yang diperoleh daripada peta ialah longitud dan latitud, di mana longitud merujuk kepada kedudukan titik di sebelah barat bumi, dan latitud merujuk kepada kedudukan titik di selatan atau utara khatulistiwa. .

Koordinat piksel ialah koordinat pada skrin, yang terdiri daripada piksel pada skrin.

Apabila memaparkan data pada peta, kita perlu menukar latitud dan longitud kepada koordinat piksel untuk mencari lokasi tertentu.

Kira latitud dan longitud berdasarkan koordinat piksel

Seterusnya, kita akan belajar cara mengira latitud dan longitud berdasarkan koordinat piksel. Dalam proses ini, kita perlu menggunakan beberapa matematik asas. Berikut ialah kod untuk proses ini:

function pixel2LatLng($x, $y, $zoom) {
    $numTiles = 1 << $zoom; // 2 ^ zoom
    $tileSize = 256;
    $x /= $tileSize;
    $y /= $tileSize;
    $x = min($x, $numTiles - 1);
    $y = min($y, $numTiles - 1);
    $lng = ($x / $numTiles) * 360.0 - 180.0;
    $lat = rad2deg(atan(sinh(pi() * (1 - 2 * $y / $numTiles))));
    return [&#39;lat&#39; => $lat, 'lng' => $lng];
}

Fungsi ini menerima 3 parameter, iaitu koordinat $x, $y bagi piksel dan parameter $zoom, yang menerangkan tahap zum. Seterusnya, kami mencipta dua pembolehubah, $numTiles dan $tileSize, yang mewakili bilangan jubin peta 2D standard dan saiz setiap jubin, iaitu 256 piksel.

Perhatikan bahawa apabila menukar koordinat piksel, kita perlu membahagikan koordinat dengan $tileSize terlebih dahulu untuk memastikan ia berada dalam julat standard. Kemudian hadkannya kepada nilai maksimum dalam setiap dimensi untuk mengelakkannya melebihi kawasan paparan peta.

Seterusnya, gunakan formula matematik mudah untuk mengira latitud dan longitud. Pertama, kita mengira $lng, iaitu longitud yang sepadan dengan koordinat piksel $x. Untuk melakukan ini, kami menggunakan pengiraan penolakan (([$x / $numTiles) * 360.0 - 180.0]) yang memberikan kita skala darjah piksel dan kemudian menolak 180 darjah daripadanya. Sebab anda perlu menolak 180 darjah adalah kerana longitud boleh sama dengan dari -180 hingga +180 darjah. Oleh itu, kita perlu mengehadkan nilai kepada julat ini.

Akhir sekali, kami mengira nilai latitud dan mengembalikan tatasusunan bersekutu yang mengandungi koordinat $lat dan $lng.

Kira koordinat piksel berdasarkan longitud dan latitud

Sbalik proses di atas, kita juga boleh mengira titik koordinat piksel berdasarkan longitud dan latitud. Berikut ialah kod untuk proses ini:

function latLng2Pixel($latitude, $longitude, $zoom) {
    $numTiles = 1 << $zoom; // 2 ^ zoom
    $tileSize = 256;
    $x = round(($longitude + 180.0) / 360.0 * $numTiles);
    $y = round((1.0 - log(tan(deg2rad($latitude)) + 1.0 / cos(deg2rad($latitude))) / pi()) / 2.0 * $numTiles);
    return [&#39;x&#39; => $x * $tileSize, 'y' => $y * $tileSize];
}

Fungsi ini hampir sama dengan yang di atas, kecuali ia mengira koordinat piksel berdasarkan latitud dan longitud dan bukannya sebaliknya. Kami menggunakan pembolehubah yang sama seperti sebelumnya, $numTiles dan $tileSize, dan memperkenalkan pembolehubah $lat dan $lng untuk mewakili nilai latitud dan longitud yang dihantar ke fungsi.

Kemudian, kami mula-mula melakukan pengiraan mudah untuk mendapatkan koordinat piksel $x. Idea formula ini ialah apabila bergerak pada peta, kerana longitud boleh berubah dari -180 darjah ke +180 darjah, kita mula-mula menambah 180 darjah ke longitud yang ditentukan supaya selepas menentukan 0 darjah, hasil yang dikira boleh dijamin adalah nilai positif. Seterusnya, kami membahagikan nilai ini sebanyak 360 darjah untuk mendapatkan koordinat x bagi lokasi titik perpuluhan dan darabkannya dengan nombor kuasa-2 peta, $numTiles, untuk mendapatkan koordinat piksel.

Seterusnya, kami mengira koordinat piksel $y. Apabila mengembara pada peta, latitud boleh berubah daripada -90 darjah kepada +90 darjah. Idea formula ini ialah, bermula dari titik rujukan (khatulistiwa), kita menggunakan fungsi tangen dan arktangen untuk mengira jarak ke dan sekitar titik yang ingin kita cari. Akhir sekali, kami membahagikan dengan $tileSize untuk menukar koordinat piksel kepada piksel dan bukannya koordinat.

Akhir sekali, tatasusunan bersekutu yang mengandungi koordinat $x dan $y dikembalikan.

Ringkasan

Di atas ialah pelaksanaan PHP untuk menukar longitud dan latitud kepada koordinat piksel dan menukar koordinat piksel kepada longitud dan latitud. Kedua-dua teknik transformasi ini boleh menjadi sangat berguna apabila memaparkan data menggunakan peta. Harap artikel ini membantu anda!

Atas ialah kandungan terperinci Bagaimana untuk menukar latitud dan longitud kepada koordinat piksel menggunakan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn