当前位置: 首页 > news >正文

QML布局相关-盒子模型

在 QML(Qt Modeling Language)中,布局相关的几个常见术语包括 margin、spacing、padding 和 border。这些术语主要出现在使用 Qt Quick Controls 或 Qt Quick Layouts 模块进行界面设计时。下面分别解释它们的含义和用途:

🔹 1. Margin(外边距)

含义:Margin 表示控件外部与其父容器或其他相邻控件之间的空间。它控制一个元素与其他元素之间的“外部”距离。

类比 CSS:类似于 CSS 中的 margin。

QML 示例:
Rectangle {
width: 200; height: 100
color: “lightblue”
anchors.centerIn: parent
anchors.margins: 20 // 控件离父窗口边界的距离为20
}

或者在使用 Layout 时:
RowLayout {
anchors.fill: parent
spacing: 10
Rectangle {
Layout.fillWidth: true
Layout.leftMargin: 10 // 左边距为10
Layout.rightMargin: 20 // 右边距为20
height: 50
color: “red”
}
}

🔹 2. Spacing(间距)

含义:Spacing 用于布局内部多个子项之间保持一致的间隔。它是在像 RowLayout、ColumnLayout、GridLayout 等布局中使用的。

类比 CSS:类似 CSS Flexbox 的 gap 属性或 margin 的组合效果。

QML 示例:
RowLayout {
width: parent.width
spacing: 15 // 每个子控件之间保持15像素的距离
Rectangle { Layout.preferredWidth: 50; height: 50; color: “red” }
Rectangle { Layout.preferredWidth: 50; height: 50; color: “green” }
Rectangle { Layout.preferredWidth: 50; height: 50; color: “blue” }
}

🔹 3. Padding(内边距)

含义:Padding 表示控件内部内容与控件边框之间的空间。它影响的是控件内部元素的布局位置,比如 Text 在 Rectangle 内的位置。

注意:QML 原生控件不直接提供 padding 属性,但某些容器如 Item, Control, ScrollView 等通过 padding 属性支持;也可以通过 Item 的 topPadding、leftPadding 等属性设置。

类比 CSS:相当于 CSS 的 padding。

QML 示例:
Button {
text: “Click Me”
padding: 10 // 文本与按钮边缘之间的距离为10
}

或者在容器中:
Item {
padding: 10
Text {
text: “Hello”
}
}

🔹 4. Border(边框)

含义:Border 表示控件的边界线条,通常用于装饰或突出显示控件区域。它包括边框宽度、颜色、样式等。

QML 示例:
Rectangle {
width: 100; height: 50
color: “yellow”
border.width: 2
border.color: “black”
}

还可以使用 radius 设置圆角:
Rectangle {
width: 100; height: 50
radius: 10
border.width: 1
border.color: “gray”
}

✅ 总结对比表:

名称 含义 类比 CSS QML 示例

Margin 控件与外部元素之间的空白 margin anchors.margins, Layout.leftMargin

Spacing 布局中多个子控件之间的间隔 gap / margin RowLayout { spacing: 10 }

Padding 控件内容与控件边框之间的空白 padding padding: 10, topPadding 等

Border 控件边框的宽度、颜色和样式 border border.width, border.color

如需进一步了解 QML 布局系统,可以参考官方文档:

🔗 https://doc.qt.io/qt-6/qtquicklayouts-index.html
🔗 https://doc.qt.io/qt-6/qml-qtquick-controls2-control.html

http://www.cnnetsun.cn/news/151474.html

相关文章:

  • Open-AutoGLM vs 竞品:谁才是长链路AI任务处理的真正王者?
  • Web安全测试
  • 当AI实现想法易如反掌时,洞见真正的需求成为关键——某知名密码分析工具的用户反馈挖掘
  • 【干货收藏】企业AI架构实战指南:从框架搭建到场景落地的底层逻辑
  • 收藏这份2025AI高薪指南!大厂抢人大战开启,小白程序员学习大模型正当时
  • 13、FPGA更新与可编程性:安全与应用解析
  • 18、多核心可重构嵌入式系统的安全设计与实现
  • 双非本科生的AI行业逆袭之路:我的经验与心得分享!
  • 运维岗位这么多,你适合哪一个
  • 基于微信小程序的在线家庭娱乐系统毕业设计源码
  • 为什么90%的企业用不好Open-AutoGLM?:硬件选型不当成最大瓶颈(附行业适配白皮书)
  • 模型体积缩小80%仍保持95%精度?Open-AutoGLM量化策略深度拆解
  • 2026年AI产品经理终极学习路线:传统产品经理的转型指南,超详细攻略,不容错过!
  • 【AI Agent可靠性突围】:Open-AutoGLM 7类错误恢复方案实测数据曝光
  • FaceFusion如何优化夜间低光环境下的人脸处理?
  • Open-AutoGLM接入成本大曝光:4个维度评估你的适配级别
  • Open-AutoGLM接口开放度实测:8项关键指标评分,你的项目适合接入吗?
  • 主流AutoGLM框架错误恢复能力对比,哪个真正提升任务成功率?
  • 【AI框架二次开发新标杆】:Open-AutoGLM 4大可扩展性设计,为何被头部企业争相采用?
  • FaceFusion镜像每日下载量突破5000次
  • 从零基础转行渗透测试到如今20k,我经历了什么?
  • 土木人“提桶跑路”零基础转行网络安全,成功实现月入过万
  • HGDB如何提升批量导入数据的速度
  • 11、加勒比与北美地区房地产投资指南
  • 42、太赫兹通信与可见光通信:5G 及未来的前沿技术
  • 46、5G及未来通信中的协同网络技术解析
  • 47、协同网络:过去、现在与未来
  • 50、5G及未来的灵活认知无线电接入技术与频谱感知
  • 58、5G及未来的物理层安全设计
  • 文献综述期末项目的撰写方法与实践研究