zoukankan      html  css  js  c++  java
  • 对flutter中,ExpsionPanel的简单改造

    因为项目有大量的下拉面板,而默认的组件(默认的padding、颜色、大小)不是我们UI设计上想要的,但是每个地方都要去改又很麻烦。于是我就想,可以对这个组件进行定制化改造,传入一些颜色、参数、图标大小之类的参数(当然还有其他方法,比如继承默认组件,然后根据ui设计进行兼容开发),使其符合我们的UI设计,并且减少时间研究此组件的时间(因为项目分三个人开发)

    研究了下该组件的源码,对其进行了以下改造:

    ExpansionPanelCustomList(
              animationDuration: Duration(milliseconds: 500),
              expansionCallback: (panelIndex, isExpanded) {
                allPlanListBloc.caculateWholePlanHeight(panelIndex);
                isAllExpanded = isExpanded;
                eventBuses.fire(WholeExpanded(isExpanded));
                setState(() {
                  isHwolePanel = true;
                  currentPanelIndex =
                      (currentPanelIndex != panelIndex) ? panelIndex : -1;
                });
              },
             //就是传了个parms参数,如果不传都有默认值
              parms: {
                'type': 'custom',//用默认的,考虑到不影响默认的样式
                'backgroundcolor': 0xffff7200,//下拉的背景颜色
                'iconcolor': 0xffffffff,//下拉icon的颜色
                'iconsize': 36.0,//下拉icon的大小 
              },
              children: mList.map((i){
                    return ExpansionPanelCustom(
                      headerBuilder: (context,isExpanded){
                         return Container();
                      },
                      body:Container(),
                      isExpanded: currentPanelIndex==i,
                    );
                  }).toList(),
                
    ),

      

    改造完的效果图:

    以下是详细的做法:

    1、去组件库拷贝这两个文件到ui/widgets下

    2、根据具体ui设计修改源码

    3、使用:导入放文件的位置

    使用代码参考以上实例

  • 相关阅读:
    Spring HTTP Service
    Nexus搭建Maven私服
    虚拟机Class文件结构笔记
    JVM内存区域与内存溢出异常
    深入学习虚拟机类加载过程
    虚拟机常用的内存查看与分析工具
    对Java内存模型即JMM的理解
    通过Redux源码学习基础概念一:简单例子入门
    跟着官网的例子学Reacjs (一)FilterableProductTable
    es6继承 vs js原生继承(es5)
  • 原文地址:https://www.cnblogs.com/qiufang/p/11303597.html
Copyright © 2011-2022 走看看