Native PDF View for iOS and Android
Add this to your package's pubspec.yaml file:
dependencies:
flutter_pdfview: ^1.0.0+10
You can install packages from the command line:
with Flutter:
$ flutter packages get
Alternatively, your editor might support pub get or flutter packages get
. Check the docs for your editor to learn more.
Opt-in to the embedded views preview by adding a boolean property to the app's Info.plist
file
with the key io.flutter.embedded_views_preview
and the value YES
.
Now in your Dart code, you can use:
import 'package:flutter_pdfview/flutter_pdfview.dart';
Name | Android | iOS |
---|---|---|
onViewCreated | ✅ | ✅ |
onRender | ✅ | ✅ |
onPageChanged | ✅ | ✅ |
onError | ✅ | ✅ |
onPageError | ✅ | ❌ |
gestureRecognizers | ✅ | ✅ |
filePath | ✅ | ✅ |
enableSwipe | ✅ | ✅ |
swipeHorizontal | ✅ | ✅ |
password | ✅ | ✅ |
nightMode | ✅ | ❌ |
password | ✅ | ✅ |
autoSpacing | ✅ | ✅ |
pageFling | ✅ | ✅ |
pageSnap | ✅ | ❌ |
Name | Description | Parameters | Return |
---|---|---|---|
getPageCount | Get total page count | - | Future<int> |
getCurrentPage | Get current page | - | Future<int> |
setPage | Go to/Set page | int page |
Future<bool> |
PDFView(
filePath: path,
enableSwipe: true,
swipeHorizontal: true,
autoSpacing: false,
pageFling: false,
onRender: (_pages) {
setState(() {
pages = _pages;
isReady = true;
});
},
onError: (error) {
print(error.toString());
},
onPageError: (page, error) {
print('$page: ${error.toString()}');
},
onViewCreated: (PDFViewController pdfViewController) {
_controller.complete(pdfViewController);
},
onPageChanged: (int page, int total) {
print('page change: $page/$total');
},
),
If you use proguard, you should include this line.
-keep class com.shockwave.**