flutter_pickers

Creator: coderz1093

Last updated:

Add to Cart

Description:

flutter pickers

flutter_pickers #

flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级及县级)、多项选择器等…… 欢迎Fork & pr贡献您的代码,大家共同学习
Example #
Web版在线Demo

flutter.eeaarr.cn (上面进不去 试试这个)




用法 #
1.Depend
dependencies:
flutter_pickers: ^2.1.9
copied to clipboard
2.Get
$ flutter packages get
copied to clipboard
3.Install
import 'package:flutter_pickers/pickers.dart';
copied to clipboard
目录 #

flutter_pickers

地址选择器

简单使用
更多用法
更多方法


单项选择器

简单使用
内置数据


多项选择器(无联动)
多项选择器(联动)
时间选择器

简单使用
更多方法
参数说明
tip


样式

内置样式
自定义样式


其他参数

overlapTabBar





地址选择器 #

Pickers.showAddressPicker()


区域数据来源
请戳我查看demo代码


支持三级联动
支持自定义颜色、大小等样式
支持显示 '全部' 选项
支持只选择 省市 2级
支持查询城市码
实时回调










三级选择器动图
二级静态图



简单使用 #
String initProvince = '四川省', initCity = '成都市', initTown = '双流区';
Widget _checkLocation() {
return InkWell(
onTap: () {
Pickers.showAddressPicker(
context,
initProvince: initProvince,
initCity: initCity,
initTown: initTown,
onConfirm: (p, c, t) {
setState(() {
initProvince = p;
initCity = c;
initTown = t;
});
},
);
},
child: Text('$initProvince - $initCity - $initTown'));
}
copied to clipboard

initTown : 不设置或者设置为null ,不显示区级

更多用法 #

demo address_picker_page.dart

AddressPicker.showPicker(
context,
initProvince: locations2[0],
initCity: locations2[1],
initTown: locations2[2],
showTitlebar: true,
menu: _headMenuView,
menuHeight: 36.0,
title: title,
cancelWidget: _cancelButton,
commitWidget: _commitButton,
headDecoration: headDecoration,
addAllItem: false,
textColor: Colors.white,
backgroundColor: Colors.grey[800],
onConfirm: (p, c, t) {},
);
copied to clipboard





参数
描述
默认




initProvince
初始化 省
''


initCity
初始化 市
''


initTown
初始化 区
''


pickerStyle
详见样式
DefaultPickerStyle()


onChanged
选择器发生变动 return (String province, String city, String town)
null


onConfirm
选择器提交 return (String province, String city, String town)
null


onCancel
选择器取消 return (bool isCancel) 是否通过点击取消按钮关闭
null


addAllItem
市、区是否添加 '全部' 选项
true



更多方法 #
/// 根据城市名 查询城市code(有先后顺序)
List<String> cityCode = Address.getCityCodeByName(provinceName:'四川省', cityName: '成都市', townName: '武侯区');
return [510000,510100,510104] or [510000,510000] or [510000] or []


/// 通过城市code 查询城市名(有先后顺序)
List<String> cityName = Address.getCityNameByCode(provinceCode: "510000", cityCode: "510100", townCode: "510104");
return [四川省, 成都市, 锦江区] or [四川省, 成都市] or [四川省] or []
copied to clipboard
单项选择器 #

Pickers.showSinglePicker()请戳我查看demo代码


单选和多选支持数据源混传 num string



简单使用. #
String initData = 'PHP';
Widget _demo() {
return InkWell(
onTap: () {
Pickers.showSinglePicker(context,
data: ['PHP', 'JAVA', 'C++', 'Dart', 'Python', 'Go'],
selectData: initData,
onConfirm: (p, position) {
setState(() {
initData = p;
});
}, onChanged: (p) => print('数据发生改变:$p'));
},
child: Text('$initData'));
}
copied to clipboard



参数
描述
默认




data
数据源
null


selectData
选中的数据
''


pickerStyle
详见样式
DefaultPickerStyle()


onChanged
选择器发生变动 return (String data,int position)
null


onConfirm
选择器提交 return (String data,int position)
null


onCancel
选择器取消 return (bool isCancel) 是否通过点击取消按钮关闭
null



内置数据 #

可直接传给 data:PickerDataType.sex


