Flutter 中的 MaterialButton 小部件:全面指南

Flutter 中的 MaterialButton 小部件:全面指南

在 Flutter 中,MaterialButton 是 Material Design 风格中的一种按钮,它提供了一种简单而直观的方式来创建符合 Material Design 指南的按钮。MaterialButton 支持多种形状、颜色和大小,并且可以响应用户的点击操作。

基础用法

MaterialButton 最基本的用法是包裹一个文本标签,并提供一个点击事件的回调:

dart 复制代码
MaterialButton(
  onPressed: () {
    // 当按钮被按下时执行的操作
  },
  child: Text('Click Me'),
)

自定义样式

MaterialButton 提供了多种属性来定制按钮的外观:

颜色和文本颜色

  • color: 设置按钮的背景颜色。
  • textColor: 设置按钮上文本的颜色。
dart 复制代码
MaterialButton(
  color: Colors.blue,
  textColor: Colors.white,
  onPressed: () {/* ... */},
  child: Text('Colored Button'),
)

形状

  • shape: 设置按钮的形状,可以是圆形、矩形或其他自定义形状。
dart 复制代码
MaterialButton(
  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10.0)),
  onPressed: () {/* ... */},
  child: Text('Shaped Button'),
)

大小

MaterialButton 的大小是根据其包裹的 child 小部件的大小自动决定的,但你可以通过 minWidthheightpadding 属性来进一步定制:

dart 复制代码
MaterialButton(
  minWidth: 100.0,
  height: 40.0,
  padding: EdgeInsets.all(8.0),
  onPressed: () {/* ... */},
  child: Text('Sized Button'),
)

点击反馈

  • onPressed: 用户点击按钮时执行的操作。
  • onLongPress: 用户长按按钮时执行的操作。
dart 复制代码
MaterialButton(
  onPressed: () {/* ... */},
  onLongPress: () {
    // 用户长按按钮时的操作
  },
  child: Text('Press or Long Press Me'),
)

禁用状态

  • disabledColor: 设置按钮禁用时的颜色。
  • onDisabled: 按钮禁用时点击事件的回调。
dart 复制代码
MaterialButton(
  disabledColor: Colors.grey,
  onPressed: () {/* ... */},
  child: Text('Disabled Button'),
)

实例:带图标的按钮

MaterialButton 可以包含图标,以提供更直观的交互提示:

dart 复制代码
MaterialButton(
  onPressed: () {/* ... */},
  child: Icon(Icons.add),
)

实例:凸起按钮

在 Material Design 中,凸起按钮(Raised Buttons)是最常见的按钮样式,它们在按下时会有一个轻微的阴影效果:

dart 复制代码
MaterialButton(
  elevation: 8.0, // 设置阴影的高度
  onPressed: () {/* ... */},
  child: Text('Raised Button'),
)

实例:平坦按钮

平坦按钮(Flat Buttons)没有阴影,通常用于较少重要的操作或设置在其他组件上:

dart 复制代码
MaterialButton(
  color: Colors.blue,
  textColor: Colors.white,
  shape: StadiumBorder(), // 使用体育场形状的边框
  onPressed: () {/* ... */},
  child: Text('Flat Button'),
)

实例:突出按钮

突出按钮(Outlined Buttons)带有边框但没有背景颜色,它们常用于需要强调的负操作,如取消或删除:

dart 复制代码
MaterialButton(
  shape: CircleBorder(),
  onPressed: () {/* ... */},
  child: Text('Outlined Button'),
  textColor: Colors.black,
  borderSide: BorderSide(
    color: Colors.black,
    width: 1.0,
  ),
)

结语

MaterialButton 是 Flutter 中一个功能丰富且高度可定制的小部件,它允许你快速创建出符合 Material Design 指南的按钮。掌握 MaterialButton 的使用,可以帮助你创建出既美观又交互性强的用户界面。

相关推荐
蜡笔小新星4 分钟前
Python Kivy库学习路线
开发语言·网络·经验分享·python·学习
凯子坚持 c4 分钟前
C语言复习概要(三)
c语言·开发语言
无限大.16 分钟前
c语言200例 067
java·c语言·开发语言
余炜yw17 分钟前
【Java序列化器】Java 中常用序列化器的探索与实践
java·开发语言
篝火悟者18 分钟前
问题-python-运行报错-SyntaxError: Non-UTF-8 code starting with ‘\xd5‘ in file 汉字编码问题
开发语言·python
Death20021 分钟前
Qt 中的 QListWidget、QTreeWidget 和 QTableWidget:简化的数据展示控件
c语言·开发语言·c++·qt·c#
六点半88822 分钟前
【C++】速通涉及 “vector” 的经典OJ编程题
开发语言·c++·算法·青少年编程·推荐算法
惜.己22 分钟前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
niu_sama26 分钟前
基于muduo库函数实现protobuf协议的通信
开发语言·qt
不写八个28 分钟前
Qt教程(001):Qt概述与安装
开发语言·qt