flutter:获取 widget 的变量类型。[变量]

flutter: get variable type of widget.[variable]

提问人:kleber 提问时间:11/17/2023 最后编辑:Victor Eronmoselekleber 更新时间:11/17/2023 访问量:33

问:

我是 flutter 的新手,如果我的问题是基本的,那么对不起。该类在类内部调用,它有两个属性,其中一个是 。TelaDadosTelaPrecosnumeroSerie

在类中,我可以使用 获取属性的值。_TelaDadosnumeroSeriewidget.numeroSerie

当我单击屁股和 时,有一个切换屁股。Índice de preçosIPCA - var. mensal

我创建了一个名为的顶级变量,我想用 填充 .numeroSeriewidget.numeroSerie

只有当切换按钮切换到 1 () 时,我才需要使用。numeroSerieSim

我可以填充,因为我可以在屏幕上方和 Android Studio 控制台中将其打印出来。但是当我尝试在称为 和的顶级函数中打印 的值时,它会打印 .numeroSerienumeroSeriegetJsonFromRestAPI2onStartnull

我需要在此函数中使用该变量,以便放置后台服务(我将使用 API url 中的数字)并测试是否有必要生成本地通知以通知来自 API 的新值。

我看了很多网站,尝试了很多东西:,把变量放在.这是我的代码(有一个内部函数即将为 null):FutureBuilderinitStateprint("onStart: $numeroSerie")onStart

import 'package:flutter/material.dart';
import 'package:permission_handler/permission_handler.dart';
import 'dart:async';
import 'dart:convert';
import 'dart:ui';
import 'package:flutter_background_service/flutter_background_service.dart';
import 'package:flutter_background_service_android/flutter_background_service_android.dart';
import 'package:http/http.dart' as http;
import 'package:intl/intl.dart' hide TextDirection;
import 'package:toggle_switch/toggle_switch.dart';

void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  await Permission.notification.isDenied.then(
        (value){
      if(value){
        Permission.notification.request();
      }
    },
  );

  runApp(MaterialApp(
    home: Home(),
    debugShowCheckedModeBanner: false,
  ));
}



class Home extends StatefulWidget {
  const Home({super.key});

  @override
  State<Home> createState() => _HomeState();
}

class _HomeState extends State<Home> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Escolha o assunto"),
      ),
      body: Container(
        child: Column(
          children: <Widget>[
            Padding(
              padding: EdgeInsets.all(10),
              child: Center(
                child: ElevatedButton(
                    style: ButtonStyle(
                        fixedSize: MaterialStateProperty.all(Size(200, 40))
                    ),
                    onPressed: (){
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => TelaPrecos()
                          )
                      );
                    },
                    child: Text("Índices de preços")
                ),
              ),
            )
          ],
        ),
      ),
    );
  }
}

class TelaPrecos extends StatefulWidget {

  const TelaPrecos({super.key});
  @override
  State<TelaPrecos> createState() => _TelaPrecosState();
}

class _TelaPrecosState extends State<TelaPrecos> {
  bool _isLoading = false;
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("Índices de preços"),
      ),
      body: Container(
        child: Column(
          children: <Widget>[
            Padding(
              padding: EdgeInsets.all(10),
              child: Center(
                child: ElevatedButton(
                    style: ButtonStyle(
                        fixedSize: MaterialStateProperty.all(Size(200, 40))
                    ),
                    onPressed: (){
                      Navigator.push(
                          context,
                          MaterialPageRoute(
                              builder: (context) => TelaDados(numeroSerie: "433", nomeSerie: "IPCA - % mensal")
                          )
                      );
                    },
                    child: Text("IPCA - var. mensal")
                ),
              ),

            ),
          ],
        ),
      ),
    );
  }
}


class IPCA {
  final DateTime data;
  final double valor;

  IPCA(this.data, this.valor);
  factory IPCA.fromJson(Map<String, dynamic> parsedJson){
    return IPCA(
      DateFormat('MM/yyyy').parse(parsedJson['data'].substring(3)),
      double.parse(parsedJson['valor']),
    );
  }
}

class TelaDados extends StatefulWidget {
  //const TelaDados({super.key});
  final String numeroSerie;
  final String nomeSerie;
  TelaDados({required this.numeroSerie, required this.nomeSerie});
  @override
  State<TelaDados> createState() => _TelaDados();
}

var numeroSerie;
var service;

Future<void> initializeService() async {
  service = FlutterBackgroundService();
  await service.configure(iosConfiguration: IosConfiguration(
    autoStart: true,
    onForeground: onStart,
    onBackground: onIosBackground,
  ),
      androidConfiguration: AndroidConfiguration(
          onStart: onStart,
          isForegroundMode: true,
          autoStart: true
      )
  );
}

Future<String> getJsonFromRestAPI2() async {
  String url = "https://api.bcb.gov.br/dados/serie/bcdata.sgs.433/dados?formato=json";
  http.Response response = await http.get(Uri.parse(url));
  return response.body;
}

@pragma('vm:registry-point')
Future<bool> onIosBackground(ServiceInstance service) async {
  WidgetsFlutterBinding.ensureInitialized();
  DartPluginRegistrant.ensureInitialized();
  return true;
}

