详解Qt Pdf之QPdfBookmarkModel 读取pdf标签页并显示

news/2024/12/4 15:47:05/

文章目录

  • 前言
    • 1. Qt 中的 `QPdfBookmarkModel` 简介
      • 1.1 主要成员类型和方法
    • 2. 使用 `QPdfBookmarkModel` 显示 PDF 标签页
      • 2.1 准备环境
      • 2.2 创建界面和基本结构
      • 2.3 加载 PDF 文件并显示书签
      • 2.4 显示书签
  • 总结


前言

Qt 是一个强大的跨平台应用程序开发框架,它提供了许多模块来帮助开发者实现各种功能。在处理 PDF 文件时,Qt 也提供了强大的支持,尤其是在 Qt 5.10 及之后的版本中,新增了 QPdfDocumentQPdfBookmarkModel 类,它们为我们提供了操作和显示 PDF 文件的能力。

在本文中,我们将详细探讨如何使用 QPdfBookmarkModel 来读取 PDF 文件中的标签页(书签),并将这些书签信息展示在 QTreeView 中。这样,用户就可以通过界面查看和跳转到 PDF 文档的不同章节。

1. Qt 中的 QPdfBookmarkModel 简介

QPdfBookmarkModel 是 Qt 5.10 引入的一个类,它继承自 QAbstractItemModel,用于表示和管理 PDF 文件中的书签信息。书签通常在 PDF 文档中用于标记不同的章节或页面,类似于目录或导航结构。

QPdfBookmarkModel 提供了一个树形结构的数据模型,每个书签作为模型的一个节点,节点之间可以有父子关系,形成一个层级结构。通过 QPdfBookmarkModel,我们可以获取每个书签的标题、级别、目标页码以及其他相关信息。

1.1 主要成员类型和方法

  • Role:用于获取书签的不同属性(如标题、级别、页码等)。

    • Title:书签的标题。
    • Level:书签的层级。
    • Page:书签所在页面的页码。
    • Location:书签目标位置的坐标。
    • Zoom:书签的缩放级别。
  • 关键方法

    • setDocument(QPdfDocument *document):设置要加载的 PDF 文档。
    • rowCount(const QModelIndex &parent):获取当前节点的子节点数量。
    • columnCount(const QModelIndex &parent):获取列数(通常是 1)。
    • data(const QModelIndex &index, int role):获取指定书签节点的属性。
    • index(int row, int column, const QModelIndex &parent):获取指定位置的书签项。
    • parent(const QModelIndex &index):获取指定书签的父项。

2. 使用 QPdfBookmarkModel 显示 PDF 标签页

接下来,我们将实现一个简单的 PDF 查看器,能够读取 PDF 文件中的书签,并通过 QTreeView 来显示这些书签。下面是实现步骤。

2.1 准备环境

首先,我们需要确保安装了 Qt 的 PDF 模块(Qt PDF),该模块从 Qt 5.10 开始提供。可以在 .pro 文件中添加以下内容来启用 PDF 模块:

QT += pdf

2.2 创建界面和基本结构

QWidget 类中创建基本界面,包含一个按钮用于加载 PDF 文件,QTreeView 用于展示 PDF 中的书签信息。

#include <QWidget>
#include <QPdfDocument>
#include <QPdfView>
#include <QVBoxLayout>
#include <QFileDialog>
#include <QPushButton>
#include <QLabel>
#include <QTreeView>
#include <QPdfBookmarkModel>class PdfViewer : public QWidget {Q_OBJECTpublic:PdfViewer(QWidget *parent = nullptr) : QWidget(parent) {// 设置布局QVBoxLayout *layout = new QVBoxLayout(this);// 创建控件QLabel *label = new QLabel("请选择 PDF 文件:", this);QPushButton *loadButton = new QPushButton("加载 PDF", this);pdfView = new QPdfView(this);// 添加控件到布局layout->addWidget(label);layout->addWidget(loadButton);layout->addWidget(pdfView);// 创建 PDF 文档对象pdfDocument = new QPdfDocument(this);// 创建书签模型bookmarkModel = new QPdfBookmarkModel(this);// 创建 QTreeView 显示书签QTreeView *bookmarkView = new QTreeView(this);bookmarkView->setModel(bookmarkModel);layout->addWidget(bookmarkView);// 连接加载按钮的点击事件connect(loadButton, &QPushButton::clicked, this, &PdfViewer::loadPdf);}private slots:void loadPdf() {// 打开文件选择对话框QString fileName = QFileDialog::getOpenFileName(this, "打开 PDF 文件", "", "PDF Files (*.pdf)");if (fileName.isEmpty()) return;// 加载 PDF 文档if (pdfDocument->load(fileName) == QPdfDocument::Error::None) {pdfView->setDocument(pdfDocument);bookmarkModel->setDocument(pdfDocument); // 设置书签模型} else {qWarning() << "无法加载 PDF 文件:" << fileName;}}private:QPdfDocument *pdfDocument;QPdfView *pdfView;QPdfBookmarkModel *bookmarkModel;  // 书签模型
};

