我在应用程序中使用CupertinoDatePicker。
Container(
height: 200,
padding: const EdgeInsets.all(16.0),
child: CupertinoDatePicker(
mode: CupertinoDatePickerMode.date,
minimumYear: DateTime.now().year,
onDateTimeChanged: (DateTime value) {
print(value);
},
)
该应用程序正在使用MaterialApp(MaterialTheme)。有没有办法更改CupertinoDatePicker的背景颜色?
这是我尝试过的方法(将CupertinoDatePicker包裹在CupertinoTheme周围,并将颜色设置为黑色),并且它不起作用。
Container(
height: 200,
padding: const EdgeInsets.all(16.0),
child: CupertinoTheme(
data: CupertinoThemeData(
primaryColor: Colors.black),
child: CupertinoDatePicker(
mode: CupertinoDatePickerMode.date,
minimumYear: DateTime.now().year,
onDateTimeChanged: (DateTime value) {
print(value);
},
),
),
)
答案 0 :(得分:1)
在撰写本文时,这是不可能的,并且date_picker.dart
的源代码中有一条注释是:
///将来考虑设置主题的默认背景色。 const Color _kBackgroundColor = CupertinoColors.white;
答案 1 :(得分:1)
在撰写本文时,Flutter已在Master频道上的cupertinoDatePicker中添加了backgroundColor属性。参见https://github.com/flutter/flutter/commit/19cdb21cb67acf51fb9b4e4e7a367d0bcd82fc7b#diff-54c54e67345e65bac63291794f109fd1 以下版本支持它: 主(#39056)v1.10.14 v1.10.13 v1.10.12 v1.10.11 v1.10.10 v1.10.9 v1.10.8 v1.10.7 v1.10.6 v1.10.5 v1.10.4 v1.10.3 v1.10.2 v1.10.1 v1.10.0 v1.9.7 v1.9.6
您可以如下设置backgroundColor:
CupertinoTimerPicker(
backgroundColor: Colors.black,
initialTimerDuration: timer,
mode: CupertinoTimerPickerMode.hms,
onTimerDurationChanged: (Duration newTimer) {
setState(() {
timer = newTimer;
});
答案 2 :(得分:0)
如果您为Flutter应用程序选择了深色主题,那么CupertinoDatePicker的文本颜色将变为白色