首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flutter showDatePicker将一周的第一天设置为星期一

Flutter中的showDatePicker函数用于显示一个日期选择器。默认情况下,日期选择器将一周的第一天设置为星期日。如果要将一周的第一天设置为星期一,可以通过设置locale属性来实现。

示例代码如下:

代码语言:txt
复制
import 'package:flutter/material.dart';
import 'package:flutter_localizations/flutter_localizations.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      localizationsDelegates: [
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
      ],
      supportedLocales: [
        const Locale('en', 'US'), // English
        const Locale('zh', 'CN'), // Chinese
      ],
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  DateTime selectedDate = DateTime.now();

  Future<void> _selectDate(BuildContext context) async {
    final DateTime? picked = await showDatePicker(
      context: context,
      initialDate: selectedDate,
      firstDate: DateTime(1900),
      lastDate: DateTime(2100),
      locale: const Locale('zh', 'CN'), // 设置为中文
      builder: (BuildContext context, Widget? child) {
        return Theme(
          data: ThemeData.light().copyWith(
            primaryColor: Colors.blue, // 设置主题颜色
            accentColor: Colors.blue, // 设置选中颜色
            colorScheme: ColorScheme.light(primary: Colors.blue), // 设置颜色方案
            buttonTheme: ButtonThemeData(
              textTheme: ButtonTextTheme.primary, // 设置按钮文本颜色
            ),
          ),
          child: child!,
        );
      },
    );
    if (picked != null && picked != selectedDate)
      setState(() {
        selectedDate = picked;
      });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Flutter showDatePicker'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'Selected Date:',
              style: TextStyle(fontSize: 20),
            ),
            Text(
              '${selectedDate.year}-${selectedDate.month}-${selectedDate.day}',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: () => _selectDate(context),
              child: Text('Select Date'),
            ),
          ],
        ),
      ),
    );
  }
}

在上述示例代码中,我们通过设置locale属性为const Locale('zh', 'CN')来将一周的第一天设置为星期一。同时,我们还通过设置主题颜色、选中颜色、按钮文本颜色等来自定义日期选择器的外观。

