qt creator源码全方面分析(2-5)

Creating Wizards in Code

介绍

如果基于模板的自定义向导提供的功能不足以满足您的情况,则可以用代码编写向导。

Qt Creator中的向导是实现Core::IWizardFactory接口的类的实例,该接口具有使用IWizardFactory::registerFactoryCreator注册的创建函数。

实现向导需要:

  • 编写从Core::IWizardFactory派生的工厂类。这是一个非常通用的界面,不会对向导的功能及其UI外观做出任何假设。

  • 提供一组参数,这些参数确定向导在“新建文件”或“项目”对话框的向导列表中的显示方式。

    从Core: IWizardFactory派生时,构造函数必须调用基类提供的以下设置函数:

    • setId
    • setWizardKind
    • setIcon
    • setDescription
    • setDisplayName
    • setCategory
    • setDisplayCategory
    • setDescriptionImage
    • setRequiredFeatures
    • setFlags
  • 实现向导UI
    通常,这将是派生自Utils::Wizard的类。Utils::Wizard扩展了QWizard的功能,以在左侧显示进度条。

  • 实现向导功能
    建议使用Core::GeneratedFile表示需要写入磁盘的文件。它们允许延迟写入实际数据到磁盘,直到向导完成。

相关类

描述
Core::IWizardFactory Qt Creator向导界面,在ExtensionSystem::PluginManager中注册其类的实现。
Core::GeneratedFile 文件,包含名称,内容和相关属性。
Utils::FileWizardPage 介绍性向导页面,询问文件名和路径。
Utils::ProjectIntroPage 介绍性向导页面,询问项目名和路径。

IWizardFactory的设置器和获取器

下面列出的设置器和获取器,确定向导在“新建文件”或“项目”对话框的向导列表中的显示方式。

类型 参数名 描述
Core::IWizardFactory::WizardKind kind 指示向导类型(项目或文件)的枚举值。
QIcon icon 显示的图标。
QString description 描述性文本。
QString displayName 要在列表中显示的名称。
QString id 向导的唯一标识符。它还决定类别中的顺序。
QString category 列出向导所属类别的标识符。它还确定类别的顺序。
QString displayCategory 类别的描述。

具有相同类别集的所有向导,在“新建文件”或“项目”对话框中被组合在一起。


原创造福大家,共享改变世界

献出一片爱心,温暖作者心灵


posted @ 2020-02-15 16:57  codeForFamily  阅读(762)  评论(0编辑  收藏  举报