React Native 全栈开发实战班 - 第四部分:用户界面进阶之动画效果实现
在移动应用中,动画效果 是提升用户体验的重要手段。合理的动画设计可以增强应用的交互性、流畅性和视觉吸引力。React Native 提供了多种实现动画的方式,包括内置的 Animated API、LayoutAnimation 以及第三方库(如 react-native-reanimated)。本章节将详细介绍如何使用这些工具来实现各种动画效果。
1.1 动画概述
在 React Native 中,动画主要用于以下场景:
- 组件的显示与隐藏: 例如,模态框的弹出与关闭。
- 界面元素的过渡: 例如,页面切换时的过渡动画。
- 交互反馈: 例如,按钮点击时的缩放效果。
- 数据驱动的动画: 例如,图表、进度条等动态变化。
React Native 提供了以下几种主要的动画实现方式:
AnimatedAPI: 强大的动画库,支持多种动画类型和插值。LayoutAnimation: 简单的布局动画,适用于布局变化时的动画效果。react-native-reanimated: 第三方动画库,功能更强大,适合复杂动画。
本章节将重点介绍 Animated API 和 LayoutAnimation 的使用。
1.2 使用 Animated API
Animated 是 React Native 提供的一个强大的动画库,支持多种动画类型和插值操作。
1.2.1 基本用法
步骤:
-
创建动画值:
使用
Animated.Value创建一个动画值。const animation = useRef(new Animated.Value(0)).current; -
定义动画:
使用
Animated.timing或其他动画函数定义动画。Animated.timing(animation, {toValue: 1,duration: 1000,useNativeDriver: true, }).start(); -
绑定动画值到样式:
使用插值函数将动画值绑定到组件的样式属性。
const opacity = animation.interpolate({inputRange: [0, 1],outputRange: [0, 1], });<Animated.View style={{ opacity }}>{/* 内容 */} </Animated.View>
示例:
// FadeInView.js
import React, { useRef } from 'react';
import { Animated, Text, View, StyleSheet } from 'react-native';const FadeInView = () => {const animation = useRef(new Animated.Value(0)).current;React.useEffect(() => {Animated.timing(animation, {toValue: 1,duration: 1000,useNativeDriver: true,}).start();}, [animation]);const opacity = animation.interpolate({inputRange: [0, 1],outputRange: [0, 1],});return (<Animated.View style={{ opacity }}><Text style={styles.text}>Fade In!</Text></Animated.View>);
};const styles = StyleSheet.create({text: {fontSize: 18,},
});export default FadeInView;
// App.js
import React from 'react';
import { View, StyleSheet } from 'react-native';
import FadeInView from './FadeInView';const App = () => {return (<View style={styles.container}><FadeInView /></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},
});export default App;
解释:
Animated.timing定义了一个从0到1的线性动画,持续时间为1000毫秒。useNativeDriver: true使用原生驱动,提高动画性能。interpolate方法将动画值从0-1映射到0-1的透明度范围。
1.2.2 组合动画
可以使用 Animated.sequence, Animated.parallel, Animated.stagger 等组合动画函数,实现复杂的动画效果。
示例:
// BounceView.js
import React, { useRef } from 'react';
import { Animated, Text, View, StyleSheet } from 'react-native';const BounceView = () => {const animation = useRef(new Animated.Value(0)).current;React.useEffect(() => {Animated.sequence([Animated.timing(animation, {toValue: 1,duration: 500,useNativeDriver: true,}),Animated.timing(animation, {toValue: 0.8,duration: 300,useNativeDriver: true,}),Animated.timing(animation, {toValue: 1,duration: 300,useNativeDriver: true,}),]).start();}, [animation]);const scale = animation.interpolate({inputRange: [0, 1],outputRange: [0.5, 1],});return (<Animated.View style={{ transform: [{ scale }] }}><Text style={styles.text}>Bounce!</Text></Animated.View>);
};const styles = StyleSheet.create({text: {fontSize: 18,},
});export default BounceView;
解释:
Animated.sequence按顺序执行多个动画。- 实现了先放大再缩小再恢复的弹跳效果。
1.2.3 插值与映射
interpolate 方法可以将动画值映射到不同的范围,实现复杂的动画效果。
示例:
// ColorChangeView.js
import React, { useRef } from 'react';
import { Animated, Text, View, StyleSheet } from 'react-native';const ColorChangeView = () => {const animation = useRef(new Animated.Value(0)).current;React.useEffect(() => {Animated.timing(animation, {toValue: 1,duration: 2000,useNativeDriver: false,}).start();}, [animation]);const backgroundColor = animation.interpolate({inputRange: [0, 1],outputRange: ['#ff0000', '#0000ff'],});return (<Animated.View style={{ backgroundColor, padding: 20 }}><Text style={styles.text}>Color Change!</Text></Animated.View>);
};const styles = StyleSheet.create({text: {fontSize: 18,color: '#fff',},
});export default ColorChangeView;
解释:
interpolate将动画值从0-1映射到颜色范围#ff0000到#0000ff,实现颜色渐变动画。
1.3 使用 LayoutAnimation
LayoutAnimation 是一种简单的布局动画,适用于布局变化时的动画效果。
1.3.1 基本用法
步骤:
-
调用
LayoutAnimation.configureNext配置动画:LayoutAnimation.configureNext({duration: 300,create: {type: LayoutAnimation.Types.easeInEaseOut,property: LayoutAnimation.Properties.opacity,},update: {type: LayoutAnimation.Types.easeInEaseOut,}, }); -
触发布局变化:
例如,更新组件的
state或props,触发重新渲染。
示例:
// LayoutAnimationExample.js
import React, { useState } from 'react';
import { View, Text, StyleSheet, LayoutAnimation, Button } from 'react-native';const LayoutAnimationExample = () => {const [show, setShow] = useState(false);const toggle = () => {LayoutAnimation.configureNext(LayoutAnimation.Presets.easeInEaseOut);setShow(!show);};return (<View style={styles.container}><Button title="Toggle" onPress={toggle} />{show && (<View style={styles.box}><Text>Hello, LayoutAnimation!</Text></View>)}</View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},box: {width: 200,height: 200,backgroundColor: '#f0f0f0',marginTop: 20,justifyContent: 'center',alignItems: 'center',},
});export default LayoutAnimationExample;
解释:
LayoutAnimation.configureNext配置布局动画。LayoutAnimation.Presets.easeInEaseOut使用预设的缓入缓出动画。- 当
show状态改变时,触发布局变化,动画效果自动应用。
1.3.2 注意事项
LayoutAnimation适用于简单的布局变化动画,不适合复杂的动画效果。LayoutAnimation不支持动画暂停、停止等高级控制。
1.4 使用 react-native-reanimated
react-native-reanimated 是一个功能强大的动画库,支持复杂的动画效果和手势交互。
1.4.1 安装 react-native-reanimated
npm install react-native-reanimated
1.4.2 基本用法
示例:
// ReanimatedExample.js
import React from 'react';
import { View, Text, StyleSheet } from 'react-native';
import Animated, { useSharedValue, useAnimatedStyle, withTiming } from 'react-native-reanimated';const ReanimatedExample = () => {const offset = useSharedValue(0);const animatedStyle = useAnimatedStyle(() => {return {transform: [{ translateY: offset.value }],};});React.useEffect(() => {offset.value = withTiming(100, { duration: 1000 });}, [offset]);return (<View style={styles.container}><Animated.View style={[styles.box, animatedStyle]}><Text>Reanimated!</Text></Animated.View></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},box: {width: 200,height: 200,backgroundColor: '#f0f0f0',justifyContent: 'center',alignItems: 'center',},
});export default ReanimatedExample;
解释:
useSharedValue创建一个共享的动画值。useAnimatedStyle定义动画样式。withTiming定义动画的时间和持续时间。
1.4.3 高级用法
react-native-reanimated 支持手势驱动、弹簧动画、弹簧驱动等高级功能。
这部分留给读者自行学习,用法基本上和基本例子一致。
导师简介
前腾讯电子签的前端负责人,现 whentimes tech CTO,专注于前端技术的大咖一枚!一路走来,从小屏到大屏,从 Web 到移动,什么前端难题都见过。热衷于用技术打磨产品,带领团队把复杂的事情做到极简,体验做到极致。喜欢探索新技术,也爱分享一些实战经验,帮助大家少走弯路!
温馨提示:可搜老码小张公号联系导师
相关文章:
React Native 全栈开发实战班 - 第四部分:用户界面进阶之动画效果实现
在移动应用中,动画效果 是提升用户体验的重要手段。合理的动画设计可以增强应用的交互性、流畅性和视觉吸引力。React Native 提供了多种实现动画的方式,包括内置的 Animated API、LayoutAnimation 以及第三方库(如 react-native-reanimated&…...
【CICD】GitLab Runner 和执行器(Executor
GitLab Runner 和执行器(Executor)是 GitLab CI/CD 管道中的两个重要组成部分。理解它们之间的关系有助于更好地配置和使用 CI/CD 流水线。runer是gitlab的ci-agent对接gitlab,而执行器是接受runer下发的ci的任务来干活的。也就是说gitrunner…...
实用教程:如何无损修改MP4视频时长
如何在UltraEdit中搜索MP4文件中的“mvhd”关键字 引言 在视频编辑和分析领域,有时我们需要深入到视频文件的底层结构中去。UltraEdit(UE)和UEStudio作为强大的文本编辑器,允许我们以十六进制模式打开和搜索MP4文件。本文将指导…...
mysqldump命令搭配source命令完成数据库迁移备份
mysqldump 命令使用 需保证mysqld在运行中, 这个命令的目的是将数据库导出到文件中,例如 mysqldump -uusername -ppassword database > db.sql 注意该命令不是在MySQL客户端(即MySQL命令行)执行的,而是在系统命…...
生信:TCGA学习(R、RStudio安装与下载、常用语法与常用快捷键)
前置环境 macOS系统,已安装homebrew且会相关命令。 近期在整理草稿区,所以放出该贴。 R语言、RStudio、R包安装 R语言安装 brew install rRStudio安装 官网地址:https://posit.co/download/rstudio-desktop/ R包下载 注意R语言环境自带…...
十三、注解配置SpringMVC
文章目录 1. 创建初始化类,代替web.xml2. 创建SpringConfig配置类,代替spring的配置文件3. 创建WebConfig配置类,代替SpringMVC的配置文件4. 测试功能 1. 创建初始化类,代替web.xml 2. 创建SpringConfig配置类,代替spr…...
为什么海外服务器IP会被封
海外服务器因为免备案而备受用户欢迎,近年来租用海外服务器的用户也越来越多,自然也可能会出现一些问题。 如果服务器IP被封,在该服务器下的所有业务都无法访问,对自己和对用户来说都会有较大的影响。因此,我们应做好相…...
图像处理技术椒盐噪声
椒盐噪声,也称为脉冲噪声,是图像中经常见到的一种噪声。它是一种随机出现的白点或者黑点,可能是亮的区域有黑色像素或是在暗的区域有白色像素(或是两者皆有)。这些白点和黑点会在图像中随机分布,导致图像中…...
[笔记]L6599的极限工作条件考量
0.名词 OTP over tempature protect.OCP over current protectOVP over voltage protectBrownout Protection Undervoltage Protection可能需要考虑hysteresis response.因为要考虑一些高频干扰 1.基本的过流保护逻辑 参考:ST L6599 器件手册 LLC开关电源&#…...
机器学习基础04
目录 1.朴素贝叶斯-分类 1.1贝叶斯分类理论 1.2条件概率 1.3全概率公式 1.4贝叶斯推断 1.5朴素贝叶斯推断 1.6拉普拉斯平滑系数 1.7API 2.决策树-分类 2.1决策树 2.2基于信息增益的决策树建立 2.2.1信息熵 2.2.2信息增益 2.2.3信息增益决策树建立步骤 2.3基于基…...
Ubuntu 20.04 配置开发环境(持续更新)
搜狗输入法不能显示中文 sudo apt install libqt5qml5 libgsettings-qt1 sudo apt install libqt5qml5 libqt5quick5 libqt5quickwidgets5 qml-module-qtquick2 编译环境配置 sudo apt-get update #base tools of ubuntu sudo apt install net-tools gitk tree vim termina…...
Rocky9/Ubuntu使用pip安装python的库mysqlclient失败解决方式
# Rocky9 直接使用pip安装mysqlclient会出现缺少依赖,需要先安装mysql-devel相关依赖。由于rocky9用MariaDB替代了MySQL,所以我们可以通过安装mariadb-devel来安装所需要的依赖。 如果Rocky9已经开启了powertool repo可以直接使用下面命令安装 dnf in…...
探索 HTML 和 CSS 实现的 3D旋转相册
效果演示 这段HTML与CSS代码创建了一个包含10张卡片的3D旋转效果,每张卡片都有自己的边框颜色和图片。通过CSS的3D变换和动画,实现了一个动态的旋转展示效果 HTML <div class"wrapper"><div class"inner" style"-…...
OpenJudge_ 简单英文题_04:0/1 Knapsack
题目 描述 Given the weights and values of N items, put a subset of items into a knapsack of capacity C to get the maximum total value in the knapsack. The total weight of items in the knapsack does not exceed C. 输入 First line: two positive integers N (…...
深入探索离散 Hopfield 神经网络
一、离散 Hopfield 神经网络的起源与发展 离散 Hopfield 神经网络由约翰・霍普菲尔德在 1982 年提出,这一创新性的成果在当时引起了广泛关注,成为早期人工神经网络的重要代表之一。 在那个时期,人工神经网络的发展还处于相对初级的阶段。霍…...
[智能车摄像头是一种安装在汽车上用于辅助驾驶和提高安全性的重要设备]
智能车摄像头是一种安装在汽车上用于辅助驾驶和提高安全性的重要设备。它们通常包括几个不同类型,如前视摄像头、环视摄像头、行车记录仪等。这些摄像头的主要功能有: 前视摄像头(Forward Camera):用于提供驾驶员前方…...
前端vue 列表中回显并下拉选择修改标签
1,vue数据列表中进行回显状态并可以在下拉框中选择修改,效果如下 2,vue 页面关键代码 <el-table-column label"审核" align"center" class-name"small-padding fixed-width" prop"status" >&…...
hbase未来的发展趋势
HBase 作为一个开源的分布式、可伸缩的 NoSQL 数据库,依托于 Hadoop 生态系统,以处理海量结构化数据为优势。随着大数据技术的发展,HBase 的发展趋势主要体现在以下几个方面: 1. 与云计算深度集成 随着企业向云迁移,HBase 也正在越来越多地部署在云环境中。云服务商(如 …...
Rust 语言学习笔记(二)
再继续快速学习一下 Rust 的以下几个知识点,就可以开始着手做点小工具了 基本数据类型复合数据类型基本的流程控制 Rust 设计为有效使用内存考虑的,它提供了非常细力度的数据类型,如整数分为有无符号,宽度从 8 位到 128 位&…...
【postman】怎么通过curl看请求报什么错
获取现成的curl方式: 1,拿别人给的curl 2,手机app界面通过charles抓包,点击接口复制curl 3,浏览器界面-开发者工具-选中接口复制curl 拿到curl之后打开postman,点击import,粘贴curl点击send&am…...
简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...
高频面试之3Zookeeper
高频面试之3Zookeeper 文章目录 高频面试之3Zookeeper3.1 常用命令3.2 选举机制3.3 Zookeeper符合法则中哪两个?3.4 Zookeeper脑裂3.5 Zookeeper用来干嘛了 3.1 常用命令 ls、get、create、delete、deleteall3.2 选举机制 半数机制(过半机制࿰…...
HTML 列表、表格、表单
1 列表标签 作用:布局内容排列整齐的区域 列表分类:无序列表、有序列表、定义列表。 例如: 1.1 无序列表 标签:ul 嵌套 li,ul是无序列表,li是列表条目。 注意事项: ul 标签里面只能包裹 li…...
将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?
Otsu 是一种自动阈值化方法,用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理,能够自动确定一个阈值,将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...
Nginx server_name 配置说明
Nginx 是一个高性能的反向代理和负载均衡服务器,其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机(Virtual Host)。 1. 简介 Nginx 使用 server_name 指令来确定…...
网络编程(UDP编程)
思维导图 UDP基础编程(单播) 1.流程图 服务器:短信的接收方 创建套接字 (socket)-----------------------------------------》有手机指定网络信息-----------------------------------------------》有号码绑定套接字 (bind)--------------…...
GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...
怎么让Comfyui导出的图像不包含工作流信息,
为了数据安全,让Comfyui导出的图像不包含工作流信息,导出的图像就不会拖到comfyui中加载出来工作流。 ComfyUI的目录下node.py 直接移除 pnginfo(推荐) 在 save_images 方法中,删除或注释掉所有与 metadata …...
