BottomNavigationBar の高さを調整する方法をまとめていきます。
SizedBox で高さを指定する
@override
Widget build(BuildContext context) {
return Scaffold(
body: const Center(
child: Text('BottomNavigationBar'),
),
bottomNavigationBar: SizedBox(
height: 120,
child: BottomNavigationBar(
items: const [
BottomNavigationBarItem(
icon: Icon(Icons.home),
label: 'Home',
),
BottomNavigationBarItem(
icon: Icon(Icons.search),
label: 'Search',
),
BottomNavigationBarItem(
icon: Icon(Icons.settings),
label: 'Settings',
),
],
backgroundColor: Colors.cyan,
)),
);
}
data:image/s3,"s3://crabby-images/308a7/308a70608f11977f26a33020414554bfba1d85d4" alt="SizedBoxで高さ指定"
Container で高さを調整する
Container を利用し、height と padding で高さを調整しています。
@override
Widget build(BuildContext context) {
return Scaffold(
body: const Center(
child: Text('BottomNavigationBar'),
),
bottomNavigationBar: Container(
height: 100,
padding: const EdgeInsets.symmetric(vertical: 10),
decoration: const BoxDecoration(
color: Colors.cyanAccent,
),
child: BottomNavigationBar(
items: const [
BottomNavigationBarItem(
icon: Icon(Icons.home),
label: 'Home',
),
BottomNavigationBarItem(
icon: Icon(Icons.search),
label: 'Search',
),
BottomNavigationBarItem(
icon: Icon(Icons.settings),
label: 'Settings',
),
],
elevation: 0,
backgroundColor: Colors.cyan,
)),
);
}
data:image/s3,"s3://crabby-images/9630a/9630a77ed2ac8fce7cbc51e88b00fa0f5d6abebd" alt="Containerで高さ調整"
label を非表示にした場合の余白を調整する
Label を非表示にした場合に余分な余白ができてしまう場合は、フォントサイズを調整します。
selectedFontSize
と unselectedFontSize
を 0 に設定します。
@override
Widget build(BuildContext context) {
return Scaffold(
body: const Center(
child: Text('BottomNavigationBar'),
),
bottomNavigationBar: BottomNavigationBar(
showSelectedLabels: false,
showUnselectedLabels: false,
selectedFontSize: 0,
unselectedFontSize: 0,
items: const [
BottomNavigationBarItem(
icon: Icon(Icons.home),
label: 'Home',
),
BottomNavigationBarItem(
icon: Icon(Icons.search),
label: 'Search',
),
BottomNavigationBarItem(
icon: Icon(Icons.settings),
label: 'Settings',
),
],
elevation: 0,
backgroundColor: Colors.cyan,
),
);
}
data:image/s3,"s3://crabby-images/6beb2/6beb24bf92196b2ff0f42497108c703826afd22a" alt="左:FontSize調整前 右:FontSize調整後"