iPhone: Wykrywanie Stuknij w MKMapView

głosy
19

W jaki sposób wykryć jeden kran na wystąpienie MKMapView? Mam do podklasy MKMapView, a następnie zastąpić touchesEndedmetodę?

Dzięki,

-Chris

Utwórz 14/08/2009 o 03:22
źródło użytkownik
W innych językach...                            


8 odpowiedzi

głosy
31

Jeśli szukasz po prostu, aby otrzymywać powiadomienia gestów zaczepów bez wpływu na którykolwiek z pozostałych dotykowym zachowania mapie, będziemy chcieli użyć UITapGestureRecognizer. To bardzo proste, wystarczy umieścić w jakimś kodem takiego.

UITapGestureRecognizer* tapRec = [[UITapGestureRecognizer alloc] 
   initWithTarget:self action:@selector(didTapMap:)];
[theMKMapView addGestureRecognizer:tapRec];
[tapRec release];

Że wywoła didTapMapkiedy theMKMapViewotrzyma gest kranu i wszystkie szczypanie, i przeciągając gesty będą nadal działać tak jak wcześniej.

Odpowiedział 31/12/2010 o 21:30
źródło użytkownik

Odpowiedział 10/11/2009 o 13:27
źródło użytkownik

głosy
2

Działa idealnie na iOS 8

- (void)viewDidLoad 
    {
        [super viewDidLoad];

        UITapGestureRecognizer *doubleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:nil];
        doubleTap.numberOfTapsRequired = 2;
        doubleTap.numberOfTouchesRequired = 1;
        [self.mapView addGestureRecognizer:doubleTap];

        UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleGesture:)];
        singleTap.numberOfTapsRequired = 1;
        singleTap.numberOfTouchesRequired = 1;
        [singleTap requireGestureRecognizerToFail: doubleTap];
        [self.mapView addGestureRecognizer:singleTap];
     }

   - (void)handleGesture:(UIGestureRecognizer *)gestureRecognizer
     {
            if (gestureRecognizer.state != UIGestureRecognizerStateEnded)
                return;
            //Do your work ...
     }
Odpowiedział 03/04/2015 o 10:46
źródło użytkownik

głosy
2

Lub w zależności od tego, co staramy się robić, dodać MKAnnotation(pinezkę, z objaśnienia), więc masz coś do kranu na - i wówczas mapa delegat otrzyma np zdarzeń.

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

Odpowiedział 18/09/2009 o 09:31
źródło użytkownik

głosy
0

moje 2 centów za Swit 5.x:

override func touchesEnded(_ touches: Set<UITouch>, with event: UIEvent?) {
    if let touch = touches.first {
        let v = touch.view
        let ssv = v?.superview?.superview
        if ssv === self.mapView{
            searchBar.resignFirstResponder()
        }
    }
}

to działa. ale szczerze może złamać jeśli jabłko warstw zmienia poglądów. Lepszy rozpoznawania.

Odpowiedział 16/09/2019 o 19:19
źródło użytkownik

głosy
0

Nic kiedykolwiek znaleziono obrobione, ale wymyśliłem tego unperfect rozwiązanie: W viewDidLoad

let singleTapRecognizer = UITapGestureRecognizer(target: self, action: #selector(onMapClicked))
singleTapRecognizer.delegate = self
mapView.addGestureRecognizer(singleTapRecognizer)

W delegata:

func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool {
    return touch.view!.frame.equalTo(mapView.frame)
}
Odpowiedział 20/09/2017 o 09:34
źródło użytkownik

głosy
0

Wystarczy dodać jakiś fragment kodu jako ilustracja @ TT-kilew odpowiedź. W moim przypadku, chcę wskazać użytkownikowi sobie na mapie, ale nie chce, aby przerwać jego dotyk przeciągania.

@interface PrettyViewController () <MKMapViewDelegate>

@property (weak, nonatomic) IBOutlet MKMapView *mapView;
@property (assign, nonatomic) BOOL userTouchTheMap;

@end

@implementation PrettyViewController

#pragma mark - UIResponder

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
    [super touchesBegan:touches withEvent:event];

    self.userTouchTheMap = [[touches anyObject].view isEqual:self.mapView];
}


#pragma mark - MKMapViewDelegate

- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)userLocation {
    //We just positioning to user
    if (!self.userTouchTheMap) {
        CLLocationDistance radius = 5000;
        [self.mapView setRegion:MKCoordinateRegionMakeWithDistance(userLocation.location.coordinate, 2*radius, 2*radius) animated:YES];
    }
}

@end
Odpowiedział 07/04/2017 o 13:59
źródło użytkownik

głosy
0

Ty w tym czasie mogę przechwycić dotyka na widoku mapy, można spróbować warstw nieprzezroczystą widok na tam i zobaczyć, czy to podnosi dotyka ...

Odpowiedział 14/08/2009 o 03:59
źródło użytkownik

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more