sex // 性别
education // 学历
subject // 学科
constellation // 星座
zodiac // 生肖
ethnicity // 民族

多项选择器(无联动) #

Pickers.showMultiPicker() 请戳我查看demo代码



示例代码 #
final timeData = [
['上午', '下午'],
List.generate(12, (index) => (index + 1).toString()).toList(),
List.generate(60, (index) => index.toString()).toList(),
List.generate(60, (index) => index.toString()).toList(),
];

void _showDemo(){
Pickers.showMultiPicker(
context,
data: timeData,
selectData: timeData2Select,
suffix: ['', '时', '分', '秒'],
onConfirm: (p) {
print('longer >>> 返回数据类型:${p.map((x) => x.runtimeType).toList()}');
},
);
}
copied to clipboard



参数
描述
默认




data
数据源
null


selectData
选中的数据
''


suffix
item后缀
null


pickerStyle
详见样式
DefaultPickerStyle()


onChanged
选择器发生变动 return (List data, List
null


onConfirm
选择器提交 return (List data, List
null


onCancel
选择器取消 return (bool isCancel) 是否通过点击取消按钮关闭
null




多项选择器(联动) #

Pickers.showMultiLinkPicker() 请戳我查看demo代码

示例代码 #
void _showPicker() {
var multiData = {
'a': {
'aa': [1, 'ww'],
'aaa': 10086
},
'b': ['bbb', 'bbbbb'],
'c': {
'cc': {
'ccc333': [111, 1111],
'cccc33': {
'ccccc4': '帮忙star',
'ccc4-2': [4442, 44442, 442]
},
},
'cc2': ['ccc', 123],
'cc3': 'star 鼓励'
}
};

Pickers.showMultiLinkPicker(
context,
data: multiData,
// 注意数据类型要对应 比如 44442 写成字符串类型'44442',则找不到
// selectData: ['c', 'cc', 'cccc33', 'ccc4-2', 44442],
selectData: ['c', 'cc3'],
columeNum: 5,
suffix: ['', '', '', '', ''],
onConfirm: (List p) {
print('longer >>> 返回数据:${p.join('、')}');
print('longer >>> 返回数据类型:${p.map((x) => x.runtimeType).toList()}');
},
);
}
copied to clipboard



参数
描述
默认




columeNum
选择器列数(必填)
null


data
数据源
null





和上面的多项选择器(无联动)差不多,就不多介绍,改动了2个字段
最外层必须是map(既然是多项,你至少得2列吧)
map类型 说明还有下一列,如果是list或者string、num 表示已经达到最后一级

时间选择器 #

Pickers.showDatePicker() 请戳我查看demo代码


16种模式「年月日时分秒」
自定义后缀
最大|最小 时间
自定义显示样式





简单使用.. #
Widget demo() {
return FlatButton(
onPressed: () {
Pickers.showDatePicker(
context,
onConfirm: (p) {
print('longer >>> 返回数据:$p');
},
// onChanged: (p) => print(p),
);
},
child: Text('Demo'));
}
copied to clipboard
更多方法. #
Pickers.showDatePicker(
context,
// 模式,详见下方
mode: DateMode.HMS,
// 后缀 默认Suffix.normal(),为空的话Suffix()
suffix: Suffix(hours: ' 小时', minutes: ' 分钟', seconds: ' 秒'),
// 样式 详见下方样式
pickerStyle: pickerStyle,
// 默认选中
selectDate: PDuration(hour: 18, minute: 36, second: 36),
minDate: PDuration(hour: 12, minute: 38, second: 3),
maxDate: PDuration(hour: 12, minute: 40, second: 36),
onConfirm: (p) {
print('longer >>> 返回数据:$p');
},
// onChanged: (p) => print(p),
);
copied to clipboard



参数
描述
默认




mode
时间选择器所显示样式 16 种时间样式
DateMode.YMD


selectData
PDuration()初始化选中时间
默认现在:PDuration.now()


minDate
PDuration()最小时间
PDuration(year: 1900)


maxDate
PDuration()最大时间
PDuration(year: 2100)


suffix
每列时间对应的单位
Suffix.normal()


pickerStyle
详见样式
DefaultPickerStyle()


onChanged
选择器发生变动 return (PDuration data)
null


onConfirm
选择器提交 return (PDuration data)
null


onCancel
选择器取消 return (bool isCancel) 是否通过点击取消按钮关闭
null



参数说明 #

PDuration()


selectDate,minDate,maxDate 和返回的数据类型 都是PDuration()

// 可以自定义设置年月日时分秒
PDuration(year: 2020, month: 1, day: 4, hour: 12, minute: 40, second: 36);
// 设置DateTime类型
PDuration.parse(DateTime.parse('20210139'));
PDuration.now();
copied to clipboard

DateMode
时间选择器所显示样式

/// 时间选择器 所显示样式
enum DateMode {
/// 【yyyy-MM-dd HH:mm:ss】年月日时分秒
YMDHMS,
/// 【yyyy-MM-dd HH:mm】年月日时分
YMDHM,
/// 【yyyy-MM-dd HH】年月日时
YMDH,
/// 【yyyy-MM-dd】年月日
YMD,
/// 【yyyy-MM】年月
YM,
/// 【yyyy】年
Y,
/// 【MM-dd HH:mm:ss】月日时分秒
MDHMS,
/// 【MM-dd HH:mm】月日时分
MDHM,
/// 【MM-dd HH:mm】月日时
MDH,
/// 【MM-dd】月日
MD,
/// 【HH:mm:ss】时分秒
HMS,
/// 【HH:mm】时分
HM,
/// 【mm:ss】分秒
MS,
/// 【ss】秒
S,
/// 【MM】月
M,
/// 【HH】时
H
}
copied to clipboard
tip #

如果用到了日期,selectData需要传入年,不然无法计算,如果没有,会默认当前年
当只有单列数据,min|max限制不产生关联 只针对单列item限制,比如 maxDate: day=3, minDate: day=10, 那么day只显示3-10之间
如果minDate:year: 2020, month: 2, day: 10, 只显示2020年2月10日之后的
minDate|maxDate 的YMD和HMS 没有关联! 没有关联!比如设置maxDate:year: 2020, month: 2, day: 10, hour:8,不是2020年2月10日8时之后的时间

样式 #
内置样式 #

style_picker_page.dart 请戳我查看demo代码
default_style.dart 源码


以下4种样式是使用 PickerStyle 类进行封装的。
都内置了夜间模式,如 NoTitleStyle.dark()
除了NoTitleStyle, 其它的样式可以传入

haveRadius: 是否圆角
title: 标题
color: 确定按钮颜色












默认样式:DefaultPickerStyle()
默认样式(暗色):DefaultPickerStyle.dark()










无标题样式:NoTitleStyle()
无标题样式(暗色):NoTitleStyle.dark()










关闭按钮样式:ClosePickerStyle()
关闭按钮样式(暗色):ClosePickerStyle.dark()










圆角按钮样式:RaisedPickerStyle()
圆角按钮样式(暗色):RaisedPickerStyle.dark()



自定义样式 #

style_picker_page.dart 请戳我查看demo代码
picker_style.dart 样式基类



/// [showTitleBar] 是否显示头部(选择器以上的控件) 默认:true
/// [menu] 头部和选择器之间的菜单widget,默认null 不显示
/// [title] 头部 中间的标题 默认SizedBox() 不显示
/// [pickerHeight] 选择器下面 picker 的整体高度 固定高度:220.0
/// [pickerTitleHeight] 选择器上面 title 确认、取消的整体高度 固定高度:44.0
/// [pickerItemHeight] 选择器每个被选中item的高度:40.0
/// [menuHeight] 头部和选择器之间的菜单高度 固定高度:36.0
/// [cancelButton] 头部的取消按钮
/// [commitButton] 头部的确认按钮
/// [textColor] 选择器的文字颜色 默认黑色
/// [textSize] 选择器的文字大小
/// [backgroundColor] 选择器的背景颜色 默认白色
/// [headDecoration] 头部Container 的Decoration 默认:BoxDecoration(color: Colors.white)
/// [itemOverlay] item的覆盖组件,可以自定义选中样式 [双横线样式可参考](https://github.com/longer96/flutter_pickers/issues/12)

class PickerStyle {}
copied to clipboard
其他参数 #
overlapTabBar #

License #
flutter_pickers 使用 MIT 许可证,详情见 LICENSE 文件。

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.