React Native 安卓端 android Image 播放gif webp 动态图

React Native 安卓端 android Image 播放gif webp 动态图

RN项目是0.78.2 React是19.0
在这里插入图片描述

基本介绍

Image 是 React Native 中用于显示各种类型图片的核心组件,支持显示网络图片、静态资源、本地图片以及 base64 编码的图片。在 Android 端,Image 组件还可以用来播放 GIF、WebP 动态图等格式。

基本用法

import React from "react";
import { View, Image, StyleSheet } from "react-native";const App = () => {return (<View style={styles.container}>{/* 加载本地静态资源 */}<Image source={require("./assets/logo.png")} style={styles.image} />{/* 加载网络图片 */}<Imagesource={{ uri: "https://reactnative.dev/img/tiny_logo.png" }}style={styles.image}/></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: "center",alignItems: "center",},image: {width: 100,height: 100,margin: 10,},
});export default App;

常用属性

1. source 属性

source 是 Image 组件最基本的属性,用于指定图片的来源:

// 本地静态资源
<Image source={require('./assets/logo.png')} />// 网络图片
<Image source={{ uri: 'https://example.com/image.jpg' }} />// base64 图片
<Image source={{ uri: 'data:image/png;base64,iVBORw0KGgoA...' }} />// 包含请求头的网络图片
<Imagesource={{uri: 'https://example.com/secure-image.jpg',headers: {Authorization: 'Bearer token123'}}}
/>

2. style 属性

Image 组件可以使用几乎所有的样式属性,常用的包括:

