Я знаю, что это старый вопрос, но это возможно, несмотря на то, что говорит «правильный» ответ.Так как это был первый результат, когда я искал это, я решил уточнить:
Вот как вы это делаете:
Вам необходимо добавить свойство в View Controller, откуда вы хотитепредставить модально, в моем случае "tapBehindGesture".
затем в viewDidAppear
if(!tapBehindGesture) {
tapBehindGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapBehindDetected:)];
[tapBehindGesture setNumberOfTapsRequired:1];
[tapBehindGesture setCancelsTouchesInView:NO]; //So the user can still interact with controls in the modal view
}
[self.view.window addGestureRecognizer:tapBehindGesture];
И вот реализация для tapBehindDetected
- (void)tapBehindDetected:(UITapGestureRecognizer *)sender
{
if (sender.state == UIGestureRecognizerStateEnded)
{
//(edited) not working for ios8 above
//CGPoint location = [sender locationInView:nil]; //Passing nil gives us coordinates in the window
CGPoint location = [sender locationInView: self.presentingViewController.view];
//Convert tap location into the local view's coordinate system. If outside, dismiss the view.
if (![self.presentedViewController.view pointInside:[self.presentedViewController.view convertPoint:location fromView:self.view.window] withEvent:nil])
{
if(self.presentedViewController) {
[self dismissViewControllerAnimated:YES completion:nil];
}
}
}
}
Просто не забудьте удалить tapBehindGesture
из view.window
в viewWillDisappear
чтобы не вызывать handleTapBehind в нераспределенном объекте.