自定义QML扩展插件与调用一步一脚印

2023-10-10 00:50

本文主要是介绍自定义QML扩展插件与调用一步一脚印,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境:Win10,Qt5

可以参考help文档->QML Plugin Example&QQmlExtensionPlugin Class

  1. 建立工程

定义的c++类为MyWin,URL为默认模块名(2者必须一致,无需大小写匹配)

目录结构图

   2.C++里定义QML类型

mywin里头可以在C++里定义QML类型,可以参考help文档->Defining QML Types from C++

如下代码:

class MyWin : public QQuickItem
{Q_OBJECTQ_DISABLE_COPY(MyWin)Q_PROPERTY(QString str READ string )//定义QML可利用的属性
public Q_SLOTS:QString string(){return "custom plugin"; }//与上方的READ string对应,QML可利用的方法,因为槽函数和信号都是可以在QML中获得
public:MyWin(QQuickItem *parent = nullptr);~MyWin();
};
myWin_plugin里头注册c++类和注册插件于Qt meta object systemqmlRegisterType<MyWin>(uri, 1, 0, "MyWin");//MyWin是c++类显示给QML的组件名,可以随便修改

3.定义QML组件

如Win.qml代码:

import QtQuick 2.0
import QtQuick.Window 2.11Window {title: "Win"width: 500height: 400color: "blue"
}

4.*.pro设置

uri = mywin #设定模块名

#DLLDESTDIR指定的目录必须为模块名,$$PWD指的是项目所在目录不是编译所在目录
#作用是生成插件所在目录
#This variable applies only to Windows targets.
#Specifies where to copy the
target dll. DLLDESTDIR=$$PWD/ModuleName

其实Unix平台上更简单,install直接COPY所有所需文件,windows这个DLLDESTDIR只能copy c++类的DLL文件

其他所需文件手动移动

5.设置qmldir

module mywin //模块名
Win 1.0 Win.qml  //qml文件指定
plugin MyWin//插件名

再次提醒,模块名必须与插件名一致

插件所在文件夹名必须与模块名一致

6.整理mywin目录文件
 

7.调用插件

 engine.addImportPath("../");//engine应该知道,添加路径为插件所在的上层目录

8.typeinfo plugin_name.qmltypes

需自己生成,不然无法语法高亮。可以参考HELP文档->Writing a qmltypes File

我这里好像不行,不知道是那种情况,不影响效果,就懒得手动生成了。

但可以在*.pro中设置

QML_IMPORT_PATH =../mywin   #mywin为插件所在目录
#这样可以代替typeinfo plugin_name.qmltypes来支持语法高亮
#注意只能使用系统标准路径语法,即‘../’而不是使用Qt宏来设置,如$$PWD/mywin,这样时无法高亮的
#这样对于qml组件和c++定义的qml组件都可以语法高亮了

上运行图:

一切预期一样。

 

 

这篇关于自定义QML扩展插件与调用一步一脚印的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/176760

相关文章

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Java常用注解扩展对比举例详解

《Java常用注解扩展对比举例详解》:本文主要介绍Java常用注解扩展对比的相关资料,提供了丰富的代码示例,并总结了最佳实践建议,帮助开发者更好地理解和应用这些注解,需要的朋友可以参考下... 目录一、@Controller 与 @RestController 对比二、使用 @Data 与 不使用 @Dat

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth