java gps_用Java解析GPS经纬度

这篇博客介绍了如何使用Java将GPS设备返回的经纬度数据转换为度分秒形式,并提供了具体的转换公式和代码示例。文章中展示了从原始数据‘3641.2220N11706.2569E’中解析经纬度的过程,通过substring方法截取和计算得出坐标。最后,博主分享了实际应用中如何调用LocationInfo类获取地理信息。
摘要由CSDN通过智能技术生成

现在正开发的定位模块用到的定位设置是塞格车圣导航设备,发送指令返回的经纬度需要进行转换,再到GIS系统获取地理信息描述。以后需要要经常用到这方面的知识,随笔写下。

将十进制数值转经纬度

公式:

Decimal Degrees = Degrees + minutes/60 + seconds/3600

例:57°55'56.6" =57+55/60+56.6/3600=57.9323888888888

如把经纬度  (longitude,latitude) (205.395583333332,57.9323888888888)转换据成坐标(Degrees,minutes,seconds)(205°23'44.1",57°55'56.6")。

步骤如下:

1、 直接读取"度":205

2、(205.395583333332-205)*60=23.734999999920 得到"分":23

3、(23.734999999920-23)*60=44.099999995200 得到"秒":44.1

发送定位指令,终端返回的经纬度信息如下:

(ONE072457A3641.2220N11706.2569E000.000240309C0000400)

按照协议解析

dc621733677c39fb6b0c6b7445108bb3.png

获得信息体的经纬度是主要,其它不要管,直接用String类的substring()方法截掉,获取的经纬度

3641.2220N11706.2569E

package com.tdt.test;

import com.tdt.api.gis.LocationInfo;

/**

*

Title:坐标转换

*

*

Description:

*

*

Copyright: Copyright (c) 2009

*

*

Company:

*

* @author sunnylocus

* @version 1.0 [2009-03-24]

*

*/

public class LonlatConversion {

/**

*

* @param dms 坐标

* @param type 坐标类型

* @return String 解析后的经纬度

*/

public static String xypase(String dms, String type) {

if (dms == null || dms.equals("")) {

return "0.0";

}

double result = 0.0D;

String temp = "";

if (type.equals("E")) {//经度

String e1 = dms.substring(0, 3);//截取3位数字,经度共3位,最多180度

//经度是一伦敦为点作南北两极的线为0度,所有往西和往东各180度

String e2 = dms.substring(3, dms.length());//需要运算的小数

result = Double.parseDouble(e1);

result += (Double.parseDouble(e2) / 60.0D);

temp = String.valueOf(result);

if (temp.length() > 9) {

temp = e1 + temp.substring(temp.indexOf("."), 9);

}

} else if (type.equals("N")) {//纬度,纬度是以赤道为基准,相当于把地球分两半,两个半球面上的点和平面夹角0~90度

String n1 = dms.substring(0, 2);//截取2位,纬度共2位,最多90度

String n2 = dms.substring(2, dms.length());

result = Double.parseDouble(n1);

result += Double.parseDouble(n2) / 60.0D;

temp = String.valueOf(result);

if (temp.length() > 8) {

temp = n1 + temp.substring(temp.indexOf("."), 8);

}

}

return temp;

}

public static void main(String[] args) {

String info="(ONE072457A3641.2220N11706.2569E000.000240309C0000400)";

info=info.substring(11,info.length()-13);

//纬度

String N = info.substring(0, info.indexOf("N"));

//经度

String E = info.substring(info.indexOf("N")+1,info.indexOf("E"));

//请求gis,获取地理信息描述

double x = Double.parseDouble(CoordConversion.xypase(E,"E"));

double y = Double.parseDouble(CoordConversion.xypase(N,"N"));

String result =LocationInfo.getLocationInfo("test", x, y); //System.out.println("径度:"+x+","+"纬度:"+y);

System.out.println(result);

}

}

运行结果

在济南市,位于轻骑路和八涧堡路附近;在环保科技园国际商务中心和济南市区贤文庄附近。

0

1

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2009-03-24 17:01

浏览 15794

评论

10 楼

vvczx

2015-11-03

楼主好人,求那个jar。谢谢啦、2313936326@qq.com

9 楼

liu1245621121

2015-09-08

楼主 好人 求包 1245621121@qq.com

8 楼

ningyuehuai

2015-07-01

楼主能把jar发我一份吗,邮箱:nyhitany@163.com   谢谢!

7 楼

975764577

2013-11-18

楼主,能把包发下给我吗? www.975764577@qq.com

6 楼

kele558

2013-11-06

能提供com.tdt.api.gis jar下载吗?

5 楼

liuliwy

2012-07-24

求那个jar包呀 楼主

邮箱是466210126@qq.com

4 楼

sunnylocus

2011-10-11

tangfei 写道

com.tdt.api.gis.LocationInfo;

这个类在哪儿呢?

这个方法封装成了一个jar包,里面太复杂了,没有贴上来。

3 楼

tangfei

2011-10-11

com.tdt.api.gis.LocationInfo;

这个类在哪儿呢?

2 楼

sunnylocus

2010-09-17

cyp5913 写道

0956f0a970daab536ce4be0ee96b00ac.gif

兄弟咋哭了呢?

1 楼

cyp5913

2010-09-16

0956f0a970daab536ce4be0ee96b00ac.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值