ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Flutter 自定义功能强大的下拉筛选菜单 package

2019-07-23 21:55:45  阅读:937  来源: 互联网

标签:hide 自定义 dropdown dropdownMenuController menu package dropDownHeaderItemStrings 


自定义功能强大的下拉筛选菜单flutter package

  • Custom dropdown header

  • Custom dropdown header item

  • Custom dropdown menu

  • Custom dropdown menu show animation time

  • Control dropdown menu show or hide

如果对您有帮助,麻烦点个关注,您的支持是我持续更新的动力。

导航

  • GIF效果图

  • 如何使用

Gif效果图

分别是仿美团和淘宝的效果图
美团的代码就在这个仓库的example目录下

webp

image


webp

如何使用

由于最近被qiang,所以没有发布到Pub,后续会发布到Pub

1、添加gzx_dropdown_menu package

打开pubspec.yaml文件
添加如下代码

  gzx_dropdown_menu :
    git:
      url: https://github.com/GanZhiXiong/gzx_dropdown_menu.git

添加位置如下图所示

webp

添加后打开Terminal,执行flutter packages get

2、使用

打开本仓库example项目下的gzx_dropdown_menu_test_page.dart文件自己看。

没空编辑文字了,而且说这么多还不如你直接运行下看下效果,然后看下代码,就知道如何使用了。

算了还是简单说下吧!!!  
你只需要将GZXDropDownHeader和GZXDropDownMenu嵌套到你的代码中即可

GZXDropDownHeader

  // 下拉菜单头部
  GZXDropDownHeader(    // 下拉的头部项,目前每一项,只能自定义显示的文字、图标、图标大小修改
    items: [
      GZXDropDownHeaderItem(_dropDownHeaderItemStrings[0]),
      GZXDropDownHeaderItem(_dropDownHeaderItemStrings[1]),
      GZXDropDownHeaderItem(_dropDownHeaderItemStrings[2]),
      GZXDropDownHeaderItem(_dropDownHeaderItemStrings[3], iconData: Icons.filter_frames, iconSize: 18),
    ],    // GZXDropDownHeader对应第一父级Stack的key
    stackKey: _stackKey,    // controller用于控制menu的显示或隐藏
    controller: _dropdownMenuController,    // 当点击头部项的事件,在这里可以进行页面跳转或openEndDrawer
    onItemTap: (index) {      if (index == 3) {
        _scaffoldKey.currentState.openEndDrawer();
        _dropdownMenuController.hide();
      }
    },    // 头部的高度
    height: 40,    // 头部背景颜色
    color: Colors.red,    // 头部边框宽度
    borderWidth: 1,    // 头部边框颜色
    borderColor: Color(0xFFeeede6),    // 分割线高度
    dividerHeight: 20,    // 分割线颜色
    dividerColor: Color(0xFFeeede6),    // 文字样式
    style: TextStyle(color: Color(0xFF666666), fontSize: 13),    // 下拉时文字样式
    dropDownStyle: TextStyle(
      fontSize: 13,
      color: Theme.of(context).primaryColor,
    ),    // 图标大小
    iconSize: 20,    // 图标颜色
    iconColor: Color(0xFFafada7),    // 下拉时图标颜色
    iconDropDownColor: Theme.of(context).primaryColor,
  ),

GZXDropDownMenu

  // 下拉菜单
  GZXDropDownMenu(    // controller用于控制menu的显示或隐藏
    controller: _dropdownMenuController,    // 下拉菜单显示或隐藏动画时长
    animationMilliseconds: 500,    // 下拉菜单,高度自定义,你想显示什么就显示什么,完全由你决定,你只需要在选择后调用_dropdownMenuController.hide();即可
    menus: [
      GZXDropdownMenuBuilder(
          dropDownHeight: 40 * 8.0,
          dropDownWidget: _buildQuanChengWidget((selectValue) {
            _dropDownHeaderItemStrings[0] = selectValue;
            _dropdownMenuController.hide();
            setState(() {});
          })),
      GZXDropdownMenuBuilder(
          dropDownHeight: 40 * 8.0,
          dropDownWidget: _buildConditionListWidget(_brandSortConditions, (value) {
            _selectBrandSortCondition = value;
            _dropDownHeaderItemStrings[1] =
            _selectBrandSortCondition.name == '全部' ? '品牌' : _selectBrandSortCondition.name;
            _dropdownMenuController.hide();
            setState(() {});
          })),
      GZXDropdownMenuBuilder(
          dropDownHeight: 40.0 * _distanceSortConditions.length,
          dropDownWidget: _buildConditionListWidget(_distanceSortConditions, (value) {
            _dropDownHeaderItemStrings[2] = _selectDistanceSortCondition.name;
            _selectDistanceSortCondition = value;
            _dropdownMenuController.hide();
            setState(() {});
          })),
    ],
  )


标签:hide,自定义,dropdown,dropdownMenuController,menu,package,dropDownHeaderItemStrings,
来源: https://blog.51cto.com/13673213/2422954

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有