gpt4 book ai didi

flutter - 如何在 flutter 的两个不同屏幕上使用同一个 bloc?

转载 作者:行者123 更新时间:2023-12-05 07:08:19 25 4
gpt4 key购买 nike

我正在尝试使用 flutter_bloc 将给我带来 firebaseuser 实例的同一个 pad 传递到两个不同的屏幕,主屏幕成功地向我显示了这个问题,当我切换到另一个屏幕时,它会一直等待并且不会从那里开始。

UserBloc 类

class UserBloc extends Bloc {
final _auth_repository = FirebaseAuthApiRespository();

Stream<FirebaseUser> streamFirebase = FirebaseAuth.instance.onAuthStateChanged;
Stream<FirebaseUser> get auhtStatus => streamFirebase;

Future<FirebaseUser> signIn() => _auth_repository.signInFirebase();
signOut() {
_auth_repository.signOut();
}

Future<FirebaseUser> signInFacebook() => _auth_repository.signInFacebook();
signOutFacebook(){
_auth_repository.signOutFacebook();
}


final _cloudFirestoreRepository = CloudFireStoreRepository();
void updateUserData(User user) => _cloudFirestoreRepository.updateUserDataFirestore(user);



@override
// TODO: implement initialState
get initialState => null;

@override
Stream mapEventToState(event) {
// TODO: implement mapEventToState
return null;
}
}

ma​​in.dart

void main() {
WidgetsFlutterBinding.ensureInitialized();
SystemChrome.setEnabledSystemUIOverlays([]);
runApp(MyApp());
}

class MyApp extends StatefulWidget {
MyApp({Key key}) : super(key: key);

@override
_MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
ManagmentStorage managmentStorage = ManagmentStorage();
@override
void initState() {
managmentStorage.createStragoe();
super.initState();
}

Widget build(BuildContext context) {
return MultiBlocProvider(
providers: [
BlocProvider<CameraBloc>(create: (BuildContext context) => CameraBloc()),
BlocProvider<UserBloc>(create: (BuildContext context) => UserBloc()),
],
child: MaterialApp(
darkTheme: ThemeData.dark(),
themeMode: ThemeMode.dark,
debugShowCheckedModeBanner: false,
home: SignInScreen(), //ProfileUserHome(), //
routes: <String, WidgetBuilder>{
'/adddocument': (BuildContext context) => ScreenAddPhoto(),
'/screenimagedetail': (BuildContext context) => ScreenImageDetail()
},
),

);
}
}

屏幕 1:

class ProfileUser extends StatelessWidget {
UserBloc userBloc;

@override
Widget build(BuildContext context) {
userBloc = BlocProvider.of<UserBloc>(context);

return StreamBuilder(
stream: userBloc.auhtStatus,
builder: (BuildContext context, AsyncSnapshot snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.none:
return Center(
child: SpinKitSquareCircle(color: Colors.white),
);
break;

case ConnectionState.waiting:
return Center(
child: SpinKitSquareCircle(color: Colors.white),
);
break;

case ConnectionState.active:
return showPofileData(snapshot);
break;

case ConnectionState.done:
return showPofileData(snapshot);
break;

default:
}
},
);
}
Widget showPofileData(AsyncSnapshot snapshot) {
if (!snapshot.hasData || snapshot.hasError) {
return Stack(
children: <Widget>[
ListView(
children: <Widget>[Text("Usuario no logeado. Haz login")],
),
],
);
} else {
var user = User(
uid: snapshot.data.uid,
name: snapshot.data.displayName,
email: snapshot.data.email,
photoURL: snapshot.data.photoUrl,
);

return Stack(
children: <Widget>[
UserBody(),
Header(
user: user,
)
],
);
}
}
}

屏幕 2:

