国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Vue3前端h5移動端頁面預(yù)覽PDF使用pdfjs-dist,添加自定義文本水印

這篇具有很好參考價值的文章主要介紹了Vue3前端h5移動端頁面預(yù)覽PDF使用pdfjs-dist,添加自定義文本水印。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

pdfjs-dist版本

pnpm i pdfjs-dist@2.5.207文章來源地址http://www.zghlxwxcb.cn/news/detail-802489.html


<script setup>
import {ref, onMounted, watch} from 'vue'
import { useRoute } from "vue-router";
import * as pdfjsLib from 'pdfjs-dist'

const route = useRoute()
// !
pdfjsLib.GlobalWorkerOptions.workerSrc = new URL('pdfjs-dist/build/pdf.worker.js', import.meta.url).href
const numPages = ref(0) // pdf一共多少頁
const nums = ref(1) // 循環(huán)加載的參數(shù)
const currentNum = ref(1) // 當前頁數(shù)
const jumpNum = ref(1)  // 輸入框需要跳轉(zhuǎn)的頁數(shù)
const inpDisabled = ref(true) // pad文件沒有加載完所有頁數(shù)則禁用
const imgSrcList = ref([]) // 存儲paf每一頁
const watermarkPoint = [
  [-120, -66], [-120, 66], [120, -66], [120, 66]
] // 水印坐標
let pageHeight = null // 每一頁高度
let pdfWrap = null
let isChangeCurrentNum = false

const query = new URLSearchParams(route.fullPath.split('?')[1]) // 從url地址欄獲取水印文本信息
const watermarkText = query.get('text') // 自定義的水印文本

// url為pdf鏈接
const loadingTask = pdfjsLib.getDocument(query.get('url'))

// dom加載之后
onMounted(() => {
  pdfWrap = document.getElementById('pdf')
  togglePage(nums.value)
})

watch(() => nums.value, (num) => {
  if (num <= numPages.value) {
    togglePage(num)
  } else {
    inpDisabled.value = false
  }
})

async function togglePage(pageNumber = 1) {
  loadingTask.promise.then(function(pdf) {
    numPages.value = pdf.numPages

    pdf.getPage(pageNumber).then((page) => {

      const scale = 0.1 // 關(guān)鍵!如果清晰度不行,慢慢調(diào)整這個數(shù)值。
      let viewport = page.getViewport({ scale });
      let scaleViewport = page.getViewport({ scale: window.screen.width / viewport.width });


      let canvas = document.createElement('canvas');

      let context = canvas.getContext('2d');

      canvas.width = scaleViewport.width;
      canvas.height = scaleViewport.height;
			
		// 只賦值一次	
      !pageHeight && (pageHeight = (scaleViewport.height * scale).toFixed(2))

      let renderContext = {
        canvasContext: context,
        viewport: scaleViewport,
      };
      let renderTask = page.render(renderContext);
      renderTask.promise.then(() => {
      // 設(shè)置自定義文本樣式
        context.font = `${16 / scale}px Microsoft Yahei`;
        context.fillStyle = 'rgba(0, 0, 0, .1)'
        context.textAlign = 'center'
        context.textBaseline = 'middle'

		// 設(shè)置自定義文本位于每一頁pdf的空間位置
        watermarkPoint.forEach(point => {
          context.translate( ((scaleViewport.width * scale / 2) + point[0]) / scale, ((scaleViewport.height * scale / 2) + point[1]) / scale )
          context.rotate(-30 * Math.PI / 180)
          context.fillText(watermarkText, 0, 0)
          context.resetTransform()
        })
		// 導(dǎo)出canvas圖片到圖片列表,循環(huán)渲染
        imgSrcList.value.push(canvas.toDataURL('img/png'))

        nums.value++
      });
    });
  }, function (reason) {
    console.error(reason);
  });
}

function goToPage(num) {
  pdfWrap.scrollTo(0, num === 1 ? 0 : pageHeight * num - pageHeight)
  currentNum.value = num
  isChangeCurrentNum = true
}

function handleScroll(e) {
  if (!isChangeCurrentNum) {
    const current = e.target.scrollTop / pageHeight
    currentNum.value = Math.ceil(current === 0 ? 1 : current)
  }
  isChangeCurrentNum = false
}

function handleBeforePage() {
  currentNum.value = currentNum.value - 1 <= 0 ? 1 : currentNum.value - 1
  goToPage(currentNum.value)
  isChangeCurrentNum = true
}
function handleNextPage() {
  currentNum.value = currentNum.value + 1 >= numPages.value ? numPages.value : currentNum.value + 1
  goToPage(currentNum.value)
  isChangeCurrentNum = true
}
</script>

