Реанимированный обратный вызов TapGestureHandler с блоком

Как бы этого добиться?

обратный вызов с Animated.event отлично работает

обратный вызов с блоком не дает обратной связи:(

import React, { useState, useEffect } from "react";
import { View, Text, FlatList, Dimensions, Image } from "react-native";
import Animated from "react-native-reanimated";
import { PanGestureHandler, TapGestureHandler, State } from "react-native-gesture-handler";
const { Value, event, call, set, add, block } = Animated;

const bottom = new Value(100);

//want to achieve something like this 
const onHandlerStateChange = block([set(bottom, add(bottom, 10))]);

// the line below Does work 
// const onHandlerStateChange = event([{ nativeEvent: { y: bottom } }]); 

const Comp = () => {
    return (
        <TapGestureHandler onHandlerStateChange={onHandlerStateChange}>
            <Animated.View style={{ flex: 1}}>
                <Animated.View style={{ flex: 1, position: "absolute", bottom: bottom }}>
                    <Text> some text</Text>
                </Animated.View>
            </Animated.View>
        </TapGestureHandler>
    );
};

export default Comp;

*const onHandlerStateChange = block([установить (снизу, добавить (снизу, 10))]); * Здесь не работает

1 ответ

Вот работающее решение.
Совет: будет очень полезно понять, как реанимированные оценивают узлы.
Вот ссылка на официальный документ, который может помочь вам понять
https://software-mansion.github.io/react-native-reanimated/about-reanimated.html

import React, { useState, useEffect } from "react";
import { View, Text, FlatList, Dimensions, Image } from "react-native";
import Animated from "react-native-reanimated";
import {
    PanGestureHandler,
    TapGestureHandler,
    State,
} from "react-native-gesture-handler";
const { Value, event, call, set, add, cond, eq, block } = Animated;

const gstate = new Value(-1);
const onHandlerStateChange = event([{ nativeEvent: { state: gstate } }]);

let bottom = new Value(100);
bottom = cond(eq(gstate, State.END), [set(bottom, add(bottom, 10))], bottom);

const Comp = () => {
    return (
        <TapGestureHandler onHandlerStateChange={onHandlerStateChange}>
            <Animated.View style={{ flex: 1, backgroundColor: "pink" }}>
                <Animated.View
                    style={{ flex: 1, position: "absolute", bottom: bottom }}
                >
                    <Text> some text</Text>
                </Animated.View>
            </Animated.View>
        </TapGestureHandler>
    );
};

export default Comp;
Другие вопросы по тегам