问题
How to change background color of TabBar without changing the AppBar in flutter? The TabBar does not have a BG proprety, is there a workaround?
回答1:
You can change the color of the TabBar by changing the Theme primaryColor like that:
return new MaterialApp(
theme: new ThemeData(
brightness: Brightness.light,
primaryColor: Colors.pink[800], //Changing this will change the color of the TabBar
accentColor: Colors.cyan[600],
),
home: new DefaultTabController(
length: 3,
child: new Scaffold(
appBar: new AppBar(
bottom: new TabBar(
indicatorColor: Colors.lime,
tabs: [
new Tab(icon: new Icon(Icons.directions_car)),
new Tab(icon: new Icon(Icons.directions_transit)),
new Tab(icon: new Icon(Icons.directions_bike)),
],
),
title: new Text('Tabs Demo'),
),
body: new TabBarView(
children: [
new Icon(Icons.directions_car),
new Icon(Icons.directions_transit),
new 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 new MaterialApp(
home: new Scaffold(
appBar: new AppBar(
title: new Text('Tabs Demo'),
),
body: new DefaultTabController(
length: 3,
child: new Column(
children: <Widget>[
new Container(
constraints: BoxConstraints(maxHeight: 150.0),
child: new Material(
color: Colors.indigo,
child: new TabBar(
tabs: [
new Tab(icon: new Icon(Icons.directions_car)),
new Tab(icon: new Icon(Icons.directions_transit)),
new Tab(icon: new Icon(Icons.directions_bike)),
],
),
),
),
new Expanded(
child: new TabBarView(
children: [
new Icon(Icons.directions_car),
new Icon(Icons.directions_transit),
new Icon(Icons.directions_bike),
],
),
),
],
),
),
),
);
}
}
回答2:
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,
);
}
回答3:
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()],
),
),
],
),
);
来源:https://stackoverflow.com/questions/50566868/how-to-change-background-color-of-tabbar-without-changing-the-appbar-in-flutter