使用JavaScript將PDF頁面中的標注扁平化的操作指南
使用Dynamsoft Document Viewer打開一個PDF文件并啟用標注添加功能
- 創(chuàng)建一個包含以下模板的新HTML文件。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"> <title>Burn PDF Annotation</title> <style> </style> </head> <body> </body> <script> </script> </html>
- 在頁面中包含Dynamsoft Document Viewer的文件。
<script src="https://cdn.jsdelivr.net/npm/dynamsoft-document-viewer@2.1.0/dist/ddv.js"></script> <link rel="stylesheet" rel="external nofollow" >
- 使用許可證初始化Dynamsoft Document Viewer??梢栽?a rel="external nofollow" target="_blank">這里申請一個證書。
Dynamsoft.DDV.Core.license = "DLS2eyJoYW5kc2hha2VDb2RlIjoiMjAwMDAxLTE2NDk4Mjk3OTI2MzUiLCJvcmdhbml6YXRpb25JRCI6IjIwMDAwMSIsInNlc3Npb25QYXNzd29yZCI6IndTcGR6Vm05WDJrcEQ5YUoifQ=="; //one-day trial Dynamsoft.DDV.Core.engineResourcePath = "https://cdn.jsdelivr.net/npm/dynamsoft-document-viewer@2.1.0/dist/engine";// Lead to a folder containing the distributed WASM files await Dynamsoft.DDV.Core.init();
- 創(chuàng)建一個新的文檔實例。
const docManager = Dynamsoft.DDV.documentManager; const doc = docManager.createDocument();
- 創(chuàng)建一個Edit Viewer實例,將其綁定到一個容器,然后用它來查看我們剛剛創(chuàng)建的文檔。其上的按鈕可以使用
UIConfig
對象進行配置。添加標注按鈕以添加創(chuàng)建標注的操作入口。
HTML:
<div id="viewer"></div>
JavaScript:
Dynamsoft.DDV.setProcessingHandler("imageFilter", new Dynamsoft.DDV.ImageFilter()); let uiConfig = { type: "Layout", flexDirection: "column", className: "ddv-edit-viewer-desktop", children: [ { type: "Layout", className: "ddv-edit-viewer-header-desktop", children: [ { type: "Layout", children: [ "ThumbnailSwitch", "FitMode", "DisplayMode", "RotateLeft", "Crop", "Filter", "Undo", "Redo", "DeleteCurrent", "DeleteAll", "Pan", "SeparatorLine", "AnnotationSet" ], enableScroll: true }, { type: "Layout", children: [ { "type": "Pagination", "className": "ddv-edit-viewer-pagination-desktop" }, { type: Dynamsoft.DDV.Elements.Button, className: "ddv-button-download", events: { click: "exportPDFWithOptions", }, }, ] } ] }, "MainView" ] } editViewer = new Dynamsoft.DDV.EditViewer({ uiConfig: uiConfig, container: document.getElementById("viewer") });
CSS:
#viewer { width: 320px; height: 480px; }
- 使用
input
選擇圖像或PDF文件,并將其加載到文檔實例中。
HTML:
<label> Select a file to load: <br/> <input type="file" id="files" name="files" onchange="filesSelected()"/> </label>
JavaScript:
async function filesSelected(){ let filesInput = document.getElementById("files"); let files = filesInput.files; if (files.length>0) { const file = files[0]; const blob = await readFileAsBlob(file); await doc.loadSource(blob); // load the file } } function readFileAsBlob(file){ return new Promise((resolve, reject) => { const fileReader = new FileReader(); fileReader.onload = async function(e){ const response = await fetch(e.target.result); const blob = await response.blob(); resolve(blob); }; fileReader.onerror = function () { reject('oops, something went wrong.'); }; fileReader.readAsDataURL(file); }) }
我們將能夠看到如下查看器:
扁平化標注并保存PDF
Dynamsoft Document Viewer支持四種處理PDF標注的方式:
none
:丟棄所有標注image
:將所有內容合并到光柵圖像中flatten
:扁平化所有標注annotation
:以可編輯的形式保存標注。標記為扁平化的單個標注仍將被扁平化
我們可以使用flatten
選項保存PDF文件來扁平化所有標注。
let blob = await doc.saveToPdf({ saveAnnotation: "flatten" })
如果我們想在使某些標注扁平化的同時保留某些標注的可編輯性,我們可以使用標注的扁平化屬性,并使用annotation
選項保存PDF。
let annotations = Dynamsoft.DDV.annotationManager.getAnnotationsByDoc(doc.uid); let annotation = annotations[0]; annotation.flattened = true; let blob = await doc.saveToPdf({ saveAnnotation: "annotation" })
內部是如何運作的
PDF文件使用PostScript語言描述。我們將使用一些示例來展示扁平化的內部操作細節(jié)。
PDF文件會包含許多字典,下面是一個頁面字典的示例:
4 0 obj << /Type/Page % Specifies that this dictionary defines a page. /Annots[ 8 0 R ] % A list of references to annotation objects on this page. /Contents 7 0 R % Reference to page content stream. /MediaBox[ 0 0 147 143.25] % Page dimensions. % Other page properties >> endobj 7 0 obj <</Filter/FlateDecode/Length 44>>stream x??41W0 BCc=#S039椝 ?J繅w媹0Tp蒞? 卵 endstream endobj
以上頁面引用了以下標注字典:
8 0 obj << /Type/Annot /AP<< /Contents(annotation) /CreationDate(D:20241227135119+08'00') /DA(0.9411764705882353 0.07450980392156863 0.0784313725490196 rg /Helvetica 16 Tf) /DS(font: 'Helvetica' 16pt; text-align:left; color:#F01314) /F 4 /IT/FreeTextTypeWriter/M(D:20241227135125+08'00')/NM(m56c4eb9uq)/RC(<?xml version="1.0"?><body xmlns="http://www.w3.org/1999/xhtml" xmlns:xfa="http://www.xfa.org/schema/xfa-data/1.0/" xfa:APIVersion="Acrobat:18.11.0" xfa:spec="2.0.2" style="font-size:16pt;text-align:left;color:#f01314;font-weight:normal;font-style:normal;font-family:'Helvetica';font-stretch:normal;"><p dir="ltr"><span>annotation</span></p></body>) /Rect[ 22.1854 112.467 98.423 129.217] /Subj() /Subtype /FreeText /T() >> endobj
扁平化后,頁面字典將變?yōu)橐韵聝热?。它不再具有標注?jié)點,并將轉換成圖形的標注的節(jié)點附加到其正文中。
4 0 obj << /Type/Page /Contents 13 0 R /MediaBox[ 0 0 147 143.25] >> endobj 7 0 obj <</Filter/FlateDecode/Length 48>>stream x???41W0 BCc=#S039椝 ?J繅w媹0Tp蒞溻 靔 ? endstream endobj 13 0 obj [ 7 0 R 14 0 R ] endobj 14 0 obj <</Filter/FlateDecode/Length 29>>stream x?T0T0 B櫆珷鐓b犩挴 M+? endstream endobj
以上就是使用JavaScript將PDF頁面中的標注扁平化的操作指南的詳細內容,更多關于JavaScript PDF標注扁平化的資料請關注腳本之家其它相關文章!
相關文章
JS Jquery 遍歷,篩選頁面元素 自動完成(實現代碼)
本篇文章是對JS Jquery 遍歷,篩選頁面元素 自動完成的實現代碼進行了詳細的分析介紹,需要的朋友參考下2013-07-07獲取下拉列表框的值是數組,split,$.inArray示例
獲取下拉列表框的值是數組,下面用product_id 去匹配是否包含在一個數組中,感興趣的朋友不要錯過2013-11-11