pdfrx 1.0.97 pdfrx: ^1.0.97 copied to clipboard
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.
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