Hello
I'm working on a project that requires creation and management of rectangles, that can be change throughout the course of time, according to some data received by a web socket.
What matters here, is that I want the QMLObjects to be fully "mirrored" in C++ classes, so we only change one object and those changes reflect to the qml rectangles.
So, according to the official QML documentation(http://doc.qt.io/qt-5/qtqml-javascri...tcreation.html), to dynamically create a rectangle I'm using this code:
	
	- function buildZone() { 
-         var component; 
-         var zone; 
-         component = Qt.createComponent("Zone.qml"); 
-         zone = component.createObject(layout, { 
-                                           "x": zoneMapper.x, 
-                                           "y": zoneMapper.getY()+30, 
-                                           "width": zoneMapper.getWidth(), 
-                                           "height": zoneMapper.getHeight(), 
-                                           "objectName": zoneMapper.getId(), 
-                                           "color":"red"}); 
-         zoneMappers.push(zoneMapper); 
-     } 
        function buildZone() {
        var component;
        var zone;
        component = Qt.createComponent("Zone.qml");
        zone = component.createObject(layout, {
                                          "x": zoneMapper.x,
                                          "y": zoneMapper.getY()+30,
                                          "width": zoneMapper.getWidth(),
                                          "height": zoneMapper.getHeight(),
                                          "objectName": zoneMapper.getId(),
                                          "color":"red"});
        zoneMappers.push(zoneMapper);
    }
To copy to clipboard, switch view to plain text mode 
  
This "zoneMapper" is an object that it is instantiated in the main.cpp of a custom class, that has x with a property as follows:
Q_PROPERTY(int x READ getX WRITE setX NOTIFY xChanged)
So when you change "x", it calls a setter in the C++ class, and everything is in sync.
Problem is, when I use a button to change zonneMapper.x, like this:
	
	- Button{ 
-         id:button1 
-         objectName:"Button1" 
-         text:"Button1Text" 
-         onClicked: { 
-             zoneMapper.x +=50; 
-         } 
-     } 
        Button{
        id:button1
        objectName:"Button1"
        text:"Button1Text"
        onClicked: {
            zoneMapper.x +=50;
        }
    }
To copy to clipboard, switch view to plain text mode 
  The dynamically created rectangle doesn't move, although the "setter" and "getter" in the class are called (I can check this with breakpoints)
I noticed though, if I do this, with a static rectangle:
	
	- Rectangle{ 
-         id: staticRect 
-         x:zoneMapper.x 
-         y:30 
-         width:50 
-         height:50 
-         color:"yellow" 
-     } 
        Rectangle{
        id: staticRect
        x:zoneMapper.x
        y:30
        width:50
        height:50
        color:"yellow"
    }
To copy to clipboard, switch view to plain text mode 
  
It moves!!!
I have another problem here, regarding the "mapping" of several rectangles, but's that's stuff for another episode
So, is there a way to bind an object in C++ to a dinamically created qml object?
Thank you
				
			
Bookmarks