This repository has been archived on 2024-07-22. You can view files and clone it, but cannot push or open issues or pull requests.
Doric/doric-Qt/doric/resources/vlayout.qml

118 lines
3.1 KiB
QML
Raw Normal View History

2021-02-23 14:28:08 +08:00
import QtQuick 2.12
import QtQuick.Controls 2.5
import QtQuick.Layouts 1.15
2021-02-23 14:28:08 +08:00
import "util.mjs" as Util
import "gravity.mjs" as Gravity
Rectangle {
2021-04-07 10:41:34 +08:00
property var wrapper
2021-04-06 17:07:48 +08:00
clip: true
property var tag: "VLayout"
property var uuid: Util.uuidv4()
property int widthSpec: 0
property int heightSpec: 0
property int childrenRectWidth: childrenRect.width
property int childrenRectHeight: childrenRect.height
2021-04-07 10:41:34 +08:00
onWidthChanged: {
console.log(tag, uuid + " onWidthChanged: " + this.width)
}
2021-04-07 10:41:34 +08:00
onHeightChanged: {
console.log(tag, uuid + " onHeightChanged: " + this.height)
}
2021-04-07 10:41:34 +08:00
onWidthSpecChanged: {
console.log(tag, uuid + " onWidthSpecChanged: " + this.widthSpec)
console.log(tag, uuid + " parent width: " + parent.width)
if (this.widthSpec === 2) {
this.width = parent.width
children[1].width = parent.width
}
}
2021-04-07 10:41:34 +08:00
onHeightSpecChanged: {
console.log(tag, uuid + " onHeightSpecChanged: " + this.heightSpec)
console.log(tag, uuid + " parent height: " + parent.height)
2021-02-24 10:50:41 +08:00
if (this.heightSpec === 2) {
this.height = parent.height
children[1].height = parent.height
}
}
2021-04-07 10:41:34 +08:00
onChildrenRectChanged: {
console.log(tag, uuid + " widthSpec: " + widthSpec + " heightSpec: " + heightSpec)
2021-03-16 15:33:24 +08:00
console.log(tag, uuid + " onChildrenRectChanged: " + childrenRect)
this.childrenRectWidth = childrenRect.width
this.childrenRectHeight = childrenRect.height
if (this.widthSpec === 1) {
this.width = childrenRectWidth
}
if (this.heightSpec === 1) {
this.height = childrenRectHeight
}
}
color: 'transparent'
MouseArea {
anchors.fill: parent
onClicked: {
2021-04-07 10:41:34 +08:00
console.log(tag, uuid + " wrapper: " + wrapper)
mouseAreaBridge.onClick(wrapper)
}
}
ColumnLayout {
property int gravity: 0
spacing: 0
Item {
id: head
objectName: "head"
}
2021-04-07 10:41:34 +08:00
onChildrenChanged: {
console.log(tag, uuid + " gravity: " + gravity)
for (var i = 0;i !== children.length;i++) {
if (children[i] !== head && children[i] !== tail) {
switch(this.gravity) {
case Gravity.enumerate().CENTER_X:
children[i].Layout.alignment = Qt.AlignHCenter
break
case Gravity.enumerate().CENTER:
children[i].Layout.alignment = Qt.AlignCenter
break
}
}
}
if (gravity === Gravity.enumerate().CENTER || gravity === Gravity.enumerate().CENTER_Y) {
head.Layout.fillHeight = true
}
2021-04-08 10:14:49 +08:00
if (parent.heightSpec == 1) {
tail.Layout.fillHeight = false
} else {
tail.Layout.fillHeight = true
}
}
Item {
id: tail
objectName: "tail"
}
}
}