最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    正文概述 掘金(longer96)   2021-02-11   1015

    flutter_pickers

    github:https://github.com/longer96/flutter_pickers

    欢迎Fork & pr贡献您的代码,大家共同学习

    Example

    Web版在线Demo

    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    用法

    1.Depend

    dependencies: 
        flutter_pickers: ^1.0.0
    

    2.Get

    $ flutter packages get
    

    3.Install

    import 'package:flutter_pickers/pickers.dart';
    

    目录

    • flutter_pickers
      • 地址选择器
        • 简单使用
        • 更多用法
        • 更多方法
      • 单项选择器
        • 简单使用
        • 内置数据
      • 多项选择器
      • 时间选择器
        • 简单使用
        • 更多方法
        • 参数说明
        • tip
      • 样式
        • 内置样式

        • 自定义样式

    地址选择器

    • 区域数据来源
    • 请戳我查看demo代码
    • 支持三级联动
    • 支持自定义颜色、大小等样式
    • 支持显示 '全部' 选项
    • 支持只选择 省市 2级
    • 支持查询城市码
    • 实时回调
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级
    三级选择器动图二级静态图

    简单使用

    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'));
    }
    
    • initTown : 不设置或者设置为null ,不显示区级

    更多用法

    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) {},
    );
    

    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    参数描述默认
    initProvince初始化 省''initCity初始化 市''initTown初始化 区''pickerStyle详见样式DefaultPickerStyle()onChanged选择器发生变动 return (String province, String city, String town)nullonConfirm选择器提交 return (String province, String city, String town)nulladdAllItem市、区是否添加 '全部' 选项true

    更多方法

    /// 根据城市名 查询城市code(有先后顺序)
    List<String> cityCode =  Locations.getTownsCityCode("四川省","成都市","锦江区");
    return [510000,510100,510104]  or  [510000,510000]  or [510000]  or  []
    
    
    /// 通过城市code 查询城市名(有先后顺序)
    List<String> cityName =  Locations.getCityNameByCode("510000","510100","510104");
    return [四川省, 成都市, 锦江区]  or  [四川省, 成都市]  or [四川省] or []
    

    单项选择器

    • 单选和多选支持数据源混传 num string
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    简单使用.

    String initData = 'PHP';
    Widget _demo() {
        return InkWell(
        onTap: () {
          Pickers.showSinglePicker(context,
              data: ['PHP', 'JAVA', 'C++', 'Dart', 'Python', 'Go'],
              selectData: initData,
              onConfirm: (p) {
                setState(() {
                  initData = p;
                });
              }, onChanged: (p) => print('数据发生改变:$p'));
        },
        child: Text('$initData'));
    }
    
    参数描述默认
    data数据源nullselectData选中的数据''pickerStyle详见样式DefaultPickerStyle()onChanged选择器发生变动 return (String data)nullonConfirm选择器提交 return (String data)null

    内置数据

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

    多项选择器

    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    示例代码

      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.showMultiplePicker(
          context,
          data: timeData,
          selectData: timeData2Select,
          suffix: ['', '时', '分', '秒'],
          onConfirm: (p) {
            print('longer >>> 返回数据类型:${p.map((x) => x.runtimeType).toList()}');
          },
        );
      }
    
    参数描述默认
    data数据源nullselectData选中的数据''suffixitem后缀nullpickerStyle详见样式DefaultPickerStyle()onChanged选择器发生变动 return (List data)nullonConfirm选择器提交 return (List data)null

    时间选择器

    • 16种模式「年月日时分秒」
    • 自定义后缀
    • 最大|最小 时间
    • 自定义显示样式
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    简单使用..

    Widget demo() {
        return FlatButton(
        onPressed: () {
          Pickers.showDatePicker(
            context,
            onConfirm: (p) {
              print('longer >>> 返回数据:$p');
            },
            // onChanged: (p) => print(p),
          );
        },
        child: Text('Demo'));
    }
    

    更多方法.

        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),
        );
    
    参数描述默认
    mode时间选择器所显示样式 16 种时间样式DateMode.YMDselectDataPDuration()初始化选中时间默认现在:PDuration.now()minDatePDuration()最小时间PDuration(year: 1900)maxDatePDuration()最大时间PDuration(year: 2100)suffix每列时间对应的单位Suffix.normal()pickerStyle详见样式DefaultPickerStyle()onChanged选择器发生变动 return (PDuration data)nullonConfirm选择器提交 return (PDuration data)null

    参数说明

    • PDuration()
        // 可以自定义设置年月日时分秒
        PDuration(year: 2020, month: 1, day: 4, hour: 12, minute: 40, second: 36);
        // 设置DateTime类型
        PDuration.parse(DateTime.parse('20210139'));
        PDuration.now();
    
    • 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
      }
    

    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时之后的时间

    样式

    内置样式

    • 以下4种样式是使用 PickerStyle 类进行封装的。
    • 都内置了夜间模式,如 NoTitleStyle.dark()
    • 除了NoTitleStyle, 其它的样式可以传入
      • haveRadius: 是否圆角
      • title: 标题
      • color: 确定按钮颜色
    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级
    默认样式:DefaultPickerStyle()默认样式(暗色):DefaultPickerStyle.dark()flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级无标题样式:NoTitleStyle()无标题样式(暗色):NoTitleStyle.dark()flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级关闭按钮样式:ClosePickerStyle()关闭按钮样式(暗色):ClosePickerStyle.dark()flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级圆角按钮样式:RaisedPickerStyle()圆角按钮样式(暗色):RaisedPickerStyle.dark()

    自定义样式

    flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    /// [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]  选择器的文字颜色 默认黑色
    /// [backgroundColor]  选择器的背景颜色 默认白色
    /// [headDecoration] 头部Container 的Decoration   默认:BoxDecoration(color: Colors.white)
    
    class PickerStyle {}
    

    License

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


    起源地下载网 » flutter 选择器库,包括日期及时间选择器(可设置范围)、单项选择器(可用于性别、民族、学历、星座、年龄、身高、体重、温度等)、城市地址选择器(分省级、地级

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元