百度地图根据地址获取经纬度

本文介绍了如何通过调用百度地图API的地理编码服务,将结构化地址转换为经纬度坐标。展示了使用JSONObject处理返回结果并获取经纬度值的核心代码片段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

地理编码服务
地理编码服务(又名Geocoder)是一类Web API接口服务;
地理编码服务提供将结构化地址数据(如:北京市海淀区上地十街十号)转换为对应坐标点(经纬度)功能;
用户可通过该功能,将结构化地址(省/市/区/街道/门牌号)解析为对应的位置坐标。地址结构越完整,地址内容越准确,解析的坐标精度越高。
在这里插入图片描述

核心代码

JSONObject location = getAddressLngLatPoint(schoolRegionDTO.getAddress());
if (ObjectUtil.isNotEmpty(location)) {
    schoolRegionDTO.setBizLongitude(location.getString("lng"));
    schoolRegionDTO.setBizLatitude(location.getString("lat"));
}

private JSONObject getAddressLngLatPoint(String address) throws Exception {
    URL url = new URL("https://api.map.baidu.com/geocoding/v3/?address=" + address + "&output=json&ak=" + "密钥");
    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
    connection.connect();

    InputStream urlStream  = connection.getInputStream();
    java.io.BufferedReader reader = new BufferedReader(new InputStreamReader(urlStream));
    String result = reader.readLine();

    JSONObject jsonObject = JSON.parseObject(result);
    if (jsonObject.getInteger("status") != 0) {
        return null;
    }
    return (JSONObject) ((JSONObject) jsonObject.get("result")).get("location");
}
### 实现点击地图获取经纬度 在 Cesium 中可以通过监听鼠标事件来捕获用户的点击动作并计算该位置的地理坐标。具体方法如下: 当用户单击地图时,`viewer.scene.pickPosition` 或 `scene.pickEllipsoid` 可用于将屏幕上的像素坐标换为世界坐标系中的笛卡尔坐标[^1]。对于更精确的结果,在未加载高程数据的情况下推荐使用 `scene.cartesianToCartographic` 函数进一步处理这些笛卡尔坐标以获得纬度和经度值。 下面是一个简单的例子展示如何实现这一功能: ```javascript // 假设 viewer 是已经初始化好的 Cesium Viewer 对象 const handler = new Cesium.ScreenSpaceEventHandler(viewer.canvas); handler.setInputAction(function (movement) { const cartesian = viewer.camera.pickEllipsoid(movement.position, viewer.scene.globe.ellipsoid); if (cartesian) { // 如果有交点,则继续执行 const cartographic = Cesium.Cartographic.fromCartesian(cartesian); // 将三维坐标成二维地理坐标 console.log('Latitude:', Cesium.Math.toDegrees(cartographic.latitude)); console.log('Longitude:', Cesium.Math.toDegrees(cartographic.longitude)); // 打印高度信息(可选) console.log('Height:', cartographic.height); // 这里可以添加更多逻辑,比如在地图上放置标记等操作... } }, Cesium.ScreenSpaceEventType.LEFT_CLICK); ``` 此代码片段展示了如何设置一个左键单击事件处理器,并从中提取出被点击处的世界坐标以及对应的经纬度信息。需要注意的是,如果启用了地形插件并且地形存在较大的起伏变化,那么使用 `pickEllipsoid` 方法可能会带来一定的精度损失;此时应考虑其他方式如 raycasting 来提高准确性[^3]。 另外,在基于 Vue.js 构建的应用程序中集成上述功能时,还需要确保按照正确的方式引入了必要的库文件和支持模块,例如通过安装 vue-cesium 插件简化开发流程[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值