qml调用c++类内函数的三种方法
一.方法一:使用 Q_INVOKABLE 宏声明成员函数
1.第一步:依然需要新建一个类NetworkHandler:
#include <QObject>
class NetworkHandler : public QObject
{
Q_OBJECT
public:
explicit NetworkHandler(QObject *parent = nullptr);
Q_INVOKABLE void onConnetClicked();
Q_INVOKABLE void onTestClicked();
Q_INVOKABLE void setValue(int newValue);
Q_INVOKABLE int getValue();
signals:
void valueChanged(int value);
void kkYUy(QString str);
private slots:
void networ_slots();
};
注意:依然需要使用 Q_INVOKABLE 这个宏声明成员函数,将函数申明为元对象系统可调用的函数,Q_INVOKABLE声明后的函数即可在qml中调用。
2.第二步:在main.cpp中进行注册:
#include <QQmlContext>
#include <QQmlEngine>
#include "network.h"
int main(int argc, char *argv[])
{
set_qt_environment();
QGuiApplication app(argc, argv);
qmlRegisterType<NetworkHandler>("NetLibrary", 1, 0, "NetworkHandler");
QQmlApplicationEngine engine;
const QUrl url(u"qrc:/qt/qml/Main/main.qml"_qs);
QObject::connect(
&engine,
&QQmlApplicationEngine::objectCreated,
&app,
[url](QObject *obj, const QUrl &objUrl) {
if (!obj && url == objUrl)
QCoreApplication::exit(-1);
},
Qt::QueuedConnection);
engine.addImportPath(QCoreApplication::applicationDirPath() + "/qml");
engine.addImportPath(":/");
engine.load(url);
if (engine.rootObjects().isEmpty()) {
return -1;
}
return app.exec();
}
注册语句:qmlRegisterType<NetworkHandler>("NetLibrary", 1, 0, "NetworkHandler");
其中NetLibrary是QML中的组件名,1.0是组件版本号,NetworkHandler是用于QML中的类名。
第三步:修改一下QML文件:
import QtQuick 6.0
import QtQuick.Controls 6.0
import NetLibrary 1.0
ApplicationWindow {
visible: true
width: 640
height: 480
title: qsTr("QML Button Example")
Column {
id: buttonRow
anchors.fill: parent
spacing: 20
NetworkHandler{
id:networkClass
}
Button {
id: button1
text: qsTr("button1")
onClicked: {
console.log("Button clicked12!")
networkClass.onConnetClicked()
networkClass.setValue(1)
button1.text = qsTr("Clicked1!")
}
}
}
}
说明:
import NetLibrary 1.0 是在 main.cpp中进行注册了类型的版本化命名空间。
导入之后,就可以如下所示 调用NetworkHandler进行实例化,并设置id为networkClass:
NetworkHandler
{
id:networkClass
}
在两个button的点击事件中,就能通过 实例化对象 networkClass调用 第一步 被 Q_INVOKABLE声明的函数了。
二.方式二:信号槽方式
1.第一步:依然需要新建一个类NetworkHandler:
#include <QObject>
class NetworkHandler : public QObject
{
Q_OBJECT
public:
explicit NetworkHandler(QObject *parent = nullptr);
Q_INVOKABLE void onConnetClicked();
Q_INVOKABLE void onTestClicked();
Q_INVOKABLE void setValue(int newValue);
Q_INVOKABLE int getValue();
signals:
void valueChanged(int value);
void kkYUy(QString str);
private slots:
void networ_slots();
};
注意:信号函数前不用加入Q_INVOKABLE宏
2.第二步:在main.cpp中进行注册:
#include <QQmlContext>
#include <QQmlEngine>
#include "network.h"
int main(int argc, char *argv[])
{
set_qt_environment();
QGuiApplication app(argc, argv);
qmlRegisterType<NetworkHandler>("NetLibrary", 1, 0, "NetworkHandler");
QQmlApplicationEngine engine;
const QUrl url(u"qrc:/qt/qml/Main/main.qml"_qs);
QObject::connect(
&engine,
&QQmlApplicationEngine::objectCreated,
&app,
[url](QObject *obj, const QUrl &objUrl) {
if (!obj && url == objUrl)
QCoreApplication::exit(-1);
},
Qt::QueuedConnection);
engine.addImportPath(QCoreApplication::applicationDirPath() + "/qml");
engine.addImportPath(":/");
engine.load(url);
if (engine.rootObjects().isEmpty()) {
return -1;
}
return app.exec();
}
注册语句:qmlRegisterType<NetworkHandler>("NetLibrary", 1, 0, "NetworkHandler");
其中NetLibrary是QML中的组件名,1.0是组件版本号,NetworkHandler是用于QML中的类名。
第三步:修改一下QML文件:
import QtQuick 6.0
import QtQuick.Controls 6.0
import NetLibrary 1.0
ApplicationWindow {
visible: true
width: 640
height: 480
title: qsTr("QML Button Example")
Column {
id: buttonRow
anchors.fill: parent
spacing: 20
NetworkHandler{
id:networkClass
}
Connections{ //信号-槽连接
target: networkClass
function onValueChanged(value){
console.log("/*-----------收到信号----------*/")
console.log(value)
}
}
Button {
id: button1
text: qsTr("button1")
onClicked: {
console.log("Button clicked12!")
networkClass.onConnetClicked()
networkClass.setValue(1)
button1.text = qsTr("Clicked1!")
}
}
}
}
说明:定义一个槽函数来接收c++中发送过来的信号
Connections{ //信号-槽连接
target: networkClass
function onValueChanged(value){
console.log("/*-----------收到信号----------*/")
console.log(value)
}
}
注意:在c++类中定义的信号是 valueChanged(),在Qml中进行监听 需要在前面加 "on",首字母大写,变为onValueChanged:{}
三.方式三:通过Q_PROPERTY宏来实现
1.第一步:依然需要新建一个类MyClass:
#include <QDebug>
#include <QObject>
class MyClass : public QObject
{
Q_OBJECT
Q_PROPERTY(int value READ getValue WRITE setValue NOTIFY valueChanged)
public:
MyClass(QObject *parent = nullptr) : QObject(parent), m_value(0) {}
int getValue() const {
qDebug()<<"MyClass--------getValue-----:"<<m_value;
return m_value;
}
void setValue(int value) {
if (m_value != value) {
m_value = value;
qDebug()<<"MyClass--------setValue-----:"<<m_value;
emit valueChanged(m_value);
}
}
signals:
void valueChanged(int newValue);
private:
int m_value;
};
说明:
Q_PROPERTY(int value READ getValue WRITE setValue NOTIFY valueChanged) 是 Qt 开发框架中的一个宏定义,用于在 QObject 的派生类中声明一个属性,
并为该属性提供读写接口以及属性值变化时的通知信号。
声明属性:
通过 Q_PROPERTY 宏,可以在 QObject 的派生类中声明一个名为 value 的属性。
该属性可以被 Qt 的属性系统识别和访问。
提供读写接口:
READ getValue 指定了读取 value 属性值的函数 getValue。
WRITE setValue 指定了设置 value 属性值的函数 setValue。
这两个函数分别用于获取和设置属性的值,从而实现了对属性值的封装和保护。
属性变化通知:
NOTIFY valueChanged 指定了当 value 属性值发生变化时发出的通知信号 valueChanged。
这允许其他对象或组件在属性值变化时采取相应的行动,如更新界面或触发其他逻辑。
注意:
这种方式只能修改类的一个属性值,一般类型比较简单,就是int、QString这种;如果需要调用类的自定方法建议还是用方式一中的Q_INVOKABLE宏方式。
2.第二步:在main.cpp中进行注册:
#include "test.h"
int main(int argc, char *argv[])
{
set_qt_environment();
QGuiApplication app(argc, argv);
qmlRegisterType<MyClass>("MyLibrary", 1, 0, "MyClass");
QQmlApplicationEngine engine;
const QUrl url(u"qrc:/qt/qml/Main/main.qml"_qs);
QObject::connect(
&engine,
&QQmlApplicationEngine::objectCreated,
&app,
[url](QObject *obj, const QUrl &objUrl) {
if (!obj && url == objUrl)
QCoreApplication::exit(-1);
},
Qt::QueuedConnection);
engine.addImportPath(QCoreApplication::applicationDirPath() + "/qml");
engine.addImportPath(":/");
engine.load(url);
if (engine.rootObjects().isEmpty()) {
return -1;
}
return app.exec();
}
注册语句:qmlRegisterType<MyClass>("MyLibrary", 1, 0, "MyClass");
第三步:修改一下QML文件:
import QtQuick 6.0
import QtQuick.Controls 6.0
import MyLibrary 1.0
ApplicationWindow {
visible: true
width: 640
height: 480
title: qsTr("QML Button Example")
Column {
id: buttonRow
anchors.fill: parent
spacing: 20
MyClass{
id:myClass
}
Button {
id: button1
text: qsTr("button1")
onClicked: {
console.log("Button clicked12!")
console.log("myClass.value:",myClass.value)
myClass.value=2
button1.text = qsTr("Clicked1!")
}
}
}
}
调用语句:
console.log("myClass.value:",myClass.value) //获取value值
myClass.value=2 //设置value值
运行后log输出:
MyClass--------getValue-----: 0
qml: myClass.value: 0
MyClass--------setValue-----: 2
相关文章:
qml调用c++类内函数的三种方法
一.方法一:使用 Q_INVOKABLE 宏声明成员函数 1.第一步:依然需要新建一个类NetworkHandler: #include <QObject> class NetworkHandler : public QObject { Q_OBJECT public: explicit NetworkHandler(QObject *parent nullptr); Q_INVOKAB…...

