php地图距离计算,php百度地图计算两地现实距离

郎健柏
2023-12-01

请自行到百度地图官网申请您的ak

<!--前端获取手机经纬度的代码-->

<!--<!DOCTYPE html>-->

<!--<html lang="en">-->

<!---->

<!--<head>-->

<!-- <meta charset="UTF-8">-->

<!-- <title>text</title>-->

<!-- <script>-->

<!-- function getLocation() {-->

<!-- if (navigator.geolocation) {-->

<!-- navigator.geolocation.getCurrentPosition(showMap,errorMap);-->

<!-- } else {-->

<!-- alert("您的浏览器不支持")-->

<!-- }-->

<!---->

<!-- }-->

<!-- function showMap(position){-->

<!-- var longitude = position.coords.longitude;-->

<!-- var latitude = position.coords.latitude;-->

<!-- alert("您的位置是:"+longitude+ "," + latitude);-->

<!--}-->

<!--function errorMap(value){-->

<!-- switch(value.code){-->

<!-- case 1: alert("位置请求被拒绝");break;-->

<!-- case 2: alert("暂时获取不到位置信息");break;-->

<!-- case 3: alert("请求超时");break;-->

<!-- case 4: alert("未知错误");break;-->

<!-- }-->

<!-- }-->

<!-- -->

<!--getLocation();-->

<!--</script>-->

<!---->

<!--</head>-->

<!--</html>-->

<?php

/**

* 计算两个地址之间的距离,单位:米

* 地址要尽量详细,减小误差

* @param address

* @param $param

* @return $param

*/

function calculateDistance($address,$param){

if (!is_array($param)){

throw new Exception("参数必须为array");

}

$length = count($param);

$url = urldecode("http://api.map.baidu.com/cloudgc/v1?ak=您的ak&address=".$address);

$result = json_decode(get($url));

$startLatLng = array(

"lat" => $result->result[0]->location->lat,

"lng" => $result->result[0]->location->lng

);

for ($i=0; $i<$length; $i++){

$url = urldecode("http://api.map.baidu.com/cloudgc/v1?ak=您的ak&address=".$param[$i]['address']);

$result = json_decode(get($url));

$endLatLng = array(

"lat" => $result->result[0]->location->lat,

"lng" => $result->result[0]->location->lng

);

$distance = array( "distance"=>getDistance($startLatLng,$endLatLng),"unit"=>"m");

array_push($param[$i],$distance);

}

return $param;

}

// $add = array(

// array("address"=>"福建省厦门市集美区"),

// array("address"=>"北京市海淀区上地十街10号")

// );

// print_r(calculateDistance("福建省厦门市集美区",$add)); /**

* 发送GET请求

* @param url

* @param param

* @return result

*/

function get($url, $param=array()){

if(!is_array($param)){

throw new Exception("参数必须为array");

}

$p='';

foreach($param as $key => $value){

$p=$p.$key.'='.$value.'&';

}

if(preg_match('/\?[\d\D]+/',$url)){//matched ?c

$p='&'.$p;

}else if(preg_match('/\?$/',$url)){//matched ?$

$p=$p;

}else{

$p='?'.$p;

}

$p=preg_replace('/&$/','',$p);

$url=$url.$p;

//echo $url;

$http =curl_init($url);

curl_setopt($http, CURLOPT_SSL_VERIFYPEER, 0);

curl_setopt($http, CURLOPT_SSL_VERIFYHOST, 2);

curl_setopt($http,CURLOPT_RETURNTRANSFER,1);

curl_setopt($http, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)");

curl_setopt($http, CURLOPT_RETURNTRANSFER,1);

curl_setopt($http, CURLOPT_HEADER,false);

$result=curl_exec($http);

curl_close($http);

return $result;

}

/**

* 计算两点之间距离

* @param start

* @param end

* @return 米

*/

function getDistance($startLatLng,$endLatLng){

if (is_array($startLatLng)&&is_array($endLatLng)){

$lat1 = (pi()/180)*$startLatLng['lat'];

$lat2 = (pi()/180)*$endLatLng['lat'];

$lng1 = (pi()/180)*$startLatLng['lng'];

$lng2 = (pi()/180)*$endLatLng['lng'];

//地球半径

$R = 6371;

//两点间的距离 km,如果想要米的话,结果*1000就可以了

$d = acos(sin($lat1)*sin($lat2)+cos($lat1)*cos($lat2)*cos($lng2-$lng1))*$R;

}else{

$d = 1;

}

return $d*1000;

}

/**

* 通过ip获取地址

* @param $ip

* @throws Exception

* @return $result

*/

function getAddressByIp($ip){

if (!filter_var($ip,FILTER_VALIDATE_IP)){

throw new Exception("IP无效");

}

$url = "http://api.map.baidu.com/location/ip?ak=您的ak&coor=bd09ll&ip=".$ip;

$result = json_decode(get($url));

if ($result->status != 0){

throw new Exception("获取坐标失败");

}

$url = "http://api.map.baidu.com/geocoder/v2/?location=".$result->content->point->y.",".$result->content->point->x."&ak=您的ak&output=json";

$result= json_decode(get($url));

echo $result->result->formatted_address;

return $result->result->formatted_address;

} //getAddressByIp("120.41.85.225");/**

