Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PinchGestureHandler and PanGestureHandler not working simultaneously #927

Closed
IsaacGluck opened this issue Jan 21, 2020 · 20 comments
Closed
Labels
Area: Gesture handlers This issue is related to problems with gesture handlers

Comments

@IsaacGluck
Copy link

Thanks in advance for the help!
Please let me know if I can provide any extra information!

  • Platform: iOS
  • sdkVersion: 35.0.0

Refs:

  this.panHandler = React.createRef();
  this.pinchHandler = React.createRef();

Handlers:

  const scale = new Animated.Value(1);
  const onZoomEvent = (zoomeEvent) => {
    if (zoomeEvent.nativeEvent.scale >= 1) {
      return Animated.event([{
        nativeEvent: {
          scale,
        },
      }])(zoomeEvent);
    } else {
      return Animated.event([{ nativeEvent: { scale: 1 } }])(zoomeEvent);
    }
  };
  const onZoomStateChange = (event) => {
    if (event.nativeEvent.oldState === State.ACTIVE) {
      Animated.spring(scale, {
        toValue: 1,
      }).start();
    }
  };

  const translateX = new Animated.Value(0);
  const translateY = new Animated.Value(0);
  const handlePanEvent = (panEvent) => {
    return Animated.event(
      [{ nativeEvent: { translationX: translateX, translationY: translateY } }],
    )(panEvent);
  };
  const onPanStateChange = (event) => {
    if (event.nativeEvent.oldState === State.ACTIVE) {
      Animated.spring(translateX, {
        toValue: 0,
      }).start();
      Animated.spring(translateY, {
        toValue: 0,
      }).start();
    }
  };

JSX:

  <PinchGestureHandler
    ref={this.pinchHandler}
    simultaneousHandlers={this.panHandler}
    onGestureEvent={onZoomEvent}
    onHandlerStateChange={onZoomStateChange}
  >
    <Animated.View>
      <PanGestureHandler
        ref={this.panHandler}
        simultaneousHandlers={this.pinchHandler}
        minPointers={2}
        onGestureEvent={handlePanEvent}
        onHandlerStateChange={onPanStateChange}
      >
        <Animated.View>
          <Animated.Image
            source={{ uri: meme.get('url') }}
            style={{
              width: displayWidth,
              height: displayHeight,
              transform: [{ scale }, { translateX }, { translateY }],
            }}
            resizeMode="contain"
          />
        </Animated.View>
      </PanGestureHandler>
    </Animated.View>
  </PinchGestureHandler>
@abandohess
Copy link

+1 having same issue

@Enoinoo
Copy link

Enoinoo commented Feb 19, 2020

Having the same issue trying to use PanGestureHandler for dragging movement and PinchGestureHandler for zooming.

Is there a fix for this yet?

@Enoinoo
Copy link

Enoinoo commented Feb 24, 2020

I think this works fine on Android, but not on iOS.

@german970814
Copy link

german970814 commented Mar 13, 2020

The issue is present on iOS version 13.3. Lower versions don't have this issue. Any workaround about it?

Using:
Platform: iOS 13.3
Expo SDK: 35.0.0
react-native-gesture-handler: 1.3.0

@zulkarnainshariff
Copy link

I had a problem with this too, solved it by putting a flex: 1 to all the <Animated.View>

@Enoinoo
Copy link

Enoinoo commented Apr 17, 2020

I had a problem with this too, solved it by putting a flex: 1 to all the <Animated.View>

I just tried this but the view just disappears.

@viveKing21
Copy link

viveKing21 commented Jun 7, 2020

I think this works fine on Android, but not on iOS.

nah its not working on android,

import React from 'react'
import {View,Image,Animated, Button} from 'react-native'
import {PinchGestureHandler} from 'react-native-gesture-handler'
export default function pinchZoom(){
const scale=React.useRef(new Animated.Value(1)).current;
const HandlePinch=new Animated.event(
[{nativeEvent:{scale:scale}}]
,
{
useNativeDriver: false
})
const anime=new Animated.ValueXY(0,0)
return(


<Animated.Image source={{uri:'https://i.ytimg.com/vi/Z4ls0-ZGnU4/maxresdefault.jpg'}}
style={{height:250,width:'100%',transform:[{scale:scale}]}}
/>

  </View>
)

}

its not even moving, dont know what im doing wrong help plz,

@majonathany
Copy link

Any fix yet?

@jakub-gonet jakub-gonet added the Area: Gesture handlers This issue is related to problems with gesture handlers label Sep 3, 2020
@jakub-gonet
Copy link
Member

Could you provide a minimal, working example in form of snack, repo, or code block here?

@wadewadewadewadewadewade

I don't know if it helps, but I'm having a similar issue, and I've made a snack that can reproduce it...sort of...

https://snack.expo.io/@aproximation/react-native-draggable

