For instance, if I wish to anchor to the parent element, regardless of what its id is, I can write anchors.top: parent.bottom
. But what if I wish to anchor to the previous sibling, or next sibling? Can that only be done by id, or is there a way to say it generically?
Here we arrive!!
import QtQuick 2.0
Rectangle {
width: 800; height: 400
//if item is not parented, -1 is returned
function itemIndex(item) {
if (item.parent == null)
return -1
var siblings = item.parent.children
for (var i = 0; i < siblings.length; i++)
if (siblings[i] == item)
return i
return -1 //will never happen
}
//returns null, if the item is not parented, or is the first one
function previousItem(item) {
if (item.parent == null)
return null
var index = itemIndex(item)
return (index > 0)? item.parent.children[itemIndex(item) - 1]: null
}
//returns null, if item is not parented, or is the last one
function nextItem(item) {
if (item.parent == null)
return null
var index = itemIndex(item)
var siblings = item.parent.children
return (index < siblings.length - 1)? siblings[index + 1]: null
}
Rectangle {
width: 200; height: 200
color: "red"
}
Rectangle {
id: green
width: 200; height: 200
color: "green"
property Item previous: previousItem(green)
anchors.left: (previous != null)? previous.right: undefined
property Item next: nextItem(green)
anchors.right: (next != null)? next.left: undefined
}
Rectangle {
width: 200; height: 200
anchors.right: parent.right
color: "blue"
}
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With