Qt三方库开发技术:Qt应用内部打开PDF文件

简介: Qt三方库开发技术:Qt应用内部打开PDF文件

若该文为原创文章,转载请注明原文出处

本文章博客地址:https://blog.csdn.net/qq21497936/article/details/99946795

各位读者,知识无穷而人力有穷,要么改需求,要么找专业人士,要么自己研究

红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软硬结合等等)持续更新中...(点击传送门)

Qt开发专栏:三方库开发技术(点击传送门)

 

前话

      白板业务需求,需要内部兼容打开pdf。

 

PDF打开方案

  • 方案一:调用外部应用打开pdf

      该方案是调用外部exe,另起进程以命令行形式打开。

  • 方案二:使用组件打开pdf

      使用QAxwidget调用active控件,qt调用active的office控件不稳定性不推荐。

  • 方案三:qt应用打开pdf

      使用开源库mupdf调用

  • 方案四:使用Pdfium

      Pdfium是谷歌开源的祈福阅读器的部分代码。

  • 方案五:qt应用使用QPdfium打开pdf(本篇使用)

      使用QPdfium是封装了方案四的库

 

下载地址

      官网git:

git clone –recursive https://github.com/paulovap/qtpdfium

      CSDN:https://download.csdn.net/download/qq21497936/11587441

 

演示Demo

     

体验下载地址

CSDN免积分下载地址:https://download.csdn.net/download/qq21497936/14084585

  QQ群下载地址:1047134658(点击“文件”搜索“pdf”,群内与博文同步更新)

 

编译qtpdfium

步骤一:移动到文件夹

       

步骤二:打开工程

       

步骤三:编译子工程pdfium

       

步骤四:出现错误”_Printf_format_string_”

      编译出现错误,如下图:

       

      修改源码如下:

       

步骤五:漫长的编译后,出现”error: kernel32.lib”等错误

      这几个静态库是windows sdk有的,找到windows sdk路径,没有的自己装VS,然后装windows sdk,笔者是使用mingw编译,不是msvc

       

      然后将所需要的库拷贝过去(以提供使用其他编译器编译时使用,省麻烦),

     

修改工程文件

       

步骤六:继续漫长的编译后(十几分钟吧),终于编译成功

       

 

Qt模块使用方法总结

      之前写过qt模块的融入方法总结,一时找不到于是又总结一下使用的方法:

方法一:将该模块部署到本地Qt环境当中去

      标准使用的方法。

方法二:将该模块当做第三方库使用,使用.h和dll库(笔者推荐)

      建议使用该方法,笔者有多台电脑不适合单独配置环境,并且从协作开发的角度上来说,他人接手代码也不应改需要重新配置他自己的开发环境。

方法三:将源码当做工程源码直接编译到工程中

      该方法是为了完全跨平台,跨编译器,跨版本,当然会导致编译时间较长。

方法四:将源码当做工程lib添加到工程中(优化方案三)

      改方法是有方法三的优点,同时又不需要每次编译,手动编译一起lib,其他修改工程的时候不再编译就行。

 

封装QtPdfium模块

       

       

 

关键代码

打开pdf

bool PdfWidget::openFile(QString fileName, QString password)
{
    /*
        enum Status {
        NOT_LOADED = -1,
        SUCCESS = 0,
        FILE_ERROR = 1,
        FORMAT_ERROR = 2,
        PASSWORD_ERROR = 3,
        HANDLER_ERROR = 4,
        FILE_NOT_FOUND_ERROR = 5
    };
     * */
    QPdfium::Status status;
    status = _pPdfium->loadFile(fileName, password);
    if(status != QPdfium::Status::SUCCESS)
    {
        qDebug() << "Failed to load file:" << fileName << "error:" << (int)status;
        return false;
    }
    qDebug() << "Succeed to load file:" << fileName << "total pages:" << _pPdfium->pageCount();
    _pageCount = _pPdfium->pageCount();
    showFirstPage();
    return true;
}

若该文为原创文章,转载请注明原文出处

本文章博客地址:https://blog.csdn.net/qq21497936/article/details/99946795


相关文章
|
7月前
|
存储 JSON API
如何将 Swagger 文档导出为 PDF 文件
你会发现自己可能需要将 Swagger 文档导出为 PDF 或文件,以便于共享和存档。在这篇博文中,我们将指导你完成将 Swagger 文档导出为 PDF 格式的过程。
|
4月前
|
C#
【PDF提取内容改名】批量提取PDF指定区域内容重命名PDF文件,PDF自动提取内容命名的方案和详细步骤
本工具可批量提取PDF中的合同编号、日期、发票号等关键信息,支持PDF自定义区域提取并自动重命名文件,适用于合同管理、发票处理、文档归档和数据录入场景。基于iTextSharp库实现,提供完整代码示例与百度、腾讯网盘下载链接,助力高效处理PDF文档。
611 40
|
4月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
6月前
|
人工智能 算法 安全
使用CodeBuddy实现批量转换PPT、Excel、Word为PDF文件工具
通过 CodeBuddy 实现本地批量转换工具,让复杂的文档处理需求转化为 “需求描述→代码生成→一键运行” 的极简流程,真正实现 “技术为效率服务” 的目标。感兴趣的快来体验下把
253 10
|
5月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
9月前
|
人工智能 编解码 文字识别
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
OCRmyPDF 是一款开源命令行工具,专为将扫描的 PDF 文件转换为可搜索、可复制的文档。支持多语言、图像优化和多核处理。
1025 17
OCRmyPDF:16.5K Star!快速将 PDF 文件转换为可搜索、可复制的文档的命令行工具
|
9月前
|
文字识别 Serverless 开发工具
【全自动改PDF名】批量OCR识别提取PDF自定义指定区域内容保存到 Excel 以及根据PDF文件内容的标题来批量重命名
学校和教育机构常需处理成绩单、报名表等PDF文件。通过OCR技术,可自动提取学生信息并录入Excel,便于统计分析和存档管理。本文介绍使用阿里云服务实现批量OCR识别、内容提取、重命名及导出表格的完整步骤,包括开通相关服务、编写代码、部署函数计算和设置自动化触发器等。提供Python示例代码和详细操作指南,帮助用户高效处理PDF文件。 链接: - 百度网盘:[链接](https://pan.baidu.com/s/1mWsg7mDZq2pZ8xdKzdn5Hg?pwd=8866) - 腾讯网盘:[链接](https://share.weiyun.com/a77jklXK)
1092 5
|
10月前
|
机器学习/深度学习 人工智能 文字识别
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
Zerox 是一款开源的本地化高精度OCR工具,基于GPT-4o-mini模型,支持PDF、DOCX、图片等多种格式文件,能够零样本识别复杂布局文档,输出Markdown格式结果。
922 4
Zerox:AI驱动的万能OCR工具,精准识别复杂布局并输出Markdown格式,支持PDF、DOCX、图片等多种文件格式
|
11月前
|
人工智能 文字识别 数据挖掘
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
MarkItDown 是微软开源的多功能文档转换工具,支持将 PDF、PPT、Word、Excel、图像、音频等多种格式的文件转换为 Markdown 格式,具备 OCR 文字识别、语音转文字和元数据提取等功能。
2332 9
MarkItDown:微软开源的多格式转Markdown工具,支持将PDF、Word、图像和音频等文件转换为Markdown格式
|
11月前
|
JavaScript
jquery图片和pdf文件预览插件
EZView.js是一款jquery图片和pdf文件预览插件。EZView.js可以为图片和pdf格式文件生成在线预览效果。支持的文件格式有pdf、jpg、 png、jpeg、gif。
316 16

推荐镜像

更多
  • qt