


最近在使用遇到几组需要自定义的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
tabs;
很明显这个是可以随意自定义的,
我们先定义好 两种切换状态的Widget
- getAllTabs() {
- return
[ - 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 你可以使用普通text
- UIText(
- 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;
- // 封装的刷新 一般对应setState
- controller.update();
- },