flutter 自定义TabBar +自定义Indicator

主要是顶部TabBar+TabView的实现,左右滑动或者点击切换。先上效果图

给每个Tab有个初始的背景颜色,Indicator是粉色的框

首先初始Tab数据,构建初始背景颜色的时候,用到了颜色混合BlendMode,详情可以百度,为了选择时indicator能上色

//用于监听Tab菜单切换
  TabController _tabController;
  //Tab 标签
  List<Widget> _tabs;

_getTabData(){
    _tabs = [];
    int day = serverTime.day;
    int month = serverTime.month;

    for(int i = 0;i<7;i++){
      tabs.add(_getTabText(month, day++));
    }
  }

  //获取tab控件
  Widget _getTabText(int month,int day){
    String tag = "";
    if(( month == DateTime.now().month )&& (day == DateTime.now().day)){
      tag = "今天";
    }else if(( month == DateTime.now().month )&&(day-1) == DateTime.now().day){
      tag = "明天";
    }else{
      tag = "${month.toString()}月${day.toString()}日";
    }
    return  Container(
      child: Text(tag),
      decoration:
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值