* 通过GPS定位拿到具体位置,电脑只有IE、edge才有定位权限

* @param $latLng=array('lat'=>?,'lng'=>?)

* @return $result->result->formatted_address

*/

function getAddressByGPS($latLng)

{

$url = "http://api.map.baidu.com/geocoder/v2/?location=" .$latLng['lat'].",".$latLng['lng']. "&ak=您的ak&output=json";

$result = json_decode(get($url));

return $result->result->formatted_address;

}

$latLng = array(

'lat'=>24.609098,

'lng'=>118.045559

);

echo getAddressByGPS($latLng);

iOS 百度地图计算两个点时间的距离

最近在解项目bug,更新地位城市的时候有个错误,后来想在位置改变多少距离之后,再取更新位置,这个功能去年做过.但是又忘记了! 所以还是记录一下吧. 百度地图提供了一个方法: BMKMapPointFo ...

JS高德地图计算两地之间的实际距离

这个是通过导航的方式来获取两地之间的实际距离,和消耗的时间(key值自己去申请哈)

百度地图坐标之间的距离php

function GetDistance($lat1, $lng1, $lat2, $lng2){ define('PI',3.1415926535898); define('EARTH_RADIUS ...

百度地图 - demo

项目需要集成百度地图,那么关于如何集成百度地图的事,就自己去百度开放平台查看文档吧,这是非常简单的事,在这里就不多说了. 那么下面我就说说我在这个demo里所做的事. 首先,项目需要具备定位及计算两地 ...

Java根据两点的经纬度来计算之间的距离

import java.util.HashMap; import java.util.Map; public class MapDistance { private static double EAR ...

百度地图api 实例 自动提示 并计算两地的行驶距离

百度地图api 实例 自动提示 并计算两地的行驶距离

百度地图Api 根据两个坐标点计算距离

百度地图Android Sdk的Api里面,没有现成的直接获取两个坐标点之间距离的方法,但是,在jsapi里面,有直接计算距离的方法. class Point: pass def max(a,b): ...

【百度地图API】如何根据摩卡托坐标进行POI查询,和计算两点距离

原文:[百度地图API]如何根据摩卡托坐标进行POI查询,和计算两点距离 摘要: 百度地图API有两种坐标系,一种是百度经纬度,一种是摩卡托坐标系.在本章你将学会: 1.如何相互转换这两种坐标: 2. ...

Java-根据经纬度计算距离(百度地图距离)

最近碰到一个需求,需要根据两个点的经纬度查询两点的距离.感觉以后还会用到,所以小记一波. 第一步:添加Maven依赖. org.ga ...

随机推荐

我们为什么使用Node

引言:Node 已经迅速成为一个可行并且真正高效的web 开发平台.在Node 诞生之前,在服务端运行JavasScript 是件不可思议的事情,并且对其他的脚本语言来说,要实现非阻塞I/O 通常需要 ...

Github的基本配置与使用

第一步:尝试创建SSH key ssh-keygen -t rsa -C xxxxx@gmail.com 默认在~/.ssh目录生成id_rsa与id_rsa.pub. -t代表密钥类型,常见的类型有 ...

如何在 &period;Net Framework 4&period;0 项目上使用 OData?

最新的 Microsoft ASP.NET Web API 2.1 OData 5.1.0 已只能在 .Net Framework 4.5 的安装了,如果要在 VS2010的 .Net Framewo ...

支持BLOB操作的Jena框架扩展——JenaBLOB

与研究语义网的同行们分享一下上半年做的一个东西,它是支持BLOB操作的Jena框架扩展--JenaBLOB,已在GitHub上开源,欢迎提出宝贵意见! 众所周知,Jena是不支持BLOB类型的Lite ...

在CentOS上部署多节点Citus集群

1 在所有节点执行以下步骤 Step 01 添加Citus Repostory # Add Citus repository for package manager curl https://inst ...

Java初学者应该注意的学习问题

作为初学者,在刚开始学习的时候,一定会走很多弯路.但其实很多弯路是不必走的,会浪费很多时间,导致学习效率大打折扣.今天小编给大家讲述一下,作为一个Java初学者,在开始学习的时候应该注意的问题,应该从 ...

ECharts常用设置记录

一.配置文档 http://echarts.baidu.com/option.html#title 二.属性配置 1.图表与边框容器距离. grid: { top: '10%', left: '70' ...

Oracle的基本查询知识

基本语法 SELECT [DISTINCT] {*, column [alias],...} FROM table;参数说明SELECT 标识出所需的数据列.函数.常量和表达式.Distinct 删除 ...

C&plus;&plus; 作业 (循环链表构建队列)

/* author screen name Andromeda_Galaxy; chinese name 杨子俊 */ #include using name ...

在AbpZero中hangfire后台作业的使用——开启hangfire

AbpZero框架已经集成了hangfire,但它默认是关闭的,我们可以在运行站点下的Startup.cs文件中把这行代码注释取消就行了,代码如下:     //Hangfire (Enable to ...

 类似资料: