vue pdfjs-dist插件base64流 pdf预览

参考文章:https://blog.csdn.net/weixin_42298182/article/details/88893575

参考文章:https://www.jianshu.com/p/0974ee6f19c4

"pdfjs-dist": "2.0.943",

<template>
  <div class="wrap">
    <div class="pdf-container">
      <canvas ref="watermark" class="watermark"></canvas>
      <canvas ref="myCanvas"></canvas>
    </div>
    <div class="pdf-control">
      <div class="pdf-control-page">
        <img src="@/assets/img/left.png" @click="prev" />
        <span class="page-number-container">
          <input
            type="number"
            v-model="pageNum"
            :disabled="pageCount===1"
            class="page-number-input"
            @blur="queueRenderPage(pageNum)"
          />
          / {{ pageCount }}页
        </span>
        <img src="@/assets/img/right.png" @click="next" />
      </div>
      <div class="pdf-control-zoom">
        <img class="zoom-out" src="@/assets/img/zoomOut.png" @click="minus" />
        <img src="@/assets/img/zoomIn.png" @click="addscale" />
      </div>
      <div>
        <span @click="$emit('closePdf')">关闭</span>
      </div>
    </div>
  </div>
</template>

<script>
import pdfJS from "pdfjs-dist";
export default {
  props: {
    base64: {
      type: String,
      default: "",
    },
  },
  data() {
    return {
      pdfUrl: "", // PDF的base64
      pdfDoc: null, // pdfjs 生成的对象
      pageNum: 0, // 当前页数
      pageRendering: false,
      pageNumPending: null,
      scale: 0.6, // 放大倍数
      page_num: 0, // 当前页数
      pageCount: 0, // 总页数
      maxscale: 5, // 最大放大倍数
      minscale: 0.3, // 最小放大倍数
      waterInfo: {},
    };
  },
  computed: {},
  created() {
    this.init();
  },
  methods: {
    // 初始化pdf
    init() {
      pdfJS.getDocument({
        data: atob(this.base64),
        cMapUrl: 'https://cdn.jsdelivr.net/npm/pdfjs-dist@2.0.943/cmaps/',
        cMapPacked: true
      }).promise.then((pdfDoc_) => {
        this.pdfDoc = pdfDoc_;
        this.pageCount = this.pdfDoc.numPages;
        this.pageNum = 1;
        this.renderPage(this.pageNum);
      });
    },
    // 渲染pdf
    renderPage(num) {
      this.pageRendering = true;
      let canvas = this.$refs.myCanvas;
      // Using promise to fetch the page
      this.pdfDoc.getPage(num).then((page) => {
        var viewport = page.getViewport(this.scale);
        canvas.height = viewport.height;
        canvas.width = viewport.width;
        let ctx = canvas.getContext("2d");
        var renderContext = {
          canvasContext: ctx,
          viewport: viewport,
        };
        var renderTask = page.render(renderContext);
        renderTask.promise.then(() => {
          ctx.fillStyle = ctx.createPattern(this.$refs.watermark, "repeat");
          ctx.fillRect(0, 0, canvas.width, canvas.height);
          this.pageRendering = false;
          if (this.pageNumPending !== null) {
            this.renderPage(this.pageNumPending);
            this.pageNumPending = null;
          }
        });
      });
    },
    // 放大
    addscale() {
      if (this.scale >= this.maxscale) {
        return;
      }
      this.scale += 0.1;
      this.queueRenderPage(this.pageNum);
    },
    // 缩小
    minus() {
      if (this.scale <= this.minscale) {
        return;
      }
      this.scale -= 0.1;
      this.queueRenderPage(this.pageNum);
    },
    // 上一页
    prev() {
      if (this.pageNum <= 1) {
        return;
      }
      this.pageNum--;
      this.queueRenderPage(this.pageNum);
    },
    // 下一页
    next() {
      if (this.pageNum >= this.pageCount) {
        return;
      }
      this.pageNum++;
      this.queueRenderPage(this.pageNum);
    },
    queueRenderPage(num) {
      var number = Number(num);
      if (this.pageRendering) {
        this.pageNumPending = number;
      } else {
        this.renderPage(number);
      }
    },
  },
};
</script>

<style lang="scss" scoped>
.wrap {
  background-color: #fff !important;
  display: flex;
  flex-direction: column;
  position: fixed;
  z-index: 1000;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  .pdf-container {
    flex: 1;
    overflow: auto;
    text-align: center;
    background-color: rgba(0, 0, 0, 0.1);
    padding: 0.5rem 0.2rem;
    .watermark {
      display: none;
    }
  }
  .pdf-control {
    padding: 0px 16px;
    height: 50px;
    line-height: 50px;
    background: rgba(103, 103, 103, 1);
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    color: #fff;
    img {
      vertical-align: middle;
    }
    .pdf-control-page {
      img {
        width: 14px;
      }
      .page-number-container {
        margin: 0px 7px;
        .page-number-input {
          width: 50px;
          background-color: #363636;
          border: none;
          border-radius: 2px;
          //   padding: 2px 4px;
          text-align: center;
          box-sizing: border-box;
          color: #fff;
          height: 20px;
        }
      }
    }
    .pdf-control-zoom {
      img {
        width: 24px;
      }
      .zoom-out {
        margin-right: 20px;
      }
    }
  }
}
</style>

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值