data:image/s3,"s3://crabby-images/231f6/231f6a6a4af3a83efc97a3828282e353aa3b1395" alt="Flutter基础与实战:从入门到APP跨平台开发"
2.7 按钮Button
在Flutter中,Button常用于处理用户的点击事件操作,与Android中的Button和iOS中的UIButton功能类似。Flutter提供了很多预定样式的Button,表2-10列出了一些常用的Button。
表2-10 Flutter中常用的Button类别及说明
data:image/s3,"s3://crabby-images/0b51e/0b51e63f1628cc1a537ddc600b1404ad77fed739" alt=""
MaterialButton是Material Design风格按钮,需要在MaterialApp组件中使用,它常用的按钮子类有RaisedButton、FlatButton、OutlineButton。基本使用如下。
data:image/s3,"s3://crabby-images/fba8a/fba8a294dcfddf6b1193c968423b9638c61cbe27" alt=""
data:image/s3,"s3://crabby-images/fb8c3/fb8c382bfe5ac810022550afbf527abf4750a649" alt=""
2-25 Material-Button按钮的基本使用效果图
MaterialButton的构造函数说明代码如下。
data:image/s3,"s3://crabby-images/c4f16/c4f16b98039771d21610ff92ff5c24d1c995ac61" alt=""
RaisedButton默认有阴影高度、背景填充,如图2-20所示。它的基本使用代码如下。
data:image/s3,"s3://crabby-images/68d6e/68d6e3905ed7aca7dcfa7ee6149ad8e8df1e1bbe" alt=""
data:image/s3,"s3://crabby-images/11544/115442d03ff1954fbdc8899fde5709699408f615" alt=""
图2-20 RaisedButton的基本使用效果图
FlatButton默认无背景填充,也无阴影高度,如图2-21所示。
data:image/s3,"s3://crabby-images/572eb/572eb653ba0bac322977d0ac874e6c28bd1fa7f3" alt=""
图2-21 FlatButton的基本使用效果图
data:image/s3,"s3://crabby-images/73094/73094dbc800dd1283bed9f31bdaad6947b037ec0" alt=""
OutlineButton默认情况下会带有边框,当点击时,会有填充的背景颜色,如图2-22所示。
data:image/s3,"s3://crabby-images/44f4b/44f4b2b82dbbca9bf3adfb98d5e1dc6bd8ef1567" alt=""
data:image/s3,"s3://crabby-images/d25fa/d25fa6376c32f26715810a300e8efc36b95ea873" alt=""
图2-22 OutlineButton按钮的基本使用效果图
TextButton默认无背景填充,也无阴影高度,如图2-23所示。
data:image/s3,"s3://crabby-images/f1a4a/f1a4a272e1824e9b6d5502d5b9c7e86314580088" alt=""
data:image/s3,"s3://crabby-images/c17ed/c17ed6553f987156a692460455ed40074b2de289" alt=""
图2-23 TextButton按钮的基本使用效果图
TextButton按钮与FlatButton不同的是,FlatButton按钮按下有高亮颜色显示,而TextButton只有水波纹显示,两者默认使用的颜色也不相同。
ElevatedButton默认情况下会带有圆角边框背景,当点击时,会有水波纹颜色与阴影,如图2-24所示。
data:image/s3,"s3://crabby-images/c260d/c260d95711623add6c3b22d0992fefa1ef090fd8" alt=""
图2-24 ElevatedButton按钮的基本使用效果图
data:image/s3,"s3://crabby-images/56d86/56d86ede9bc429d098bc32c0f8685485d6d8fb50" alt=""
图2-25为OutlinedButton的效果图,与OutlineButton定义非常相似,但两者有明显的视觉差异,OutlinedButton看起来更加舒适。
data:image/s3,"s3://crabby-images/1e9a5/1e9a5423eed367039a525b6b2f490fe77199582e" alt=""
图2-25 OutlinedButton按钮的基本使用效果图
data:image/s3,"s3://crabby-images/5e09b/5e09b23f5ee8ddcf0fc03637ed7172701c60fa5e" alt=""
常用的IconButton系列按钮有BackButton、CloseButton、PopupMenuButton,如图2-26所示,BackButton按钮默认配置了后退的图标,基本使用代码如下。
data:image/s3,"s3://crabby-images/b73d7/b73d7b93842865dfb5761f28b3e00cbcda6a2266" alt=""
如图2-27所示,CloseButton按钮默认配置了一个关闭图标,基本使用代码如下。
data:image/s3,"s3://crabby-images/a1bcd/a1bcd064ab467ef7c0deeb673cfccf55147212b5" alt=""
data:image/s3,"s3://crabby-images/7f18a/7f18a4dae29ab578d1477de9143efa2f0280a46b" alt=""
图2-26 BackButton的使用效果图
data:image/s3,"s3://crabby-images/20dd7/20dd74b18b04914603e7807c6f155d9105dd674a" alt=""
图2-27 CloseButton的使用效果图
PopupMenuButton是弹出的菜单按钮,基本使用代码如下。
data:image/s3,"s3://crabby-images/3f0d5/3f0d59b23d51cd72d58d654d454f779ab51590d7" alt=""
data:image/s3,"s3://crabby-images/baf1b/baf1b60eb632760634149dec834e0b9a5512b494" alt=""
data:image/s3,"s3://crabby-images/50075/50075e5158b900d4d886436ae5f83007fde75d71" alt=""
2-26 Popup-MenuButton基本使用效果图