import React, { useRef } from 'react';
import { View, Image, TouchableOpacity, StyleSheet, PanResponder, Animated } from 'react-native';
import { useNavigation, useFocusEffect } from '@react-navigation/native';
const DraggableButton = () => {
const navigation = useNavigation();
const goToCustomerScreen = () => {
navigation.navigate('Customer');
}
const pan = useRef(new Animated.ValueXY()).current;
const panResponder = useRef(
PanResponder.create({
onMoveShouldSetPanResponder: () => true,
onPanResponderGrant: () => {
pan.setOffset({
x: pan.x._value,
y: pan.y._value
});
},
onPanResponderMove: Animated.event(
[
null,
{dx: pan.x, dy: pan.y}
],
{useNativeDriver: false}
),
onPanResponderRelease: () => {
pan.flattenOffset();
}
})
).current;
return (
<Animated.View
style={[
styles.container,
{
transform: [{ translateX: pan.x }, { translateY: pan.y }],
},
]}
{...panResponder.panHandlers}
>
<TouchableOpacity style={styles.button} onPress={goToCustomerScreen}>
<Image style={styles.image} source={require('../../assets/imgs/tabs/customer_select.png')} />
</TouchableOpacity>
</Animated.View>
);
};
const styles = StyleSheet.create({
container: {
position: 'absolute',
right: 20,
bottom: 100,
zIndex: 1,
},
button: {
width: 40,
height: 40,
backgroundColor: '#fff',
justifyContent: 'center',
alignItems: 'center',
borderRadius: 25,
},
image: {
width: 38,
height: 38,
},
});
export default DraggableButton;
react native 悬浮客服可拖动
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 基于react实现的移动端的可吸附悬浮按钮 预览地址(移动端): https://kkfor.github.io/...
- https://blog.csdn.net/money9sun/article/details/79696845 ...
- 原文链接:https://blog.csdn.net/qq_22329521/article/details/79...
- 在初始化listView时设置属性 removeClippedSubviews={false} 亲测有效 flat...
- ToastAndroid官方文档介绍:https://reactnative.cn/docs/0.51/toast...