zoukankan      html  css  js  c++  java
  • 将半径转换为经纬度工具类

    1.将半径转换为经纬度工具类

    package com.zhl.scheduling.utils;

    public class LocalUtil {



    private static final double PI = 3.14159265;

    private static final double EARTH_RADIUS = 6378137;

    private static final double RAD = Math.PI / 180.0;



    /**

    * @param raidus 单位米

    * 指定位置(某一处的经纬度lng lat)和搜索半径(r),搜索指定范围内的数据

    * 如果对精度要求不是很高,可以根据指定位置的经纬度和半径计算出经纬度的范围,然后判断DB中的经纬度是否在此范围内

    * 根据map提供的计算两个坐标之间距离的方法,逐一计算指定位置和我们DB库中的位置的距离s,用s和r进行比较,如果s<r,则在搜索范围内,返给前段标注在地图上。这种方法如果数据量小,可以尝试,如果数据量大,没测试过,但可以想象

    * return minLat,minLng,maxLat,maxLng

    * param lat 纬度 lon 经度 raidus 单位米

    */

    public static double[] getAround(double lat,double lon,double raidus){



    Double latitude = lat;

    Double longitude = lon;



    Double degree = (24901*1609)/360.0;

    double raidusMile = raidus;



    Double dpmLat = 1/degree;

    Double radiusLat = dpmLat*raidusMile;

    Double minLat = latitude - radiusLat;

    Double maxLat = latitude + radiusLat;



    Double mpdLng = degree*Math.cos(latitude * (PI/180));

    Double dpmLng = 1 / mpdLng;

    Double radiusLng = dpmLng*raidusMile;

    Double minLng = longitude - radiusLng;

    Double maxLng = longitude + radiusLng;

    //System.out.println("["+minLat+","+minLng+","+maxLat+","+maxLng+"]");

    return new double[]{minLat,minLng,maxLat,maxLng};

    }



    /**

    * 根据两点间经纬度坐标(double值),计算两点间距离,单位为米

    * @param lng1

    * @param lat1

    * @param lng2

    * @param lat2

    * @return

    */

    public static double getDistance(double lng1, double lat1, double lng2, double lat2)

    {

    double radLat1 = lat1*RAD;

    double radLat2 = lat2*RAD;

    double a = radLat1 - radLat2;

    double b = (lng1 - lng2)*RAD;

    double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) +

    Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));

    s = s * EARTH_RADIUS;

    s = Math.round(s * 10000) / 10000;

    return s;

    }



    public static void main(String[] args){

    Double lat1 = 34.264648; //纬度

    Double lon1 = 108.952736; //经度



    int radius = 1000; //半径

    //[34.25566276027792,108.94186385411045,34.27363323972208,108.96360814588955]

    double around[]=getAround(lat1,lon1,radius);

    for (int i = 0; i < around.length; i++) {

    System.out.println(around[i]);

    }

    System.out.println("-----------");



    //911717.0 34.264648,108.952736,39.904549,116.407288

    double dis = getDistance(108.94186385411045,34.25566276027792,108.96360814588955,34.26363323972208);

    System.out.println(dis);

    }

    }
  • 相关阅读:
    D
    hdu2376 Average distance (树形dp)
    hdu2376 Average distance (树形dp)
    选拔赛——旅游
    选拔赛——旅游
    cf 990c(思维+括号匹配)
    cf 990c(思维+括号匹配)
    Garland CodeForces
    Garland CodeForces
    Sherlock and his girlfriend CodeForces
  • 原文地址:https://www.cnblogs.com/bt2882/p/10870286.html
Copyright © 2011-2022 走看看