#flutter #transparency #flutter-appbar
#flutter #прозрачность #flutter-панель приложений
Вопрос:
Я пытаюсь создать макет flutter с прозрачной панелью приложений и нижней панелью приложений. Тем не менее, я хочу иметь возможность перемещаться между вкладками. Проблема в том, что у меня могут быть вкладки с возможностью прокрутки, но тело не находится под панелями приложений. Или у меня может быть тело под панелями приложений, но вкладки недоступны для прокрутки.
Я уже пробовал реализацию с использованием Stack(), а не Scaffold() . Однако я думаю, что это помещает TabBarView перед панелями приложений из-за невозможности различать панели тела и приложения.
Это код, в котором панели приложений не видны:
class _AppStateTab extends State<App>{
@override
Widget build(BuildContext context) {
return MaterialApp(
home: DefaultTabController(
length: 3,
child: Stack(
children: <Widget>[
Positioned(
top: 0.0,
left: 0.0,
right: 0.0,
child: AppBar(
backgroundColor: Colors.transparent,
elevation: 0.0,
actions: <Widget>[
IconButton(
icon: Icon(Icons.search),
color: Colors.white,
onPressed: () {},
),
IconButton(
icon: Icon(Icons.cached),
color: Colors.white,
onPressed: () {},
),
],
),
),
Positioned(
bottom: 0.0,
left: 0.0,
right: 0.0,
child: BottomAppBar(
color: Colors.transparent,
elevation: 0.0,
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
IconButton(
icon: Icon(Icons.dialpad),
color: Colors.white,
onPressed: (){},
),
IconButton(
icon: Icon(Icons.camera_alt),
color: Colors.white,
onPressed: (){},
),
IconButton(
icon: Icon(Icons.edit),
color: Colors.white,
onPressed: (){},
),
],
),
),
),
TabBarView(
children: <Widget>[
Calculator(),
Camera(),
Solution(),
],
)
],
),
),
);
}
}
И это код, в котором тело не перемещается под панелями приложений:
@override
Widget build(BuildContext context){
return Scaffold(
appBar: AppBar(
title: Text('data'),
backgroundColor: Colors.transparent,
elevation: 0.0,
),
body: TabBarView(
controller: _tabController,
children: _tabList,
),
bottomNavigationBar: BottomAppBar(
color: Colors.transparent,
elevation: 0.0,
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
IconButton(
icon: Icon(Icons.dialpad),
color: Colors.white,
onPressed: (){
_tabController.animateTo(0);
},
),
IconButton(
icon: Icon(Icons.camera_alt),
color: Colors.white,
onPressed: (){
_tabController.animateTo(1);
},
),
IconButton(
icon: Icon(Icons.edit),
color: Colors.white,
onPressed: (){
_tabController.animateTo(2);
},
),
],
),
),
);
Ответ №1:
Хорошо, просто обновление, мне удалось исправить мою проблему. Я не понимал, что порядок внутри стека определяет, так сказать, его уровень. Первый элемент находится в самом конце, а каждый другой элемент находится на один слой впереди. Итак, чтобы исправить это, все, что я сделал, это переставил тело так, чтобы оно было первым элементом, а позиции следовали за ним. Это позволило создать приложение с возможностью прокрутки с прозрачными панелями приложений.