Failed to receive system gesture state notification before next touch

user2506238 picture user2506238 · Nov 4, 2013 · Viewed 9k times · Source

I have a control that will switch two views alternatively in a view. ie, Two view controllers are added by sub view method in a container view. A pinch out gusture zooms in current view, and shows the second view. If wish to go to the previous view, a pinch out gusture will do that. The issue is that, the view doest not react for the gusture sometimes not always and a meessage

"Failed to receive system gesture state notification before next touch"

is printed out in the log. Any suggestion why this message is coming and view doesn't recognize the gesture?

- (void)scaleHandler:(UIPinchGestureRecognizer *)gestureRecognizer{

CGFloat currentScale = [[[gestureRecognizer view].layer valueForKeyPath:@"transform.scale"] floatValue];
if([gestureRecognizer state] == UIGestureRecognizerStateBegan) {
    // Reset the last scale, necessary if there are multiple objects with different scales
    lastScale = [gestureRecognizer scale];
}

if ([gestureRecognizer state] == UIGestureRecognizerStateBegan ||
    [gestureRecognizer state] == UIGestureRecognizerStateChanged) {

    // Constants to adjust the max/min values of zoom
    CGFloat kMaxScale = 1.0;
    CGFloat kMinScale = 1.0;
    gestureRecognizer.view.alpha = 1/currentScale;
    if ([gestureRecognizer view] == [self.firstView view]) {
        kMaxScale = 10.0;
        kMinScale = 1.0;
        gestureRecognizer.view.alpha = 1/currentScale;
    }

    if ([gestureRecognizer view] == [self.pageView view]) {
        kMaxScale = 1.0;
        kMinScale = 0.1;
        gestureRecognizer.view.alpha = currentScale;
    }


   // NSLog(@"Current Scale is %f",[gestureRecognizer scale]);

    CGFloat newScale = 1 -  (lastScale - [gestureRecognizer scale]);
    newScale = MIN(newScale, kMaxScale / currentScale);
    newScale = MAX(newScale, kMinScale / currentScale);

    CGAffineTransform transform = CGAffineTransformScale([[gestureRecognizer view] transform], newScale, newScale);
    [gestureRecognizer view].transform = transform;

    lastScale = [gestureRecognizer scale];  // Store the previous scale factor for the next pinch gesture call
}

if([gestureRecognizer state] == UIGestureRecognizerStateEnded){

      if ([gestureRecognizer view] == [self.firstView view]) {
        if(currentScale > 1.0f){
            [self setPinchOutAnimationHidden:YES];
        }
        else{
            [self setPinchOutAnimationHidden:NO];
        }
      }
      else{
          if(currentScale < 0.9f){
              [self setPinchInAnimationToHidden:YES];
          }
          else{
              [self setPinchInAnimationToHidden:NO];
          }
      }

}

}

- (void)setPinchInAnimationToHidden: (BOOL)shouldHide{

if(shouldHide){
    NSLog(@"animation 1 - pinch in");
    [UIView animateWithDuration:0.5 delay:0 options:UIViewAnimationOptionCurveEaseOut animations:^{
        CGAffineTransform transform = CGAffineTransformScale([self.pageView.view transform], 0, 0);
        self.pageView.view.transform = transform;
    } completion:^(BOOL finished){
       // [firstView.view sendSubviewToBack:pageView.view];
        NSLog(@"animation 1 - pinchin completion handler");
        [self.view insertSubview:self.pageView.view belowSubview:self.firstView.view];
        self.pageView.view.transform = CGAffineTransformMakeScale(1.0, 1.0);
        self.pageView.view.alpha = 1.0;
    }];
}
else{
      NSLog(@"animation 2- pinch in");
    [UIView animateWithDuration:0.5 delay:0 options:UIViewAnimationOptionCurveEaseOut animations:^{
        self.pageView.view.transform = CGAffineTransformMakeScale(1.0, 1.0);
        self.pageView.view.alpha = 1.0;
    } completion:nil];
}
}

- (void)setPinchOutAnimationHidden: (BOOL)shouldHide{
if(shouldHide){
    NSLog(@"animation 3 - pinch out");
   // firstView = [ViewFactory firstViewController];
    [UIView animateWithDuration:0.5 delay:0 options:UIViewAnimationOptionCurveEaseOut animations:^{
        CGAffineTransform transform = CGAffineTransformScale([self.firstView.view transform], 15.0, 15.0);
        self.firstView.view.transform = transform;
        self.firstView.view.alpha = 0.0;
    } completion:^(BOOL finished){
           NSLog(@"animation 3 - pinch out - completion handler");
        //[pageView.view sendSubviewToBack:firstView.view];
        [self.view insertSubview:self.firstView.view belowSubview:self.pageView.view];
        self.firstView.view.transform = CGAffineTransformMakeScale(1.0, 1.0);
        self.firstView.view.alpha = 1.0;
    }];
}
else{
     NSLog(@"animation 4- pinch out");
    [UIView animateWithDuration:0.5 delay:0 options:UIViewAnimationOptionCurveEaseOut animations:^{
        self.firstView.view.transform = CGAffineTransformMakeScale(1.0, 1.0);
        self.firstView.view.alpha = 1.0;
    } completion:nil];
}
}

Answer

sera picture sera · Mar 15, 2019

view doesn't recogonize the gusture

Register your guesture to recognize the states

UIPinchGestureRecognizer *pinchGuestureRecog = [UIPinchGestureRecognizer alloc]initWithTarget:self action: @selector(scaleHandler:)];