Qt Application和qml页面通信传递数据

1:第一步,创建中间类
也就是自己定义一个继承于QObject 的类 Class Trans
这个类用来和qml进行绑定链接,不用主窗口类,尽量分开,不然关系太绕了

.H

#ifndef TRANSOBJ_H
#define TRANSOBJ_H
//TransObj.h
#pragma once

#include <QObject>
#include <QDebug>
#include <QString>
class Trans : public QObject  //自己定义的类,需要继承与QObject  
{
    Q_OBJECT
public:
    Trans();
    ~Trans();

public:  //这个getValFromQml 加了Q_INVOKABLE 宏,代表和qml进行绑定
    Q_INVOKABLE void getValFromQml(QString name,float v);  //链接需要绑定的函数
signals:
    void valueFromCpp(int val);
};


#endif // TRANSOBJ_H

.C++

#include "Transobj.h"
#include <QDebug>
#include <QString>
 Trans::Trans()
{
}
Trans:: ~Trans()
{
}

void Trans::getValFromQml(QString name,float v)
{
    qDebug()<<"Qml:"<<name<<"value:"<<v<<endl;  //打印信息
}

2:在加载qml页面前将类进行绑定
在主窗口类里面定义一个 类对象
Trans trans //这就是为啥不用主窗口类来做中间类的原因,防止出现两个窗口
绑定操作

	//函数名字千万别写错了,有几个很相近的接口
	//其中的quickWidget是在qt界面设计里面添加的,qml只能通过这个添加页面的qt应用程序
 ui->quickWidget->rootContext()->setContextProperty("trans",&trans);//绑定中间类
 ui->quickWidget->setSource(QUrl::fromLocalFile(":/Qml/wk_001.qml")); //加载页面

3:在qml中使用

     Slider {  //滑块
         id: slider
         x: 84
         y: 41
         to: 50
         from: -50
         value: 0
         stepSize: 0.1
         Connections{
             target: spinBox
             onValueChanged:{
                 slider.value = spinBox.value
             }
         }
         //在这里直接调用trans里面的函数就可以
         onValueChanged: trans.getValFromQml("温度",slider.value);
         }

当温度改变时,调用函数,传递参数,这样就可以根据传入的参数来设置不同的值了
在这里插入图片描述

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

漏洞百出

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值