彩票走势图

「Qt Widget中文示例指南」如何实现文档查看器?(三)

翻译|使用教程|编辑:龚雪|2024-03-20 11:13:00.957|阅读 24 次

概述:本文将为大家介绍如何使用Qt Widget小部件创建文档查看器,欢迎下载最新版组件体验~

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

Qt 是目前最先进、最完整的跨平台C++开发工具。它不仅完全实现了一次编写,所有平台无差别运行,更提供了几乎所有开发过程中需要用到的工具。如今,Qt已被运用于超过70个行业、数千家企业,支持数百万设备及应用。

文档查看器是一个显示和打印JSON、文本和PDF文件的Widgets应用程序。Document Viewer(文档查看器)演示了如何使用带有静态和动态工具栏、菜单和操作的QMainWindow,此外它还演示了基于小部件的应用程序中的以下特性:

  • 使用查询和保存用户参数,并管理以前打开的文件历史记录。
  • 控制光标悬停在小部件上时的操作。
  • 创建动态加载的插件。

在上文中(点击这里回顾>>)主要介绍了创建一个应用程序和主窗口的一些类,本文将继续介绍一些其他类,请持续关注哦~

Qt技术交流群:166830288      欢迎一起进群讨论

「Qt Widget中文示例指南」如何实现文档查看器?
创建一个应用程序和主窗口
其他相关类

HoverWatcher类

HoverWatcher类在将鼠标悬停在小部件上时设置覆盖光标,并在离开时恢复它。为了防止为同一个小部件创建多个HoverWatcher实例,它被实现为每个小部件单个实例。

HoverWatcher继承自,并将它所监视的QWidget作为实例的父对象。它安装了一个事件过滤器来拦截悬停事件而不消耗它们:

HoverWatcher::HoverWatcher(QWidget *watched)
: QObject(watched), m_watched(watched)
{
Q_ASSERT(watched);
m_cursorShapes[Entered].emplace(Qt::OpenHandCursor);
m_cursorShapes[MousePress].emplace(Qt::ClosedHandCursor);
m_cursorShapes[MouseRelease].emplace(Qt::OpenHandCursor);
// no default for Left => restore override cursor
m_watched->installEventFilter(this);
}

HoverAction枚举列出了HoverWatcher响应的动作:

enum HoverAction {
Entered,
MousePress,
MouseRelease,
Left,
Ignore
};

静态函数创建监视器,为特定的QWidget检查它们是否存在,或者解散监视器:

static HoverWatcher *watcher(QWidget *watched);
static const HoverWatcher *watcher(const QWidget *watched);
static bool hasWatcher(QWidget *widget);
static void dismiss(QWidget *watched);

可以为每个HoverAction设置或取消光标形状,如果没有关联的游标形状,则在触发操作时恢复应用程序的覆盖游标。

public slots:
void setCursorShape(HoverAction type, Qt::CursorShape shape);
void unSetCursorShape(HoverAction type);

mouseButtons属性保存了用于MousePress操作的鼠标按钮:

void setMouseButtons(Qt::MouseButtons buttons);
void setMouseButton(Qt::MouseButton button, bool enable);

特定于动作的信号在处理一个动作后发出:

signals:
void entered();
void mousePressed();
void mouseReleased();
void left();

发出一个通用信号,将处理后的动作作为参数传递:

void hoverAction(HoverAction action);

RecentFiles类

RecentFiles是一个 ,专门用于管理最近打开的文件列表。

RecentFiles有插槽添加单个文件或多个文件,如果路径指向存在且可以打开的文件,则将一个条目添加到最近的文件列表中。如果一个文件已经在列表中,它将从其原始位置移除并添加到顶部。

public slots:
void addFile(const QString &fileName) { addFile(fileName, EmitPolicy::EmitWhenChanged); }
void addFiles(const QStringList &fileNames);

文件通过名称或索引从列表中删除:

void removeFile(const QString &fileName) { removeFile(m_files.indexOf(fileName)); }
void removeFile(qsizetype index) {removeFile(index, RemoveReason::Other); }

插槽实现保存和恢复从QSettings:

void saveSettings(QSettings &settings, const QString &key) const;
bool restoreFromSettings(QSettings &settings, const QString &key);

在恢复设置时,不存在的文件将被忽略。maxFiles属性保存要存储的最近文件的最大数量(默认为10)。

qsizetype maxFiles();
void setMaxFiles(qsizetype maxFiles);

RecentFiles在接受一个文件之前验证它是否可以被读取。

RecentFileMenu类

RecentFileMenu是一个,专门用于将RecentFiles对象显示为子菜单。

它的构造函数接受一个指向父QObject的指针和一个指向RecentFiles对象的指针,该对象的内容将被可视化。它的fileOpened()信号,当用户从列表中选择一个最近的文件时触发,将绝对路径作为参数传递给该文件。

注意:RecentFileMenu要么被它的父部件销毁,要么被传递给它的构造函数的RecentFiles对象销毁。

class RecentFileMenu : public QMenu
{
Q_OBJECT

public:
explicit RecentFileMenu(QWidget *parent, RecentFiles *recent);

signals:
void fileOpened(const QString &fileName);
...
};

Qt Widget组件推荐
  • QtitanRibbon - Ribbon UI组件:是一款遵循Microsoft Ribbon UI Paradigm for Qt技术的Ribbon UI组件,QtitanRibbon致力于为Windows、Linux和Mac OS X提供功能完整的Ribbon组件。
  • QtitanChart - Qt类图表组件:是一个C ++库,代表一组控件,这些控件使您可以快速地为应用程序提供漂亮而丰富的图表。
  • QtitanDataGrid - Qt网格组件:提供了一套完整的标准 QTableView 函数和传统组件无法实现的独特功能。使您能够将不同来源的各类数据加载到一个快速、灵活且功能强大的可编辑网格中,支持排序、分组、报告、创建带状列、拖放按钮和许多其他方便的功能。
  • QtitanDocking:允许您像 Visual Studio 一样为您的伟大应用程序配备可停靠面板和可停靠工具栏。黑色、白色、蓝色调色板完全支持 Visual Studio 2019 主题!


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn

文章转载自:慧都网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP