Вы можете использовать Rx.combineLatest3
Like эту ссылку для объединения потоков, но, как я понимаю из вашего кода, лучше определить модель следующим образом:
Class MyModel{
PageController pageController;
int currentPage;
bool isLastPage;
...
}
А затем иметь единый поток, который с ним работает.
Изменить: примененная модель к коду
Я изменил код двумя способами.
Первый
Вы можете определить модель и работать с этой моделью, поэтому вам не нужны 3 разных потока, это нормально, если вам всегда нужна версия комбинированного потока, а не каждый из потоков в каких-либо других местах.
Я написал код в одном файле.
import 'package:flutter/material.dart';
import 'package:rxdart/rxdart.dart';
class MyModel {
PageController pageController;
int currentPage;
bool isLastPage;
MyModel({this.currentPage, this.pageController, this.isLastPage});
}
class WelcomeBloc {
var _myModel = PublishSubject<MyModel>();
Stream<MyModel> get getModel => _myModel.stream;
// updatePage(int page) {
// _page.sink.add(page);
// }
// updatePageState(bool state) {
// _lastPage.sink.add(state);
// }
void updateModel(MyModel model) {
_myModel.sink.add(model);
}
dispose() {
_myModel.close();
}
}
final welcomeBloc = WelcomeBloc();
class ViewerWrapper extends StatelessWidget {
@override
Widget build(BuildContext context) {
return StreamBuilder<MyModel>(
stream: welcomeBloc.getModel,
builder: (context, AsyncSnapshot<MyModel> snapshot) {
if (snapshot.hasData) {
MyModel model = snapshot.data;
return PageView(
children: <Widget>[
Page1(),
Page2(),
Login(),
],
onPageChanged: (page) {
model.currentPage = page;
welcomeBloc.updateModel(model);
print(model.currentPage);
// welcomeBloc.updatePage(page + 1);
},
controller: model.pageController,
);
}
return Center(child: CircularProgressIndicator());
});
}
}
Второй
Если вам также нужны другие потоки в других местах и т. on, вы можете комбинировать потоки, вы можете комбинировать их как хотите, перечислять, отображать или заданную модель, я использовал модель (MyModel).
import 'package:flutter/material.dart';
import 'package:rxdart/rxdart.dart';
class MyModel {
PageController pageController;
int currentPage;
bool isLastPage;
MyModel({this.currentPage, this.pageController, this.isLastPage});
}
class WelcomeBloc {
final _controller = PublishSubject<PageController>();
final _page = PublishSubject<int>();
final _lastPage = PublishSubject<bool>();
Stream<MyModel> get combinedStream =>
Rx.combineLatest3(_page, _lastPage, _controller,
(int page, bool isLast, PageController controller) {
return MyModel(
currentPage: page,
isLastPage: isLast,
pageController: controller,
);
});
Stream<PageController> get getController => _controller.stream;
Stream<int> get currentPage => _page.stream;
Stream<bool> get isLastPage => _lastPage.stream;
updatePage(int page) {
_page.sink.add(page);
}
updatePageState(bool state) {
_lastPage.sink.add(state);
}
dispose() {
_controller.close();
_page.close();
_lastPage.close();
}
}
final welcomeBloc = WelcomeBloc();
class ViewerWrapper extends StatelessWidget {
@override
Widget build(BuildContext context) {
return StreamBuilder<MyModel>(
stream: welcomeBloc.combinedStream,
builder: (context, AsyncSnapshot<MyModel> snapshot) {
if (snapshot.hasData) {
MyModel model = snapshot.data;
return PageView(
children: <Widget>[
Page1(),
Page2(),
Login(),
],
onPageChanged: (page) {
welcomeBloc.updatePage(page);
print(model.currentPage);
// welcomeBloc.updatePage(page + 1);
},
controller: model.pageController,
);
}
return Center(child: CircularProgressIndicator());
});
}
}