iOS8:在外部点击时关闭表单
我们目前正在使用一种类似于上述解决方案的解决方案(参见Ares的回答)。这在iOS8中似乎不起作用 我有一张表单,我想在用户点击表单后面的灰色视图时立即将其删除。 以前,这似乎可以通过在窗口中添加手势识别器来实现,并检查点击位置以查看它是否在当前表单之外 我还注意到需要转换的点(开关x和y)是在横向模式下使用的设备。除此之外,现在它只接收表单中出现的手势,在屏幕上任何地方的点击手势都会触发事件之前iOS8:在外部点击时关闭表单,ios,objective-c,xcode,ios8,Ios,Objective C,Xcode,Ios8,我们目前正在使用一种类似于上述解决方案的解决方案(参见Ares的回答)。这在iOS8中似乎不起作用 我有一张表单,我想在用户点击表单后面的灰色视图时立即将其删除。 以前,这似乎可以通过在窗口中添加手势识别器来实现,并检查点击位置以查看它是否在当前表单之外 我还注意到需要转换的点(开关x和y)是在横向模式下使用的设备。除此之外,现在它只接收表单中出现的手势,在屏幕上任何地方的点击手势都会触发事件之前 - (void)viewDidLoad { [super viewDidLoad];
- (void)viewDidLoad
{
[super viewDidLoad];
self.recognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleTapBehind:)];
self.recognizer.numberOfTapsRequired = 1;
self.recognizer.cancelsTouchesInView = NO;
[self.view.window addGestureRecognizer:self.recognizer];
}
- (void)handleTapBehind:(UITapGestureRecognizer *)sender
{
if (sender.state == UIGestureRecognizerStateEnded)
{
CGPoint location = [sender locationInView:nil];
if (UIInterfaceOrientationIsLandscape([UIApplication sharedApplication].statusBarOrientation) && IOS8)
{
location = CGPointMake(location.y, location.x);
}
// if tap outside pincode inputscreen
BOOL inView = [self.view pointInside:[self.view convertPoint:location fromView:self.view.window] withEvent:nil];
if (!inView)
{
[self.view.window removeGestureRecognizer:sender];
[self dismissViewControllerAnimated:YES completion:nil];
}
}
}
如您引用的线程中所述,您应该添加一个
uigestureRecognitizerDelegate
,并实现以下方法:
- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer {
return YES;
}
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer {
return YES;
}
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldReceiveTouch:(UITouch *)touch {
return YES;
}
我不知道你是什么意思?这如何反映ios8中的API更改?上面提到的代码在ios7中运行良好。或者这是一种规避ios8错误的方法吗?要使您发布的代码在ios8中正常工作,请在您的
self.recognizer
中添加一个UIgestureRecognitizerDelegate
,并添加这些委派方法。我正在使用nib文件创建ViewController。在这种情况下,在viewDidLoad:
上的self.view.window
为零,因此我必须将手势识别器设置为viewdide:
才能工作。