将PDF流使用 canvas 绘制展示在页面上(一)

将PDF流展示在页面上

使用 pdfjs-dist 库来渲染 PDF 页面到 canvas 上进行绘制展示

安装 pdfjs-dist 依赖

bash 复制代码
npm install pdfjs-dist
或者
yarn add pdfjs-dist

创建一个组件来处理 PDF 流的加载和渲染

该组件中是一个包含 PDF 文件的 Base64。

将 pdf 流传入该组件中使用

javascript 复制代码
/** @format */

import React, { useState, useEffect, useRef } from 'react';
var pdfjsLib = require('pdfjs-dist/es5/build/pdf.js');
// eslint-disable-next-line import/first
import 'pdfjs-dist/es5/build/pdf.worker.entry';

const PdfViewer = ({ url, id }) => {
    const [pageNumbers, setPageNumbers] = useState(0);
    const [currentPage, setCurrentPage] = useState(1);
    const [loading, setLoading] = useState(true);
    const [rendering, setRendering] = useState(false);
    const pdfRef = useRef(null);
    function renderPdf(pdfFile) {
        let canvas = document.getElementById(id);
        let canvasContext = canvas.getContext('2d');
        pdfFile.getPage(currentPage).then((page) => {
            //逐页解析PDF
            var viewport = page.getViewport({ scale: 5 }); // 页面缩放比例,值越大越清晰
            canvas.height = viewport.height;
            canvas.width = viewport.width;
            canvasContext.clearRect(0, 0, canvas.width, canvas.height);
            var renderContext = {
                canvasContext: canvasContext,
                viewport: viewport,
                rotate: 90,
            };
            setRendering(true);
            page.render(renderContext).promise.finally(() => {
                setRendering(false);
            }); //渲染生成
        });
    }

    useEffect(() => {
        let loadingTask = pdfjsLib.getDocument({
            url: url,
            //cMapUrl: './cmaps/',
            //cMapPacked: true,
        });
        loadingTask.promise
            .then((pdf) => {
                // console.log(pdf.numPages);
                pdfRef.current = pdf;
                setPageNumbers(pdf.numPages);
                renderPdf(pdf);
            })
            .catch((error) => {
                console.log(error);
            })
            .finally(() => {
                setLoading(false);
            });
    }, []);

    useEffect(() => {
        if (pdfRef.current) {
            window.scrollTo({ top: 0 });
            renderPdf(pdfRef.current);
        }
    }, [currentPage]);

    return (
        <div>
            <canvas id={'pdf' + id} style={{ width: '100%' }} />
        </div>
    );
};

export default PdfViewer;

使用示例

javascript 复制代码
import React from 'react';
import PdfViewerfrom './PdfViewer.jsx';
 render() {
 const url= 'XXXX....BYFhEdCmVuZHN0cmVhbQplbmRvYmoKc3RhcnR4cmVmCjg2NTkxCiUlRU9GCg=='// base64 格式
	  return (
		  	<PdfViewer 
		  		id={'pdf_file'} 
		  		url={`data:application/pdf;base64,${url}`}
		  	></PdfViewer>
	  )
 }

使用问题

在使用的过程中,有一个项目是可以的,但是另一个项目会报错,如下图:


相关推荐
momo_养身版16 分钟前
Browser use — 利用 AI 操作浏览器 · 原理篇
前端·openai
悲且狂20 分钟前
Vue环境搭建:vue+idea
前端·vue.js·intellij-idea
Allen Bright21 分钟前
【XML基础-1】深入理解XML:介绍、语法规则与实际应用
xml·前端
大个个个个个儿32 分钟前
vue3腾讯云直播 前端拉流(前端页面展示直播)
前端·javascript·腾讯云
momo_养身版35 分钟前
Browser use — 利用 AI 操作浏览器 · 实践篇
前端·ai编程
Cutey91643 分钟前
实现可配置的滚动效果:JavaScript与CSS双方案
javascript·面试
看晴天了44 分钟前
关于web应用开发赛道的备考
前端·node.js·ecmascript 6
LoveCan1 小时前
ant-design-vue自动计算a-table每一列的宽度的实现
前端·vue.js
张天宇1 小时前
微信小程序custom-tab-bar
前端
喝西瓜汁的兔叽Yan1 小时前
【常用功能】下载文件和复制到剪切板
前端·javascript