2014-01-08 50 views
3

我的想法是在列表中创建一堆QObject驱动类的实例(用C++创建)。然后将此列表传递给QML,并且可以通过单独的QML对象查看每个条目。现在我希望能够将特定实例传递回C++(例如,单击时)。QObject从C++到QML到QML到C++(在列表中)

下面是一些代码:

QObject的派生类

class Data : public QObject 
{ 
    Q_OBJECT 
    Q_PROPERTY(QString name READ name NOTIFY nameChanged) 

    Data(std::string n):_name(n){}; 
    QString name(){return QString::fromStdString(_name);}; 
signals: 
    void nameChanged(); 
private: 
    std::string _name; 
} 

控制器(创建列表并接收选择的实例)

class Controller : public QObject 
{ 
    Q_OBJECT 
    Q_PROPERTY(QQmlListProperty<Data> list READ list NOTIFY listChanged) 

    Controller() 
    { 
     _list.append(new Data("data 1"); 
     _list.append(new Data("data 2"); 
     _list.append(new Data("data 3"); 
    }; 
    QQmlListProperty<Data> list() // <--- provide data to QML 
    { 
     return QQmlListProperty<Grammar>(this, _list); 
    }; 
    void takeThisOne(Data* d)// <--- receive selected instance from QML 
    { 
     //do something with d 
    } 
signals: 
    void listChanged(); 
private: 
    QList<Data*> _list; 
} 

QML主(显示数据列表)

ApplicationWindow 
{ 
    id: mainWindowContainer 
    width: 800 
    height: 500 

    ListView 
    { 
     id: dataList 
     delegate: Rectangle{ 
        height: 10 
       width: 100 
        Text{text: name} 
        } 
     model: controller.list // <-- what data type are the list items here? 
    } 

    Button 
    { 
     id: btnOpen 
     text: "open selected Data in the DataViewer" 
     onClicked{ 
      // what data type is dataList.currentItem and dataList.currentItem.modelData? 
      var dataViewer = Qt.createComponent("DataViewer.qml").createObject(mainWindowContainer, {data: dataList.currentItem.modelData}); 
      dataViewer.show()} 
    } 
} 

QML DataViewer(显示数据并将其返回给控制器)​​

Window 
{ 
    height: 400 
    width: 800 
    property variant data // <--- tried 'property Data data', but did not work 

    TextArea 
    { 
     text: data.name 
    } 

    Button 
    { 
     id: btnReturn 
     text: "return to controller" 
     onClicked: {controller.takeThisOne(data)} // <--- does not work 
    } 
} 

我希望这个示例代码是可以理解的。感谢您的帮助!

编辑:

我做的主要qmlRegisterType<Data>()。还尝试了qmlRegisterType<Data>("stuff", 1, 0, "Data")并将stuff 1.0导入到DataViewer中。 的问题是,我不知道哪个数据类型我的数据是在不同的点:

Controller: list of Data* 
QML main : list of ??? 
      dataList.currentItem = ??? 
      dataList.currentItem.modelData = ??? 
DataViewer: variant or Data (according to property type, but Data does not work) 
Controller: obviously not Data* as hoped, but what else? 
+0

您是否注册过QML的'Data'类型?即''qmlRegisterType ();'在你的main()中。 – Dickson

+0

是的,我做到了。我在该问题中添加了一些更多的细节 – Bert

+0

尝试向DataViewer传递'{data:dataList.currentItem}'而不是'dataList.currentItem.modelData'。 'dataList.currentIndex'必须先设置才能获得'currentItem'。 – Dickson

回答

1

我终于想通了如何做到这一点!诀窍是使用

{data: dataList.model[dataList.currentIndex]}

,而不是{data: dataList.currentItem]}{data: dataList.currentItem.modelData]}在main.qml。尽管我仍然不知道使用了哪些数据类型,以及为什么currentItem似乎使用与[dataList.currentIndex]不同的数据类型,这完全适用!