使用Animated.View实现全屏页面可以向下拖动,松开手指页面返回原处的效果

使用Animated.View实现全屏页面可以向下拖动,松开手指页面返回原处的效果

效果示例图

在这里插入图片描述

在这里插入图片描述

代码示例

import React, {useRef, useState} from 'react';
import {
  View,
  Text,
  Animated,
  Easing,
  PanResponder,
  StyleSheet,
} from 'react-native';

const TestDragCard = () => {
  const pan = useRef(new Animated.ValueXY()).current;
  const panResponder = PanResponder.create({
    onMoveShouldSetPanResponder: () => true,
    onPanResponderMove: (evt, gestureState) => {
      console.log('{ds]', gestureState.dy);
      Animated.event([null, {dy: pan.y}], {
        useNativeDriver: false,
      })(evt, gestureState);
    },
    onPanResponderRelease: (e, gestureState) => {
      if (gestureState.dy > 50) {
        Animated.timing(pan, {
          toValue: {x: 0, y: 0},
          easing: Easing.linear,
          duration: 300,
          useNativeDriver: true,
        }).start(() => {
          // 模拟加载数据的异步操作
          console.log('[放开我]');
        });
      } else {
        Animated.spring(pan, {
          toValue: {x: 0, y: 0},
          friction: 5,
          useNativeDriver: true,
        }).start();
      }
    },
  });

  const panStyle = {
    transform: pan.getTranslateTransform(),
  };

  return (
    <>
      <View style={styles.container}>
        <Animated.View
          style={[panStyle, styles.animatedView]}
          {...panResponder.panHandlers}>
          <Text>内容</Text>
        </Animated.View>
      </View>
    </>
  );
};
const styles = StyleSheet.create({
  container: {
    flex: 1,
  },
  animatedView: {
    borderColor: 'red',
    borderWidth: 1,
    borderStyle: 'solid',
    flex: 1,
  },
});

export default TestDragCard;

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,展品详情页面的显示入场动画可以通过自定义类名和 animate.css 动画库来实现。下面是一个示例代码: ```html <!DOCTYPE html> <html> <head> <title>展品详情页面</title> <!-- 引入animate.css动画库 --> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css" /> <style> /* 自定义样式 */ .exhibit { width: 500px; height: 300px; background-color: #f2f2f2; border: 1px solid #ccc; padding: 20px; box-sizing: border-box; } /* 自定义入场动画 */ .exhibit-show { animation: my-show 1s ease; } /* 自定义动画细节 */ @keyframes my-show { 0% { opacity: 0; transform: translateY(50px); } 100% { opacity: 1; transform: translateY(0); } } </style> </head> <body> <h1>展品详情页面</h1> <div class="exhibit animate__animated"> <h2>展品名称</h2> <p>展品介绍...</p> </div> <script> // 使用JS动态添加类名实现入场动画 const exhibit = document.querySelector(".exhibit"); exhibit.classList.add("animate__fadeInUp", "exhibit-show"); </script> </body> </html> ``` 在上面的示例代码中,我们首先引入了 animate.css 动画库,并给展品详情页面的 `div` 元素添加了一个名为 `animate__animated` 的类名,以便使用 animate.css 提供的动画效果。然后,我们自定义了一个名为 `my-show` 的入场动画,通过给 `exhibit-show` 类名前缀应用这个动画效果实现了展品详情页面的入场动画。最后,我们使用 JavaScript 动态添加类名的方式,实现了入场动画的触发。 你可以根据需要自定义动画效果、持续时间等参数,并使用 animate.css 提供的动画效果,或者自定义动画效果使用自定义类名来实现展品详情页面的入场动画。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值