используя UIView в качестве подпредставления MKMapView, чтобы нарисовать маршрут - PullRequest
3 голосов
/ 14 января 2010

Прежде всего, я прошу прощения за мой плохой английский.

Я пытаюсь нарисовать маршрут в UIView и установить это представление как MKMapView.

Теперь у меня есть класс UIView (ViewClass), в который я помещаю все методы touch и устанавливаю представление моего viewcontroller как экземпляр этого класса. MKMapView является подпредставлением viewcontroller.view. Я могу получить все штрихи в MKMapView. Чтобы нарисовать след, я установил UIView (trailView) как подпредставление MKMapView с чистым цветом фона. Я пытаюсь переместить trailView, когда MKMapView движется, но я не получаю хороших результатов. Движение не идеально.

Идея состоит в том, чтобы подключить представление к MKMapView. Я не знаю, возможно ли это или мне действительно нужно использовать MKAnnotationView. Я пробовал раньше с MKAnnotationView, но это занимает много памяти.

Я действительно ценю некоторую помощь. Заранее спасибо.

Ответы [ 3 ]

1 голос
/ 25 июня 2010

iOS4 имеет новую систему наложения, включая рендеринг путей. Я еще не использовал его, но, похоже, это было бы НАИБОЛЕЕ проще, чем пытаться свернуть собственное наложение.

См. http://developer.apple.com/iphone/library/documentation/MapKit/Reference/MKOverlayPathView_class/Reference/Reference.html#//apple_ref/doc/uid/TP40009713

0 голосов
/ 21 января 2010

След выстроен в линию, но когда я прокручиваю, я получаю плохой результат. Что касается версии моего приложения с MKAnnotatioView, я могу показать вам код, но я не могу показать вам журнал, потому что, к сожалению, я не с iphone сейчас ...

-(void)locationManager:(CLLocationManager *)manager didUpdateToLocation:(CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation {  

self.startingPoint = newLocation;

CLLocation *lastLocation;

if([pointArray count] >= 2)
{
    lastLocation = [pointArray objectAtIndex:1];
    [pointArray removeAllObjects];
}       

mapView.showsUserLocation = NO;

double lat,lon;     
lat = newLocation.coordinate.latitude;
lon = newLocation.coordinate.longitude;         

if(distanceIndex == 0)
{
    [pointArray insertObject:newLocation atIndex:0];
}
else 
{               
    if(distanceIndex == 1)
    {
        [pointArray insertObject:newLocation atIndex:1];
    }
    else 
    {
        [pointArray insertObject:lastLocation atIndex:0];
        [pointArray insertObject:newLocation atIndex:1];
    }
}           

if(distanceIndex == 0)
{
    MarkPlace *mark = nil;  

    NSDateFormatter *dateFormatter = [[NSDateFormatter alloc]init];
    [dateFormatter setDateStyle:NSDateFormatterNoStyle];
    [dateFormatter setTimeStyle:NSDateFormatterShortStyle];     
    NSString *dateStr = [dateFormatter stringFromDate:[NSDate date]];
    [dateFormatter release];
    NSString *subtitle = [NSString stringWithFormat:@"Time Here: %@", dateStr];
    mark = [[[MarkPlace alloc] initWithCoordinate:[[pointArray objectAtIndex:0] coordinate] currentTime:subtitle annotationType:MarkPlaceTypeEnd title:@"Pin Title"] autorelease];
    [mapView addAnnotation:mark];




}

//create the route
MKCoordinateSpan span = mapView.region.span;
CLLocationCoordinate2D center = mapView.region.center;

IFRouteAnnotations *routeAnnotation = [[[IFRouteAnnotations alloc] initWithPoints:pointArray:0:span:center] autorelease];
[mapView addAnnotation:routeAnnotation];

[mapView setRegion:routeAnnotation.region animated:TRUE];

distanceIndex = distanceIndex + 1;
[routeAnnotation release];

}

    -(void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated {
//re-enable and re-position the route display
for (NSObject *key in [routeViews allKeys]) {
    IFRouteView *routeView = [routeViews objectForKey:key];
    [routeView regionChanged];
}

}

-(MKAnnotationView *)mapView:(MKMapView *)_mapView viewForAnnotation:(id <MKAnnotation>)annotation{

MKAnnotationView *annotationView = nil;
NSLog(@"viewForAnnotation");
if(distanceIndex == 0)
{       
    MKPinAnnotationView *pin=[[[MKPinAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:@"Pin"] autorelease];
    pin.pinColor = MKPinAnnotationColorGreen;
    pin.animatesDrop = TRUE;
    pin.userInteractionEnabled = YES;

    annotationView = pin;
    [annotationView setEnabled:YES];
    [annotationView setCanShowCallout:YES];
}

if([annotation isKindOfClass:[IFRouteAnnotations class]])
{
    IFRouteAnnotations *routeAnnotation = (IFRouteAnnotations *)annotation;

    annotationView = [routeViews objectForKey:routeAnnotation.routeID];

    if(annotationView == nil)
    {
        IFRouteView *routeView = [[[IFRouteView alloc] initWithFrame:CGRectMake(0,0, mapView.frame.size.width, mapView.frame.size.height)]autorelease];

        routeView.annotation = routeAnnotation;
        routeView.mapView = mapView;

        [routeViews setObject:routeView forKey:routeAnnotation.routeID];

        annotationView = routeView;
    }
}   
return annotationView;

}

Не знаю, поймешь ли ты что-нибудь. Мой код основан на тексте ссылки . Спасибо за вашу помощь!! :)

0 голосов
/ 20 января 2010

Это очень хороший вопрос.

Как насчет того, чтобы получить данные о пикселях из области карты, которая вас интересует, и в зависимости от цвета пути, выполнить вычисления ближайшего соседа. в направлении, которое вы ищете. Сохранить этот путь на ходу и отобразить другой цвет в trailView?

Что еще более усложняет задачу, так это масштабирование, поскольку вам потребуется независимый от разрешения след (преобразование координаты карты), а не пиксельная координата. Таким образом, вы преобразуете свои пиксельные координаты в координаты карты, а затем он должен масштабироваться для увеличения.

...