<template>
  <div>
    <div class="overflow-y-scroll" id="pdf" style="height: calc(100vh - 60px);" @scroll="handleScroll">
      <img v-for="src in imgSrcList" :src="src" alt="">
    </div>
    <div v-if="imgSrcList.length !== 0" class="operation-box">
      <div class="operation">
        <div class="page-num-info">
          <span>{{ currentNum }}</span>
          /
          <span v-if="!inpDisabled">{{ numPages }}</span>
          <van-loading style="margin-left: 3px;margin-top: 3px" v-else size="14" type="spinner" />
        </div>
        <van-icon @click="handleBeforePage" name="arrow-left" />
        <div class="jump-box" v-if="!inpDisabled">
          <div class="inp-box">
            跳轉(zhuǎn) <input style="width: 60px;text-align: center;color: black" type="number" v-model="jumpNum" /></div>
          <div @click.stop="goToPage(jumpNum)">確定</div>
        </div>
        <div v-else class="tips">文件正在加載中..跳轉(zhuǎn)功能暫不可用</div>
        <van-icon @click="handleNextPage" name="arrow" />
        <van-icon @click="goToPage(1)" class="home" name="wap-home" size="20" />
      </div>
    </div>
  </div>
</template>

<style scoped lang="less">
.operation-box {
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  .operation {
    display: flex;
    align-items: center;
    justify-content: space-around;
    background-color: #404040;
    width: 100%;
    color: #fff;
    padding: 10px 20px;
    border-radius: 30px;
    box-sizing: border-box;
    .jump-box {
      flex: 1;
      font-size: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      .inp-box {
        margin-right: 5px;
      }
    }
    .tips {
      flex: 1;
      text-align: center;
      font-size: 14px;
    }
    .page-num-info {
      display: flex;
      justify-content: center;
      align-items: center;
      font-size: 14px;
    }
    .page-num-info, .home {
      width: 60px;
      text-align: center;
    }
  }
}
</style>

