版本:0.2.6
LiteOfd 是一个用于处理 OFD(Open Fixed-layout Document)文件的轻量级库。它提供了解析、渲染和操作 OFD 文档的功能,使开发者能够在 Web 应用中轻松展示和操作 OFD 文档。
🔗 Demo: https://signitdoc.github.io/liteofd/
以下是一个OFD文档渲染的示例图片:
该图片展示了使用LiteOfd库渲染OFD文档的效果。您可以看到文档内容被准确地呈现,包括文本、图形和布局等元素。
使用npm安装
npm install liteofd
注意:目前打包遇到问题,发布到npm之后字体文件因为无法正确加载导致渲染字体可能出现问题,所以建议源码引入。另外如果有人愿意贡献打包脚本,可以联系我。QQ:897761547,谢谢!或者帮忙修改打包脚本,提PR。
步骤是将OFD文档解析之后调用渲染方法,然后将渲染结果添加到显示组件中
import { LiteOfd } from 'liteofd'
function parseOfdFile(file: File) {
const liteOfd = new LiteOfd()
let appContent = getElementById("ofd-content")
appContent.innerHTML = ''
liteOfd.parse(file).then((data: OfdDocument) => {
console.log('解析OFD文件成功:', data);
let ofdDiv = liteOfd.render(undefined, 'background-color: white; margin-top: 12px;')
appContent.appendChild(ofdDiv) //
}).catch((error) => {
console.error('解析OFD文件失败:', error);
});
}
描述:解析上传的 OFD 文件。
参数:
- file: File - 用户上传的 OFD 文件对象
返回值:
- Promise:一个 Promise,解析成功后返回 OfdDocument 对象
示例:
const fileInput = document.getElementById('fileInput') as HTMLInputElement;
const file = fileInput.files?.[0];
if (file) {
liteOfd.parseFile(file).then((data: OfdDocument) => {
console.log('解析OFD文件成功:', data);
}).catch((error) => {
console.error('解析OFD文件失败:', error);
});
}
描述:渲染 OFD 文档。
返回值:
- HTMLDivElement:渲染后的 div 元素
示例:
let renderDiv = liteOfd.render(undefined, 'background-color: white; margin-top: 12px;')
document.getElementById('content').appendChild(renderDiv);
描述:获取当前页面索引。
返回值:
- number:当前页面的索引
示例:
const currentPage = liteOfd.getCurrentPageIndex();
console.log(`当前页面:${currentPage}`);
描述:获取文档总页数。
返回值:
- number:文档的总页数
示例:
const totalPages = liteOfd.getTotalPages();
console.log(`总页数:${totalPages}`);
描述:跳转到下一页。
示例:
liteOfd.nextPage();
描述:跳转到上一页。
示例:
liteOfd.prevPage();
描述:滚动到指定页面。
参数:
- pageIndex: number - 目标页面索引
示例:
liteOfd.scrollToPage(1); // 跳转到第一页
描述:放大文档。
示例:
liteOfd.zoomIn();
描述:缩小文档。
示例:
liteOfd.zoomOut();
描述:重置文档缩放比例。
示例:
liteOfd.resetZoom();
描述:搜索文档中的关键词。
参数:
- keyword: string - 要搜索的关键词
示例:
liteOfd.searchText("示例关键词");
描述:获取指定页面或全文的文本内容。
参数:
- pageIndex: number | null - 页面索引,如果为 null 则获取全文
返回值:
- string:指定页面或全文的文本内容
示例:
const content = liteOfd.getContentText(null);
console.log("文档内容:", content);
描述:执行指定的动作(如跳转到特定页面)。
参数:
- action: XmlData - 要执行的动作数据
示例:
// 假设 action 是从大纲数据中获取的
liteOfd.executeAction(action);
LiteOfd 类会触发一些自定义事件,您可以监听这些事件来执行相应的操作:
描述:当 OFD 文档页面发生变化时触发。
示例:
window.addEventListener('ofdPageChange', (event: CustomEvent) => {
// 更新页面信息显示
updatePageInfo();
});
描述:当点击签名元素时触发。
示例:
appContent.addEventListener('signature-element-click', (event: CustomEvent) => {
const { nodeData, sealObject } = event.detail;
console.log('Clicked Signature Element:', nodeData);
console.log('Seal Object:', sealObject);
// 显示签名详情
displaySignatureDetails(nodeData, sealObject);
});
字段名 | 类型 | 描述 |
---|---|---|
files | any | OFD解析出来的所有文件,即ZIP解压缩后的原始文件,包含文件路径 |
data | any | 解析的OFD数据,XmlData类型 |
pages | XmlData[] | OFD的页面数据数组 |
ofdXml | XmlData | OFD.xml文件数据 |
documentData | XmlData | document.xml文件数据 |
publicRes | XmlData | publicres.xml文件数据 |
documentRes | XmlData | documentRes.xml文件数据 |
rootContainer | Element | 根容器,HTMLDivElement类型 |
loadedMediaFile | Map<string, any> | 已加载的资源图片,包括图片等 |
mediaFileList | any | 多媒体文件列表 |
signatures | XmlData | 签名数据,signatures.xml文件的数据 |
signatureList | XmlData[] | 签名数据列表,包含signatures.xml中所有签名组成的XmlData数组 |
outlines | XmlData | 大纲数据列表,包含ofd:Outlines中所有大纲数据 |
annots | XmlData | 注释数据列表,包含ofd:Annotations中的数据 |
字段名 | 类型 | 描述 |
---|---|---|
attrsMap | Map<string, any> | 属性值映射 |
children | XmlData[] | 子标签数组 |
value | string | 标签中的值 |
tagName | string | 标签的名称 |
fileName | string | XML文件的路径和名称 |
id | string | 节点的ID属性值 |
signList | XmlData[] | 页面包含的签名数组 |
sealObject | any | 签名的数据,印章数据(如signedvalue.data中的数据) |
sealData | OfdDocument | string | null | OFD类型签章的数据或图片的base64数据 |
annots | XmlData | null | 注释数据列表,包含ofd:Annotations |
- 在使用 LiteOfd 类的方法之前,请确保已经成功解析了 OFD 文件。
- 某些方法(如 nextPage、prevPage 等)可能会触发 ofdPageChange 事件,请根据需要添加相应的事件监听器。
- 对于大型 OFD 文件,解析和渲染可能需要一些时间,建议添加适当的加载提示。