使用MapKit叠加图片和视图教程(2)
来源:互联网 发布:快剪视频软件 编辑:程序博客网 时间:2024/05/22 00:35
如果你喜欢的话那就在地图上放置一个Pin — 注解
如果你用Maps程序搜索过位置信息,那么你肯定看到过在地图上出现的许多Pin。这可以理解为注解(annotation),它是用
在程序中使用注解来标出具体的某个景点,这对游客来说非常有用。注解对象的使用方法跟MKOverlay 和MKOverlayView非常类似, 只不过需要使用的类是MKAnnotation
在Annotations群组中创建一个名为
然后用下面的代码替换
#import <Foundation/Foundation.h>#import <MapKit/MapKit.h>typedef NS_ENUM(NSInteger, PVAttractionType) { PVAttractionDefault = 0, PVAttractionRide, PVAttractionFood, PVAttractionFirstAid}; @interface PVAttractionAnnotation : NSObject @property (nonatomic) CLLocationCoordinate2D coordinate;@property (nonatomic, strong) NSString *title;@property (nonatomic, strong) NSString *subtitle;@property (nonatomic) PVAttractionType type; @end
上面的代码中,首先是import MapKit,然后为PVAttractionType.定义了一个枚举。这个枚举列出了注解的类型:游乐设施,食物,急救和默认。
接着让这个类遵循
OK, 下面我们来看看PVAttractionAnnotation的实现。
将
#import “PVAttractionAnnotation.h”
@implementation PVAttractionAnnotation@end
这可能是本文中最简单的实现了!在里面不需要实现任何内容;只需要了解在头文件定义的一些属性即可!
现在需要创建一个MKAnnotation
在Annotation群组中创建另外一个类:PVAttractionAnnotationVi
用下面的代码替换PVAttractionAnnotationVi
#import <Foundation/Foundation.h>#import <MapKit/MapKit.h>@interface PVAttractionAnnotationVi ew : MKAnnotationView @end
将下面的代码添加到
#import "PVAttractionAnnotationView.h" #import "PVAttractionAnnotation.h"@implementation PVAttractionAnnotationVi ew - (id)initWithAnnotation:(id)annotation reuseIdentifier:(NSString *)reuseIdentifier { self = [super initWithAnnotation:annotation reuseIdentifier:reuseIdentifier]; if (self) { PVAttractionAnnotation *attractionAnnotation = self.annotation; switch (attractionAnnotation.type) { case PVAttractionFirstAid: self.image = [UIImage imageNamed:@"firstaid"]; break; case PVAttractionFood: self.image = [UIImage imageNamed:@"food"]; break; case PVAttractionRide: self.image = [UIImage imageNamed:@"ride"]; break; default: self.image = [UIImage imageNamed:@"star"]; break; } } return self;} @end
上面重载了方法
非常棒! 现在你创建好了注解和与其相关的view,下面可以将它们添加到map view中了!
首先,你需要准备在
在plist文件中包含了坐标信息以及其它与公园景点相关的一些详细信息,如下所示:
- 使用MapKit叠加图片和视图教程(2)
- 使用MapKit叠加图片和视图教程(1)
- Core Location定位和MapKit视图使用
- IOS学习之Core Location定位和MapKit视图使用
- MapKit之大头针全面解析(使用系统大头针、自定义大头针callout视图、使用图片显示大头针)
- iOS-raywenderlich翻译-使用MapKit叠加图层
- iOS-raywenderlich翻译-使用MapKit叠加图层
- IOS学习之十二:Core Location定位和MapKit视图使用
- IOS学习之十二:Core Location定位和MapKit视图使用
- java使用Graphics2D图片叠加
- MAPKit使用
- MapKit缩放和CAKeyframeAnimation类使用!
- iOS中 CoreLocation 和 MapKit 的使用
- 2个图片的叠加
- 图片叠加
- MapKit 教程: 覆盖物
- html和css两个图片叠加
- html和css两个图片叠加
- 写在研一下的总结
- iOS中如何创建一个滑出式导航面板(…
- iOS中如何创建一个滑出式导航面板(1)
- UIPopoverController的使用
- 使用MapKit叠加图片和视图教程(1)
- 使用MapKit叠加图片和视图教程(2)
- 【IOS】利用ASIHTTPRequest
- Auto Layout iOS
- presentModalViewController…
- SpriteKit初探的解释--自学X…
- SpriteKit碰撞检测
- 【iOS录音与播放】实现利用音频队…
- ios音频队列实现录音和播音(转)
- IOS socket基于tcp/udp…