flutter showDatePicker showTimePicker 国际化(中文显示)

吐槽一下: csdn 代码块没有flutter语言,格式乱糟糟的

pubspec.yaml

dependencies:
  flutter:
    sdk: flutter

  flutter_localizations:
    sdk: flutter

main.dart

import 'package:flutter_localizations/flutter_localizations.dart';

return MaterialApp(
      debugShowCheckedModeBanner: false,
      home: Tabs(),
      onGenerateRoute: onGenerateRoute,
      initialRoute: '/',
      localizationsDelegates: [
        //此处
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
      ],
      supportedLocales: [
        //此处
        const Locale('zh', 'CH'),
        const Locale('en', 'US'),
      ],
);

TimePicker.dart

  DateTime _nowDate = DateTime.now();
  var _nowTime = TimeOfDay(hour: 08, minute: 00);

  _showDatePicker() async {
    var result = await showDatePicker(
      context: context,
      initialDate: _nowDate,
      firstDate: DateTime(1980),
      lastDate: DateTime(2100),
      locale: Locale('zh'),
    );

    setState(() {
      if (result == null) return;
      _nowDate = result;
    });
  }

  _showTimePicker() async {
    var result = await showTimePicker(
      context: context,
      initialTime: _nowTime,
      builder: (BuildContext context, Widget? child) {
        return Localizations(
          locale: const Locale('zh'),
          child: child,
          delegates: <LocalizationsDelegate>[
            GlobalMaterialLocalizations.delegate,
            GlobalWidgetsLocalizations.delegate,
          ],
        );
      },
    );

    setState(() {
      if (result == null) return;
      _nowTime = result;
    });
  }
InkWell(
            child: Row(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                Text("${formatDate(_nowDate, [yyyy, '-', mm, '-', dd])}"),
                Icon(Icons.arrow_drop_down),
              ],
            ),
            onTap: _showDatePicker,
          ),

       InkWell(
            child: Row(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                Text("${_nowTime.format(context)}"),
                Icon(Icons.arrow_drop_down),
              ],
            ),
            onTap: _showTimePicker,
          ),

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值