调用百度API返回经纬度

后台调用百度API接口生成:

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 java.util.HashMap;
import java.util.Map;

import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.util.JSONTokener;
/**
* @Description: 调用百度公共接口获取经纬度
* @ClassName: EntCoordSyncJob
* @author 明
* @date 2019年9月30日
*
*/
public class EntCoordSyncJob {
  static String AK = "Mwdez7V8QGg0hw3G1keqeoc7cgiktSx1"; // 百度地图密钥
  public static void main(String[] args) throws Exception {
    Map<String, String> lngAndLat = EntCoordSyncJob.getLngAndLat("大");
    System.out.println(lngAndLat);
  }
  public static Map<String,String> getLngAndLat(String address)throws Exception{
  Map<String,String> map=new HashMap<String, String>();
  String url = "http://api.map.baidu.com/geocoder?address="+address+"&output=json&ak="+AK+"";
  String json = loadJSON(url);
  JSONObject obj = JSONObject.fromObject(json);
  if(obj.get("status").toString().equals("OK")){
    Object typeObject = new JSONTokener(obj.get("result").toString()).nextValue();
    if(typeObject instanceof JSONArray) {
    map.put("error","请输入正确地址");
    return map;
  }
  if(typeObject instanceof JSONObject) {
    String lng=obj.getJSONObject("result").getJSONObject("location").getString("lng");
    String lat=obj.getJSONObject("result").getJSONObject("location").getString("lat");
      map.put("lng", lng);
      map.put("lat", lat);
    return map;
  }
}else{
  map.put("error","请输入正确地址");
}
  return map;
}

public static String loadJSON (String url)throws Exception {
  StringBuilder json = new StringBuilder();
try {
  URL oracle = new URL(url);
  URLConnection yc = oracle.openConnection();
  BufferedReader in = new BufferedReader(new InputStreamReader(
  yc.getInputStream()));
  String inputLine = null;
  while ( (inputLine = in.readLine()) != null) {
  json.append(inputLine);
}
  in.close();
} catch (MalformedURLException e) {
  e.printStackTrace();
} catch (IOException e) {
  e.printStackTrace();
}
  return json.toString();
  }
}

通过 http://api.map.baidu.com/geocoder 和

 http://api.map.baidu.com/geocoding/v3/ 

获取地址 “北京市顺义区金关北二街5号”的经纬度都是  {'lng': 116.87314337408223, 'lat': 40.175352148045754} --A

而在 百度 “拾取坐标系统” http://api.map.baidu.com/lbsapi/getpoint/index.html 获取的经纬度却是:116.924888,40.196355 --B

在“拾取坐标系统”里,用“坐标反查”在图上定位,A定的点不对,差了几公里;B 定位精准。

5、百度坐标为何有偏移?

国际经纬度坐标标准为WGS-84,国内必须至少使用国测局制定的GCJ-02,对地理位置进行首次加密。百度坐标在此基础上,进行了BD-09二次加密措施,更加保护了个人隐私。百度对外接口的坐标系并不是GPS采集的真实经纬度,需要通过坐标转换接口进行转换。

前端生成:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="keywords" content="百度地图,百度地图API,百度地图自定义工具,百度地图所见即所得工具" />
<meta name="description" content="百度地图API自定义地图,帮助用户在可视化操作下生成百度地图" />
<title>百度地图API自定义地图</title>
<!--引用百度地图API-->
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=Mwdez7V8QGg0hw3G1keqeoc7cgiktSx1"></script>
</head>
<body>
<!--百度地图容器-->
<div style="width:700px;height:550px;border:#ccc solid 1px;font-size:12px" id="map"></div>
<p style="color:red;font-weight:600">地图生成工具基于百度地图JS api v2.0版本开发,使用请申请密匙。
<a href="http://developer.baidu.com/map/index.php?title=jspopular/guide/introduction" style="color:#2f83c7" target="_blank">了解如何申请密匙</a>
<a href="http://lbsyun.baidu.com/apiconsole/key?application=key" style="color:#2f83c7" target="_blank">申请密匙</a>
</p>
</body>
<script type="text/javascript">
//创建和初始化地图函数:
function initMap(){
createMap();//创建地图
setMapEvent();//设置地图事件
addMapControl();//向地图添加控件
addMapOverlay();//向地图添加覆盖物
}
function createMap(){
map = new BMap.Map("map");
map.centerAndZoom(new BMap.Point(116.403874,39.914889),12);
}
function setMapEvent(){
map.enableScrollWheelZoom();
map.enableKeyboard();
map.enableDragging();
map.enableDoubleClickZoom()
}
function addClickHandler(target,window){
target.addEventListener("click",function(){
target.openInfoWindow(window);
});
}
function addMapOverlay(){
var markers = [
{content:"我的备注",title:"我的标记",imageOffset: {width:0,height:3},position:{lat:39.917545,lng:116.406749}}
];
for(var index = 0; index < markers.length; index++ ){
var point = new BMap.Point(markers[index].position.lng,markers[index].position.lat);
var marker = new BMap.Marker(point,{icon:new BMap.Icon("http://api.map.baidu.com/lbsapi/createmap/images/icon.png",new BMap.Size(20,25),{
imageOffset: new BMap.Size(markers[index].imageOffset.width,markers[index].imageOffset.height)
})});
var label = new BMap.Label(markers[index].title,{offset: new BMap.Size(25,5)});
var opts = {
width: 200,
title: markers[index].title,
enableMessage: false
};
var infoWindow = new BMap.InfoWindow(markers[index].content,opts);
marker.setLabel(label);
addClickHandler(marker,infoWindow);
map.addOverlay(marker);
};
}
//向地图添加控件
function addMapControl(){
var scaleControl = new BMap.ScaleControl({anchor:BMAP_ANCHOR_BOTTOM_LEFT});
scaleControl.setUnit(BMAP_UNIT_IMPERIAL);
map.addControl(scaleControl);
var navControl = new BMap.NavigationControl({anchor:BMAP_ANCHOR_TOP_LEFT,type:BMAP_NAVIGATION_CONTROL_LARGE});
map.addControl(navControl);
var overviewControl = new BMap.OverviewMapControl({anchor:BMAP_ANCHOR_BOTTOM_RIGHT,isOpen:true});
map.addControl(overviewControl);
}
var map;
initMap();
</script>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知青先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值