- provider模块用于提供数据
- 会作为一个节点显示在一条树上
- 必须至少有两个类
- provider类,继承与QgsDataProvider
- RootItem类,节点类
- provider类,继承与QgsDataProvider
- 提供连接节点的话还需提供连接节点类
- 提供自定义连接的话还需实现连接类
- 无父类,自由发挥
- 系统有写好的httlp连接类,可以直接使用
- 最简单的provider模块编写
- 在src/providers下新建一个目录
- 模仿ows插件,ows下所有文件拷贝过去,替换名称就行,注意代码里的文件名也要修改
- 修改.cpp .h文件名
- 修改代码引用的文件名
- 修改代码里的类名
- 在*provider.cpp中替换provider显示的名字
- 修改CMakeLists.txt里的文件名
- 修改src/providers下的CMakeLists.txt,添加harmony目录
- 在src/providers下新建一个目录
- 编写具有自定义ui的provider模块harmony
- 说明
- ows模块使用自带的QgsNewHttpConnection类,所以不带ui
- provider模块的ui统一放在\src\ui目录下
- 继承自Qt窗口类的界面类可以放在\src\gui目录(qgis自带的gui放在那里),我们可以就放在provider目录
- 这个例子是实现了一个connection窗口类,在单机新连接后弹出一个对话框
- 在ows的基础上修改
- 需要的修改
- harmonydataitems.cpp
- 打开这个#if,激活newConnection()槽函数
- 在newConnection中调用新写的对话框
- harmonydataitems.cpp
- 步骤
- 在已经有个无 ui provider模块的基础上
- 新建一个基于QDialog的对话框
- 将代码复制到src/providers/harmony中
- 并在CMakeLists.txt中添加这两个文件
- 将ui文件复制到src/ui中
- CMakeLists.txt
######################################################## # Files #设置源文件列表 SET(HARMONY_SRCS harmonyprovider.cpp harmonydataitems.cpp harmonyconnection.cpp ) #头文件 SET(HARMONY_MOC_HDRS harmonyprovider.h harmonydataitems.h harmonyconnection.h ) ######################################################## # Build #添加生成的MOC源文件,这些文件是根据头文件生成的 QT4_WRAP_CPP(HARMONY_MOC_SRCS ${HARMONY_MOC_HDRS}) #设置库文件目录 INCLUDE_DIRECTORIES( #qgis core ../../core #qgis gui ../../gui ${CMAKE_CURRENT_BINARY_DIR}/../../ui ) #生成动态库 ADD_LIBRARY (harmonyprovider MODULE ${HARMONY_SRCS} ${HARMONY_MOC_SRCS}) #链接其他库 TARGET_LINK_LIBRARIES (harmonyprovider qgis_core qgis_gui ) ######################################################## # Install #生成插件 INSTALL(TARGETS harmonyprovider RUNTIME DESTINATION ${QGIS_PLUGIN_DIR} LIBRARY DESTINATION ${QGIS_PLUGIN_DIR})
- 说明