pdf_render 1.4.6 copy "pdf_render: ^1.4.6" to clipboard
pdf_render: ^1.4.6 copied to clipboard

A plugin that provides you with intermediate PDF rendering APIs and easy-to-use Flutter Widgets.

example/lib/main.dart

import 'dart:io';

import 'package:flutter/foundation.dart'
    show kIsWeb; // for checking whether running on Web or not
import 'package:flutter/material.dart';
import 'package:flutter_cache_manager/flutter_cache_manager.dart';
import 'package:pdf_render/pdf_render.dart';
import 'package:pdf_render/pdf_render_widgets.dart';

void main(List<String> args) => runApp(const MyApp());

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  @override
  _MyAppState createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  final controller = PdfViewerController();
  TapDownDetails? _doubleTapDetails;

  @override
  void dispose() {
    controller.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: ValueListenableBuilder<Matrix4>(
              // The controller is compatible with ValueListenable<Matrix4> and you can receive notifications on scrolling and zooming of the view.
              valueListenable: controller,
              builder: (context, _, child) => Text(controller.isReady
                  ? 'Page #${controller.currentPageNumber}'
                  : 'Page -')),
        ),
        backgroundColor: Colors.grey,
        body: GestureDetector(
          // Supporting double-tap gesture on the viewer.
          onDoubleTapDown: (details) => _doubleTapDetails = details,
          onDoubleTap: () => controller.ready?.setZoomRatio(
            zoomRatio: controller.zoomRatio * 1.5,
            center: _doubleTapDetails!.localPosition,
          ),
          child: Stack(
            children: [
              !kIsWeb && Platform.isMacOS
                  // Networking sample using flutter_cache_manager
                  ? PdfViewer.openFutureFile(
                      // Accepting function that returns Future<String> of PDF file path
                      () async => (await DefaultCacheManager().getSingleFile(
                              'https://github.com/espresso3389/flutter_pdf_render/raw/master/example/assets/hello.pdf'))
                          .path,
                      viewerController: controller,
                      onError: (err) => print(err),
                      params: const PdfViewerParams(
                        padding: 10,
                        minScale: 1.0,
                        // scrollDirection: Axis.horizontal,
                      ),
                    )
                  : PdfViewer.openAsset(
                      'assets/hello.pdf',
                      viewerController: controller,
                      onError: (err) => print(err),
                      params: const PdfViewerParams(
                        padding: 10,
                        minScale: 1.0,
                        // scrollDirection: Axis.horizontal,
                      ),
                    ),
              // Simple scroll position indicator
              ValueListenableBuilder(
                valueListenable: controller,
                builder: (context, m, child) {
                  if (!controller.isReady) return Container();
                  final v = controller.viewRect;
                  final all = controller.fullSize;
                  final top = v.top / all.height * v.height;
                  final height = v.height / all.height * v.height;
                  return Positioned(
                    right: 0,
                    top: top,
                    height: height,
                    width: 8,
                    child: Container(color: Colors.red),
                  );
                },
              ),
            ],
          ),
        ),
        floatingActionButton: Column(
          mainAxisAlignment: MainAxisAlignment.end,
          children: <Widget>[
            FloatingActionButton(
              child: const Icon(Icons.first_page),
              onPressed: () => controller.ready?.goToPage(pageNumber: 1),
            ),
            FloatingActionButton(
              child: const Icon(Icons.last_page),
              onPressed: () =>
                  controller.ready?.goToPage(pageNumber: controller.pageCount),
            ),
            FloatingActionButton(
              child: const Icon(Icons.bug_report),
              onPressed: () => rendererTest(),
            ),
          ],
        ),
      ),
    );
  }

  /// Just testing internal rendering logic
  Future<void> rendererTest() async {
    final PdfDocument doc;
    if (!kIsWeb && Platform.isMacOS) {
      final file = (await DefaultCacheManager().getSingleFile(
              'https://github.com/espresso3389/flutter_pdf_render/raw/master/example/assets/hello.pdf'))
          .path;
      doc = await PdfDocument.openFile(file);
    } else {
      doc = await PdfDocument.openAsset('assets/hello.pdf');
    }

    try {
      final page = await doc.getPage(1);
      final image = await page.render();
      print(
          '${image.width}x${image.height}: ${image.pixels.lengthInBytes} bytes.');
    } finally {
      doc.dispose();
    }
  }
}
197
likes
110
pub points
98%
popularity

Publisher

verified publisherespresso3389.jp

A plugin that provides you with intermediate PDF rendering APIs and easy-to-use Flutter Widgets.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (LICENSE)

Dependencies

collection, flutter, flutter_web_plugins, js, plugin_platform_interface, vector_math

More

Packages that depend on pdf_render