低纬度与地址互换,根据经纬度计算距离

2023-05-16

1、根据地址,返回对应的经纬度

2、根据输入的经纬度,返回对应的地址

3、根据两个位置的经纬度,来计算两地的距离

直接上代码

package com.demo.jw.util.common;


import com.alibaba.fastjson.JSONObject;
import com.sun.org.apache.bcel.internal.generic.IF_ACMPEQ;
import org.apache.http.client.HttpClient;
import org.omg.CORBA.WStringSeqHelper;
import org.springframework.util.StringUtils;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;
import java.text.MessageFormat;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;


public class LatitudeUtils {


    /**
     * 没有ak有的服务请求获取不到地址
     */
    public static final String ak = "l010vL91***ih17OfTbu8";

    private static double EARTH_RADIUS = 6378.137;

    private static double rad(double lat1) {
        return lat1 * Math.PI / 180.0;
    }




    /**
     * 返回输入地址的经纬度坐标
     * key lng(经度),lat(纬度)
     */
    public static Map<String,String> getGeocoderLatitude(String address){
        BufferedReader in = null;
        try {
            //将地址转换成utf-8的16进制
            address = URLEncoder.encode(address, "UTF-8");
            URL tirc = new URL("https://api.map.baidu.com/geocoder/v2/?address="+ address +"&output=json&key="+ UUID.randomUUID().toString().replace("-","")+"&ak="+ak);


            in = new BufferedReader(new InputStreamReader(tirc.openStream(),"UTF-8"));
            String res;
            StringBuilder sb = new StringBuilder("");
            while((res = in.readLine())!=null){
                sb.append(res.trim());
            }
            String str = sb.toString();
            Map<String,String> map = null;
            if(!StringUtils.isEmpty(str)){
                int lngStart = str.indexOf("lng\":");
                int lngEnd = str.indexOf(",\"lat");
                int latEnd = str.indexOf("},\"precise");
                if(lngStart > 0 && lngEnd > 0 && latEnd > 0){
                    String lng = str.substring(lngStart+5, lngEnd);
                    String lat = str.substring(lngEnd+7, latEnd);
                    map = new HashMap<String,String>();
                    map.put("lng", lng);
                    map.put("lat", lat);
                    return map;
                }
            }
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            try {
                if(in!=null){
                    in.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
	
	    /**
     * 根据经度纬度,返回对应的地址
     * 参数为String类型
     * @param lat 经度
     * @param lng 纬度
     * @return
     */
    public static String getLocationAddress(String lat, String lng)
    {
        BufferedReader in = null;
        try {
            String location = MessageFormat.format("{0},{1}", lat, lng);
            URL tirc = null;
            tirc = new URL("https://api.map.baidu.com/geocoder/v2/?location="+location+"&output=json&ak="+ak);

            in = new BufferedReader(new InputStreamReader(tirc.openStream(),"UTF-8"));
            String res;
            StringBuilder sb = new StringBuilder("");
            while((res = in.readLine())!=null){
                sb.append(res.trim());
            }
            String str = sb.toString();
            JSONObject obj = JSONObject.parseObject(str);
            if (0==obj.getInteger("status")){
                JSONObject tmp = obj.getJSONObject("result");
                if (null!=tmp){
                    return tmp.getString("formatted_address");
                }
            }
        }catch (Exception e) {
            e.printStackTrace();
        }finally{
            try {
                if(in!=null){
                    in.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        return null;
    }

    /**
     * 根据两个位置的经纬度,来计算两地的距离(单位为KM)
     * 参数为String类型
     * @param lat1Str 用户经度
     * @param lng1Str 用户纬度
     * @param lat2Str 商家经度
     * @param lng2Str 商家纬度
     * @return
     */
    public static String getDistance(String lat1Str, String lng1Str, String lat2Str, String lng2Str) {
        if(StringUtils.isEmpty(lat1Str)||StringUtils.isEmpty(lng1Str)
                ||StringUtils.isEmpty(lat2Str)||StringUtils.isEmpty(lng2Str)){
            return "";
        }
        double lat1 = Double.parseDouble(lat1Str);
        double lng1 = Double.parseDouble(lng1Str);
        double lat2 = Double.parseDouble(lat2Str);
        double lng2 = Double.parseDouble(lng2Str);
        double patm = 2;
        double radLat1 = rad(lat1);
        double radLat2 = rad(lat2);
        double difference = radLat1 - radLat2;
        double mdifference = rad(lng1) - rad(lng2);
        double distance = patm * Math.asin(Math.sqrt(Math.pow(Math.sin(difference / patm), patm)
                + Math.cos(radLat1) * Math.cos(radLat2)
                * Math.pow(Math.sin(mdifference / patm), patm)));
        distance = distance * EARTH_RADIUS;
        String distanceStr = String.valueOf(distance);
        return distanceStr;
    }

    public static void main(String args[]){
        try {
            Map<String, String> json = LatitudeUtils.getGeocoderLatitude("武汉市汉口火车站");
            System.out.println("经度 : " + json.get("lng"));
            System.out.println("纬度 : " + json.get("lat"));
        }catch (Exception e ){
            e.printStackTrace();
        }
    }


}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

低纬度与地址互换,根据经纬度计算距离 的相关文章

随机推荐

  • 手把手教你重置windows server 2016管理员密码

    需求 xff1a windows server 2016管理员密码丢失 xff0c 需要重置 一 思路分解 xff1a 虚拟机通过控制台挂载windows 2016镜像 xff0c 物理机通过BMC挂载镜像 开机后镜像启动至安装页面 打开d
  • formData传递数组

    在formData添加数组时 xff0c 会有一个的问题 xff0c 就是post请求会把数组拼接成一个字符串发送给服务器 这种时候有两种解决方案 一 后台拿到字符串后 xff0c 再通过截取字符串来生成数组 二 对数据进行字符串化 xff
  • 【面试】C/C++面试宝典一

    1 const 修饰变量 xff0c 说明该变量不可以被改变 xff1b 修饰指针 xff0c 分为指向常量的指针 xff08 pointer to const xff09 和自身是常量的指针 xff08 常量指针 xff0c const
  • vue3 + vite + ts + setup , 第十九练 vue3 中使用vue-router(三),动态路由

    动态路由 我们在做页面菜单权限的时候回用到动态路由来处理权限 xff0c 使用动态路由都是后台会返回一个路由表前端通过调接口拿到后处理 后端处理路由 动态路由主要通过两个函数实现 router addRoute 和 router remov
  • Android NestedScrollView 嵌套ViewPager不显示和出现空白部分 解决方法

    Android NestedScrollView 嵌套ViewPager不显示和出现空白部分 解决方法 问题分析 xff1a NestedScrollView里面只能有一个ViewGroup xff0c 也就是只允许有一个子节点 xff08
  • 组合导航(八):INS/GPS组合导航

    INS GPS组合导航1 误差反馈1 1 开环INS GPS架构1 2 闭环INS GPS架构 2 组合导航的类型2 1 松耦合 的INS GPS组合导航2 2 紧耦合 的INS GPS组合导航2 3 深度耦合的 INS GPS组合导航 3
  • 内网nginx代理到外网nginx(nginx之间的转发操作)

    nginx的基本常用命令 nginx t gt nginx刷新配置重启 nginx s reload 2 挂载信息查看 gt df h 挂载目录查看 etc nginx服务器之间的配置转发操作 最重要的部分 xff08 设置外层的nginx
  • 如何使用./ 执行和sh执行shell

    方法一 xff1a 给xxx sh文件加上可执行权限 chmod 指令加上可执行性权限 xff0c 然后直接使用 43 文件名 就可以运行 方法二 xff1a 直接使用 bin bash 43 文件名执行 方法三 xff1a 使用sh指令
  • Centos 7(1810)安装kubernetes单机版

    第一步 xff1a 基础网络配置 xff0c 需要能解析域名 1 部署一台CentOS虚拟机 xff0c 本次以最小化安装 xff01 2 配置基本的网络 xff0c 由于本次是最小化安装所以无法用命令行配置地址 命令行配置如下 xff1a
  • spring和springMVC配置文件中的扫描包如何配置

    我的项目大概文件路径 xff1a 然后进入主题 xff1a spring的配置文件名称为applicationContext xml springMVC的配置文件名称为dispatcherServlet servlet xml 1 spri
  • ESXi系统介绍及部署实战

    本文是向大家介绍ESXi系统部署 xff0c ESXi专为运行虚拟机 最大限度降低配置要求和简化部署而设计 只需几分钟时间 xff0c 客户便可完成从安装到运行虚拟机的全过程 一 ESXi简介 ESXi专为运行虚拟机 企业级虚拟化产品 xf
  • 一生产者多消费者模型 / 多生产者一消费者模型

    1 异常问题 xff08 wait问题 xff09 wait中断 xff1a 在调用处立即中断并且释放锁 xff0c 该线程转入等待队列 当收到持有同一把锁的线程notify通知后进入锁池队列 xff0c 再次获得同步锁之后才会继续执行 这
  • 磁共振处理软件Ubuntu->fsl安装

    经历了两天的时间 xff0c 终于在Ubuntu上安装了fsl 分享一下 xff01 xff01 xff01 所有资料 xff08 VW virtual box虚拟机 43 Ubuntu16 04 xff09 都在后面 xff0c 附链接
  • PyCharm 导包提示 unresolved reference完整解决方案

    描述 xff1a 模块部分 xff0c 写一个外部模块导入的时候居然提示unresolved reference xff0c 下面是解决方案 PyCharm 导包提示 unresolved reference解决方法是把文件夹设置为根目录
  • vue3 + vite + ts + setup , 第二十练 vue3 中使用unocss原子化

    什么是css原子化 xff1f CSS原子化的优缺点 1 减少了css体积 xff0c 提高了css复用 2 减少起名的复杂度 3 增加了记忆成本 将css拆分为原子之后 xff0c 你势必要记住一些class才能书写 xff0c 哪怕ta
  • 关于spacy和en_core_web_sm的一些问题解决办法

    报错 OSError E053 Could not read config cfg from C Users pc AppData Local Programs Python Python38 Lib site packages en co
  • Error running ‘xxApplication‘: Command line is too long. Shorten command line for ......

    idea 项目无法启动解决报错 xff1a Error running xxApplication Command line is too long Shorten command line for SvrCloudCareApplicat
  • linux发布项目以及常用操作

    linux的常用操作 xff0c 基于Xshell和Xftp 先把下载地址给兄弟们安排上 xff1a https www netsarang com zh free for home school Xshell xff1a Xshell 是
  • java接收回调通知实现方式

    演示POST方式发送通知信息 xff0c 请求参数位于request中的body中 记录一次回调参数的对接 xff0c 写起来感觉很简单 xff0c 但是表达就感觉特别难 文章内容仅供参考 xff0c 内容有误请及时指出纠正 回调通知示例
  • 低纬度与地址互换,根据经纬度计算距离

    1 根据地址 xff0c 返回对应的经纬度 2 根据输入的经纬度 xff0c 返回对应的地址 3 根据两个位置的经纬度 xff0c 来计算两地的距离 直接上代码 span class token keyword package span s