Как передать данные из метода _callLogs в тело и распечатать их? - PullRequest
0 голосов
/ 18 февраля 2020

Я новичок в использовании флаттерной среды и хочу передать журналы вызовов своему приложению, чтобы я мог их распечатать. Как мне это сделать?

class _QuoteListState extends State<QuoteList> {

   Future<bool>_callLogs() async {
     Iterable<CallLogEntry> entries = await CallLog.get();

   }

 @override
 Widget build(BuildContext context) {
   return Scaffold(
     backgroundColor: Colors.grey[200],
     appBar: AppBar(
       title: Text('Calls Log'),
       centerTitle: true,
       backgroundColor: Colors.purple,
     ),
     body: ListView.builder(
       itemCount: entries.length,
       itemBuilder: (context, index){

       }
     )
   );

Ответы [ 2 ]

0 голосов
/ 18 февраля 2020

Вы можете использовать Future Builder для достижения этой цели.

Следуя минимальному коду, имитируйте ваши условия, чтобы вы могли реализовать его в своем собственном коде.

import 'package:flutter/material.dart';

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

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

class _DeleteWidgetState extends State<DeleteWidget> {
  @override
  void initState() {
    super.initState();
  }

  List<int> _data;

  Future<bool> _callLogs() async {
    await Future.delayed(Duration(seconds: 4));
    _data = [6, 5, 4, 3, 2, 1];
    return true;
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Container(
        child: Center(
          child: FutureBuilder(
            future: _callLogs(),
            builder: (context, snapshot) {
              if (!snapshot.hasError) {
                if (snapshot.data == true) {
                  return ListView.builder(
                    itemCount: _data.length,
                    itemBuilder: (context, index) {
                      return Text(_data[index].toString());
                    },
                  );
                } else {
                  return Text("Whatever when it returns false");
                }
              } else {
                return Text("Something wents wrong");
              }
            },
          ),
        ),
      ),
    );
  }
}
0 голосов
/ 18 февраля 2020

Вы должны получить данные из асинхронной функции c и установить их в локальные переменные, чтобы было удобно вызывать setState внутри _callLogs as, чтобы ваш виджет сохранял состояние и записывал, как показано ниже

   import 'package:call_log/call_log.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(MaterialApp(
    home: LogsList(),
  ));
}

class LogsList extends StatefulWidget {
  @override
  _LogsListState createState() => _LogsListState();
}

class _LogsListState extends State<LogsList> {
  @override
  void initState() {
    super.initState();
    _callLogs();
  }

  Future<void> _callLogs() async {
    Iterable<CallLogEntry> entries = await CallLog.get();
    List _data = entries.map((data) => data).toList();
    setState(() {
      _entries = _data;
    });
  }

  List<CallLogEntry> _entries = [];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      backgroundColor: Colors.grey[200],
      appBar: AppBar(
        title: Text('Calls Log'),
        centerTitle: true,
        backgroundColor: Colors.purple,
      ),
      body: ListView.builder(
          itemCount: _entries.length,
          itemBuilder: (context, i) {
            final CallLogEntry callLogEntry = _entries[i];

            return ListTile(
              title: Text(callLogEntry.formattedNumber),
              subtitle: Text(callLogEntry.duration.toString()),
            );
          }),
    );
  }
}

, убедитесь, что чтобы добавить это в ваш проект Android Манифест:

...