Flutter自定义tabbar任意样式
场景描述
最近在使用遇到几组需要自定义的tabbar或者类似组件,在百度查询资料中通常,需要自定义
TabIndicator extends Decoration
比如上图中的带圆角的指示器这样实现
就很麻烦, 搜出来的相关也是在此之处上自己画,主要再遇到一个稍微特殊的,比如带背景切换的,带特殊图形或者path的,费事费力。
有经验同学可能就会相当那我干脆直接用radiogroup做单选然后去关联page切换。但再劳神之前,
不如点进去tabbar看一下,flutter精髓之一就是万物皆为widget,局部子的自定义正式优势所在,
思路描述
/// The length of this list must match the [controller]'s [TabController.length]/// and the length of the [TabBarView.children] list.final List<Widget> tabs;
很明显这个是可以随意自定义的,
我们先定义好 两种切换状态的Widget
getAllTabs() {return <Tab>[for (int i = 0; i < controller.tabs.length; i++)Tab(child: Stack(children: [ImageUtils.assetImage(isSelect? "bg_data_tab_select": "bg_data_tab_unselect",width: 72.w,height: 34.w,fit: BoxFit.cover),// 这个是我自定义背景 文字widget 你可以使用普通textUIText(widgetWidth: 72.w,widgetHeight: 34.w,fontWeight: FontWeight.w500,text: controller.tabs[i],fontSize: 18.w,textAlign: TextAlign.center,widgetAlignment: Alignment.center,fontColor: isSelect? const Color(0xFF202437): Colors.white,letterSpacing: -0.04,)],),),];
此时我们只需要得到isSelect值,改变的时候动态去刷新state即可 将前面的isSelect 改为controller.tabIndex =i即可
TabBar(onTap: (index) {// 赋值controller.tabIndex = index;// 封装的刷新 一般对应setStatecontroller.update();
},