Flutter - 加载网络图片的几种方式

本文介绍了如何在Flutter应用中使用Image.network加载网络图片,以及如何通过FadeInImage组件实现默认占位图和淡入效果,提升用户体验。还提到了透明图片库TransparentImage的使用方法。
摘要由CSDN通过智能技术生成

使用方法如下,和上面的用法一样

Image.network(

‘https://github.com/flutter/plugins/raw/master/packages/video_player/doc/demo_ipod.gif?raw=true’,

);

Image.network的例子

import ‘package:flutter/material.dart’;

void main() => runApp(new ImageDemoApp());

class ImageDemoApp extends StatelessWidget {

@override

Widget build(BuildContext context) {

return new MaterialApp(

title: ‘Image Demo’,

home: new HomePage(),

);

}

}

class HomePage extends StatefulWidget {

@override

State createState() => new _HomePageState();

}

class _HomePageState extends State {

@override

Widget build(BuildContext context) {

return new Scaffold(

appBar: new AppBar(title: new Text(‘Web Image Demo Page’),),

body: new ListView(children: [

Container(

margin: EdgeInsets.only(bottom: 12.0),

decoration: BoxDecoration(color: Colors.grey),

child: Column(children: [

Image.network(

‘https://raw.githubusercontent.com/flutter/website/master/_includes/code/layout/lakes/images/lake.jpg’,

),

Text(‘Image.network’)

],),

),

Container(

margin: EdgeInsets.only(bottom: 12.0),

decoration: BoxDecoration(color: Colors.grey),

child: Column(children: [

Image.network(

‘https://github.com/flutter/plugins/raw/master/packages/video_player/doc/demo_ipod.gif?raw=true’,

),

Text(‘Image.network Animated Gifs’)

],),

),

],),

);

}

}

有默认占位图和淡入效果


在图片加载过程中,给用户展示一张默认的图片,能提高用户体验。

使用FadeInImage组件来达到这个功能。FadeInImage能处理内存中,App资源或者网络上的图片。

加载网络图片

import ‘package:transparent_image/transparent_image.dart’;

FadeInImage.memoryNetwork(

placeholder: kTransparentImage,

image: ‘https://github.com/flutter/website/blob/master/_includes/code/layout/lakes/images/lake.jpg?raw=true’,

);

示例效果

使用FadeInImage.memoryNetwork

import ‘package:flutter/material.dart’;

import ‘package:transparent_image/transparent_image.dart’;

void main() => runApp(new FadeInImageDemoApp());

class FadeInImageDemoApp extends StatelessWidget {

@override

Widget build(BuildContext context) {

return new MaterialApp(

title: ‘Image Demo’,

home: new HomePage(),

);

}

}

class HomePage extends StatefulWidget {

@override

State createState() => new _HomePageState();

}

class _HomePageState extends State {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

总结

找工作是个很辛苦的事情,而且一般周期都比较长,有时候既看个人技术,也看运气。第一次找工作,最后的结果虽然不尽如人意,不过收获远比offer大。接下来就是针对自己的不足,好好努力了。

最后为了节约大家的时间,我把我学习所用的资料和面试遇到的问题和答案都整理成了PDF文档,都可以分享给有需要的朋友,如有需要私信我【资料】或者**【点这里】免费领取**

《Android面试复习资料汇总》

喜欢文章的话请关注、点赞、转发 谢谢!

比offer大。接下来就是针对自己的不足,好好努力了。

最后为了节约大家的时间,我把我学习所用的资料和面试遇到的问题和答案都整理成了PDF文档,都可以分享给有需要的朋友,如有需要私信我【资料】或者**【点这里】免费领取**

《Android面试复习资料汇总》

喜欢文章的话请关注、点赞、转发 谢谢!

  • 22
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter是Google开发的一个开源移动应用开发框架,用于创建跨平台的移动应用。在Flutter中设置加载动画是一个常见的需求,尤其是在应用需要加载数据或进行其他耗时操作时。为了提高用户体验,开发者通常会在这些操作期间展示一个加载动画,告诉用户应用正在响应。 在Flutter中实现加载动画,可以通过以下几种方式: 1. 使用内置的`CircularProgressIndicator`或`LinearProgressIndicator`小部件来展示一个简单的进度条。这些小部件自带动画效果,可以直接在UI中使用。 2. 使用` flutter_spinkit`这样的第三方库,它提供了一系列预定义的动画小部件,比如旋转的星星、圆圈、线条等。 3. 自定义动画:如果你需要一个更加个性化或者复杂的动画效果,可以使用`AnimationController`来控制动画的播放,并结合`Tween`来定义动画的具体行为。通过`AnimatedBuilder`或`AnimatedWidget`结合`StatefulWidget`来实现自定义的动画效果。 下面是一个使用`CircularProgressIndicator`的例子: ```dart import 'package:flutter/material.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Demo', home: Scaffold( appBar: AppBar( title: Text('Flutter Loading Animation'), ), body: Center( child: CircularProgressIndicator(), // 这里使用了CircularProgressIndicator ), ), ); } } ``` 在上面的代码中,`CircularProgressIndicator`被放置在了`Center`小部件中,这样它会显示在屏幕的中央位置,并且带有旋转动画效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值