我已经在我的MKMapView中添加了一个MKCircle作为MKOverlay。我还添加了一个UISlider来决定圆的半径。不幸的是,当使用它时,它看起来有点“滞后”,不像我想要的那样流畅。
示例:http://dl.dropbox.com/u/3077127/mkoverlayDelay.mov
这是我的代码:
- (void)addCircle
{
// draw the radius circle for the marker
double radius = 2000.0;
MKCircle *circle = [MKCircle circleWithCenterCoordinate:location radius:radius];
[circle setTitle:@"background"];
[mapView addOverlay:circle];
MKCircle *circleLine = [MKCircle circleWithCenterCoordinate:location radius:radius];
[circleLine setTitle:@"line"];
[mapView addOverlay:circleLine];
}
- (void)addCircleWithRadius:(double)radius
{
MKCircle *circle = [MKCircle circleWithCenterCoordinate:location radius:radius];
[circle setTitle:@"background"];
[mapView addOverlay:circle];
MKCircle *circleLine = [MKCircle circleWithCenterCoordinate:location radius:radius];
[circleLine setTitle:@"line"];
[mapView addOverlay:circleLine];
}
- (void)sliderChanged:(UISlider*)sender
{
[mapView removeOverlays:[mapView overlays]];
double radius = (sender.value * 100);
[self addCircleWithRadius:radius];
}
- (MKOverlayView *)mapView:(MKMapView *)mapView viewForOverlay:(id <MKOverlay>)overlay{
MKCircle *circle = overlay;
MKCircleView *circleView = [[[MKCircleView alloc] initWithCircle:overlay] autorelease];
if ([circle.title isEqualToString:@"background"])
{
circleView.fillColor = UIColorFromRGB(0x598DD3);
circleView.alpha = 0.25;
}
else
{
circleView.strokeColor = UIColorFromRGB(0x5C8AC7);
circleView.lineWidth = 2.0;
}
return circleView;
}有没有人有什么建议可以让我更顺畅呢?
诚挚的问候,
保罗·皮伦
发布于 2011-02-07 01:17:59
我已经尝试过你的代码,并找到了一种非常简单的方法来使它更流畅。
如果您在:- (void)sliderChanged:(UISlider*)sender中更改调用的顺序
您可以调用[self addCircleWithRadius:radius];
在调用[mapView removeOverlays:[mapView overlays]];之前
只需确保你没有删除你刚刚添加的覆盖,只删除旧的。
这将给你一个更平滑的大小调整,特别是当新的圆比旧的小的时候。
对于较大的圆,最好使用NSOperations来确保更快地创建视图,这将使其更平滑。
希望这能有所帮助。
发布于 2011-02-07 02:00:05
您最好的选择可能是自己绘制圆,或者使用MKMapView顶部的另一个UIView,或者使用地图视图中的MKAnnotationView。
这位博主也做了类似的事情(在iOS4之前,添加了覆盖层)。http://spitzkoff.com/craig/?p=65
https://stackoverflow.com/questions/4876035
复制相似问题