ChangeNotifier 不更新小部件

时间:2021-04-13 08:03:32

标签: flutter provider flutter-change-notifier

每次将新元素(位置)添加到数据库时,我都会尝试更新下面的 listView,但是 它仅在我关闭并重新打开应用程序时更新,但不会在用户导航到 LocationHistory 页面时更新

class LocationHistory extends StatefulWidget {


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

class _LocationHistoryState extends State<LocationHistory> {


  Widget build(BuildContext context) {


            return Scaffold(

              appBar: AppBar(
       
                leading: new IconButton(
                  icon: Icon(Icons.arrow_back),
                  onPressed: () => Navigator.of(context).pop(),
                ),
                title: Text("Saved Locations"),


              ),

              body: Consumer<LocationHistoryModel>(
                  builder: (context, locationHistoryModel, child){
                  return ListView.builder(
                  itemCount: locationHistoryModel.currentUserLocations.length,
                  itemBuilder: (context, index) =>
                      Column(
                        children: <Widget>[
                          buildListTile(
                            address: locationHistoryModel
                                .currentUserLocations[index].address,
                            createdAt: locationHistoryModel
                                .currentUserLocations[index].createdAt,
                            inOut: locationHistoryModel
                                .currentUserLocations[index].inOut,
                          ),
             


                        ],
                      )

              );}

            ),);
        







  }
}

我使用notifyListeners通知列表重建自身的locationHistoryModel

class LocationHistoryModel extends ChangeNotifier{

  final locationHistory = LocationHistoryRep();
  List currentUserLocations =[];
  User _user;


  set user(User value) {
    _user = value;
  }

  User get user => _user;

  LocationHistoryModel () {

    getLocationHistory();

  }



  getLocationHistory() async{

    var locationsHistory = await locationHistory.getAllSavedLocations();

    List allUsersLocations = locationsHistory["data"] ;

    for(int i =0; i<allUsersLocations.length;i++){

           if(allUsersLocations[i]["userId"]==_user.id){
             currentUserLocations.add(LocationElement.fromJson(allUsersLocations[i]));
           }
    }
    notifyListeners();

    return currentUserLocations;



  }

  setLocation({String address, String inOut}) async{

     await locationHistory.addCurrentLocation(address: address,inOut: inOut,userId: _user.id);
    notifyListeners();

  }

当我导航到列表时,我尝试在此处更新列表的小部件未找到任何更改

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  GoogleMapController mapController;

  void _onMapCreated(GoogleMapController controller) {
    mapController = controller;
  }


  @override
  void initState() {
    super.initState();
    Provider.of<AuthModel>(context, listen: false).getUser();


  }



  @override
  Widget build(BuildContext context) {
    Size size = MediaQuery.of(context).size;
    final location = Provider.of<Location>(context);
    final locationHistory = Provider.of<LocationHistoryModel>(context);



    return location.currentLocation == null ? Scaffold(body: CircularIndicator()): Scaffold(

      appBar: AppBar(
        centerTitle: true,
          backgroundColor: Colors.orange,
        title: Center(child: Text('Remote Tracker')),


      ),

      ),
      floatingActionButton: new FloatingActionButton(
        backgroundColor: Colors.orange,
        child: const Icon(Icons.location_on),
        onPressed: () async{

          showDialog(context: context,
              builder: (BuildContext context){
                return AdvanceCustomAlert(
                  location.address,
                      () async{
                    await locationHistory.setLocation(address: location.address,inOut: "out");
                    Navigator.of(context).push(MaterialPageRoute(
                      builder: (context) => LocationHistory(),
                    // here when navigating to LocationHistory the list is not updating
                    ));
                    },
                      () async{
                    await locationHistory.setLocation(address: location.address,inOut: "in");
                    Navigator.of(context).pop();

                    },
                );
              }
          );// Add your onPressed code here!
        },
      ),
      floatingActionButtonLocation:
      FloatingActionButtonLocation.centerFloat,
      bottomNavigationBar: new BottomAppBar(
        color: Colors.white,

      ),
        body: Container(
          width: size.width,
          height: size.height,
          child: Stack(
            alignment: Alignment.centerRight,
            children: <Widget>[
              GoogleMap(
                onMapCreated: _onMapCreated,
                myLocationEnabled: true,
                initialCameraPosition: CameraPosition(
                  target: LatLng(location.currentLocation.latitude,location.currentLocation.longitude),
                  zoom: 14.0,
                ),
              ),



            ],
          ),
        ),

    );
  }
}

0 个答案:

没有答案