跳到内容
  • 福昕首页
  • 开发中心
  • SDK文档资料
  • 福昕首页
  • 开发中心
  • SDK文档资料
申请试用
  • 企业自动化
    • Compressor
  • 福昕CloudAPI
  • 福昕PDF SDK 软件开发工具包
    • 福昕PDF SDK(ActiveX)
    • 福昕PDF SDK(桌面/服务器)
    • 福昕PDF SDK(Plug-in)
    • 福昕 PDF SDK(安卓)
    • 福昕PDF SDK(iOS)
    • 福昕PDF SDK(Web)
  • 福昕管理控制台
    • 公有云
    • 私有云
    • 通用情况
  • 福昕阅读器
    • RMS插件
  • 福昕高级编辑器
    • AI助手
    • Mac版本
      • 常规问题
    • windows版本
      • ECM集成
      • 互联PDF
      • 企业管理指南
      • 保护
      • 内容编辑
      • 创建PDF
      • 压缩
      • 图章
      • 安装与卸载
      • 常见问题
      • 打印
      • 注释/评论
      • 福昕插件
      • 翻译助手
      • 翻译助手教程
      • 试用与激活
      • 转换
      • 页面管理
    • 教育用户
      • 论文查重
      • 论文畅
    • 网页版
      • 电子签章
    • 订阅
    • 资源
  • 福昕高级编辑器Linux版本
  • 福船图纸管理系统
  • 福昕PDF SDK 软件开发工具包 > 福昕PDF SDK(Web)
  • 标签:
  • Blob下载,PDF截图,takeSnapshot,异步快照,截图,渲染,设备坐标转换,页面

专业获取当前页面截图的技术实现方案

  • 福昕知识库
  • 2025-07-09

本文详细介绍如何通过编程方式获取PDF文档当前页面的精确截图。如下代码实现基于PDF渲染引擎,通过设备坐标转换和高精度区域捕获技术,确保获取的截图与可视化内容一致。

				
					async function snapCurrentPage() {
    var docRender = await pdfui.getPDFDocRender();

    var curPageIndex = docRender.currentPageNumber;

    var curPageRender = docRender.pagesRender.pageRenders[docRender.currentPageNumber];


    //获取当前页面渲染层的缩放比例及旋转角度
    var scaleNum = curPageRender.scale;
    var RotationAngle = curPageRender.rotate;
    var curPageRect = {
        left: 0,
        bottom: 0,
        right: curPageRender.page.info.width,
        top: curPageRender.page.info.height
    }
    console.log("scaleNum:", scaleNum, "RotationAngle:", RotationAngle, "curPageRect:", curPageRect);
    //将当前页面区域的矩形值 转换为 设备坐标形式
    var devRect = curPageRender.page.getDeviceRect(curPageRect, scaleNum,RotationAngle);
    console.log(devRect);

    pdfui.takeSnapshot(curPageIndex, devRect.left, devRect.top, devRect.right, devRect.bottom).then(blob => {
        console.log(blob);
        const url = URL.createObjectURL(blob);
        console.log(url);
        let link = document.createElement('a');
        link.style.display = 'none';
        link.href = url;
        link.setAttribute('download', "test");
        document.body.appendChild(link);
        link.click();
        URL.revokeObjectURL(link.href); // 释放URL 对象
        document.body.removeChild(link);
    });
}
				
			

相关内容

基于HTTP范围请求的非事件监听式PDF注释数据自动导入方案

基于ActiveX控件的高效PDF阅读水印实现方案

Web SDK UIExtension 右键菜单深度定制指南(基于jQuery-contextMenu)

如何分别自定义文本类型注释(打字机/文本框/注释框)的默认样式属性

在WebSDK实现放置签名

解决旧版本fsdk_SDK.dll编译程序替换高版本dll报错问题

C#版的福昕SDK, 如何正确释放PDF处理对象以优化内存使用

如何总是用文件名作为文档标题

如何设置新建空白页面的尺寸以及横纵置

如何获取PDF中的所有表单域,并输出相关的属性信息?

推荐内容

专业获取当前页面截图的技术实现方案

基于HTTP范围请求的非事件监听式PDF注释数据自动导入方案

基于ActiveX控件的高效PDF阅读水印实现方案

Web SDK UIExtension 右键菜单深度定制指南(基于jQuery-contextMenu)

如何分别自定义文本类型注释(打字机/文本框/注释框)的默认样式属性

在WebSDK实现放置签名

解决旧版本fsdk_SDK.dll编译程序替换高版本dll报错问题

C#版的福昕SDK, 如何正确释放PDF处理对象以优化内存使用

如何总是用文件名作为文档标题

如何设置新建空白页面的尺寸以及横纵置

产品
  • 应用行业
  • 白皮书
开发支持
  • 开发中心
  • SDK文档资料

销售咨询:010-50951668

客服电话:0591-38509808

销售咨询
微信公众号

©2025 福建福昕软件开发股份有限公司 版权所有

隐私策略