React Native在Android平台运行gif的解决方法
时间:2022-04-24
本文章向大家介绍React Native在Android平台运行gif的解决方法,主要内容包括概述、RN在Android平台的解决方法、自定义组件实现、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
概述
目前RN在Android平台上不支持gif格式的图片,而在ios平台是支持的,期待以后的版本中系统也是可以默认支持Android的。首先说下在ios平台怎么加载gif呢?
<Image source= {require('./img/loading.gif')} style = {styles.loading}/>
完整实例:
xport default class Loading extends React.Component {
render(){
if (!this.props.isShow) {
return <View />
}
return (
<View style = {styles.container}>
<Image source= {require('./img/loading.gif')} style = {styles.loading}/>
</View>
)
};
}
const styles = StyleSheet.create({
container:{
backgroundColor: 'transparent',
position: 'absolute',
top: 0,
left: 0,
height: Util.screenSizeUtil.height,
width: Util.screenSizeUtil.width,
alignItems: 'center',
justifyContent: 'center',
},
loading:{
height:30,
width:30,
},
})
RN在Android平台的解决方法
facebook fresco方法
要解决上面的问题,方法还是很多的,最简单的莫过于使用facebook的jar支持库,在android/app/build.gradle文件中新增
compile 'com.facebook.fresco:animated-gif:0.13.0'
Fresco是一个强大的图片加载组件,Android 本身的图片库不支持此格式,但是Fresco支持。使用时,和往常一样,仅仅需要提供一个图片的URI即可,剩下的事情,Fresco会处理。 如我们运行一个名为loading.gif的图片:
<Image source={{uri:loading}} style={{width:20,height:20}}/>
当然网上还有另外的方法,就是自己去实现读取gif图片,对图片资源做拆解,这有点类似于,在很久以前,Android平台也是不支持gif的,出现了自定义view对gif图片进行拆解,然后运行image的方案。有点类似于Android的帧动画,在xml定义图片数组,然后使用Animator来加载。不过这种方法性能差。
自定义组件实现
将gif切成15张png的图片,暂且命名为loading1、loading2…. loading15。
在构造方法中初始化图片数组
//图片数组
var loading_imgs = new Array();
//最大图片张数
const imageLength = 15;
//动画使用的数组下标
const imageIndex = 0;
constructor(props) {
super(props);
this.state = {
dataSource: new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2,}),
….
imageIndex:imageIndex,
};
//组装图片数组 共15张图片 loading1 -> loading15
for( i=1;i<= imageLength;i++){
let loadingUri = "loading" + i;
let img = <Image source={{uri:loadingUri}} key={i} style={{width:20,height:20}}/>;
loading_imgs.push(img);
}
}
也没渲染
render() {
return (
<View style={styles.container}>
<View style={{position:'absolute', top:-1000}}>
{
loading_imgs.map((item,i)=> loading_imgs[i])
}
</View>
</View>
)};
轮播图片
每隔100毫秒切换一张图片,当数据加载完毕,清楚定时任务,并且将图片置为第一张。
图片轮播函数
_loop() {
this.loopCount++;
if (this.loopCount < loading_imgs.length) {
this.setState({
imageIndex: this.loopCount,
});
}else {
this.loopCount = -1;
}
}
//轮播图片
this.timerPic = setInterval(this._loop.bind(this), 100);
//清除图片轮播效果
this.timer1 && clearInterval(this.timer1);
this.loopCount = -1;
这样就实现了自己实现对gif运行的实现,不过其性能确实太差,建议使用第一种。
附:RN知识库
- 服务器未能识别 HTTP 标头 SOAPAction 的值
- 实用代码-C#获取本机网络适配器信息及MAC地址
- WordPress 自定义 login (登录页面)CSS 样式
- [C#1] 12-特性
- HTTP Basic Authentication for RESTFul Service
- [C#2] 4-可空类型、静态类
- jquery 操作css 尺寸
- Windows 7上IIS出现http 500错误
- [C#2] 2-匿名方法
- jquery 操作css 选择器
- 主页后台源码及释义
- [C#2] 3-局部类型、属性访问器保护级别、命名空间别名限定符
- (2013.09更新)最新W3School 离线完整版CHM 电子书下载
- [C#2] 1-泛型
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- C# dotnet 使用判断文件夹存在的方法判断一个文件路径会怎样
- 怎样给wordpress网站模板,添加最新文章、随机文章、热评文章?
- [医疗信息化][DICOM教程]1.使用Java的DICOM基础-理解DICOM文件-DICOM Basics using Java - Making Sense of the DICOM File
- python自动播放网课
- Istio实战——流量管理
- WordPress移除head头部js、css、feed等多余加载项
- python控制鼠标键盘,解放你的双手~
- 用腾讯云批量计算(batch-compute)调度GPU分布式机器学习
- R语言模拟保险模型中分类器的ROC曲线不良表现
- Linux xargs grep zgrep命令
- r语言空间可视化绘制道路交通安全事故地图
- 小知识:Oracle RAC添加服务名实现单节点访问
- Python去掉图片四周纯色边框
- R语言空间可视化:绘制英国脱欧投票地图
- CC攻击防御的一种方法