iphone 地图应用。MKMapView

目前几乎所有服务行业的产品都考虑到加入地图的功能,这大大提升了软件的易用和直观性。在iphone 中运用地图并不是一件困难的事情,因为SDK中已经提供了地图控件。


下边是我总结iphone地图的用法。




1。

现在.h文件中添加地图头文件

#import<MapKit/MapKit.h>



2

在.h文件中添加地图委托<MKMapViewDelegate>



3。

在.h文件中声明地图成员变量以及用到的函数

//地图变量

MKMapView *mapView;


//地图自动缩放。用于在设置过MapAnnotation地标后,执行次函数,就会自动的缩放地图到合适的大小。

- (void)zoomToFitMapAnnotations:(MKMapView*)inMapView;



4。

在.m的init函数中创建地图控件

//map

mapView = [[MKMapViewalloc] initWithFrame:CGRectMake(0,44, 320, self.view.frame.size.height - 88)];

[mapViewsetMapType: MKMapTypeStandard];

mapView.delegate=self;

[self.viewaddSubview:mapView];



5

在dealloc函数中释放

[mapViewrelease];



移除所有地标

[mapViewremoveAnnotations: [mapViewannotations]];



#pragma mark -

#pragma mark地图委托


- (MKAnnotationView *)mapView:(MKMapView *)theMapView viewForAnnotation:(id <MKAnnotation>)iAnnotation{

DebugLog(@"viewForAnnotation");

if ([iAnnotationisKindOfClass:[MKUserLocationclass]])

        return nil;

    

    if ([iAnnotation isKindOfClass:[MapAnnotationclass]]) // for Golden Gate Bridge

    {

MapAnnotation *annotation = iAnnotation;

staticNSString *AnnotationIdentifier = @"AnnotationIdentifier";

staticNSString *UserIdentifier = @"UserIdentifier";

NSString *Identifier =nil;

if (annotation.tag == -1) {

Identifier = AnnotationIdentifier;

}else {

Identifier = UserIdentifier;

}

       MKAnnotationView* pinView = (MKAnnotationView *) [mapViewdequeueReusableAnnotationViewWithIdentifier:Identifier];

//如果不存在的情况就创建

if (!pinView)

        {

if ([IdentifierisEqualToString:AnnotationIdentifier]) {

//自定义的大头针样式,这样的好处是,点击此按钮,会弹出一个提示框,并且提升框可以响应点击。

pinView = [[[MKPinAnnotationViewalloc] initWithAnnotation:iAnnotationreuseIdentifier:Identifier] autorelease];

[(MKPinAnnotationView *)pinViewsetPinColor:MKPinAnnotationColorRed];

UIButton *button = [UIButtonbuttonWithType:UIButtonTypeDetailDisclosure];

[buttonaddTarget:selfaction:@selector(curPositionButtonPressed:)forControlEvents:UIControlEventTouchUpInside];

[pinViewsetImage:[UIImageimageNamed:@"datouzhen.png"]];

pinView.rightCalloutAccessoryView = button;


/*

//默认的红色大头针,点击只能显示提示框,但不能点击此按钮。

pinView = [[[MKPinAnnotationView alloc] initWithAnnotation:iAnnotation reuseIdentifier:Identifier] autorelease];

[(MKPinAnnotationView *)pinView setPinColor:MKPinAnnotationColorRed];

*/


}else {

pinView = [[[MKAnnotationViewalloc] initWithAnnotation:iAnnotationreuseIdentifier:Identifier] autorelease];

UIButton *button = [UIButtonbuttonWithType:UIButtonTypeDetailDisclosure];

button.tag =annotation.tag;

[buttonaddTarget:selfaction:@selector(annotationButtonPressed:)forControlEvents:UIControlEventTouchUpInside];

[pinViewsetImage:[UIImageimageNamed:@"ann.png"]];

pinView.rightCalloutAccessoryView = button;

}

            pinView.canShowCallout =YES;

            return pinView;

        }

//如果这个已经存在,就需要重新给pinView.annotation设置值。

        else

        {

            pinView.annotation = iAnnotation;

        }

        return pinView;

    }

returnnil;

}



- (void)mapView:(MKMapView *)mapView annotationView:(MKAnnotationView *)view calloutAccessoryControlTapped:(UIControl *)control {

}



//选中了红色大头针,会显示提示按钮。点击按钮执行的函数。

- (void)curPositionButtonPressed:(UIButton *)inButton {

//inButton.tag

}


//单击某一个annotation标签的时候,会显示一个提示,提示框上有一个右箭头按钮。点击此按钮的时候,执行此函数。

- (void)annotationButtonPressed:(UIButton *)inButton {

//inButton.tag

}


//插入图钉。并设置图钉的名称和位置

-(void) setPointAnnotation{

[mapViewremoveAnnotations: [mapViewannotations]];

CLLocationCoordinate2D coordinate = {_position.latitude,_position.longitude};

MapAnnotation *annotation = [[[MapAnnotationalloc] initWithCoordinate:coordinate]autorelease];

annotation.tag = -1;

annotation.title = @"提示信息";

[mapViewaddAnnotation:annotation];

[mapViewselectAnnotation:annotationanimated:YES];

}



玩过google app的都知道,我们在地图上加一个目的地的时候,annotationview是从上掉下来的,如何实现这样的效果?经过实战,我找到有两种方法可以完成这样的效果。

第一种是实现MKMapViewDelegate的一个方法,然后自已实现下落的动画效果,代码如下:

  1. - (void)mapView:(MKMapView *)mapView didAddAnnotationViews:(NSArray *)views {   
  2.     MKAnnotationView *aV;   
  3.     for (aV in views) {  
  4.         CGRect endFrame = aV.frame;  
  5.           
  6.         aV.frame = CGRectMake(aV.frame.origin.x, aV.frame.origin.y - 230.0, aV.frame.size.width, aV.frame.size.height);  
  7.           
  8.         [UIView beginAnimations:nil context:NULL];  
  9.         [UIView setAnimationDuration:0.45];  
  10.         [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];  
  11.         [aV setFrame:endFrame];  
  12.         [UIView commitAnimations];  
  13.           
  14.     }  
  15. }  


第二种方法很简单,只需要设置一个annotationview的属性值,也是在MKMapViewDelegate的一个方法中实现,代码如下:

  1. - (MKAnnotationView *)mapView:(MKMapView *)mV viewForAnnotation:(id <MKAnnotation>)annotation  
  2. {  
  3.     if (annotation == mV.userLocation) {  
  4.         return nil;  
  5.     }  
  6.     MKPinAnnotationView *pinView = nil;   
  7.     static NSString *defaultPinID = @"custom pin";  
  8.     pinView = (MKPinAnnotationView *)[mV dequeueReusableAnnotationViewWithIdentifier:defaultPinID];  
  9.     if ( pinView == nil )  
  10.     {  
  11.         pinView = [[[MKPinAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:defaultPinID] autorelease];  
  12.         [pinView setDraggable:YES];  
  13.           
  14.     }  
  15.     pinView.pinColor = MKPinAnnotationColorRed;  
  16.       
  17.     pinView.canShowCallout = YES;  
  18.     pinView.animatesDrop = YES;  
  19.       
  20.     return pinView;  
  21. }  


注意,就是

  1. pinView.animatesDrop = YES;  
起的作用。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值