<Imagesource={require("./assets/logo.png")}style={{width: 100, // 宽度height: 100, // 高度resizeMode: "cover", // 调整模式borderRadius: 50, // 圆角borderWidth: 2, // 边框宽度borderColor: "#000", // 边框颜色backgroundColor: "#f0f0f0", // 背景色opacity: 0.8, // 透明度}}
/>

3. resizeMode 属性

控制图片如何适应给定的尺寸:

  • cover: 保持图片宽高比,裁剪长边
  • contain: 保持图片宽高比,缩放图片使其完全显示
  • stretch: 拉伸图片填满尺寸,不保持宽高比
  • repeat: 平铺图片(仅 iOS 支持)
  • center: 居中显示,不缩放
<Imagesource={{ uri: "https://example.com/image.jpg" }}style={{ width: 200, height: 200 }}resizeMode="cover"
/>

显示动态图片(GIF/WebP)

Android 端支持 GIF 和 WebP

在 Android 上,React Native 的 Image 组件默认支持 GIF 动画。为了支持 WebP 动态图,需要添加额外的配置:

  1. android/app/build.gradle 中添加 WebP 支持:
dependencies {// 支持动画 WebPimplementation 'com.facebook.fresco:animated-gif:3.4.0'// 如果你需要支持WebP格式,包括WebP动图implementation 'com.facebook.fresco:animated-webp:3.2.0'implementation 'com.facebook.fresco:webpsupport:3.2.0'
}
  1. 在代码中使用动态图片:
// GIF 图片
<Imagesource={{ uri: 'https://example.com/animation.gif' }}style={{ width: 200, height: 200 }}
/>// WebP 动态图
<Imagesource={{ uri: 'https://example.com/animation.webp' }}style={{ width: 200, height: 200 }}
/>

图片预加载

对于网络图片,可以使用 Image.prefetch 方法进行预加载,提升用户体验:

// 预加载单张图片
Image.prefetch("https://example.com/image.jpg").then(() => console.log("图片预加载成功")).catch((error) => console.error("图片预加载失败", error));// 预加载多张图片
const urls = ["https://example.com/image1.jpg","https://example.com/image2.jpg",
];Promise.all(urls.map((url) => Image.prefetch(url))).then(() => console.log("所有图片预加载成功")).catch((error) => console.error("部分图片预加载失败", error));

性能优化

1. FastImage 组件

对于有大量图片的应用,可以考虑使用第三方库 react-native-fast-image,它在性能上有显著提升:
在这里插入图片描述
在这里插入图片描述

import FastImage from "react-native-fast-image";// 使用方法类似 Image
<FastImagesource={{ uri: "https://example.com/image.jpg" }}style={{ width: 100, height: 100 }}resizeMode={FastImage.resizeMode.cover}
/>;

2. 图片缓存

react-native-fast-image 提供了缓存控制功能:

<FastImagesource={{uri: "https://example.com/image.jpg",// 缓存策略cache: FastImage.cacheControl.immutable,// 请求优先级priority: FastImage.priority.high,}}style={{ width: 100, height: 100 }}
/>

常见问题与解决方案

1. Android 上 GIF 不播放或性能问题

如果 GIF 动画在 Android 上播放有问题,可以尝试以下解决方案:

  • 确保 GIF 文件大小适中
  • 使用 react-native-gifreact-native-fast-image 替代原生 Image
  • 考虑使用 Lottie 动画作为替代方案

2. 圆形图片

创建圆形图片的最佳方式:

<Imagesource={{ uri: "https://example.com/avatar.jpg" }}style={{width: 100,height: 100,borderRadius: 50, // 设置为宽高的一半overflow: "hidden",}}
/>

总结

React Native 的 Image 组件是一个功能强大的图片显示工具,可以满足大多数应用场景的需求。在 Android 端,它支持 GIF 和 WebP 动态图片的播放,通过合理配置和使用第三方库,可以显著提升图片加载性能和用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实时数字人——DH_LIVE

前两天亲手搭建了实时对话数字人VideoChat&#xff0c;今天来搭建下DH_LIVE。 DH_LIVE一个实时数字人解决方案&#xff0c;从输入文字到数字人对口型说话用时2-3秒。 今天就来实际操作下dh_live的搭建过程。 首先贴上git地址&#xff1a;https://github.com/kleinlee/DH_liv…

AOSP CachedAppOptimizer 冻结方案

背景 Android 一直面临一个核心难题&#xff1a;如何优化进程对有限系统资源&#xff08;如 CPU、电量&#xff09;的使用&#xff0c;同时保证用户体验。 当进程进入后台后&#xff0c;它们虽不再贡献用户体验&#xff0c;却仍可能消耗资源。传统的杀后台方案虽然节省资源&a…

实体店的小程序转型之路:拥抱新零售的密码-中小企实战运营和营销工作室博客

实体店的小程序转型之路&#xff1a;拥抱新零售的密码-中小企实战运营和营销工作室博客 在当今数字化浪潮的冲击下&#xff0c;实体店面临着前所未有的挑战&#xff0c;但小程序的出现为实体店转型新零售带来了新的曙光。先来看一组惊人的数据&#xff0c;据相关统计&#xff…

Java求职面试:从Spring Boot到微服务的全面考核

Java求职面试实录&#xff1a;从Spring Boot到微服务的全面考核 第一轮&#xff1a;基础技术的考察 场景&#xff1a; 赵大宝走进了一家互联网大厂的面试间&#xff0c;面试官严肃地看着他。 面试官&#xff1a; 赵大宝&#xff0c;你好。我们先从简单的开始。请你解释一下J…

记录一个坑关于STM32 ARM Compiler Version

在用 Keil 进行 STM32 开发的时候&#xff0c;一开始下载&#xff0c;下载的 ARM 编译器是 Version6&#xff0c;他就不兼容老的代码&#xff0c;就很抽象。 所以必须要更换编译器。 可以去官网下载编译器 Downloads - Arm Developer &#xff0c;也可以自己找资源哈&#xff…

PCIe体系结构学习入门——PCI总线概述(二)PCI总线的桥和配置

这里写目录标题 序言存储器域和 PCI 总线域HOST 主桥PCI 桥和 PCI 设备配置空间PCI 桥PCI 设备配置空间PCI 总线的配置非透明 PCI 桥序言 接续前章内容,本章继续讲述 PCI 总线概述的第二部分——PCI 总线的桥和配置。 如果需要进一步了解前一章节内容,可以访问:PCIe体系结构…

浔川代码编辑器v2.0(测试版)更新公告

浔川代码编辑器v2.0(测试版)更新公告 发布日期&#xff1a;** 2023年4月30日 我们很高兴地宣布浔川代码编辑器v2.0测试版即将上线&#xff01;本次更新带来了多项功能改进和问题修复&#xff0c;旨在为用户提供更稳定、更强大的编程体验。 主要更新内容 1. **Bug修复与稳定性提…

微信小程序 tabbar底部导航栏

官方文档&#xff1a;https://developers.weixin.qq.com/miniprogram/dev/reference/configuration/app.html#tabBar 一、常规菜单格式 在app.json 文件中配置&#xff0c;其他关键点详见官方文档&#xff0c;后续更新不规则图标的写法

Spring 中@Autowired,@Resource,@Inject 注解实现原理

使用案例 前置条件&#xff1a; 现在有一个 Vehicle 接口&#xff0c;它有两个实现类 Bus 和 Car &#xff0c;现在还有一个类 VehicleService 需要注入一个 Vehicle 类型的 Bean&#xff1a; public interface Vehicle {}Component public class Car implements Vehicle {}C…

【Rust结构体】Rust结构体详解:从基础到高级应用

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

《LightLLM:开启大语言模型推理新时代》

《LightLLM:开启大语言模型推理新时代》 大语言模型推理的困境与挑战 在当今人工智能飞速发展的时代,大语言模型(LLMs)无疑是最为耀眼的明星技术之一。从 OpenAI 的 GPT 系列到谷歌的 BERT,再到国内如百度文心一言、阿里通义千问等,大语言模型以其强大的语言理解和生成能…

【Python Web开发】02-Socket网络编程02

文章目录 1. 服务器端1.1 socket.socket()1.2 socket.bind()1.3 socket.listen()1.4 socket.accept()1.5 socket.recv()1.6 socket.send() 和 socket.sendall()1.7 socket.close() 2. 客户端2.1 socket.socket()2.2 socket.connect()2.3 socket.send() 和 socket.sendall()2.4 …

Flutter 在全新 Platform 和 UI 线程合并后,出现了什么大坑和变化?

Flutter 在全新 Platform 和 UI 线程合并后&#xff0c;出现了什么大坑和变化&#xff1f; 在两个月前&#xff0c;我们就聊过 3.29 上《Platform 和 UI 线程合并》的具体原因和实现方式&#xff0c;而事实上 Platform 和 UI 线程合并&#xff0c;确实为后续原生语言和 Dart 的…

蓝桥杯 1. 四平方和

四平方和 原题目链接 题目描述 四平方和定理&#xff08;又称拉格朗日定理&#xff09;指出&#xff1a; 每个正整数都可以表示为 至多 4 个正整数的平方和。 如果将 0 包括进去&#xff0c;则每个正整数都可以恰好表示为 4 个非负整数的平方和。 例如&#xff1a; 5 0 …

开发并发布一个属于自己的包(npm)

一、CommonJS规范导入require 创建一个npm包涉及几个步骤&#xff0c;包括设置你的项目结构、编写代码、编写文档、测试你的代码&#xff0c;以及发布到npm仓库。以下是一个基本的指南&#xff0c;帮助你从头开始创建一个npm包。 步骤 1: 初始化npm项目 创建项目文件夹&#x…

CRTP(Curiously Recurring Template Pattern)

C 中的 CRTP&#xff08;奇异递归模板模式&#xff09; CRTP&#xff08;Curiously Recurring Template Pattern&#xff09;是一种利用模板继承实现 静态多态&#xff08;Static Polymorphism&#xff09; 的设计模式。通过基类模板以派生类作为模板参数&#xff0c;CRTP 允许…

小白工具视频转MPG, 功能丰富齐全,无需下载软件,在线使用,超实用

在视频格式转换需求日益多样的今天&#xff0c;小白工具网的在线视频转 MPG 功能https://www.xiaobaitool.net/videos/convert-to-mpg/ &#xff09;脱颖而出&#xff0c;凭借其出色特性&#xff0c;成为众多用户处理视频格式转换的优质选择。 从格式兼容性来看&#xff0c;它支…

银河麒麟系统离线安装nodejs

本篇文章我们介绍如何通过nvm(node版本管理工具)来实现离线安装nodejs 第一步&#xff1a;下载nvm https://github.com/nvm-sh/nvm/releases/tag/v0.40.1 在页面找到【Source code(tar.gz)】下载 第二步&#xff1a;安装nvm 将下载好的tar.gz拷贝到银河麒麟系统文件夹下(加…

Go语言中包导入下划线的作用解析

在Go语言的代码中&#xff0c;有时会看到类似以下的导入语句&#xff1a; import _ "github.com/mattn/go-sqlite3"这种以下划线_开头的导入方式&#xff0c;显得有些特别&#xff0c;尤其是对于新手来说&#xff0c;可能会感到困惑&#xff0c;为什么要这样写&…

Winddows11官网下载安装VMware Workstation Pro17(图文详解)

Winddows11安装VMware17 1、官网下载2、安装3、总结 1、官网下载 官网地址 点击Products&#xff0c;滑到最下面&#xff0c;选择SEE DESKTOPP HYPERVISORS 选择 DOWNLOAD FUSION OR WORKSTATION 自动跳转到下面哪个服界面&#xff0c;注册 输入邮箱地址和图片下面的文字…