先放一个界面效果吧!
data:image/s3,"s3://crabby-images/94520/94520803010e3a120cdaa68d78fdc403b222e386" alt=""
说明:该演示程序为一个App管理程序,可以将多个App进行吸入管理。
(动画中的RedRect为一个带有QSplashScreen的独立应用程序)
- 左侧边栏用的是QQuickView进行.qml文件的加载(即QtQuick环境)
- 右侧是用layout进行QWidget的融入(QtWidgets环境)
- 期间会有多次qml & c++的交互
一、qml中访问c++中的内容
关键点:.h中继承QObject、Q_DECLARE_METATYPE;.cpp中qmlRegisterType
cpp
class AppInfo : public QObject
{
Q_OBJECT
Q_PROPERTY(QString showName READ showName WRITE setShowName NOTIFY showNameChanged)
Q_PROPERTY(QString realName READ realName WRITE setRealName NOTIFY realNameChanged)
Q_PROPERTY(QString coreName READ coreName WRITE setCoreName NOTIFY coreNameChanged)
Q_PROPERTY(QString iconPath READ iconPath WRITE setIconPath NOTIFY iconPathChanged)
public:
AppInfo(QObject* parent = nullptr);
AppInfo(const QString& showName, const QString& realName, const QString& coreName, const QString& iconPath, QObject* parent = nullptr);
AppInfo(const AppInfo& other);
AppInfo& operator=(const AppInfo& other);
bool operator==(const AppInfo& other);
QString showName() const;
QString realName() const;
QString coreName() const;
QString iconPath() const;
void setShowName(const QString& showName);
void setRealName(const QString& realName);
void setCoreName(const QString& coreName);
void setIconPath(const QString& iconPath);
signals:
void showNameChanged();
void realNameChanged();
void coreNameChanged();
void iconPathChanged();
private:
QString showName_;
QString realName_;
QString coreName_;
QString iconPath_;
};
Q_DECLARE_METATYPE(AppInfo)
cpp
qmlRegisterType<AppInfo>();
这样以后,
1.1.可以直接在qml中进行该类的实例化,进而进行访问(qmlRegisterType时需要添加参数);
data:image/s3,"s3://crabby-images/3e377/3e37735b15112026de450c4689624486be509b7e" alt=""
1.2.也可以直接在其他类中直接返回该类指针,直接给qml进行使用(当然前提也是其他类也进行了注册,已经在qml里实例化了)。
1.3.还可以再c++处实例化,然后设置到qml上下文中
data:image/s3,"s3://crabby-images/220c1/220c11785f4b002060f07bd89b93e9deff23cb88" alt=""
2.1.也可以直接继承QAbstractListModel等类,进行实例化,qml中可以直接访问相关属性
data:image/s3,"s3://crabby-images/2d0a0/2d0a0ed95108dcf26bf8831ce66086d413ff6496" alt=""
主要在于红框中的方法的重写。
二、c++中访问qml中的内容
主要在于从qml上下文中获取根QObject*,进而通过findChild进行相关元素的获取。进而通过QMetaObject::invokeMethod进行相关qml中function的调用:
data:image/s3,"s3://crabby-images/93c7f/93c7f759ec41c7d309438a5e000936dbe885b82e" alt=""
data:image/s3,"s3://crabby-images/98156/98156cb6717d6b8f422690cd22694a83f244a380" alt=""
相关注意点:
qml中访问只能访问类的指针,不能访问类对象;
qmlRegisterType注册类时,带了namespace的类,类指针在qml中是不能够访问的。