Flutter时间选择器插件scroll_time_picker的使用

发布于 1周前 作者 songsunli 来自 Flutter

Flutter时间选择器插件scroll_time_picker的使用

Scroll Time Picker

Flutter Package Pub Points Popularity

一个用于Flutter的时间选择器小部件。

截图

Logo

开始使用

在你的pubspec.yaml文件中添加以下依赖:

dependencies:
  scroll_time_picker: ^1.0.0

使用示例

下面是一个完整的示例,展示如何使用scroll_time_picker插件来选择时间。

import 'package:flutter/material.dart';
import 'package:scroll_time_picker/scroll_time_picker.dart';

void main() {
  runApp(MaterialApp(home: const MyApp()));
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  DateTime _selectedTime = DateTime.now(); // 初始化当前时间

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Scroll Time Picker Example"), // 应用程序标题
        centerTitle: true, // 标题居中
      ),
      body: Column(
        children: [
          Container(
            height: 100,
            alignment: Alignment.center,
            child: Text(
              "$_selectedTime", // 显示当前选中的时间
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.w500),
            ),
          ),
          Container(
            alignment: Alignment.centerRight,
            padding: const EdgeInsets.only(right: 48), // 设置右侧内边距
            child: TextButton(
              onPressed: () {
                setState(() {
                  _selectedTime = DateTime.now(); // 重置时间为当前时间
                });
              },
              child: Text(
                "TODAY", // 按钮文本
                style: TextStyle(color: Colors.red), // 文本颜色为红色
              ),
            ),
          ),
          SizedBox(
            height: 250,
            child: ScrollTimePicker(
              selectedTime: _selectedTime, // 当前选中的时间
              is12hFormat: true, // 使用12小时制
              onDateTimeChanged: (DateTime value) { // 时间改变时的回调
                setState(() {
                  _selectedTime = value; // 更新选中的时间
                });
              },
            ),
          ),
        ],
      ),
    );
  }
}

更多关于Flutter时间选择器插件scroll_time_picker的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter时间选择器插件scroll_time_picker的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter项目中使用scroll_time_picker插件的一个代码示例。这个插件允许你以滚动的方式选择时间,非常适合需要用户从时间列表中选择特定时间的场景。

首先,确保你已经在pubspec.yaml文件中添加了scroll_time_picker依赖:

dependencies:
  flutter:
    sdk: flutter
  scroll_time_picker: ^x.y.z  # 请替换为最新版本号

然后,运行flutter pub get来安装依赖。

接下来,你可以在你的Dart文件中使用ScrollTimePicker。以下是一个完整的示例,展示了如何在Flutter应用中集成并使用scroll_time_picker插件:

import 'package:flutter/material.dart';
import 'package:scroll_time_picker/scroll_time_picker.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Scroll Time Picker Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: TimePickerDemo(),
    );
  }
}

class TimePickerDemo extends StatefulWidget {
  @override
  _TimePickerDemoState createState() => _TimePickerDemoState();
}

class _TimePickerDemoState extends State<TimePickerDemo> {
  DateTime? selectedTime;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Scroll Time Picker Demo'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              selectedTime == null
                  ? 'Select a time'
                  : 'Selected Time: ${selectedTime!.toLocal()}',
              style: TextStyle(fontSize: 24),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: () {
                _showTimePicker(context);
              },
              child: Text('Select Time'),
            ),
          ],
        ),
      ),
    );
  }

  Future<void> _showTimePicker(BuildContext context) async {
    final TimeOfDay? picked = await showDialog<TimeOfDay>(
      context: context,
      builder: (BuildContext context) {
        return AlertDialog(
          title: Text('Select Time'),
          content: SingleChildScrollView(
            child: Column(
              mainAxisSize: MainAxisSize.min,
              children: <Widget>[
                ScrollTimePicker(
                  initialTime: selectedTime == null
                      ? TimeOfDay.now()
                      : TimeOfDay.fromDateTime(selectedTime!),
                  onChanged: (TimeOfDay value) {
                    // This callback can be used to update UI while scrolling
                    setState(() {
                      selectedTime = DateTime(
                        DateTime.now().year,
                        DateTime.now().month,
                        DateTime.now().day,
                        value.hour,
                        value.minute,
                      );
                    });
                  },
                ),
              ],
            ),
          ),
          actions: <Widget>[
            TextButton(
              onPressed: () => Navigator.of(context).pop(),
              child: Text('Cancel'),
            ),
            TextButton(
              onPressed: () {
                final TimeOfDay? timePicked =
                    ScrollTimePicker.of(context)?.currentTime;
                if (timePicked != null) {
                  setState(() {
                    selectedTime = DateTime(
                      DateTime.now().year,
                      DateTime.now().month,
                      DateTime.now().day,
                      timePicked.hour,
                      timePicked.minute,
                    );
                  });
                }
                Navigator.of(context).pop();
              },
              child: Text('OK'),
            ),
          ],
        );
      },
    );

    if (picked != null && picked != selectedTime?.toLocal()) {
      setState(() {
        selectedTime = DateTime(
          DateTime.now().year,
          DateTime.now().month,
          DateTime.now().day,
          picked.hour,
          picked.minute,
        );
      });
    }
  }
}

在这个示例中,我们创建了一个简单的Flutter应用,包含一个按钮,点击按钮后会弹出一个对话框,对话框中显示了一个ScrollTimePicker。用户可以通过滚动来选择时间,选择完成后点击“OK”按钮确认选择。选择的时间会显示在对话框关闭后的主屏幕上。

注意,ScrollTimePicker.of(context)用于获取对话框中的ScrollTimePicker实例,以便获取当前选择的时间。这是一个常见的Flutter提供者模式用法,但在这个特定插件中,ScrollTimePicker本身并不提供状态管理功能,所以我们在这里主要是为了演示如何获取用户选择的时间。

希望这个示例能帮助你理解如何在Flutter项目中使用scroll_time_picker插件!

回到顶部