代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Java
】
根据经纬度、半径计算距离 最大最小经纬度
作者:
xx1225
/ 发布于
2013/10/18
/
742
public class LatLonUtil { private static final double PI = 3.14159265; // 圆周率 private static final double EARTH_RADIUS = 6378137; private static final double RAD = Math.PI / 180.0; // @see // The circumference of the earth is 24,901 miles. // 24,901/360 = 69.17 miles / degree /** * @param raidus * 单位:米 return minLat,minLng,maxLat,maxLng */ public static double[] getAround(double lat, double lon, int 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] getAround(lat1, lon1, radius); // 911717.0 34.264648,108.952736,39.904549,116.407288 double dis = getDistance(108.952736, 34.264648, 116.407288, 39.904549); System.out.println(dis); } }
试试其它关键字
经纬度
同语言下
.
List 切割成几份 工具类
.
一行一行读取txt的内容
.
Java PDF转换成图片并输出给前台展示
.
java 多线程框架
.
double类型如果小数点后为零则显示整数否则保留两位小
.
将图片转换为Base64字符串公共类抽取
.
sqlParser 处理SQL(增删改查) 替换schema 用于多租户
.
JAVA 月份中的第几周处理 1-7属于第一周 依次类推 29-
.
java计算两个经纬度之间的距离
.
输入时间参数计算年龄
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
xx1225
贡献的其它代码
(
7
)
.
Socket通讯
.
初始屏停留时间及居中显示
.
批量改文件名
.
二叉树的定义,节点的增删改查,父节点、子节点的各种
.
验证函数的返回值是通过寄存器来传递
.
PHP与mysql建立链接
.
根据经纬度、半径计算距离 最大最小经纬度
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3