Flutter Cupertino bottom_tab_bar: 'Метод' method 'был вызван на null'
В моем приложении есть панель cupertino bottom_tab_bar, но каждый раз, когда я нажимаю один из значков, чтобы изменить страницу, консоль отладки показывает:
════════ Исключение, зафиксированное жестом ═════════════════════════════════════ ═════
Метод jumpToPage был вызван с нулевым значением.
Получатель: ноль
Пробовал позвонить: jumpToPage(2)
═══════════════════════════════════════════════════════════════════════════════
и это не меняет страницу.
Мой код Dart:
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:fluttershare/pages/activity_feed.dart';
import 'package:fluttershare/pages/profile.dart';
import 'package:fluttershare/pages/search.dart';
import 'package:fluttershare/pages/timeline.dart';
import 'package:fluttershare/pages/upload.dart';
import 'package:google_sign_in/google_sign_in.dart';
final GoogleSignIn googleSignIn = GoogleSignIn();
class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}
class _HomeState extends State<Home> {
bool isAuth = false;
PageController pageController;
int pageIndex = 0;
@override
void initState() {
super.initState();
pageController = PageController();
// Detects when user signed in
googleSignIn.onCurrentUserChanged.listen((account) {
handleSignIn(account);
}, onError: (err) {
print('Error signing in: $err');
});
// Reauthenticate user when app is opened
googleSignIn.signInSilently(suppressErrors: false).then((account) {
handleSignIn(account);
}).catchError((err) {
print('Error signing in: $err');
});
}
handleSignIn(GoogleSignInAccount account) {
if (account != null) {
print('User signed in!: $account');
setState(() {
isAuth = true;
});
} else {
setState(() {
isAuth = false;
});
}
}
@override
void dispose() {
pageController.dispose();
super.dispose();
}
login() {
googleSignIn.signIn();
}
logout() {
googleSignIn.signOut();
}
onPageChanged(int pageIndex) {
setState(() {
this.pageIndex = pageIndex;
});
}
onTap(int pageIndex) {
pageController.jumpToPage(
pageIndex,
);
}
Scaffold buildAuthScreen() {
return Scaffold(
body: PageView(
children: <Widget>[
Timeline(),
ActivityFeed(),
Upload(),
Search(),
Profile(),
],
controller: pageController,
onPageChanged: onPageChanged,
physics: NeverScrollableScrollPhysics(),
),
bottomNavigationBar: CupertinoTabBar(
currentIndex: pageIndex,
onTap: onTap,
activeColor: Theme.of(context).primaryColor,
items: [
BottomNavigationBarItem(icon: Icon(Icons.whatshot)),
BottomNavigationBarItem(icon: Icon(Icons.notifications_active)),
BottomNavigationBarItem(
icon: Icon(
Icons.photo_camera,
size: 35.0,
),
),
BottomNavigationBarItem(icon: Icon(Icons.search)),
BottomNavigationBarItem(icon: Icon(Icons.account_circle)),
]),
);
// return RaisedButton(
// child: Text('Logout'),
// onPressed: logout,
// );
}
Scaffold buildUnAuthScreen() {
return Scaffold(
body: Container(
decoration: BoxDecoration(
gradient: LinearGradient(
begin: Alignment.topRight,
end: Alignment.bottomLeft,
colors: [
Theme.of(context).accentColor,
Theme.of(context).primaryColor,
],
),
),
alignment: Alignment.center,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Text(
'FlutterShare',
style: TextStyle(
fontFamily: "Signatra",
fontSize: 90.0,
color: Colors.white,
),
),
GestureDetector(
onTap: login,
child: Container(
width: 260.0,
height: 60.0,
decoration: BoxDecoration(
image: DecorationImage(
image: AssetImage(
'assets/images/google_signin_button.png',
),
fit: BoxFit.cover,
),
),
),
)
],
),
),
);
}
@override
Widget build(BuildContext context) {
return isAuth ? buildAuthScreen() : buildUnAuthScreen();
}
}
Версия Flutter: уже актуальна. Flutter уже обновлен на бета-версии канала Flutter 1.14.6 • бета-версия канала • https://github.com/flutter/flutter.gitFramework • версия fabeb2a16f (4 недели назад) • 28.01.2020 07:56:51 -0800 Engine • версия c4229bfbba Tools • Dart 2.8.0 (сборка 2.8.0-dev.5.0 fc3af737c7)
1 ответ
Прежде всего, я бы посоветовал не создавать метод с именем onTap()
для поддержания хорошей практики.
В вашем случае, в вашем случае вы не указываете и не предоставляете pageIndex
значение, когда вы вызываете метод в своем onTap
собственность CupertinoTabBar
Виджет. Это должно быть правильным способом и также должно решить проблему
bottomNavigationBar: CupertinoTabBar(
currentIndex: pageIndex,
onTap: onTap(pageIndex),
//rest of your code
поскольку вы не предоставляете pageIndex
, он принимает значение как null и пытается вызвать jumpToPage
для нулевого значения.