·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> app软件开发 >> IOS开发 >> iOS根据坐标数据点所在的坐标区域来动态显示到可视范围

iOS根据坐标数据点所在的坐标区域来动态显示到可视范围

作者:佚名      IOS开发编辑:admin      更新时间:2022-07-23

在地图上标注很多点之后,地图的中心点可以设置,但是缩放级别用起来就有点囧了,

所以,就需要根据坐标数据点所在的坐标区域来动态计算,把所有点都刚好显示到地图的可视范围内。

直接上代码:

 

    //清理坐标数据的视图和数据
    [_bMapView removeAnnotations:_mapAnnotations];
    [_mapAnnotations removeAllObjects];
    [_carPointArray removeAllObjects];
    //声明解析时对坐标数据的位置区域的筛选,包括经度和纬度的最小值和最大值
    CLLocationDegrees minLat;
    CLLocationDegrees maxLat;
    CLLocationDegrees minLon;
    CLLocationDegrees maxLon;
    //解析数据
    for (int i=0; i<rows.count; i++) {
        NSDictionary *row = [rows objectAtIndex:i];
        坐标模型类 *item = [[坐标模型类 alloc] initWithJson:row];
        if (item.vehicleNo && [item.vehicleNo length]>0) {
            标注模型类 *annotation = [[标注模型类 alloc] init];
            annotation.coordinate = item.baiduCoordinate;
            annotation.item = item;
            [_mapAnnotations addObject:annotation];
            [_bMapView addAnnotation:annotation];
            [annotation release];
            
            if (i==0) {
                //以第一个坐标点做初始值
                minLat = item.baiduCoordinate.latitude;
                maxLat = item.baiduCoordinate.latitude;
                minLon = item.baiduCoordinate.longitude;
                maxLon = item.baiduCoordinate.longitude;
            }else{
                //对比筛选出最小纬度,最大纬度;最小经度,最大经度
                minLat = MIN(minLat, item.baiduCoordinate.latitude);
                maxLat = MAX(maxLat, item.baiduCoordinate.latitude);
                minLon = MIN(minLon, item.baiduCoordinate.longitude);
                maxLon = MAX(maxLon, item.baiduCoordinate.longitude);
            }
            
            [_carPointArray addObject:item];
        }
        [item release];
    }
    //动态的根据坐标数据的区域,来确定地图的显示中心点和缩放级别
    if (_carPointArray.count > 0) {
        //计算中心点
        CLLocationCoordinate2D centCoor;
        centCoor.latitude = (CLLocationDegrees)((maxLat+minLat) * 0.5f);
        centCoor.longitude = (CLLocationDegrees)((maxLon+minLon) * 0.5f);
        BMKCoordinateSpan span;
        //计算地理位置的跨度
        span.latitudeDelta = maxLat - minLat;
        span.longitudeDelta = maxLon - minLon;
        //得出数据的坐标区域
        BMKCoordinateRegion region = BMKCoordinateRegionMake(centCoor, span);
        //百度地图的坐标范围转换成相对视图的位置
        CGRect fitRect = [_bMapView convertRegion:region toRectToView:_bMapView];
        //将地图视图的位置转换成地图的位置
        BMKMaPRect fitMapRect = [_bMapView convertRect:fitRect toMapRectFromView:_bMapView];
        //设置地图可视范围为数据所在的地图位置
        [_bMapView setVisibleMapRect:fitMapRect animated:YES];
        
    }

  

补充:

MKMapRect zoomRect = MKMapRectNull;
for (id <MKAnnotation> annotation in mapView.annotations) {
    MKMapPoint annotationPoint = MKMapPointForCoordinate(annotation.coordinate);
    MKMapRect pointRect = MKMapRectMake(annotationPoint.x, annotationPoint.y, 0, 0);
    if (MKMapRectIsNull(zoomRect)) {
        zoomRect = pointRect;
    } else {
        zoomRect = MKMapRectUnion(zoomRect, pointRect);
    }
}
[mapView setVisibleMapRect:zoomRect animated:YES];

  

 

 

最后来张效果图: