Flutter 3 基础12: 选择并显示时间

上一篇文章中,我们掌握了如何选择并显示一定格式的日期内容,以及如何本地化日期选择对话框的文字语言。

本文继续添加一个新的部件:时间选择。

启动 Android Studio,打开 hello_world 项目,运行虚拟机,这样就可以实时看到编码产生的效果。现在,我们的部件页面展示了日期选择,文本框和按钮三个部件。

打开时间选择对话框

  1. lib/widget 文件夹下,打开 my_widgets.dart 文件,定位到下列代码:
dart 复制代码
Widget buildDateField(BuildContext context) {
  1. 在这一行代码的上方,添加下列代码:
dart 复制代码
// 选择时间
Widget buildTimeField(BuildContext context) {
  return Column(
    crossAxisAlignment: CrossAxisAlignment.start,
    children: [
      Row(
        mainAxisAlignment: MainAxisAlignment.spaceBetween,
        children: [
          const Text(
            '时间',
            style: TextStyle(fontSize: 20.0),
          ),
          TextButton(
            child: const Text(
              '选择',
              style: TextStyle(fontSize: 20.0),),
            onPressed: () async {
              showTimePicker(
                initialTime: TimeOfDay.now(),
                context: context,
              );
            },
          ),
        ],
      ),
    ],
  );
}
  1. 继续在 my_widgets.dart 文件中,定位到下列代码:
dart 复制代码
buildMaterialButton(),
  1. 在这一行代码的上方,添加下列代码:
dart 复制代码
buildTimeField(context),
  1. 热重启项目。点击部件导航图标,页面上出现了时间选择的按钮。
  1. 点击时间的选择按钮,会弹出时间选择的对话框。

显示选择的时间

  1. 继续在 my_widgets.dart 文件中,定位到下列代码:
dart 复制代码
DateTime _dueDate = DateTime.now();
  1. 在这一行代码的下方,添加下面的代码:
dart 复制代码
TimeOfDay _timeOfDay = TimeOfDay.now();
  1. 继续在 my_widgets.dart 文件中,定位到下列代码:
dart 复制代码
showTimePicker(
  1. 把这一行代码,替换为以下代码:
dart 复制代码
final timeOfDay = await showTimePicker(
  1. 继续在 my_widgets.dart 文件中,定位到下列代码:
dart 复制代码
final timeOfDay = await showTimePicker(
  initialTime: TimeOfDay.now(),
  context: context,
);
  1. 在这一块代码的下方,添加下面的代码:
dart 复制代码
setState(() {  
  if (timeOfDay != null) {  
    _timeOfDay = timeOfDay;  
  }  
});
  1. 继续在 my_widgets.dart 文件中,定位到下列代码:
dart 复制代码
Row(  
  mainAxisAlignment: MainAxisAlignment.spaceBetween,  
  children: [  
    const Text(  
      '时间',  
      style: TextStyle(fontSize: 20.0),  
    ),  
    TextButton(  
      child: const Text(  
        '选择',  
        style: TextStyle(fontSize: 20.0),),  
      onPressed: () async {  
        final timeOfDay = await showTimePicker(  
          // 2  
          initialTime: TimeOfDay.now(),  
          context: context,  
        );  
  
        setState(() {  
          if (timeOfDay != null) {  
            _timeOfDay = timeOfDay;  
          }  
        });  
      },  
    ),  
  ],  
),
  1. 在这一块代码的下方,添加下面的代码:
dart 复制代码
Text(_timeOfDay.format(context)),
  1. 保存文件,热重启项目。点击部件导航图标,点击时间的选择按钮,选择一个时间,点击 确定 按钮,这时,时间显示在了页面上。

提交代码

我们已经实现了时间的选择,又到达了一个小小的里程碑,应该对代码进行提交,保持良好编程习惯。

shell 复制代码
git add .
git commit -m '选择并显示时间。'
相关推荐
Coffeeee12 小时前
闲聊几句,Android老哥们,你们多久没做技改需求了
android·程序员·代码规范
TT_Close13 小时前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
萝卜er13 小时前
Fragment 生命周期与状态恢复-《Android深水区(四)》
android
萝卜er13 小时前
Intent 显式、隐式与 PendingIntent-《Android深水区(五)》
android
Kapaseker15 小时前
一文吃透 Kotlin 集合操作符
android·kotlin
三少爷的鞋16 小时前
Main-safe:现代Android 架构真正的分水岭
android
你听得到1116 小时前
用户说 App 卡,但说不清在哪?我把 Flutter 监控 SDK 升级成了链路观测工作台
前端·flutter·性能优化
沐怡旸1 天前
深入解析 Android Performance Analyzer (APA) 底层架构与技术原理
android
李斯维1 天前
从历史的角度看 Android 软件架构
android·架构·android jetpack
plainGeekDev1 天前
Activity 间传值 → Navigation 参数
android·java·kotlin