How to change background color of TabBar without changing the AppBar in flutter? How to change background color of TabBar without changing the AppBar in flutter? dart dart

How to change background color of TabBar without changing the AppBar in flutter?


Create a simple Widget for this, cannot be simpler:

class ColoredTabBar extends Container implements PreferredSizeWidget {  ColoredTabBar(this.color, this.tabBar);  final Color color;  final TabBar tabBar;  @override  Size get preferredSize => tabBar.preferredSize;  @override  Widget build(BuildContext context) => Container(    color: color,    child: tabBar,  );}


You can change the color of the TabBar by changing the Theme primaryColor like that:

return MaterialApp(      theme: ThemeData(        brightness: Brightness.light,        primaryColor: Colors.pink[800], //Changing this will change the color of the TabBar        accentColor: Colors.cyan[600],      ),      home: DefaultTabController(        length: 3,        child: Scaffold(          appBar: AppBar(            bottom: TabBar(              indicatorColor: Colors.lime,              tabs: [                Tab(icon: Icon(Icons.directions_car)),                Tab(icon: Icon(Icons.directions_transit)),                Tab(icon: Icon(Icons.directions_bike)),              ],            ),            title: Text('Tabs Demo'),          ),          body: TabBarView(            children: [              Icon(Icons.directions_car),              Icon(Icons.directions_transit),              Icon(Icons.directions_bike),            ],          ),        ),      ),    );

If you are not using it in an AppBar you could wrap the TabBar in a Material widget and set the color attribute, like that:

class TabBarDemo extends StatelessWidget {  @override  Widget build(BuildContext context) {    return MaterialApp(      home: Scaffold(        appBar: AppBar(          title: Text('Tabs Demo'),        ),        body: DefaultTabController(          length: 3,          child: Column(            children: <Widget>[              Container(                constraints: BoxConstraints(maxHeight: 150.0),                child: Material(                  color: Colors.indigo,                  child: TabBar(                    tabs: [                      Tab(icon: Icon(Icons.directions_car)),                      Tab(icon: Icon(Icons.directions_transit)),                      Tab(icon: Icon(Icons.directions_bike)),                    ],                  ),                ),              ),              Expanded(                child: TabBarView(                  children: [                    Icon(Icons.directions_car),                    Icon(Icons.directions_transit),                    Icon(Icons.directions_bike),                  ],                ),              ),            ],          ),        ),      ),    );  }}


Change Background Color of TabBar in Flutter..

Simply use TabBar in Body of Scaffold, wrap it with Column Widget so that, you can use both without any issue. Wrap TabBar with Container widget to change the tab color.In this way you can change the color of Tab bar in FLutter.

Here's the sample Code...

   Scaffold(       appBar: AppBar(       backgroundColor: const Color(0xFF3baee7),       title: Text("Jobs"),        ),      body: Column(      // Column         children: <Widget>[          Container(            color: Colors.deepOrangeAccent,        // Tab Bar color change             child: TabBar(           // TabBar             controller: tabController,             unselectedLabelColor: Colors.lightBlue[100],             labelColor: const Color(0xFF3baee7),             indicatorWeight: 2,             indicatorColor: Colors.blue[100],             tabs: <Widget>[                              Tab(                 text: "All Jobs",               ),               Tab(                 text: "Most Recent",               ),               Tab(                 text: "Saved Jobs",               )             ],           ),         ),         Expanded(             flex: 3,             child: TabBarView(         // Tab Bar View             physics: BouncingScrollPhysics(),             controller: tabController,             children: <Widget>[AllJobScreen(), AllJobScreen(), AllJobScreen()],               ),            ),         ],    ),  );