pdfrx
pdfrx is a rich and fast PDF viewer implementation built on the top of PDFium. The plugin supports Android, iOS, Windows, macOS, Linux, and Web.
Interactive Demo
A demo site using Flutter Web
Multi-platform support
- Android
- iOS
- Windows
- macOS
- Linux (even on Raspberry PI)
- Web (*using PDF.js)
Example Code
The following fragment illustrates the easiest way to show a PDF file in assets:
import 'package:pdfrx/pdfrx.dart';
...
class _MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('Pdfrx example'),
),
body: PdfViewer.asset('assets/hello.pdf'),
),
);
}
}
Anyway, please follow the instructions below to install on your environment.
Getting Started
Installation
Add this to your package's pubspec.yaml
file and execute flutter pub get
:
dependencies:
pdfrx: ^1.0.97
Note for Windows
Ensure your Windows installation enables Developer Mode.
The build process internally uses symbolic link and it requires Developer Mode to be enabled. Without this, you may encounter errors like this.
Open PDF File
PdfViewer supports following functions to open PDF file on specific medium:
- PdfViewer.asset
- Open PDF of Flutter's asset
- PdfViewer.file
- Open PDF from file
- macOS: may be blocked by App Sandbox
- Open PDF from file
- PdfViewer.uri
- Open PDF from URI (
https://...
or relative path)- Flutter Web: may be blocked by CORS
- macOS: may be blocked by App Sandbox
- Open PDF from URI (
Deal with Password Protected PDF Files
PdfViewer.asset(
'assets/test.pdf',
// Most easiest way to return some password
passwordProvider: () => 'password',
...
),
For more customization and considerations, see Deal with Password Protected PDF Files using PasswordProvider.
Customizations/Features
You can customize the behaviour and the viewer look and feel by configuring PdfViewerParams.
Text Selection
The following fragment enables text selection feature:
PdfViewer.asset(
'assets/test.pdf',
enableTextSelection: true,
...
),
PDF Feature Support
Viewer Customization
- Page Layout (Horizontal Scroll View/Facing Pages)
- Showing Scroll Thumbs
- Dark/Night Mode Support
- Document Loading Indicator
- Viewer Customization using Widget Overlay
Additional Customizations
- Doubleātap to Zoom
- Adding Page Number on Page Bottom
- Per-page Customization using Widget Overlay
- Per-page Customization using Canvas
Additional Widgets
PdfDocumentViewBuilder/PdfPageView
PdfPageView is just another PDF widget that shows only one page. It accepts PdfDocument and page number to show a page within the document.
PdfDocumentViewBuilder is used to safely manage PdfDocument inside widget tree and it accepts builder
parameter that creates child widgets.
The following fragment is a typical use of these widgets:
PdfDocumentViewBuilder.asset(
'asset/test.pdf',
builder: (context, document) => ListView.builder(
itemCount: document?.pages.length ?? 0,
itemBuilder: (context, index) {
return Container(
margin: const EdgeInsets.all(8),
height: 240,
child: Column(
children: [
SizedBox(
height: 220,
child: PdfPageView(
document: document,
pageNumber: index + 1,
alignment: Alignment.center,
),
),
Text(
'${index + 1}',
),
],
),
);
},
),
),
PdfDocument Management
PdfDocumentViewBuilder can accept PdfDocumentRef from PdfViewer to safely share the same PdfDocument instance. For more information, see example/viewer/lib/thumbnails_view.dart.
Low Level PDF API
- Easy to use Flutter widgets
- Easy to use PDF APIs
- PDFium bindings
- Not encouraged but you can import package:pdfrx/src/pdfium/pdfium_bindings.dart