class ProfileUserHome extends StatelessWidget {
UserBloc userBloc;

@override
Widget build(BuildContext context) {
userBloc = BlocProvider.of<UserBloc>(context);
return Scaffold(
body: StreamBuilder(
stream: userBloc.auhtStatus,
builder: (BuildContext context, AsyncSnapshot snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.none:
return Center(
child: SpinKitSquareCircle(color: Colors.white),
);
break;

case ConnectionState.waiting:
return Center(
child: SpinKitSquareCircle(color: Colors.white),
);
break;

case ConnectionState.active:
return profileuserinfo(snapshot);
break;

case ConnectionState.done:
return profileuserinfo(snapshot);
break;
default:
}
},
),
);
}

Widget profileuserinfo(AsyncSnapshot snapshot) {
if (!snapshot.hasData || snapshot.hasError) {
return Center(child: Text("Usuario no logeado. Haz login"));
} else {
var user = User(
uid: snapshot.data.uid,
name: snapshot.data.displayName,
email: snapshot.data.email,
photoURL: snapshot.data.photoUrl,
);
return ListView(children: <Widget>[
HeaderProfileUserHome(user: user)
]);
}
}
}

底部导航栏:

class NavBarUser extends StatefulWidget {
@override
State<StatefulWidget> createState() {
// TODO: implement createState
return _NavBarUser();
}
}

class _NavBarUser extends State<NavBarUser> {
int indexTap = 0;
@override
Widget build(BuildContext context) {
PageController controller = PageController(initialPage: 0, keepPage: true);

void onTapTapped(int index) {
setState(() {
indexTap = index;
controller.animateToPage(index,
duration: Duration(milliseconds: 200), curve: Curves.ease);
});
}

void pageChanged(int index) {
setState(() {
indexTap = index;
});
}

final pageView = PageView(
controller: controller,
onPageChanged: (index) {
pageChanged(index);
},
children: <Widget>[UserHome(), ProfileUserHome()],
);

return MultiBlocProvider(
providers: [
BlocProvider<CameraBloc>(create: (BuildContext context) => CameraBloc()),
BlocProvider<UserBloc>(create: ( BuildContext context) => UserBloc()),

],
child: Scaffold(
body: pageView,
bottomNavigationBar: Theme(
data: Theme.of(context).copyWith(
canvasColor: Colors.black,
primaryColor: Color.fromARGB(230, 226, 80, 116)),
child: BottomNavigationBar(
onTap: (index) {
onTapTapped(index);
},
currentIndex: indexTap,
items: [
BottomNavigationBarItem(icon: Icon(Icons.home), title: Text("")),
BottomNavigationBarItem(
icon: Icon(Icons.person), title: Text("")),
],
),
),
),

);
}
}

登录成功图片:

enter image description here

图像屏幕 1

enter image description here

images screen2 profile 问题来了 :c

enter image description here

我在个人资料屏幕上没有任何显示,当我回到家时也没有显示 enter image description here

enter image description here

enter image description here

enter image description here

最佳答案

你做错了,你使用的是 flutter_bloc 库:

  • 您需要指定事件和状态。
  • 您需要向 Bloc 发送事件
  • 处理 mapEventToState 中的事件
  • 屈服状态

    @覆盖 流 mapEventToState(事件){ //TODO: 实现 mapEventToState 返回空值;

  • 最后,通过 flutter_bloc 库而不是 StreamBuilder 使用 BlocBuilder 小部件来监听状态

该库有一个编写良好的文档和教程,您可以查看 https://bloclibrary.dev/#/gettingstarted


您还在 main.dart 和 NavBarUser 小部件中提供了两次 BLOCS。因此从 NavBarUser 中删除它

MultiBlocProvider(
providers: [
BlocProvider<CameraBloc>(create: (BuildContext context) => CameraBloc()),
BlocProvider<UserBloc>(create: ( BuildContext context) => UserBloc()),

],

关于flutter - 如何在 flutter 的两个不同屏幕上使用同一个 bloc?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61903343/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com