List<IPCA> listaBack = [];
var ultimaDataIPCA;
Future loadIPCAData2() async {
  String jsonString = await getJsonFromRestAPI2();
  final jsonResponse = json.decode(jsonString);
  for (Map<String, dynamic> i in jsonResponse){
    listaBack.add(IPCA.fromJson(i));
  }
  ultimaDataIPCA = listaBack.last.data;
}


@pragma('vm:registry-point')
void onStart(ServiceInstance service) {
  DartPluginRegistrant.ensureInitialized();
  if(service is AndroidServiceInstance){
    service.on("setAsForeground").listen((event) {
      service.setAsForegroundService();
    });
    service.on("setAsBackground").listen((event) {
      service.setAsBackgroundService();
    });
  }
  service.on("stopService").listen((event) {
    service.stopSelf();
  });

  Timer.periodic(const Duration(seconds: 1), (timer) async {
    if(service is AndroidServiceInstance){
      if(await service.isForegroundService()){
        service.setForegroundNotificationInfo(title: "SCRIPT ACADEMY", content: "sub my channel");
      }
    }
    // perfom some operation on background which is not noticeable to the user everytime
    //print("background service running");
    loadIPCAData2();
    print("background service running $ultimaDataIPCA");
    print("onStart: $numeroSerie");
  });

}

class _TelaDados extends State<TelaDados> {

  Future<String> getJsonFromRestAPI() async {
    //String url = "https://api.bcb.gov.br/dados/serie/bcdata.sgs.433/dados?formato=json";
    String url = "https://api.bcb.gov.br/dados/serie/bcdata.sgs.${widget.numeroSerie}/dados?formato=json";
    http.Response response = await http.get(Uri.parse(url));
    return response.body;
  }

  List<IPCA> chartData = [];

  DateTime startval1 = DateFormat('MM/yyyy').parse('01/2021');
  DateTime endval1 = DateFormat('MM/yyyy').parse('12/2021');

  TextEditingController dateInputEnd = TextEditingController();
  TextEditingController dateInputIni = TextEditingController();

  Future loadIPCAData() async {
    String jsonString = await getJsonFromRestAPI();
    final jsonResponse = json.decode(jsonString);
    setState(() {
      for (Map<String, dynamic> i in jsonResponse){
        chartData.add(IPCA.fromJson(i));
      }
      endval1 = chartData.last.data;
      startval1 = chartData[chartData.length-13].data;
    });
  }

  List<IPCA> itemsBetweenDates({
    required List<IPCA> lista,
    required DateTime start,
    required DateTime end,
  }) {
    var output = <IPCA>[];
    for (var i = 0; i < lista.length; i += 1) {
      DateTime date = lista[i].data;
      if (date.compareTo(start) >= 0 && date.compareTo(end) <= 0) {
        output.add(lista[i]);
      }
    }
    return output;
  }

  @override
  void initState() {
    // TODO: implement initState
    super.initState();
    loadIPCAData();
    numeroSerie = widget.numeroSerie;
  }
  var initialIndex = 0;

  @override
  Widget build(BuildContext context) {

    filtrarDados(){

      dateInputIni.text = DateFormat('MM/yyyy').format(startval1).toString();
      dateInputEnd.text = DateFormat('MM/yyyy').format(endval1).toString();

      DateTime dataIni = DateFormat('MM/yyyy').parse(dateInputIni.text.toString());
      DateTime dataFim = DateFormat('MM/yyyy').parse(dateInputEnd.text.toString());

      late var lista_filtrada = itemsBetweenDates(lista: chartData, start: dataIni, end: dataFim);

      lista_filtrada.sort((a, b){ //sorting in descending order
        return a.data.compareTo(b.data);
      });
      return lista_filtrada;
    }

    return Scaffold(
        appBar: AppBar(
          title: Text("${widget.nomeSerie}"),
        ),
        body: SingleChildScrollView(
            child: Stack(
                children: <Widget>[
                  Container(
                      padding: EdgeInsets.all(40),
                      child: Column(
                        children: <Widget>[
                          ToggleSwitch(
                            initialLabelIndex: initialIndex,
                            totalSwitches: 2,
                            labels: [
                              'Não',
                              'Sim',
                            ],
                            onToggle: (index) async {
                              final service = FlutterBackgroundService();
                              if(index==1){
                                await initializeService();
                                service.startService();
                              } else {
                                service.invoke("stopService");
                              }
                              setState(() {
                                initialIndex = index!;
                              });
                            },
                          ),
                        ],
                      )
                  )
                ]
            )
        )
    );
  }
}

欢迎任何建议!很抱歉打扰。

Flutter 服务 背景 切换

评论


答:

0赞 kleber 11/20/2023 #1

我解决了我的问题:a)我使用了该库并将此代码放在函数中以在本地保存:
shared_preferencesgetJsonFromRestAPInumeroSerie

final prefs = await SharedPreferences.getInstance();
await prefs.setString('numeroSerieSGS', widget.numeroSerie);

b) 我创建了这个函数来读取保存的数据:

Future<String> getStringFromLocalStorage(String key) async {
  final prefs = await SharedPreferences.getInstance();
return prefs.getString(key) ?? '';
}

c) 在函数中,我放置了以下代码来读取数据并归因于变量onStartnumeroSGS

String? numeroSGS = await getStringFromLocalStorage("numeroSerieSGS");