在我的 AppBar 菜单中,我尝试放置一个具有此功能的按钮(用于更改屏幕):
onPressed: (){
Navigator.push(
context,
MaterialPageRoute(builder: (context) => Read_Pdf()),
);
}
但总是出现“... => Read_Pdf())”,错误原因是“预期有 2 个位置参数,但找到 0 个。尝试添加缺少的参数。”
这是包含 Read_Pdf 类的 file.dart 的内容:
import 'dart:io';
import 'dart:typed_data';
import 'package:flutter/material.dart';
import 'package:path_provider/path_provider.dart';
import 'package:flutter_full_pdf_viewer/full_pdf_viewer_scaffold.dart';
const String _documentPath = 'PDFs/manual_demo.pdf';
// ignore: camel_case_types
class Read_Pdf extends StatelessWidget {
final BuildContext context;
String pdfPath;
Read_Pdf(this.context, this.pdfPath);
Future<String> prepareTestPdf() async {
final ByteData bytes = await DefaultAssetBundle.of(context).load(_documentPath);
final Uint8List list = bytes.buffer.asUint8List();
final tempDir = await getTemporaryDirectory();
final tempDocumentPath = '${tempDir.path}/$_documentPath';
final file = await File(tempDocumentPath).create(recursive: true);
file.writeAsBytesSync(list);
return tempDocumentPath;
}
@override
Widget build(BuildContext context) {
return PDFViewerScaffold(
appBar: AppBar(
title: Text("Document"),
),
path: pdfPath);
}
}
我知道与 pdfPath 变量存在冲突,但我不知道如何解决。 最佳答案
发生这种情况是因为您没有将参数传递给 Read_Pdf() 的构造函数
Read_Pdf(this.context, this.pdfPath);
它需要 上下文 和 pdfPath ,你可以这样做onPressed: (){
Navigator.push(
context,
MaterialPageRoute(builder: (context) => Read_Pdf(context, pdfPath)),
);
}
它会做到的。但在你的实现中:
我可以看到你在 Read_Pdf 中有一个演示 pdf
将您的构造函数更改为
Read_Pdf({this.context, this.pdfPath = _documentPath});
this.pdfPath = _documentPath 的作用是将 _documentPath 分配给 pdfPath 如果在实例化 Read_Pdf 时未提供它。所以现在 onPressed 函数将更改为
onPressed: (){
Navigator.push(
context,
MaterialPageRoute(builder: (context) => Read_Pdf(context: context)),
);
}
关于flutter - 我想在我的 flutter 应用程序上正确加载其他屏幕,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/63469890/