码迷,mamicode.com
首页 > 其他好文 > 详细

位置与地图(三)给地图添加覆盖层

时间:2014-07-01 06:17:34      阅读:758      评论:0      收藏:0      [点我收藏+]

标签:地图   覆盖层   

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.mapView = [[MKMapView alloc] initWithFrame:self.view.bounds];
    self.mapView.mapType = MKMapTypeStandard;
    self.mapView.scrollEnabled = YES;
    //  设置地图不可旋转
    self.mapView.rotateEnabled = NO;
    self.mapView.zoomEnabled = YES;
    self.mapView.showsUserLocation = YES;
    
    //  设置地图中心的经纬度
    CLLocationCoordinate2D center = {39.910650,116.47030};
    //  设置地图显示的范围,数值越小细节越清楚
    MKCoordinateSpan span = {0.01,0.01};
    //  二者合一设置显示区域
    MKCoordinateRegion region = {center,span};
    [self.mapView setRegion:region animated:YES];

    [self.view addSubview:self.mapView];
    
    UILongPressGestureRecognizer *longGesture = [[UILongPressGestureRecognizer alloc] initWithTarget:self action:@selector(longPress:)];
    [self.mapView addGestureRecognizer:longGesture];
    
    //  设置代理
    self.mapView.delegate = self;
    
}

- (void)longPress:(UILongPressGestureRecognizer *)longGesture{
    
    //  获取长按点得坐标
    CGPoint postion = [longGesture locationInView:self.mapView];
    //  将长按点坐标转换为经纬度
    CLLocationCoordinate2D coord2D = [self.mapView convertPoint:postion toCoordinateFromView:self.mapView];
    //  创建一个圆形覆盖层对象
    MKCircle *circle = [MKCircle circleWithCenterCoordinate:coord2D radius:100];
    //  将单个的覆盖层添加到指定的层级
    [self.mapView addOverlay:circle level:MKOverlayLevelAboveLabels];
    
}

//  该方法返回的MKOverlayRenderer负责绘制覆盖层控件
- (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id<MKOverlay>)overlay{

    MKCircle *circle = (MKCircle *)overlay;
    // iOS7之后,推荐使用MKXxxRenderer来负责渲染覆盖层控件
    MKCircleRenderer *circleRend = [[MKCircleRenderer alloc] initWithCircle:circle];
    circleRend.alpha = 0.3;
    //  填充颜色
    circleRend.fillColor = [UIColor blueColor];
    //  边框颜色
    circleRend.strokeColor = [UIColor redColor];
    
    return circleRend;
}


/*********iOS7新增的MKTileOverlay覆盖层*******************************************
- (void)longPress:(UILongPressGestureRecognizer *)longGesture{
    
    //  指定本地图片覆盖
    NSURL *url = [[NSBundle mainBundle] URLForResource:@"hmt" withExtension:@"png"];
    MKTileOverlay *tileOverlay = [[MKTileOverlay alloc] initWithURLTemplate:[url description]];
    [self.mapView addOverlay:tileOverlay];
    
}

//  该方法返回的MKOverlayRenderer负责绘制覆盖层控件
- (MKOverlayRenderer *)mapView:(MKMapView *)mapView rendererForOverlay:(id<MKOverlay>)overlay{
    
    MKTileOverlayRenderer *tileRender = [[MKTileOverlayRenderer alloc] initWithOverlay:(MKTileOverlay *)overlay];
    tileRender.alpha = 0.2;
    return circleRend;
}
*/
bubuko.com,布布扣

位置与地图(三)给地图添加覆盖层,布布扣,bubuko.com

位置与地图(三)给地图添加覆盖层

标签:地图   覆盖层   

原文地址:http://blog.csdn.net/hmt20130412/article/details/36009093

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!