地图使用小结(百度、google)

1、轨迹回放:线条绘制与点到点动画

百度: 
线条绘制:
[BMKPolyline setPolylineWithCoordinates:coor count:count];
       动画:
 [UIView animateWithDuration:node.distance/30/timeFloat animations:^{
                currentIndex++;
                BMKSportNode *node = [sportNodes objectAtIndex:currentIndex ];
                BMKPointAnnotation.coordinate = node.coordinate;
            } completion:^(BOOL finished) {
            //循环
            }];
google:
线条:
GMSMutablePath *path = [GMSMutablePath path];
GMSPolyline.path=path;
动画:与百度不一样,使用[UIView animateWith] 无动画效果,没深究,然后使用CATransaction动画 加定时器 
            [CATransaction begin];
            [CATransaction setValue:[NSNumber numberWithFloat:node1.distance/30/timeFloat] forKey:kCATransactionAnimationDuration];
            gmsMarker.position = node.coordinate;
            [CATransaction commit];
 google地图移除覆盖物线条标注   self.map=nil;

(google动画无效果原因google大头针继承NSObject,所以使用CATransaction

2、绘制多边形覆盖物(屏幕触摸点绘制多边形)

百度:
//用户点击屏幕获取经纬度
- (void)mapView:(BMKMapView *)mapView onClickedMapBlank:(CLLocationCoordinate2D)coordinate
备注:需实现
- (BMKAnnotationView *)mapView:(BMKMapView *)mapView viewForAnnotation:(id <BMKAnnotation>)annotation此方法
点击大头针才回调
//点击大头针回调 
- (void)mapView:(BMKMapView *)mapView didSelectAnnotationView:(BMKAnnotationView *)view
google
google地图点击返回坐标
- (void)mapView:(GMSMapView *)mapView didTapAtCoordinate:(CLLocationCoordinate2D)coordinate
//点击大头针回调
- (void)mapView:(BMKMapView *)mapView didSelectAnnotationView:(BMKAnnotationView *)view
知道相应的代理实现多边形覆盖物就简单了~

3、点到点旋转角度 距离计算

#pragma mark -- 两点距离角度计算
-(double)distanceBetweenPoints:(CLLocationCoordinate2D)startCoor endCoor:(CLLocationCoordinate2D)endCoor
{
    double sx=startCoor.latitude;
    double sy=startCoor.longitude;
    double ex=endCoor.latitude;
    double ey=endCoor.longitude;
    
    return sqrt(fabs(ex-sx)*fabs(ex-sx)+fabs(ey-sy)*fabs(ey-sy));
}
-(double)calcAngleStrtCoor:(CLLocationCoordinate2D)startCoor endCoor:(CLLocationCoordinate2D)endCoor
{
    //角度时钟0点计算旋转
    double sx=startCoor.latitude;
    double sy=startCoor.longitude;
    double ex=endCoor.latitude;
    double ey=endCoor.longitude;
    NSLog(@"start %f,%f",sx,sy);
    double angle1= (atan2((ey-sy), (ex-sx)));
    double theta= angle1 *(180/M_PI);
    NSLog(@"%f",theta);
    double theta1=90;
    NSLog(@"上一个角度%f",theta1);
    if (theta<0) {
        theta=360-fabs(theta)-theta1;
    }else
    {
        theta=theta-theta1;
    }
    NSLog(@"旋转角度%f",theta);
    angle1 = M_PI/180*theta;
    return angle1;
}

4、根据GPS坐标 反地理编码

百度:
             
	     geoCodeSearch = [[BMKGeoCodeSearch alloc] init];
              geoCodeSearch.delegate = self;           BMKReverseGeoCodeOption *reverseGeoCodeOption= [[BMKReverseGeoCodeOption alloc] init]; 
               reverseGeoCodeOption.reverseGeoPoint = coor;
           [geoCodeSearch reverseGeoCode:reverseGeoCodeOption];
//BMKGeoCodeSearchDelegate
- (void)onGetReverseGeoCodeResult:(BMKGeoCodeSearch *)searcher result:(BMKReverseGeoCodeResult *)result errorCode:(BMKSearchErrorCode)error {
	//result   位置信息
}



//google
       GMSReverseGeocodeCallback callBack = ^(GMSReverseGeocodeResponse *response, NSError *error) {
       if(error == nil) {
              GMSAddress *firstResult = response.firstResult; 
              NSString *country = firstResult.country; 
              NSString *administrativeArea = firstResult.administrativeArea; 
              NSString *locality = firstResult.locality; 
              NSString *subLocality = firstResult.subLocality;
              NSString *thoroughfare = firstResult.thoroughfare;
        } 
   };
     [[GMSGeocoder geocoder] reverseGeocodeCoordinate:coor completionHandler:callBack];

转载自:https://blog.csdn.net/seequan/article/details/77839927

You may also like...