php百度地图计算两地现实距离
请自行到百度地图官网申请您的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);
php百度地图计算两地现实距离的更多相关文章
- iOS 百度地图计算两个点时间的距离
最近在解项目bug,更新地位城市的时候有个错误,后来想在位置改变多少距离之后,再取更新位置,这个功能去年做过.但是又忘记了! 所以还是记录一下吧. 百度地图提供了一个方法: BMKMapPointFo ...
- JS高德地图计算两地之间的实际距离
这个是通过导航的方式来获取两地之间的实际距离,和消耗的时间(key值自己去申请哈) <!doctype html> <html> <head> <meta c ...
- 百度地图坐标之间的距离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 实例 自动提示 并计算两地的行驶距离 <!DOCTYPE html> <html> <head> <meta http-equiv=" ...
- 百度地图Api 根据两个坐标点计算距离
百度地图Android Sdk的Api里面,没有现成的直接获取两个坐标点之间距离的方法,但是,在jsapi里面,有直接计算距离的方法. class Point: pass def max(a,b): ...
- 【百度地图API】如何根据摩卡托坐标进行POI查询,和计算两点距离
原文:[百度地图API]如何根据摩卡托坐标进行POI查询,和计算两点距离 摘要: 百度地图API有两种坐标系,一种是百度经纬度,一种是摩卡托坐标系.在本章你将学会: 1.如何相互转换这两种坐标: 2. ...
- Java-根据经纬度计算距离(百度地图距离)
最近碰到一个需求,需要根据两个点的经纬度查询两点的距离.感觉以后还会用到,所以小记一波. 第一步:添加Maven依赖. <dependency> <groupId>org.ga ...
随机推荐
- SPSS分析过程可自动化,你知道吗
SPSS分析过程可自动化,你知道吗 在使用SPSS的过程中,有时候会遇到重复进行相同分析操作的情况,或者分析过程很复杂的情况. 这时候我们多么希望SPSS能够记住上一次的分析步骤,不要让我们重复的去点 ...
- 关于Server.MapPath和HostingEnvironment.MapPath
最近做的项目需要在Controller里重写一个static的方法,在方法内用常用的Server.MapPath会报一个错误:An object reference is required for t ...
- 电脑缺失ACPI.sys
解决方法:注:U盘内需要有PE系统 拷贝一份正常的acpi.sys文件到u盘,插入电脑 > 开机时按F9 > 选中第三个USB *** > 回车进入PE系统,将acpi.sys放入图 ...
- Leetcode 125.验证回文字符串(Python3)
题目: 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写. 说明:本题中,我们将空字符串定义为有效的回文串. 示例 1: 输入: "A man, a plan, ...
- IntelliJ IDEA 如何在同一个窗口创建多个项目
一.IntelliJ IDEA与Eclipse的区别 二.在同一个窗口创建多个项目 1.打开IntelliJ IDEA,点击Create New Project 2.Java Enterprise ...
- 二、Python安装和第一个程序
<1.Python语言介绍1.官方介绍:Python 是一款易于学习且功能强大的编程语言. 它具有高效率的数据结构,能够简单又有效地实现面向对象编程.Python 简洁的语法与动态输入之特性,加 ...
- Python学习之函数(多层函数)、re模块的正则匹配--计算复杂加减乘除
头疼,其实这个程序在我看的视频当中是当做re模块的运用来进行测试的,而到了我这里就成了简化版的了,因为我实在是做吐了,恕小弟无能,只能做简化版的.为何说是简化版呢,因为要求是给的计算式是多层嵌套的小括 ...
- jmeter-监听器介绍与使用
12.jmeter-监听器介绍与使用 jmeter-监听器介绍与使用 察看结果树 Summary Report 聚合报告 Backend Listener Aggregate Graph 断言结果 C ...
- Jmeter运行原理
Jmeter运行原理: JMETER是运行在JVM虚拟机上的,每个进程的开销比loadrunner的进程开销大,如果以进程的方式来运行每台负载机上的进程数量不会允许太多,当有大量并发时就需要大量的负载 ...
- numpy.flatnonzero():
numpy.flatnonzero(): 该函数输入一个矩阵,返回扁平化后矩阵中非零元素的位置(index) 这是官方文档给出的用法,非常正规,输入一个矩阵,返回了其中非零元素的位置. 1 >& ...