Flutter - вызов функции из другого виджета - PullRequest
0 голосов
/ 21 апреля 2020

Я разрабатываю приложение с нижней панелью навигации, где я могу перейти к 2 экранам. В нижней панели навигации у меня есть кнопка с плавающим действием от этой кнопки с плавающим действием, я буду вызывать функцию в другом виджете (findQuakes ()), но я не могу вызвать функцию findQuakes () из моей кнопки с плавающим действием. Это виджет нижней панели навигации, где я буду вызывать функцию findQuakes ():

import 'dart:async';

import 'package:flutter/material.dart';
import 'package:erdbeben/models/quake.dart';
import 'package:erdbeben/network/network.dart';
import 'package:erdbeben/ui/earthquakeMapPage.dart';
import 'package:erdbeben/ui/earthquakeListPage.dart';

class BottomNavigationBarController extends StatefulWidget {
  @override
  _BottomNavigationBarControllerState createState() => _BottomNavigationBarControllerState();
}

class _BottomNavigationBarControllerState extends State<BottomNavigationBarController> {
  int _currentPageNumber;
  final List<Widget> pages = [
    EarthquakeMap(),
    EarthquakeList(),
  ];
  Widget _currentPage;
  final PageStorageBucket _bucket = PageStorageBucket();

  @override
  void initState() {
    _currentPageNumber = 0;
    _currentPage = EarthquakeMap();
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: PageStorage(bucket: _bucket, child: _currentPage),
      floatingActionButton: FloatingActionButton(
          onPressed: () {
            setState(() {
              EarthquakeMapState().findQuakes();
            });
          },
          child: Text("2.5+")),
      floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked,
      bottomNavigationBar: BottomNavigationBar(
        items: [
          BottomNavigationBarItem(
            icon: Icon(Icons.public),
            title: Text('Karte'),
          ),
          BottomNavigationBarItem(
            icon: Icon(Icons.dehaze),
            title: Text('Liste'),
          ),
        ],
        onTap: (int index) => _showPage(index),
      ),
    );
  }

  void _showPage(int index) {
    setState(() {
      switch (index) {
        case 0:
          _currentPage = EarthquakeMap();
          _currentPageNumber = 0;
          break;
        case 1:
          _currentPage = EarthquakeList();
          _currentPageNumber = 1;
          break;
      }
    });
  }
}

И это StatefulWidget с функцией findQuakes ():

import 'dart:async';

import 'package:flutter/material.dart';
import 'package:erdbeben/models/quake.dart';
import 'package:erdbeben/network/network.dart';
import 'package:google_maps_flutter/google_maps_flutter.dart';
import 'package:erdbeben/ui/bottomNavigationBarController.dart';

class EarthquakeMap extends StatefulWidget {
  @override
  State<StatefulWidget> createState() => new EarthquakeMapState();
}

class EarthquakeMapState extends State<EarthquakeMap> {
  Future<Quake> quakesData;
  List<Marker> _earthquakeList = <Marker>[];
  Completer<GoogleMapController> _controller = Completer();

  @override
  void initState() {
    quakesData = Network().getAllQuakes();
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Stack(
        children: <Widget>[_buildEarthquakeMap(context)],
      ),
    );
  }

  _buildEarthquakeMap(BuildContext context) {
    return Container(
      width: MediaQuery.of(context).size.width,
      height: MediaQuery.of(context).size.height,
      child: GoogleMap(
        mapType: MapType.hybrid,
        zoomControlsEnabled: false,
        onMapCreated: (GoogleMapController controller) {
          _controller.complete(controller);
        },
        initialCameraPosition: CameraPosition(target: LatLng(52.519735, 13.4046413)),
        markers: Set<Marker>.of(_earthquakeList),
      ),
    );
  }

  findQuakes() {
    setState(() {
      _earthquakeList.clear();
      _handleResponse();
    });
  }

  void _handleResponse() {
    setState(() {
      quakesData.then((quakes) => [
            quakes.features.forEach((quake) => [
                  _earthquakeList.add(Marker(
                      markerId: MarkerId(quake.id),
                      infoWindow: InfoWindow(title: quake.properties.mag.toString(), snippet: quake.properties.place),
                      icon: BitmapDescriptor.defaultMarkerWithHue(BitmapDescriptor.hueMagenta),
                      position: LatLng(quake.geometry.coordinates[1], quake.geometry.coordinates[0]),
                      onTap: () {}))
                ])
          ]);
    });
  }
}

Как я могу вызвать функцию findQuakes () из BottomNavigationBarController?

Кто-нибудь может мне помочь, я не нашел решения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...