NLP任务四大范式的进阶历程:从传统TF-IDF到Prompt-Tuning(提示词微调)
引言:从TF-IDF到Prompt-Tuning(提示词微调),NLP的四次变革 自然语言处理(NLP)技术从最早的手工特征设计到如今的Prompt-Tuning,经历了四个重要阶段。随着技术的不断发展,我们的目标…...

GAMES101:现代计算机图形学入门-笔记-09
久违的101图形学回归咯 今天的话题应该是比较轻松的:聊一聊在渲染中比较先进的topics Advanced Light Transport 首先是介绍一系列比较先进的光线传播方法,有无偏的如BDPT(双向路径追踪),MLT(梅特罗波利斯…...

【Db First】.NET开源 ORM 框架 SqlSugar 系列
.NET开源 ORM 框架 SqlSugar 系列 【开篇】.NET开源 ORM 框架 SqlSugar 系列【入门必看】.NET开源 ORM 框架 SqlSugar 系列【实体配置】.NET开源 ORM 框架 SqlSugar 系列【Db First】.NET开源 ORM 框架 SqlSugar 系列【Code First】.NET开源 ORM 框架 SqlSugar 系列 …...

MySQL聚合查询分组查询联合查询
#对应代码练习 -- 创建考试成绩表 DROP TABLE IF EXISTS exam; CREATE TABLE exam ( id bigint, name VARCHAR(20), chinese DECIMAL(3,1), math DECIMAL(3,1), english DECIMAL(3,1) ); -- 插入测试数据 INSERT INTO exam (id,name, chinese, math, engli…...

告别照相馆!使用AI证件照工具HivisionIDPhotos打造在线证件照制作软件
文章目录 前言1. 安装Docker2. 本地部署HivisionIDPhotos3. 简单使用介绍4. 公网远程访问制作照片4.1 内网穿透工具安装4.2 创建远程连接公网地址 5. 配置固定公网地址 前言 本文主要介绍如何在Linux系统使用Docker快速部署一个AI证件照工具HivisionIDPhotos,并结合…...

通信原理第三次实验
实验目的与内容 实验操作与结果 5.1 刚开始先不加入白噪声,系统设计如下: 正弦波参数设置如下: FM设计如下: 延迟设计如下: 两个滤波器设计参数如下: 输出信号频谱为(未加入噪声)&a…...

【halcon】Metrology工具系列之 get_metrology_object_result_contour
get_metrology_object_result_contour (操作员) 名称 get_metrology_object_result_contour — 查询测量对象的结果轮廓。 签名 get_metrology_object_result_contour( : Contour : MetrologyHandle, Index, Instance, Resolution : ) 描述 get_metrology_object_result_…...

A052-基于SpringBoot的酒店管理系统
🙊作者简介:在校研究生,拥有计算机专业的研究生开发团队,分享技术代码帮助学生学习,独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取,记得注明来意哦~🌹 赠送计算机毕业设计600…...

NLP信息抽取大总结:三大任务(带Prompt模板)
信息抽取大总结 1.NLP的信息抽取的本质?2.信息抽取三大任务?3.开放域VS限定域4.信息抽取三大范式?范式一:基于自定义规则抽取(2018年前)范式二:基于Bert下游任务建模抽取(2018年后&a…...

python常见问题-pycharm无法导入三方库
1.运行环境 python版本:Python 3.9.6 需导入的greenlet版本:greenlet 3.1.1 2.当前的问题 由于需要使用到greenlet三方库,所以进行了导入,以下是我个人导入时的全过程 ①首先尝试了第1种导入方式:使用pycharm进行…...

迅为RK3588开发板Android系统开发笔记-使用ADB工具
1 使用 ADB 工具 ADB 英文名叫 Android debug bridge ,是 Android SDK 里面的一个工具,用这个工具可以操作管理 Android 模拟器或者真实的 Android 设备,主要的功能如下所示: 在 Android 设备上运行 shell 终端,用命…...
什么是分布式数据库?
随着现代互联网应用和大数据时代的到来,分布式数据库成为了解决大规模数据存储和高并发处理的核心技术之一。本文将通过深入浅出的方式,带你全面理解分布式数据库的概念、工作原理以及底层实现技术。无论你是刚刚接触分布式数据库的开发者,还…...
Leetcode 3363. Find the Maximum Number of Fruits Collected
Leetcode 3363. Find the Maximum Number of Fruits Collected 1. 解题思路2. 代码实现 题目链接:3363. Find the Maximum Number of Fruits Collected 1. 解题思路 这一题是一道陷阱题…… 乍一眼看过去,由于三人的路线完全可能重叠,因此…...
【数据仓库 | Data Warehouse】数据仓库的四大特性
1. 前言 数据仓库是用于支持管理和决策的数据集合,它汇集了来自不同数据源的历史数据,以便进行多维度的分析和报告。数据仓库的四大特点是:主题性,集成性,稳定性,时变性。 2. 主题性(Subject-Oriented) …...
springboot配置多数据源mysql+TDengine保姆级教程
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、pom文件二、yamlDataSourceConfigServiceMapper.xml测试总结 前言 Mybatis-plus管理多数据源,数据库为mysql和TDengine。 一、pom文件 <de…...

dns实验2:反向解析
启动服务: 给虚拟机网卡添加IP地址: 查看有几个IP地址: 打开配置文件: 重启服务,该宽松模式,关闭防火墙: 本机测试: windows测试:(本地shell)...

ZooKeeper 基础知识总结
先赞后看,Java进阶一大半 ZooKeeper 官网这样介绍道:ZooKeeper 是一种集中式服务,用于维护配置信息、命名、提供分布式同步和提供组服务。 各位hao,我是南哥,相信对你通关面试、拿下Offer有所帮助。 ⭐⭐⭐一份南哥编写…...
npm库xss依赖的使用方法和vue3 中Web富文本编辑器 wangeditor 使用xss库解决 XSS 攻击的方法
npm库xss依赖的使用方法和vue3 中Web富文本编辑器 wangeditor 使用xss库解决 XSS 攻击的方法 1. npm库xss依赖的使用方法1.1 xss库定义1.2 xss库功能 2. vue3 中 wangeditor 使用xss库解决 XSS 攻击的方法和示例2.1 在终端执行如下命令安装 xss 依赖2.2 在使用 wangeditor 的地…...

微信小程序蓝牙writeBLECharacteristicValue写入数据返回成功后,实际硬件内信息查询未存储?
问题:连接蓝牙后,调用小程序writeBLECharacteristicValue,返回传输数据成功,查询硬件响应发现没有存储进去? 解决:一直以为是这个write方法的问题,找了很多相关贴,后续进行硬件日志…...

大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...

Linux-07 ubuntu 的 chrome 启动不了
文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了,报错如下四、启动不了,解决如下 总结 问题原因 在应用中可以看到chrome,但是打不开(说明:原来的ubuntu系统出问题了,这个是备用的硬盘&a…...

JUC笔记(上)-复习 涉及死锁 volatile synchronized CAS 原子操作
一、上下文切换 即使单核CPU也可以进行多线程执行代码,CPU会给每个线程分配CPU时间片来实现这个机制。时间片非常短,所以CPU会不断地切换线程执行,从而让我们感觉多个线程是同时执行的。时间片一般是十几毫秒(ms)。通过时间片分配算法执行。…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...

初探Service服务发现机制
1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能:服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源…...
作为测试我们应该关注redis哪些方面
1、功能测试 数据结构操作:验证字符串、列表、哈希、集合和有序的基本操作是否正确 持久化:测试aof和aof持久化机制,确保数据在开启后正确恢复。 事务:检查事务的原子性和回滚机制。 发布订阅:确保消息正确传递。 2、性…...

Scrapy-Redis分布式爬虫架构的可扩展性与容错性增强:基于微服务与容器化的解决方案
在大数据时代,海量数据的采集与处理成为企业和研究机构获取信息的关键环节。Scrapy-Redis作为一种经典的分布式爬虫架构,在处理大规模数据抓取任务时展现出强大的能力。然而,随着业务规模的不断扩大和数据抓取需求的日益复杂,传统…...
uniapp 实现腾讯云IM群文件上传下载功能
UniApp 集成腾讯云IM实现群文件上传下载功能全攻略 一、功能背景与技术选型 在团队协作场景中,群文件共享是核心需求之一。本文将介绍如何基于腾讯云IMCOS,在uniapp中实现: 群内文件上传/下载文件元数据管理下载进度追踪跨平台文件预览 二…...

spring Security对RBAC及其ABAC的支持使用
RBAC (基于角色的访问控制) RBAC (Role-Based Access Control) 是 Spring Security 中最常用的权限模型,它将权限分配给角色,再将角色分配给用户。 RBAC 核心实现 1. 数据库设计 users roles permissions ------- ------…...
【WebSocket】SpringBoot项目中使用WebSocket
1. 导入坐标 如果springboot父工程没有加入websocket的起步依赖,添加它的坐标的时候需要带上版本号。 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dep…...