Передайте значение на другую страницу, чтобы открыть PDF - PullRequest
0 голосов
/ 17 февраля 2020

Я новичок во флаттере, я передаю ссылку на файл PDF на эту страницу, когда я печатаю, она всегда присутствует, но страница однажды читает файл PDF, а когда go возвращается и делает то, что agian не читает ссылка, я не знаю почему?

Может кто-нибудь помочь мне решить эту проблему?

import 'package:flutter/material.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter_plugin_pdf_viewer/flutter_plugin_pdf_viewer.dart';

class ReadPdf extends StatefulWidget {

  final String value;
  ReadPdf({Key key, this.value}) : super(key: key);

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

class _ReadPdfState extends  State<ReadPdf>{
  PDFDocument document;
  var my_uid;
  loadFromUrl() async{
    document = await PDFDocument.fromURL('${widget.value}');
    print('yes' + widget.value);
  }

  @override
  void initState() {

    super.initState();
    loadFromUrl();

    FirebaseAuth.instance.currentUser().then((user){

      setState(() {
        my_uid = user.uid;
        print(user.uid);
      });
    }).catchError((e){
      print(e);
    });
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        body: Column(
          children: <Widget>[
            Expanded(
              child: Center(
                child: document !=null ? PDFViewer(
                  document: document,
                ) : Text('Try agian'),
              ),
            ),
          ],
        ),
      ),
    );
  }
}

enter image description here

1 Ответ

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

Я думаю, что проблема заключается в операции "asyn c", которая еще не завершена при вызове метода сборки.

Вместо условного document !=null, попробуйте поместить loadFromUrl в FutureBuilder, например так:

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        body: Column(
          children: <Widget>[
            Expanded(
              child: Center(
                  child: FutureBuilder(
                future: loadFromUrl(),
                builder: (context, snapshot) {
                  if (snapshot.hasData == false) {
                    return CircularProgressIndicator();
                  }

                  //or snapshot.data if your loadFromUrl returns the document, I think that is more "correct"
                  return PDFViewer(document: document);
                },
              )),
            ),
          ],
        ),
      ),
    );
  }

и ваш метод должен вернуть будущее чего-либо (PDFDocument в вашем случае)

Future<String> loadFromUrl() async {
    await Future.delayed(Duration(seconds: 2));
  }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...