My actual Android 9 device is behaving the way iPhone 8 in emulation is behaving on that snack: the first drag is jerky but sort of works, and subsequent drags have no animation, and the object just appears at the new destination when you release the mouse.

I tried to update the README for that snack to describe what I'm seeing

@RahulRijhwani
Copy link

I am stuck at same issue
Any update

@vivrkerror404
Copy link

I am using PanResponder and pinch GestureHandler and faced the same issue and I fixed it by including a condition(gestureState.numberActiveTouches) in onStartShouldSetPanResponder value inside PanResponder.create(),
below is my code
eg:-
gestureState.numberActiveTouches = 1 means touch event
gestureState.numberActiveTouches = 2 means pinch event

  onStartShouldSetPanResponder: (evt, gestureState) => {if(gestureState.numberActiveTouches == 2){return false } else{return true} },

@seancheung
Copy link

seancheung commented Jun 16, 2021

Same here.
It works on Android but not iOS.
What about pinch and pan both with tow touched?(like the iOS photo markup app)

@DanleyCr7
Copy link

DanleyCr7 commented Jun 28, 2021

react-native link react-native-gesture-handler

path android\app\src\main\java\com\hans_patient\MainActivity.java;

import com.facebook.react.ReactActivityDelegate;
import com.facebook.react.ReactRootView;
import com.swmansion.gesturehandler.react.RNGestureHandlerEnabledRootView;

@OverRide
protected ReactActivityDelegate createReactActivityDelegate() {
return new ReactActivityDelegate(this, getMainComponentName()) {
@OverRide
protected ReactRootView createRootView() {
return new RNGestureHandlerEnabledRootView(MainActivity.this);
}
};
}

@amanda-t
Copy link

amanda-t commented Jul 9, 2021

I had the same issue where my simultaneous pinch/2-finger pan on an image worked on Android but not iOS, but then I found out it just doesn't work on my older first-generation iPhone SE. It does work on an iPhone XR. So maybe it's an older device thing?

Made a simple Snack here: https://snack.expo.io/@amandatusing/simultaneous-pinch-and-zoom-gestures.

It's working on a Google Pixel 4a Android version 11 and an iPhone XR iOS 14.6.
On iPhone SE iOS 14.6 the gestures can't happen simultaneously. You can either 2-finger pan or pinch separately, but not together.

And it's not just my example. The react-native-gesture-handler demos, like scale and rotate, also don't work on my 1st-gen iPhone SE simultaneously.

UPDATE: Although simultaneous pinch and pan wasn't working on my phone when developing locally with Expo, it does work in the built App in Testflight.

@innocentmasuki
Copy link

I am using PanResponder and pinch GestureHandler and faced the same issue and I fixed it by including a condition(gestureState.numberActiveTouches) in onStartShouldSetPanResponder value inside PanResponder.create(), below is my code eg:- gestureState.numberActiveTouches = 1 means touch event gestureState.numberActiveTouches = 2 means pinch event

  onStartShouldSetPanResponder: (evt, gestureState) => {if(gestureState.numberActiveTouches == 2){return false } else{return true} },

This fixed the problem for me

@niujianqiang123
Copy link

react-native-gesture-handler v2.13.4 iOS v17.0 已修复,当我用option+mouse进行缩放,因为两个触点的中心,并没有发生移动,所以drag不会触发,当我用alt+mouse放置一个偏移的点,进行两个点缩放时,拖拽是生效的

@niujianqiang123
Copy link

code is this

// -------------------svg拖拽相关逻辑-----------------------
  const dragGesture = Gesture.Pan()
    .onStart(_e => {})
    .onUpdate(e => {
      const x = start.value.x + e.translationX;
      const y = start.value.y + e.translationY;
      offset.value = {
        x,
        y,
      };
    })
    .onEnd(() => {
      start.value = {
        x: offset.value.x,
        y: offset.value.y,
      };
    });
  // --------------svg缩放相关逻辑----------------
  const zoomGesture = Gesture.Pinch()
    .onStart(_e => {})
    .onUpdate(e => {
      const scaleValue = savedScale.value * e.scale;
      if (scaleValue > 3 || scaleValue < 1) {
        return;
      }
      scale.value = scaleValue;
    })
    .onEnd(_e => {
      savedScale.value = scale.value;
    })
    .simultaneousWithExternalGesture(dragGesture);
  const composed = Gesture.Simultaneous(dragGesture, zoomGesture);

  return (
        <GestureDetector gesture={composed}>
          <Svg />
        </GestureDetector>

@BrandonCao
Copy link

Any update on this?

@j-piasecki
Copy link
Member

I'm not sure whether that's still the case but some time ago there was a problem with simultaneous gestures in general in Expo Go (i.e. simultaneous didn't work at all). If this is still affecting you please open a new issue with a self-contained reproducer that doesn't rely on Expo Go (development build is fine).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area: Gesture handlers This issue is related to problems with gesture handlers
Projects
None yet
Development

No branches or pull requests