QML Item 元素

Item 是 QML 中最基础的视觉元素,作为所有可视组件的基类,它提供了基本的属性和功能,但不具有可视化表现(没有颜色、边框等)。

核心属性

属性 类型 默认值 描述
x real 0 X 坐标位置
y real 0 Y 坐标位置
width real 0 宽度
height real 0 高度
z real 0 Z 轴顺序(堆叠顺序)
opacity real 1.0 透明度(0.0-1.0)
visible bool true 是否可见
enabled bool true 是否接受用户输入
clip bool false 是否裁剪子项超出部分

布局相关属性

属性 类型 描述
anchors AnchorLine 锚定系统
baselineOffset real 基线偏移
transform list<Transform> 变换列表
transformOrigin enumeration 变换原点

常用信号

信号 描述
onXChanged X 坐标改变时触发
onYChanged Y 坐标改变时触发
onWidthChanged 宽度改变时触发
onHeightChanged 高度改变时触发
onChildrenChanged 子项变化时触发

基本用法

qml

复制代码
import QtQuick 2.15

Item {
    id: rootItem
    width: 400
    height: 300
    
    // 作为容器使用
    Item {
        x: 50
        y: 50
        width: 200
        height: 200
        
        Rectangle {
            width: 100
            height: 100
            color: "red"
        }
    }
    
    // 不可见的交互区域
    Item {
        width: 50
        height: 50
        x: 300
        y: 200
        
        MouseArea {
            anchors.fill: parent
            onClicked: console.log("点击了不可见区域")
        }
    }
}

作为组件基类

qml

复制代码
// MyComponent.qml
Item {
    property alias color: rect.color
    property string text
    
    width: 150
    height: 50
    
    Rectangle {
        id: rect
        anchors.fill: parent
        color: "lightblue"
    }
    
    Text {
        text: parent.text
        anchors.centerIn: parent
    }
}

// 使用自定义组件
MyComponent {
    text: "自定义项"
    color: "salmon"
}
相关推荐
人还是要有梦想的7 天前
QT qml布局讲解
qt·布局·qml
Rookie Linux11 天前
使用Qt6 QML以及第三方库FluentUI、PCapPlusPlus开发一个自定义抓包软件
网络·c++·qt·cmake·qml
谁刺我心12 天前
[QtCPP]Examples使用示例-QtMultimedia、QMediaPlayer、Audio音频引擎测试mp3播放
qt·音视频·qml
Quz12 天前
Qt Quick 粒子系统(二):系统控制与生命周期管理
qt·qml·粒子系统
Quz13 天前
Qt Quick 粒子系统(三):发射器深度解析
qt·qml·粒子系统
nnnnichijou14 天前
Qt 6.9 嵌入式 Linux 交叉编译全栈填坑指南(以树莓派5 AArch64 为例
qt·嵌入式·交叉编译·qml·树莓派5
Quz15 天前
Qt Quick 粒子系统(一):架构总览与四层模型
qt·架构·qml
Ulyanov21 天前
深入QML-Python通信 构建响应式交互界面的桥梁设计:QML+PySide6现代开发入门(五)
开发语言·python·算法·交互·qml·系统仿真
东方.既白1 个月前
QML简易地铁导乘屏
qml
Ulyanov1 个月前
PySide6 + QML 混合编程全景解析:从底层原理到企业级实战
python·pyside6·qml·雷达电子对抗