android中心坐标,android 百度地图 获取滑动结束后的中心点经纬度

需求是这样的,手动滑动地图停止后,直接获取到当前地图中心坐标的经纬度。

百度地图给出了一个监听事件:OnMapStatusChangeListener

该事件包含三个方法,分别是:onMapStatusChangeStart(地图状态改变开始时的地图状态)、onMapStatusChange( 当前地图状态)、onMapStatusChangeFinish(地图状态改变结束后的地图状态)

很显然,我需要在最后一个方法中去实现,通过onMapStatusChangeFinish方法我可以获取到MapStatus直接.toString拿到了一堆字符串,仔细分析发现包含了经纬度,而且里面的字段是用'n(换行)'隔开的,

不知道百度为什么会返回这种格式,返回json的多好,23333.

直接返回的格式如下:

"target lat: 39.914884096217335杠ntarget lng: 116.40388321804957杠ntarget screen x: 357杠ntarget screen y: 262杠nzoom: 13.108601,rotate: 0.0杠noverlook: 0.0杠n"

我需要的是经纬度,直接想到了截取字符串。

public void onMapStatusChangeFinish(MapStatus status) {

String _str = status.toString();

String _regex = "target lat: (.*)\ntarget lng";

String _regex2 = "target lng: (.*)\ntarget screen x";

String _latitude = latlng(_regex, _str);

String _longitude = latlng(_regex2, _str);

System.out.println(_latitude+","+_longitude);

}

private String latlng(String regexStr, String str) {

Pattern pattern = Pattern.compile(regexStr);

Matcher matcher = pattern.matcher(str);

while (matcher.find()) {

str = matcher.group(1);

}

return str;

}

今天代码检查的时候同事告诉我,可以通过MapStatus直接拿到滑动结束之后的经纬度,测试之后发现果然可以。上面的方法使用起来在效率上肯定没直接拿到的快。

代码很简单:

public void onMapStatusChangeFinish(MapStatus status) {

LatLng _latLng = status.target;

System.out.println(_latLng .latitude+","+_latLng.longitude);

}

论仔细看懂api的重要性。切记

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
获取高分一号影像中心点经纬度坐标可以通过以下步骤实现: 1. 首先,需要获取高分一号影像的元数据信息,其中包括影像的行列数、像元分辨率、中心点坐标等。可以使用GDAL库读取影像元数据信息。 2. 然后,根据影像的行列数、像元分辨率和中心点坐标计算出影像的四个角点坐标。 3. 最后,利用GIS软件或者在线地图服务,将四个角点坐标输入到地图中,即可获取高分一号影像中心点经纬度坐标。 以下是示例代码: ```python import gdal import numpy as np # 读取影像元数据信息 dataset = gdal.Open('GF1.tif') cols = dataset.RasterXSize rows = dataset.RasterYSize transform = dataset.GetGeoTransform() # 计算影像四个角点坐标 ulx = transform[0] uly = transform[3] lrx = ulx + cols * transform[1] lry = uly + rows * transform[5] # 计算影像中心点坐标 center_x = (ulx + lrx) / 2 center_y = (uly + lry) / 2 # 将中心点坐标转换为经纬度坐标 driver = gdal.GetDriverByName('MEM') ds = driver.Create('', 1, 1, 1, gdal.GDT_Float32) ds.SetGeoTransform((center_x, transform[1], transform[2], center_y, transform[4], transform[5])) srs = gdal.osr.SpatialReference() srs.ImportFromWkt(dataset.GetProjection()) ds.SetProjection(srs.ExportToWkt()) res = gdal.ReprojectImage(dataset, ds, dataset.GetProjection(), srs.ExportToWkt(), gdal.GRA_NearestNeighbour) center_lon, center_lat, _ = np.array(res.GetRasterBand(1).ReadAsArray()).ravel() print('高分一号影像中心点经度为:', center_lon) print('高分一号影像中心点纬度为:', center_lat) ``` 需要注意的是,以上代码中的`GF1.tif`是高分一号影像的文件路径,需要根据实际情况进行修改。此外,代码中使用了GDAL库进行影像处理。如果没有安装GDAL库,可以使用以下命令进行安装: ```bash pip install gdal ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值