利用flutter實(shí)現(xiàn)炫酷的list
前言
使用了flutter一段時間,越來越喜歡flutter了,flutter比我們想象中的強(qiáng)大。這篇文章介紹了怎么使用flutter來展示一個很漂亮的list,先看下效果圖。
樣式還是很漂亮的,下面我們一步一步完成這個小項(xiàng)目。
開發(fā)前準(zhǔn)備
我們會用到加載網(wǎng)絡(luò)圖片F(xiàn)adeInImage這么個widget,需要一個loading的icon,所以需要在pubspec.yaml里配置下靜態(tài)資源,只有配置過的靜態(tài)資源才可以在項(xiàng)目中使用
assets: - assets/images/
需要mock一些假數(shù)據(jù)和一些常用的常量,所以專門建了個constant.dart來管理
assets: - assets/images/
appBar部分
appBar需要透明的背景這樣才能將后面的圖片展示出來,看起來很像沉浸式。
需要將elevations設(shè)置為0,這樣就可以取消安卓特有的陰影效果,下面是代碼:
Scaffold( appBar: AppBar( backgroundColor: Colors.transparent, elevation: 0, title: Text( 'flutter awesome list', style: TextStyle( color: Colors.white, ), ), ), body: HomeBody(), );
Banner部分
我們需要使用Transform.translate()
這個weidget來將Banner部分向上移動,讓appBar全部展示在banner上面,這里給的offset為offset: Offset(0, -56)
,56為appBar的高度
下面的斜切造型需要使用ClipPath()
來完成,用法有點(diǎn)像canvas,代碼如下:
class MyClipper extends CustomClipper<Path> { @override Path getClip(Size size) { Path p = Path(); p.lineTo(size.width, 0.0); p.lineTo(size.width, size.height / 4.75); p.lineTo(0.0, size.height / 3.75); p.close(); return p; } @override bool shouldReclip(CustomClipper oldClipper) { return true; } }
用戶信息的展示用的widget是ListTile和CircleAvatar,用法也比較簡單,我直接貼代碼了:
ListTile( leading: CircleAvatar( backgroundImage: NetworkImage(CONSTANT.userAvatar), ), title: Text( CONSTANT.userName, style: CONSTANT.defaultTextStyle, textScaleFactor: 1.5, ), subtitle: Text( CONSTANT.userProfile, style: CONSTANT.defaultTextStyle, ), )
列表展示部分
列表的展示使用的是ListView.builder()
,兩個必傳參數(shù)itemCount和itemBuilder,前者控制列表的數(shù)量,后者控制item的展示,因?yàn)閕tem的樣式還是比較多的,所以抽離成單獨(dú)的StatelessWidget組件:AwesomeListItem
我們用InkWell組件將AwesomeListItem包裹,InkWell是flutter自帶的組件,這個組件的特點(diǎn)是點(diǎn)擊的時候帶有水墨綻開的效果。點(diǎn)擊item的時候,我們使用Navigator.push
跳轉(zhuǎn)到詳情頁面
圖片的展示,我們還是使用的FadeInImage,這種漸入效果的用戶體驗(yàn)還是很不錯的。然后再使用Hero()來包裹FadeInImage,這樣能在頁面跳轉(zhuǎn)的時候提供圖片之間的過渡動畫,很是強(qiáng)大和炫酷
Hero( tag: index, child: FadeInImage( image: NetworkImage(data.image), fit: BoxFit.cover, placeholder: AssetImage('assets/images/loading.gif'), ), )
詳情頁面
最后就是詳情頁面的展示,這個頁面并沒有寫什么樣式,展示了從列表頁跳轉(zhuǎn)過來時,圖片的過渡效果,有興趣的同學(xué)可以豐富下頁面的樣式和內(nèi)容
感興趣的同學(xué)可以看下源碼xch1029/awesomelist
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
相關(guān)文章
Android實(shí)現(xiàn)將一個Activity設(shè)置成窗口樣式的方法
這篇文章主要介紹了Android實(shí)現(xiàn)將一個Activity設(shè)置成窗口樣式的方法,涉及Android的窗口樣式設(shè)置與布局技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-02-02Android?Bugreport實(shí)現(xiàn)原理深入分析
這篇文章主要介紹了Android?Bugreport實(shí)現(xiàn)原理,Bugreport主要用于分析手機(jī)的狀態(tài),在應(yīng)用開發(fā)中,程序的調(diào)試分析是日常生產(chǎn)中進(jìn)程會進(jìn)行的工作,Bugreport就是很常用的工具,需要的朋友可以參考下2024-05-05Android App支付系列(二):支付寶SDK接入詳細(xì)指南(附官方支付demo)
本篇文章介紹了Android App支付系列(二):支付寶SDK接入詳細(xì)指南(附官方支付demo) ,有興趣的同學(xué)可以了解一下。2016-11-11使用OkHttp包在Android中進(jìn)行HTTP頭處理的教程
HTTP頭部處理是HTTP網(wǎng)絡(luò)編程中的基本操作,安卓中使用OkHttp包(github.com/square/okhttp)進(jìn)行相關(guān)操作當(dāng)然也是得心應(yīng)手,這里我們就來看一下使用OkHttp包在Android中進(jìn)行HTTP頭處理的教程2016-07-07Android消息通知Notification常用方法(發(fā)送消息和接收消息)
最近在做消息通知類Notification的相關(guān)業(yè)務(wù),利用閑暇時間總結(jié)一下,主要分為兩部分來記錄:發(fā)送消息和接收消息,對Android消息通知相關(guān)知識感興趣的朋友一起看看吧2024-02-02