React native pan responder trapping all touch events from propagating to children
I'm trying to wrap all of my component 'scenes' in an expo multitouch component (which is a wrapper for the pan responder) so that, if a person performs a multitouch gesture at any point, this will trigger an app menu, and otherwise, the child views respond to the touch event. How do I accomplish this? It seems that the parent traps and stops propagation of all events - I would've expected those events to bubble upward from the innermost elements.
Ordinarily I would use a shake gesture, but I'm using expo, which reserves that gesture for its own menu.
Here's my code:
class ResultsScreen extends React.Component {
render() {
const props = {
onTouchBegan: ({ identifier }) => {
console.log('onTouchBegan', identifier);
},
};
return (
<MultiTouchView
style={{ flex: 1 }}
{...props}
>
{ /* scrolling not working */ }
<ScrollView
style={{
flex: 1,
}}
>
</ScrollView>
</MultiTouchView>
)
}
And just to note that it still uses React Native's methods, if I set:
onStartShouldSetPanResponderCapture: ()=>false,
onMoveShouldSetPanResponderCapture: ()=>false,
onStartShouldSetPanResponder: ()=>false,
onMoveShouldSetPanResponder: ()=>false,
within that props
object then the underlying elements will respond as expected - I just no longer get the onTouchBegan events.
javascript react-native gesture expo event-bubbling
add a comment |
I'm trying to wrap all of my component 'scenes' in an expo multitouch component (which is a wrapper for the pan responder) so that, if a person performs a multitouch gesture at any point, this will trigger an app menu, and otherwise, the child views respond to the touch event. How do I accomplish this? It seems that the parent traps and stops propagation of all events - I would've expected those events to bubble upward from the innermost elements.
Ordinarily I would use a shake gesture, but I'm using expo, which reserves that gesture for its own menu.
Here's my code:
class ResultsScreen extends React.Component {
render() {
const props = {
onTouchBegan: ({ identifier }) => {
console.log('onTouchBegan', identifier);
},
};
return (
<MultiTouchView
style={{ flex: 1 }}
{...props}
>
{ /* scrolling not working */ }
<ScrollView
style={{
flex: 1,
}}
>
</ScrollView>
</MultiTouchView>
)
}
And just to note that it still uses React Native's methods, if I set:
onStartShouldSetPanResponderCapture: ()=>false,
onMoveShouldSetPanResponderCapture: ()=>false,
onStartShouldSetPanResponder: ()=>false,
onMoveShouldSetPanResponder: ()=>false,
within that props
object then the underlying elements will respond as expected - I just no longer get the onTouchBegan events.
javascript react-native gesture expo event-bubbling
add a comment |
I'm trying to wrap all of my component 'scenes' in an expo multitouch component (which is a wrapper for the pan responder) so that, if a person performs a multitouch gesture at any point, this will trigger an app menu, and otherwise, the child views respond to the touch event. How do I accomplish this? It seems that the parent traps and stops propagation of all events - I would've expected those events to bubble upward from the innermost elements.
Ordinarily I would use a shake gesture, but I'm using expo, which reserves that gesture for its own menu.
Here's my code:
class ResultsScreen extends React.Component {
render() {
const props = {
onTouchBegan: ({ identifier }) => {
console.log('onTouchBegan', identifier);
},
};
return (
<MultiTouchView
style={{ flex: 1 }}
{...props}
>
{ /* scrolling not working */ }
<ScrollView
style={{
flex: 1,
}}
>
</ScrollView>
</MultiTouchView>
)
}
And just to note that it still uses React Native's methods, if I set:
onStartShouldSetPanResponderCapture: ()=>false,
onMoveShouldSetPanResponderCapture: ()=>false,
onStartShouldSetPanResponder: ()=>false,
onMoveShouldSetPanResponder: ()=>false,
within that props
object then the underlying elements will respond as expected - I just no longer get the onTouchBegan events.
javascript react-native gesture expo event-bubbling
I'm trying to wrap all of my component 'scenes' in an expo multitouch component (which is a wrapper for the pan responder) so that, if a person performs a multitouch gesture at any point, this will trigger an app menu, and otherwise, the child views respond to the touch event. How do I accomplish this? It seems that the parent traps and stops propagation of all events - I would've expected those events to bubble upward from the innermost elements.
Ordinarily I would use a shake gesture, but I'm using expo, which reserves that gesture for its own menu.
Here's my code:
class ResultsScreen extends React.Component {
render() {
const props = {
onTouchBegan: ({ identifier }) => {
console.log('onTouchBegan', identifier);
},
};
return (
<MultiTouchView
style={{ flex: 1 }}
{...props}
>
{ /* scrolling not working */ }
<ScrollView
style={{
flex: 1,
}}
>
</ScrollView>
</MultiTouchView>
)
}
And just to note that it still uses React Native's methods, if I set:
onStartShouldSetPanResponderCapture: ()=>false,
onMoveShouldSetPanResponderCapture: ()=>false,
onStartShouldSetPanResponder: ()=>false,
onMoveShouldSetPanResponder: ()=>false,
within that props
object then the underlying elements will respond as expected - I just no longer get the onTouchBegan events.
javascript react-native gesture expo event-bubbling
javascript react-native gesture expo event-bubbling
edited Nov 20 '18 at 0:21
mheavers
asked Nov 20 '18 at 0:16
mheaversmheavers
10.9k46153256
10.9k46153256
add a comment |
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53384464%2freact-native-pan-responder-trapping-all-touch-events-from-propagating-to-childre%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53384464%2freact-native-pan-responder-trapping-all-touch-events-from-propagating-to-childre%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown