原创

百度地图API通过经纬度获取两点间直线距离

企业web项目中经常使用到地图功能,目前比较流行的无疑是百度地图了,其百度地图API为应用开发者提供了强大的功能,下面为大家讲述一下如何通过百度地图API获取两个经纬度之间两点间直线距离。

package com.yoodb;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import org.springframework.util.StringUtils;
import com.sankai.zhcloud.util.entity.LatitudeAndLongitude;
import net.sf.json.JSONObject;
public class LngAndLatUtil {
    /**
     * 根据地址获得经纬度
     */
    public static LatitudeAndLongitude getLngAndLat(String address) {
LatitudeAndLongitude latAndLng = new LatitudeAndLongitude();
String url = "http://api.map.baidu.com/geocoder/v2/?address=" + address + "&output=json&ak=注册ak值";
String json = loadJSON(url);
if (StringUtils.isEmpty(json)) {
    return latAndLng;
}
int len = json.length();
if (json.indexOf("{") != 0 || json.lastIndexOf("}") != len - 1) {
    return latAndLng;
}
JSONObject obj = JSONObject.fromObject(json);
if (obj.get("status").toString().equals("0")) {
    double lng = obj.getJSONObject("result").getJSONObject("location").getDouble("lng");
    double lat = obj.getJSONObject("result").getJSONObject("location").getDouble("lat");
    latAndLng.setLatitude(lat);
    latAndLng.setLongitude(lng);
}
return latAndLng;
    }
    public static String loadJSON(String url) {
StringBuilder json = new StringBuilder();
try {
    URL urlObj = new URL(url);
    URLConnection uc = urlObj.openConnection();
    BufferedReader br = new BufferedReader(new InputStreamReader(uc.getInputStream()));
    String inputLine = null;
    while ((inputLine = br.readLine()) != null) {
json.append(inputLine);
    }
    br.close();
} catch (MalformedURLException e) {
} catch (IOException e) {
}
return json.toString();
    }
    /**
     * 把代码中的ak值(红色字部分)更改为注册ak值
     */
    public static void main(String[] args) {
LatitudeAndLongitude latAndLng = LngAndLatUtil.getLngAndLat("天安门");
System.out.println("经度:" + latAndLng.getLongitude() + "---纬度:" + latAndLng.getLatitude());
    }
  
    /**
     * 补充:计算两点之间真实距离
     * @return 米
     */
    public static double getDistance(double longitude1, double latitude1, double longitude2, double latitude2) {
// 维度
double lat1 = (Math.PI / 180) * latitude1;
double lat2 = (Math.PI / 180) * latitude2;
// 经度
double lon1 = (Math.PI / 180) * longitude1;
double lon2 = (Math.PI / 180) * longitude2;
// 地球半径
double R = 6371;
// 两点间距离 km
double d = Math.acos(Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1)) * R;
return d * 1000;
    }
}
~阅读全文~人机检测~

关注下方微信公众号“Java精选”(w_z90110),回复关键词领取资料:如Mysql、Hadoop、Dubbo、Spring Boot等,免费领取视频教程、资料文档和项目源码。

Java精选专注程序员推送一些Java开发知识,包括基础知识、各大流行框架(Mybatis、Spring、Spring Boot等)、大数据技术(Storm、Hadoop、MapReduce、Spark等)、数据库(Mysql、Oracle、NoSQL等)、算法与数据结构、面试专题、面试技巧经验、职业规划以及优质开源项目等。其中一部分由小编总结整理,另一部分来源于网络上优质资源,希望对大家的学习和工作有所帮助。

您可能感兴趣的文章

评论

  1. #1

    打算大三大 (2020/01/03 10:49:36)回复
    55打算大三大四的萨顶顶打啊打

分享:

支付宝

微信