定制Qt帮助系统
版权声明
该文章原创于Qter开源社区(www.qter.org),作者yafeilinux,转载请注明出处!
导语
一个完善的应用程序应该提供尽可能丰富的帮助信息。在Qt中可以使用工具提示、状态提示以及“What’s This”等简单的帮助提示,也可以使用QtAssistant来提供强大的在线帮助。如果要进行详细的功能和使用的介绍,单单使用这些提示信息是不行的,这就需要提供HTML格式的帮助文本。在程序中可以通过调用Web浏览器或者使用QTextBrowser来管理和应用这些HTML文件。不过,Qt提供了更加强大的工具,那就是Qt Assistant,它支持索引和全文检索,而且可以为多个应用程序同时提供帮助,我们可以通过定制Qt Assistant来实现强大的在线帮助系统。
为了将Qt Assistant定制为我们自己的应用程序的帮助浏览器,需要先进行一些准备工作,主要是生成一些文件,最后再在程序中启动Qt Assistant。主要的步骤如下:
1.创建HTML格式的帮助文档;
2.创建Qt帮助项目(Qt help project).qhp文件,该文件是XML格式的,用来组织文档,并且使它们可以在Qt Assistant中使用;
3.生成Qt压缩帮助(Qt compressed help).qch文件,该文件由.qhp文件生成,是二进制文件;
4.创建Qt帮助集合项目(Qt help collection project).qhcp文件,该文件是XML格式的,用来生成下面的.qhc文件;
5.生成Qt帮助集合(Qt help collection).qhc文件,该文件是二进制文件,可以使Qt Assistant只显示一个应用程序的帮助文档,也可以定制Qt Assistant的外观和一些功能;
6.在程序中启动Qt Assistant。
环境:Windows Xp + Qt 4.8.5+QtCreator2.8.0
目录
一、创建HTML格式的帮助文档
二、创建.qhp文件
三、生成.qch文件
四、创建.qhcp文件
五、生成.qhc文件
六、在程序中启动QtAssistant
正文
一、创建HTML格式的帮助文档
1.新建Qt Gui应用,项目名称为“myWhatsThis”,类名为“MainWindow”,基类保持QMainWindow不变。
2.然后可以通过各种编辑器例如Microsoft Word来编辑要使用的文档,最后保存为HTML格式的文件,例如这里我们创建了5个HTML文件。然后在项目目录中新建文件夹,命名为“documentation”,再将这些HTML文件放入其中。再在documentation文件夹中再新建一个“images”文件夹,往里面复制一个图标图片,以后将作为Qt Assistant的图标,例如这里使用了yafeilinux.png图片。
二、创建.qhp文件
首先在documentation文件夹中创建一个文本文件,然后进行编辑,最后另存为“myHelp.qhp”,注意后缀为.qhp。文件的内容如下:
<?xml version="1.0"encoding="GB2312"?>
<QtHelpProjectversion="1.0">
<namespace>yafeilinux.myHelp</namespace>
<virtualFolder>doc</virtualFolder>
<filterSection>
<toc>
<section title="我的帮助"ref="./index.html">
<section title="关于我们"ref="./aboutUs.html">
<section title="关于yafeilinux"ref="./about_yafeilinux.html"></section>
<section title="关于Qt Creator系列教程" ref="./about_QtCreator.html"></section>
</section>
<section title="加入我们"ref="./joinUs.html"></section>
</section>
</toc>
<keywords>
<keyword name="关于"ref="./aboutUs.html"/>
<keyword name="yafeilinux" ref="./about_yafeilinux.html"/>
<keyword name="Qt Creator"ref="./about_QtCreator.html"/>
</keywords>
<files>
<file>about_QtCreator.html</file>
<file>aboutUs.html</file>
<file>about_yafeilinux.html</file>
<file>index.html</file>
<file>joinUs.html</file>
<file>images/*.png</file>
</files>
</filterSection>
</QtHelpProject>
这个.qhp文件是XML格式的,对于XML格式不是这里介绍的重点,我们主要讲解其中的内容,如果大家想了解XML格式相关的知识,可以参考这里。在第一行是XML序言,这里指定了编码encoding为GB2312,这样就可以使用中文了,如果只想使用英文,那么编码一般是UTF-8;第二行指定了QtHelpProject版本为1.0;第三行指定了命名空间namespace,每一个.qhp文件的命名空间都必须是唯一的,命名空间会成为Qt Assistant中的页面的URL的第一部分,这个在后面的内容中会涉及到;第四行指定了一个虚拟文件夹virtualFolder,这个文件夹并不需要创建,它只是用来区分文件的;再下面的过滤器部分filterSection标签包含了目录表、索引和所有文档文件的列表。过滤器部分可以设置过滤器属性,这样以后可以在Qt Assistant中通过过滤器来设置文档的显示有否,不过,因为我们这里只有一个文档,所以不需要Qt Assistant的过滤器功能,这里也就不需要设置过滤器属性;在目录表toc(table ofcontents)标签中创建了所有HTML文件的目录,指定了它们的标题和对应的路径,这里设定的目录表为:
♦ 我的帮助 ♦ 关于yafeilinux
♦ 关于Qt Creator系列教程
♦ 加入我们
然后是keywords标签,它指定了所有索引的关键字和对应的文件,这些关键字会显示在Qt Assistant的索引页面;在files标签中列出了所有的文件,也包含图片文件。
三、生成.qch文件
这里为了测试创建的文件是否可用,可以先生成.qch文件,然后在QtAssistant中注册它。这样运行QtAssistant就会看到我们添加的文档了。不过,这一步不是必须的。我们打开命令行控制台,然后使用cd命令跳转到项目目录的documentation目录中,分别输入下面的命令后按下回车:
qhelpgeneratormyHelp.qhp –o myHelp.qch
assistant –registermyHelp.qch
要保证命令可以正常运行,前提是已经将Qt安装目录的bin目录的路径添加到了系统的PATH环境变量中。命令运行结果如下图所示。
当注册成功时,会显示“Documentationsuccessfully registered”提示对话框。这时在开始菜单中启动Qt Assistant(或者直接在命令行输入assistant来启动Qt Assistant),可以发现已经出现了我们的HTML文档,如下图所示。
四、创建.qhcp文件
要想使Qt Assistant只显示我们自己的帮助文档的最简单的方法就是生成帮助集合文件即.qhc文件,要生成.qhc文件,首先要创建.qhcp文件。在documentation文件夹中新建文本文档,对其进行编辑,最后另存为“myHelp.qhcp”,注意后缀为.qhcp。这里还要创建一个名为“about.txt”的文本文件,在其中输入一些该帮助的说明信息,作为QtAssistant的About菜单的显示内容。myHelp.qhcp文件的内容如下:
<?xml version="1.0"encoding="GB2312"?>
<QHelpCollectionProjectversion="1.0">
<assistant>
<title>我的帮助系统</title>
<applicationIcon>images/yafeilinux.png</applicationIcon>
<cacheDirectory>cache/myHelp</cacheDirectory>
<homePage>qthelp://yafeilinux.myHelp/doc/index.html</homePage>
<startPage>qthelp://yafeilinux.myHelp/doc/index.html</startPage>
<aboutMenuText>
<text>关于该帮助</text>
</aboutMenuText>
<aboutDialog>
<file>./about.txt</file>
<icon>images/yafeilinux.png</icon>
</aboutDialog>
<enableDocumentationManager>false</enableDocumentationManager>
<enableAddressBar>false</enableAddressBar>
<enableFilterFunctionality>false</enableFilterFunctionality>
</assistant>
<docFiles>
<generate>
<file>
<input>myHelp.qhp</input>
<output>myHelp.qch</output>
</file>
</generate>
<register>
<file>myHelp.qch</file>
</register>
</docFiles>
</QHelpCollectionProject>
在assistant标签中是对Qt Assistant的外观和功能的定制,其中设置了标题、图标、缓存目录、主页、起始页、About菜单文本、关于对话框的内容和图标等,还关闭了一些没有用的功能。对于缓存目录cacheDirectory,是进行全文检索等操作时缓存文件要存放的位置。对于主页homePage和起始页startPage,这里使用了第二步中提到的Qt Assistant的页面的URL,这个URL由“qthelp://”开始,然后是在.qhp文件中设置的命名空间,然后是虚拟文件夹,最后是具体的HTML文件名。因为Qt Assistant可以添加或者删除文档来为多个应用程序提供帮助,但是这里只是为一个应用程序提供帮助,并且不希望删除我们的文档,所以禁用了文档管理器documentation manager;因为这里的文档集很小,而且只有一个过滤器部分,所以也关闭了地址栏address bar和过滤器功能filter functionality。
在前面第三步中我们已经生成了.qch文件并且在Qt Assistant中进行了注册,但那只是为了测试文件是否可用,其实完全可以跳过第三步,因为在这里的docFiles标签中就完成了第三步的操作。不过与第三步不同的是,第三步是在默认的集合文件中注册的,而这里是在我们自己的集合文件中注册的。
五、生成.qhc文件
在命令行输入如下命令:
qcollectiongenerator myHelp.qhcp –omyHelp.qhc
输出结果如下图所示。
为了测试我们定制的QtAssistant,可以在输入如下命令:
assistant –collectionFile myHelp.qhc
这里在运行Qt Assistant时指定了集合文件为我们自己的.qhc文件,所以运行后只会显示我们自己的HTML文档。可以看到,现在QtAssistant的图标也更改了,打开“Help”菜单中的“关于该帮助”菜单,这里是前面添加的about.txt文件的内容,效果如下图所示。
六、在程序中启动Qt Assistant
这里先要将Qt安装目录的bin目录中的assistant.exe程序复制到我们项目目录的documentation目录中。为了启动Qt Assistant,先要创建了一个Assistant类。首先向项目中添加新文件,模板选择C++ Class,类名为“Assistant”,基类不填写,类型信息选择无。然后将assistant.h文件更改如下:
#ifndef ASSISTANT_H
#define ASSISTANT_H
#include <QtCore/QString>
class QProcess;
class Assistant
{
public:
Assistant();
~Assistant();
void showDocumentation(const QString &file);
private:
bool startAssistant();
QProcess *proc;
};
#endif // ASSISTANT_H
在Assistant类中主要是使用QProcess类创建一个进程来启动Qt Assistant。下面是assistant.cpp文件的内容:
#include <QtCore/QByteArray>
#include <QtCore/QProcess>
#include <QtGui/QMessageBox>
#include "assistant.h"
Assistant::Assistant()
)
{
}
Assistant::~Assistant()
{
if (proc && proc->state() == QProcess::Running) {
// 试图终止进程
proc->terminate();
proc->waitForFinished(3000);
}
// 销毁proc
delete proc;
}
// 显示文档
void Assistant::showDocumentation(const QString &page)
{
if (!startAssistant())
return;
QByteArray ba("SetSource ");
ba.append("qthelp://yafeilinux.myHelp/doc/");
proc->write(ba + page.toLocal8Bit() + '\n');
}
// 启动Qt Assistant
bool Assistant::startAssistant()
{
// 如果没有创建进程,则新创建一个
if (!proc)
proc = new QProcess();
// 如果进程没有运行,则运行assistant,并添加参数
if (proc->state() != QProcess::Running) {
QString app = QLatin1String("../myWhatsThis/documentation/assistant.exe");
QStringList args;
args << QLatin1String("-collectionFile")
<< QLatin1String("../myWhatsThis/documentation/myHelp.qhc");
proc->start(app, args);
if (!proc->waitForStarted()) {
QMessageBox::critical(0, QObject::tr("my help"),
QObject::tr("Unable to launch Qt Assistant (%1)").arg(app));
return false;
}
}
return true;
}
在startAssistant()函数中使用QProcess创建了一个进程来启动Qt Assistant,这里使用了命令行参数来使用帮助集合文件,对于assistant.exe和myHelp.qhc都使用了相对地址;在showDocumentation()函数中可以指定具体的页面作为参数来使Qt Assistant显示指定的页面;在析构函数中,如果进程还在运行,则终止进程,最后销毁了进程指针。
下面来使用Assistant类来启动Qt Assistant。在mainwindow.h文件中先添加前置声明:
class Assistant;
再添加private对象指针声明:
Assistant *assistant;
然后添加一个私有槽:
private slots:
void startAssistant();
现在到mainwindow.cpp文件中进行更改。添加头文件包含#include "assistant.h",然后在构造函数中添加如下代码:
QAction *help = new QAction("help",this);
ui->mainToolBar->addAction(help);
connect(help, SIGNAL(triggered()), this, SLOT(startAssistant()));
// 创建Assistant对象
assistant = new Assistant;
这里创建了一个“help”动作,并将它添加到了工具栏中,可以使用该动作启动QtAssistant。下面是startAssistant()槽的定义:
void MainWindow::startAssistant()
{
// 按下“help”按钮,运行Qt Assistant,显示index.html页面
assistant->showDocumentation("index.html");
}
最后在析构函数中销毁assistant指针,即在MainWindow::~MainWindow()函数中添加如下代码:
// 销毁assistant
delete assistant;
现在运行程序,按下工具栏上的“help”动作,就可以启动Qt Assistant了。这里还要提示一下,如果要发布该程序,那么需要将documentation目录复制到发布目录中,这时运行程序。
结语
使用Qt定制帮助系统,可以制作功能强大的上下文相关的帮助文档,而对于一个优秀的软件而言,帮助菜单是必须有的。
涉及到的代码: |
定制Qt帮助系统的更多相关文章
- Windows 7 封装篇(一)【母盘定制】[手动制作]定制合适的系统母盘
Windows 7 封装篇(一)[母盘定制][手动制作]定制合适的系统母盘 http://www.win10u.com/article/html/10.html Windows 7 封装篇(一)[母盘 ...
- 定制x86 Linux系统
/************************************************************************************* * 定制x86 Linux ...
- 深入浅出 - Android系统移植与平台开发(十)- Android编译系统与定制Android平台系统(瘋耔修改篇二)
第四章.Android编译系统与定制Android平台系统 4.1Android编译系统 Android的源码由几十万个文件构成,这些文件之间有的相互依赖,有的又相互独立,它们按功能或类型又被放到不同 ...
- 深度探索QT窗口系统(五篇)
窗口作为界面编程中最重要的部分,没有窗口就没有界面,是窗口让我们摆脱了DOS时代,按钮是一个窗口,文本框是一个窗口,标签页是一个窗口,...一个窗口可以由多个窗口组成,每天我们都在与窗口打交道,当你打 ...
- iOS自定制tabbar与系统的tabbar冲突,造成第一次点击各个item图片更换选中,第二次选中部分item图片不改变
可以选择是使用自定制的还是系统的,如果使用自定制的,就使用以下方法即可隐藏系统的uitabbarButton,从而使item恢复正确 //隐藏UITabBarButton -(void)viewWil ...
- 界面编程之QT窗口系统20180726
/*******************************************************************************************/ 一.坐标系统 ...
- Qt 学习之路 2(24):Qt 绘制系统简介
Qt 学习之路 2(24):Qt 绘制系统简介 豆子 2012年10月30日 Qt 学习之路 2 77条评论 Qt 的绘图系统允许使用相同的 API 在屏幕和其它打印设备上进行绘制.整个绘图系统基于Q ...
- Qt Resource系统概说(资源压缩不压缩都可以)
什么是Qt Resource系统?简单的说,就是在可执行程序中存储binary文件,而且还是与平台无关的. 与Qt Resource系统密切相关的有三个法宝,分别是qmake.rcc.QFile. q ...
- 企业更需要定制化CRM系统满足个性化需求
随着市场的发展和信息技术的进步,越来越多的企业购买CRM客户关系管理系统来帮助管理.提高效率.但哪怕处在相同行业的企业,他们对于CRM的功能需求都会有着很大的不同.因此,大部分企业都开始进行个性化定制 ...
随机推荐
- QtWebkit2.2.0 HTML5.0支持情况
Canvas: 支持element, 2d context以及文本 解析规则:支持 HTML5 tokenizer/tree building, SVG in text/html, MathML ...
- Hacker(17)----认识Windows系统漏洞
Windows系统是迄今为止使用频率最高的操作系统,虽然其安全性随着版本的更新不断提高,但由于人为编写的缘故始终存在漏洞和缺陷.但Mircosoft公司通过发布漏洞补丁来提高系统的安全性,使Windo ...
- Sybase自增字段跳号的解决方法
Sybase自增字段跳号原因及影响: 在Sybase数据库中如果数据库在开启的情况下,因为非正常的原因(死机.断电)而导致数据库服务进程强制结束. 那么自动增长的字段将会产生跳号的情况,再往数据表里面 ...
- QT5-控件-QComboBox
#ifndef MAINWINDOW_H #define MAINWINDOW_H #include <QMainWindow> #include <QComboBox> cl ...
- 小安,今天学会了MySQL中查询时间的方法哦
- Kendo Web UI Grid数据绑定,删除,编辑,并把默认英文改成中文
Kendo Web UI 是个不错的Jquery框.可惜老外写的,很多都是默认的英文,当然我们也可以设置成中文,接下来,我们就看看Grid是如何实现的数据绑定(Kendo Grid数据绑定实现有很多方 ...
- [Python shelve模块Error]bsddb.db.DBPageNotFoundError: (-30986, 'DB_PAGE_NOTFOUND: Requested page not found')
在用scrapy抓数据,用shelve保存时出现了这个Error,目标是储存一串unicode字符串组成的列表,exception代码是tempbase['joke']=joke_list,测试只要j ...
- IOS 文件管理 2
IOS开发-文件管理(二) 五.Plist文件 String方式添加 NSString *path = [NSHomeDirectory( ) stringByAppen ...
- sqlserver exists和in 与exists和not in
1.exists 和 in 1.1 正常情况下exists和in的效果是一样的,如图试验 即使子查询中包含null也没有关系,依然可以正常使用 1.2 in 和 exists效率比较 先看in 由图中 ...
- php----浅谈一下empty isset is_null的用处
} } { } { } } } { } { } is_null():判断变量是否为null if ($a){} 那这个未声明变量会报noti ...