推荐的腾讯云相关产品:腾讯云移动开发平台(https://cloud.tencent.com/product/mpp)

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

你真的会用Flutter日期类组件吗

老孟导读:Flutter系统提供了一些日期选择类组件,比如DayPicker、MonthPicker、YearPicker、showDatePicker、CupertinoDatePicker等,其中前...4个Material风格组件,最后一个iOS风格组件。...这些天以矩形网格排列,一周每一天都有一列。 DayPicker有几个必填参数,分别如下: selectedDate:选中日期,选中日期有圆形背景。 currentDate:当前日期,文字高亮。...lastDate: DateTime(2030)); print('$result'); }, ) 效果如下: 相关参数介绍如下: initialDate初始化时间,通常情况下设置当前时间...builder参数可用于包装对话框窗口小部件以添加继承窗口小部件,例如Theme,设置深色主题用法如下: showDatePicker( builder: (context, child) {

2.1K20

MySQL日期时间计算速查表

或 PM %r 时间,12-小时(hh:mm:ss AM 或 PM) %S 秒(00-59) %s 秒(00-59) %T 时间, 24-小时 (hh:mm:ss) %U 周 (00-53) 星期日是一周第一天...%u 周 (00-53) 星期一一周第一天 %V 周 (01-53) 星期日是一周第一天,与 %X 使用 %v 周 (01-53) 星期一一周第一天,与 %x 使用 %W 星期名 %w 周天...(0=星期日, 6=星期六) %X 年,其中星期日是周第一天,4 位,与 %V 使用 %x 年,其中星期一是周第一天,4 位,与 %v 使用 %Y 年,4 位 %y 年,2 位 QUARTER...原理:10被比较数,后面1,3,5,7比较数,后面四个依次与10比较,看后面数字组有多少个少于10,则返回其个数。前提是后面数字组从小到大排列,否则返回结果0。...(2)当关键词使用时,表示设置时间间隔,常用在date_add()与date_sub()函数里,例如:interval 1 day ,解释时间间隔设置1天。

1.8K20

MySQL 格式化日期函数 DATE_FORMAT(), FROM_UNIXTIME() 和 UNIX_TIMESTAMP() 之间区别

或 PM %r 时间,12-小时(hh:mm:ss AM 或 PM) %S 秒(00-59) %s 秒(00-59) %T 时间, 24-小时 (hh:mm:ss) %U 周 (00-53) 星期日是一周第一天...%u 周 (00-53) 星期一一周第一天 %V 周 (01-53) 星期日是一周第一天,与 %X 使用 %v 周 (01-53) 星期一一周第一天,与 %x 使用 %W 星期名 %w 周天...(0=星期日, 6=星期六) %X 年,其中星期日是周第一天,4 位,与 %V 使用 %x 年,其中星期一是周第一天,4 位,与 %v 使用 %Y 年,4 位 %y 年,2 位 FROM_UNIXTIME...UNIX_TIMESTAMP() UNIX_TIMESTAMP() 函数 MySQL 中存储日期数据转换成时间戳,其语法是 UNIX_TIMESTAMP(date ) 。...它只有一个参数,date 合法日期。 ----

65330

sql分别用日期、月、年 分组 group by 分组,datepart函数,datediff函数 统计

dbcontext.users.Where(x => ((DbFunctions)null).DateDiffDay(x.created_time, DateTime.Now) == 0).ToList(); /* * 设置语言英语...*/ set language N’English’ –设置语言英语 select datename(weekday, ‘2013-06-08’) 会输出 Saturday /*...* 设置语言简体中文 */ set language N’Simplified Chinese’ –设置语言简体中文 select datename(weekday, ‘2013-06-08...’) 会输出 星期六 /* * 设置一周第一天星期一 */ set datefirst 1 –设置一周第一天星期一(美国一周第一天习惯为星期天) select datepart...(weekday, ‘2013-06-08’) 会输出 6 /* * 设置一周第一天星期日 */ set datefirst 7 –设置一周第一天星期日(美国一周第一天习惯为星期天

2.5K50

PHP时间日期增减操作示例【date strtotime实现加一天、加一月等操作】

("$date1 +5 day")); //输出结果:2018-12-26 //相应地,要增加月,年,day改成month或year即可 //+++ 今天、昨天、明天 、上一周、下一周 +++++++...* 参数:$gdate 日期,默认为当天,格式:YYYY-MM-DD * $first 一周星期一还是星期天开始,0星期天,1星期一 * 返回:数组array("开始日期", "结束日期");...<hr '; echo '本周第一天星期一一周开始):'.date('Y-m-d', time()-86400*date('w')+(date('w') 0?86400:-6*86400)).'...————————————– 本周第一天星期一一周开始):2018-12-17 ——————————————————————————– 本月第一天:2018-12-01 ———————————...(因为一月个月不可能有10周),且月份1时候,年减1处理 if(date('m',$last_week_time) == '01' and $tmp_last_week 10){ $last_week_year

4.2K31

DM达梦数据库关于时间日期函数总结

总结了几点常用关于日期时间相关一些函数用法,有时候可以很方便帮你解决些棘手问题 1. 查询当前日期 select TRUNC(SYSDATE) from dual; 2....dual; --去年今天 8.关于w、ww、iw用法和区别: ww:按每年1月1日一周第一天,1月8日第二周第一天 w:与ww功能类似,不过它是按每月1日每周第一天,例如1日当月第一周第一天...,8日第二周第一天 iw:自然周,星期一至星期日算一周,且每年第一个星期一一周 select to_char(sysdate,‘ww’) from dual; – 查询今年第几周,每天第一天一周第一天...– 查询今年第几周,自然周 select to_char(sysdate,‘w’) from dual; --查询本月第几周 select trunc(日期,‘d’) from dual; --意周日一周起始日期...查询当周第一天 select trunc(日期,‘iw’) from dual;–意周日一周结束日期 查询当周第一天 结束语 这边文章总结了大梦数据库常用一些有关时间及日期方面的函数,并列举了每个函数用法

38010

sql日期格式化「建议收藏」

DATE_FORMAT(date,format) %a 缩写星期名 %b 缩写月名 %c 月,数值 %D 带有英文前缀月中天 %d 月天,数值(00-31) %e 月天,数值(0-31...%r 时间,12-小时(hh:mm:ss AM 或 PM) %S 秒(00-59) %s 秒(00-59) %T 时间, 24-小时 (hh:mm:ss) %U 周 (00-53) 星期日是一周第一天...%u 周 (00-53) 星期一一周第一天 %V 周 (01-53) 星期日是一周第一天,与 %X 使用 %v 周 (01-53) 星期一一周第一天,与 %x 使用 %W 星期名...%w 周天 (0=星期日, 6=星期六) %X 年,其中星期日是周第一天,4 位,与 %V 使用 %x 年,其中星期一是周第一天,4 位,与 %v 使用 %Y 年,4 位 %y 年,2...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站立刻删除。

1.4K20

MySQL时间格式化date_format

语法 DATE_FORMAT(date,format) date 参数是合法日期;format 规定日期/时间输出格式。...格式 描述 %a 缩写星期名 %b 缩写月名 %c 月,数值 %D 带有英文前缀月中天 %d 月天,数值(00-31) %e 月天,数值(0-31) %f 微秒 %H 小时 (00-23) %h...或 PM %r 时间,12-小时(hh:mm:ss AM 或 PM) %S 秒(00-59) %s 秒(00-59) %T 时间, 24-小时 (hh:mm:ss) %U 周 (00-53) 星期日是一周第一天...%u 周 (00-53) 星期一一周第一天 %V 周 (01-53) 星期日是一周第一天,与 %X 使用 %v 周 (01-53) 星期一一周第一天,与 %x 使用 %W 星期名 %w 周天...(0=星期日, 6=星期六) %X 年,其中星期日是周第一天,4 位,与 %V 使用 %x 年,其中星期一是周第一天,4 位,与 %v 使用 %Y 年,4 位 %y 年,2 位

16610
领券