到了這里,關(guān)于Vue3前端h5移動端頁面預(yù)覽PDF使用pdfjs-dist,添加自定義文本水印的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • vue3管理系統(tǒng)中后臺返回pdf格式的文件流,前端如何預(yù)覽?以及uniapp微信小程序中后臺返回的base64位的pdf文件如何預(yù)覽?

    vue3管理系統(tǒng)中后臺返回pdf格式的文件流,前端如何預(yù)覽?以及uniapp微信小程序中后臺返回的base64位的pdf文件如何預(yù)覽?

    后臺返回的是base64格式的pdf文件,首先需要解析base64文件的插件 image-tools 1 安裝并引入插件 2 封裝預(yù)覽pdf的函數(shù) 3 調(diào)用接口獲取數(shù)據(jù)

    2024年01月18日
    瀏覽(171)
  • 前端vue3實現(xiàn)本地及在線文件預(yù)覽(含pdf/txt/mp3/mp4/docx/xlsx/pptx)

    前端vue3實現(xiàn)本地及在線文件預(yù)覽(含pdf/txt/mp3/mp4/docx/xlsx/pptx)

    (一)微軟office免費預(yù)覽( 推薦 ) 支持doc/docx/xls/xlsx/ppt/pptx等多種office文件格式的免費預(yù)覽 (二)XDOC文檔預(yù)覽云服務(wù) ?移動端和PC端無插件預(yù)覽PDF、OFD、Word、WPS等多種格式文檔 本地或內(nèi)網(wǎng)預(yù)覽需要借助插件實現(xiàn),pdf、mp3、mp4等主要靠原生標簽或瀏覽器自帶功能,盡量減少

    2024年02月05日
    瀏覽(63)
  • vue3 電子書 pdf轉(zhuǎn)圖片 pdf實現(xiàn)翻頁效果 pdfjs-dist、turn.js電子書翻頁效果

    vue3 電子書 pdf轉(zhuǎn)圖片 pdf實現(xiàn)翻頁效果 pdfjs-dist、turn.js電子書翻頁效果

    下載 turn.js 這里使用的是? turn4? ,需要下載到本地引入,通過npm下載會報錯可以到官網(wǎng)下載,也可以直接在本博客下,已經(jīng)上傳到博客 導(dǎo)入文件之前先創(chuàng)建?? vue.config.js 適配一下jquery ,創(chuàng)建好文件以后,把以下代碼復(fù)制進去 回到vue頁面,導(dǎo)入以下文件 參考博客:GitHub -

    2024年02月16日
    瀏覽(59)
  • 在uni中使用vue3寫h5的pdf導(dǎo)出

    先安裝依賴 把dom轉(zhuǎn)canvas,屏幕截圖基于 DOM,因此可能不是 100% 準確到真實表示,因為它不會制作實際的屏幕截圖,而是根據(jù)頁面上可用的信息構(gòu)建屏幕截圖。 components/pdf? 創(chuàng)建pdf文件夾 在main文件中引入 在需要的頁面綁定id? 事件

    2024年02月16日
    瀏覽(18)
  • 前端使用vue-pdf、pdf-lib、canvas 給PDF文件添加水印,并預(yù)覽與下載

    前端使用vue-pdf、pdf-lib、canvas 給PDF文件添加水印,并預(yù)覽與下載

    原理就是給顯示pdf 的容器增加一層水印遮罩層 下載: 通過url獲取pdf文件的arrarybuffer文件流 將arraybuffer數(shù)據(jù)轉(zhuǎn)成pdf文檔 添加水印字體(內(nèi)置/自定義) 為每頁pdf添加文字水印 保存pdf文件的unit64Arrary文件流 預(yù)覽: 創(chuàng)建canvas容器(用于顯示水印文字) 創(chuàng)建水印canvas 將水印canv

    2024年01月24日
    瀏覽(24)
  • Vue3PDF預(yù)覽(vue3-pdf-app)

    Vue3PDF預(yù)覽(vue3-pdf-app)

    vue3-pdf-app 插件 網(wǎng)站預(yù)覽PDF最佳且最簡單的方式: 如果需要自定義網(wǎng)頁內(nèi)預(yù)覽,可以采用本PDF預(yù)覽組件(PDFViewer.vue) 本組件基于 ?vue3-pdf-app@1.0.3 ?插件進行二次封裝,更適合日常使用需要! 插件支持功能包括但不限于:縮放、旋轉(zhuǎn)、全屏預(yù)覽、打印、下載、內(nèi)容檢索、dar

    2023年04月21日
    瀏覽(23)
  • uniapp使用H5實現(xiàn)預(yù)覽pdf文件

    uniapp使用H5實現(xiàn)預(yù)覽pdf文件

    下載后把壓縮包解壓到自己的項目的static文件夾下的pdf文件下,如圖 新建一個文件名為filePreview.vue 在下載文件事件 1.如果預(yù)覽文件是亂碼情況或者在pc上報ocale.properties的請求返回404 解決:就是pdfjs下載版本有問題,下載以前的老版本 2.如果出現(xiàn)跨域問題直接修改源代碼在v

    2024年02月09日
    瀏覽(25)
  • 前端實現(xiàn)PDF預(yù)覽【vue】

    前言:項目中提出這樣一個需求,在移動端H5頁面預(yù)覽pdf功能。pdf文件由后端返回的一個地址,前端實現(xiàn)展示預(yù)覽pdf文件 在此僅提供兩種方法: 一、使用iframe標簽通過src屬性直接展示pdf文件 ? ? ? ? 坑點:兼容比較差,PC端能正常展示,移動端會出現(xiàn)空白的問題 二、使用第

    2024年01月16日
    瀏覽(21)
  • vue前端預(yù)覽pdf并加水印、ofd文件,控制打印、下載、另存,vue-pdf的使用方法以及在開發(fā)中所踩過的坑合集

    vue前端預(yù)覽pdf并加水印、ofd文件,控制打印、下載、另存,vue-pdf的使用方法以及在開發(fā)中所踩過的坑合集

    根據(jù)公司的實際項目需求,要求實現(xiàn)對pdf和ofd文件的預(yù)覽,并且需要限制用戶是否可以下載、打印、另存pdf、ofd文件,如果該用戶可以打印、下載需要控制每個用戶的下載次數(shù)以及可打印的次數(shù)。正常的預(yù)覽pdf很簡單,直接調(diào)用瀏覽器的預(yù)覽就可以而且功能也比較全,但是一

    2024年02月16日
    瀏覽(93)
  • vue3 實現(xiàn)預(yù)覽pdf的幾種方式(vue3-pdf, iframe流展示,vue-office/pdf)

    功能描述: 要實現(xiàn)菜單(二級)綁定文件,并進行預(yù)覽(點擊菜單即觸發(fā)),支持文件上傳下載(綁定菜單),文件以byte[]形式保存到數(shù)據(jù)庫(至于為什么不用文件存儲系統(tǒng),因為這是領(lǐng)導(dǎo)定的 =,= 而且這個功能比較小,數(shù)據(jù)也不多,成本有限),同時,要解析pdf文件里的內(nèi)

    2024年02月16日
    瀏覽(19)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包