Я пытаюсь открыть загруженный файл PDF в моем приложении, тогда он отображается нормально, но когда я открываю его из любого другого приложения, такого как программа чтения PDF, его формат файла шоу не поддерживается.
- PDF файл хранится в этом каталоге:
internal storage/MyApp/pdf
- Я хочу получить доступ к этому PDF-файлу из любого PDF-ридера или открыть его из моего файлового менеджера, так что нужно сделать.
- I я не использую каталог путей
getExternalStorageDirectory()
- Я даю внутренний путь хранения, например,
/storage/emulated/0/MyApp
Это мой полный код
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:logger/logger.dart';
import 'package:open_file/open_file.dart';
import 'package:path_provider/path_provider.dart';
import 'package:http/http.dart' as http;
void main(){
runApp(new MaterialApp(
debugShowCheckedModeBanner: false,
home: new FileDownloadView()
));
}
class FileDownloadView extends StatefulWidget {
@override
_FileDownloadViewState createState() => _FileDownloadViewState();
}
class _FileDownloadViewState extends State<FileDownloadView> {
String _filePath = "";
Future<String> get _localDevicePath async {
final _devicePath = await getExternalStorageDirectory();
return _devicePath.path;
}
Future<File> _localFile({String path, String type}) async {
String _path = await _localDevicePath;
var _newPath = await Directory("/storage/emulated/0/$path").create();
return File("${_newPath.path}/pdf.$type");
}
Future _downloadSamplePDF() async {
final _response =
await http.get("https://firebasestorage.googleapis.com/v0/b/text-recognition-28371.appspot.com/o/Direct%20Recruitment%202020.pdf?alt=media&token=114498c1-0e84-48e0-bda0-15d4b688f745");
if (_response.statusCode == 200) {
final _file = await _localFile(path: "MyApp", type: "pdf");
final _saveFile = await _file.writeAsBytes(_response.bodyBytes);
Logger().i("File write complete. File Path ${_saveFile.path}");
setState(() {
_filePath = _saveFile.path;
});
} else {
Logger().e(_response.statusCode);
}
}
Future _downloadSampleVideo() async {
final _response = await http.get(
"https://sample-videos.com/video123/mp4/720/big_buck_bunny_720p_2mb.mp4");
if (_response.statusCode == 200) {
final _file = await _localFile(type: "mp4", path: "videos");
final _saveFile = await _file.writeAsBytes(_response.bodyBytes);
Logger().i("File write complete. File Path ${_saveFile.path}");
setState(() {
_filePath = _saveFile.path;
});
} else {
Logger().e(_response.statusCode);
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
FlatButton.icon(
icon: Icon(Icons.file_download),
label: Text("Sample Pdf"),
onPressed: () {
_downloadSamplePDF();
},
),
FlatButton.icon(
icon: Icon(Icons.file_download),
label: Text("Sample Videos"),
onPressed: () {
_downloadSampleVideo();
},
),
Text(_filePath),
FlatButton.icon(
icon: Icon(Icons.shop_two),
label: Text("Show"),
onPressed: () async {
final _openFile = await OpenFile.open(_filePath);
Logger().i(_openFile);
},
),
],
),
),
);
}
}
Android Манифест
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example2.downloder_app">
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<!-- io.flutter.app.FlutterApplication is an android.app.Application that
calls FlutterMain.startInitialization(this); in its onCreate method.
In most cases, you can leave this as-is, but you if you want to provide
additional functionality it is fine to subclass or reimplement
FlutterApplication and put your custom class here. -->
<application
android:name="io.flutter.app.FlutterApplication"
android:label="downloder_app"
android:icon="@mipmap/ic_launcher"
android:testOnly="false">
<activity
android:name=".MainActivity"
android:launchMode="singleTop"
android:theme="@style/LaunchTheme"
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
android:hardwareAccelerated="true"
android:windowSoftInputMode="adjustResize">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<!-- Don't delete the meta-data below.
This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
<meta-data
android:name="flutterEmbedding"
android:value="2" />
</application>
</manifest>