qml中qmlRegisterSingletonType单例的使用

文章介绍了如何在QML中使用C++实现单例类,通过`qmlRegisterSingletonType`进行注册,并展示了如何在qml文件中导入和使用该单例类,以及相关的属性操作和信号处理。
摘要由CSDN通过智能技术生成

这是一种常用的交互方式,直接上代码;

main.cpp中将单例类注册进去,这个单例有点不单例,大家可以根据情况修改

    // 单例
    qmlRegisterSingletonType("MySingleApi", 1, 0, "MyApi", [](QQmlEngine *engine, QJSEngine *scriptEngine) -> QJSValue {
        Q_UNUSED(engine)

        static int seedValue = 5;
        QJSValue example = scriptEngine->newObject();
        example.setProperty("someProperty", seedValue++);
        return example;
    });
    
    // 1: 注册号,23,主次版本号,调用名,单例的返回函数
    qmlRegisterSingletonType<MySingleton>("MySingleApi", 1, 0, "MySingleApi", instance);

cpp文件:

class MySingleton : public QObject
{
    Q_OBJECT
    Q_PROPERTY(int someProperty READ someProperty WRITE setSomeProperty NOTIFY somePropertyChanged)
public:
    explicit MySingleton(QObject* parent = nullptr);
    MySingleton* instance(); // 获取单例实例

    // 添加其他成员函数和属性...
    Q_INVOKABLE int doSomething() {
        setSomeProperty(5);
        return m_someProperty;
    }

    int someProperty() const { return m_someProperty; }
    void setSomeProperty(int val) {
        m_someProperty = val;
        emit somePropertyChanged(val);
    }

signals:
    void somePropertyChanged(int newValue);

private:
    static MySingleton *m_instance; // 单例实例
    int m_someProperty;   // 数据
};


、、 --------------------------------------------


MySingleton* MySingleton::m_instance = nullptr;

MySingleton *MySingleton::instance()
{

    // SingletonTypeExample *example = new SingletonTypeExample();
    // return example;
    static MySingleton *ins = new MySingleton;
    return ins;
}

MySingleton::MySingleton(QObject* parent) : QObject(parent)
{
    // 初始化单例
}

qml文件:

// 单例,导入的方式
import MySingleApi 1.0

Window {
    width: 640
    height: 480
    visible: true
    title: qsTr("Hello World")
    property int someValue: MySingleApi.doSomething()
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值