2.3 加载 PDF 文件并显示书签

PdfViewer 类中,我们创建了 QPdfDocument 对象用来加载 PDF 文件,并将该对象传递给 QPdfBookmarkModel 以提取书签信息。通过 QTreeView,我们可以展示 PDF 文件中的书签。

  • loadPdf():当用户点击“加载 PDF”按钮时,程序会弹出文件选择对话框,用户选择 PDF 文件后,调用 pdfDocument->load() 加载文件。如果文件加载成功,调用 bookmarkModel->setDocument(pdfDocument) 设置文档并加载书签数据。

  • bookmarkModel->setDocument(pdfDocument):该方法会解析 PDF 文件中的书签,并填充 QPdfBookmarkModel,然后 QTreeView 会根据模型数据来显示书签。

2.4 显示书签

QTreeView 中,书签将以树形结构展示。每个节点对应一个书签,点击某个书签节点可以跳转到对应的页面。书签信息会包括书签的标题、层级(深度)和对应的页码。

总结

本文介绍了如何在 Qt 中使用 QPdfBookmarkModel 来读取和显示 PDF 文件中的书签。我们通过 QTreeView 展示了书签数据,并提供了一个简单的界面供用户选择和查看 PDF 文件。通过这些功能,用户能够更方便地浏览和导航 PDF 文档。

通过 QPdfBookmarkModelQPdfView,我们可以更好地控制和展示 PDF 文件中的内容,为应用程序提供强大的 PDF 浏览和处理能力。


http://www.ppmy.cn/news/1552316.html

相关文章

Android Studio 右侧工具栏 Gradle 不显示 Task 列表

问题&#xff1a; android studio 4.2.1版本更新以后AS右侧工具栏Gradle Task列表不显示&#xff0c;这里需要手动去设置 解决办法&#xff1a; android studio 2024.2.1 Patch 2版本以前的版本设置&#xff1a;依次打开 File -> Settings -> Experimental 选项&#x…

【Ant Design Pro】1. config 配置

前置说明 这里我使用的是 simple 版本&#xff0c;并结合 antd pro 脚手架搭建&#xff08;现在默认使用为 umi4 版本&#xff09;&#xff1a; 虽然这个文档好像已经好久没有更新了。 config 文件&#xff1a; config.ts // https://umijs.org/config/ import { defineConfi…

专讲debug的文章

https://arxiv.org/pdf/2402.16906 这篇文章是在通义实验室的codebase里找到的&#xff0c;感觉是我比较关心的LLM相关的研究&#xff0c;主要想看下现在对代码测试的自动化程度&#xff0c;以及使用的方法以及一些观点视角&#xff0c;看了给定的实例是类似力扣上的那种代码&…

51单片机从入门到精通:理论与实践指南入门篇(三)

上一节博客给大家基本介绍了51单片机 51单片机从入门到精通&#xff1a;理论与实践指南入门篇&#xff08;二&#xff09; https://blog.csdn.net/speaking_me/article/details/144068159?spm1001.2014.3001.5501 那么这节课就来介绍——花样流水灯的实现 花样流水灯电路设…

网络安全系列 之 SQL注入学习总结

目录 1. sql注入概述2. sql注入测试工具3. sql注入防御方法 3.1 问题来源3.2 防御方法4. SQL注入防御举例 4.1 使用JDBC时&#xff0c;SQL语句进行了拼接 1. 使用statement的executeQuery、execute、executeUpdate等函数时&#xff0c;传入的SQL语句拼接了来自外部的不可信参数…

联想YOGA Pro 14s至尊版电脑找不到独立显卡(N卡)问题,也无法安装驱动的问题

问题描述 电脑是联想YOGA Pro 14s至尊版&#xff0c;电脑上装的独立显卡是4060&#xff0c;一直是能够使用独立显卡的。然而有两次突然就找不到显卡了&#xff0c;NVIDIA CONTROL PANEL也消失了&#xff0c;而且也无法安装驱动。具体表现如下&#xff1a; 无法连接外接显示器…

【音视频】HLS和DASH 流媒体协议的详细介绍和实现方式

深入探讨 HLS 和 DASH 流媒体协议 1. HLS&#xff08;HTTP Live Streaming&#xff09; 核心技术细节 HLS&#xff08;HTTP Live Streaming&#xff09;是由苹果公司提出的一种基于 HTTP 协议的流媒体协议。它将视频分割成多个小片段&#xff0c;通过 .m3u8 文件作为索引进行…

解决 el-input 红色波浪线问题

解决 el-input 红色波浪线问题 添加 spellcheck"false" <el-input class"inputStyle" v-model"codeNum" spellcheck"false" change"orderFn" ref"inputSelectBound" label""></el-input>…