/**
* 经纬度转换 ,度分秒转度
* @param jwd
* @author LiuJie
* @return
*/
public static String Dms2D(String jwd){
if(StringUtil.isNotEmpty(jwd)&&(jwd.contains("°"))){//如果不为空并且存在度单位
//计算前进行数据处理
jwd = jwd.replace("E", "").replace("N", "").replace(":", "").replace(":", "");
double d=0,m=0,s=0;
d = Double.parseDouble(jwd.split("°")[0]);
//不同单位的分,可扩展
if(jwd.contains("′")){//正常的′
m = Double.parseDouble(jwd.split("°")[1].split("′")[0]);
}else if(jwd.contains("'")){//特殊的'
m = Double.parseDouble(jwd.split("°")[1].split("'")[0]);
}
//不同单位的秒,可扩展
if(jwd.contains("″")){//正常的″
//有时候没有分 如:112°10.25″
s = jwd.contains("′")?Double.parseDouble(jwd.split("′")[1].split("″")[0]):Double.parseDouble(jwd.split("°")[1].split("″")[0]);
}else if(jwd.contains("''")){//特殊的''
//有时候没有分 如:112°10.25''
s = jwd.contains("'")?Double.parseDouble(jwd.split("'")[1].split("''")[0]):Double.parseDouble(jwd.split("°")[1].split("''")[0]);
}
jwd = String.valueOf(d+m/60+s/60/60);//计算并转换为string
//使用BigDecimal进行加减乘除
/*BigDecimal bd = new BigDecimal("60");
BigDecimal d = new BigDecimal(jwd.contains("°")?jwd.split("°")[0]:"0");
BigDecimal m = new BigDecimal(jwd.contains("′")?jwd.split("°")[1].split("′")[0]:"0");
BigDecimal s = new BigDecimal(jwd.contains("″")?jwd.split("′")[1].split("″")[0]:"0");
//divide相除可能会报错(无限循环小数),要设置保留小数点
jwd = String.valueOf(d.add(m.divide(bd,6,BigDecimal.ROUND_HALF_UP)
.add(s.divide(bd.multiply(bd),6,BigDecimal.ROUND_HALF_UP))));*/
}
return jwd;
}
java经纬度度分秒转换为小数点格式
最新推荐文章于 2024-06-06 21:30:00 发布