zoukankan      html  css  js  c++  java
  • QML 布局之一:锚布局详解(各种例子)

    一、简介

    anchors 提供了一种方式,让你可以通过指定一个元素与其他元素的关系来确定元素在界面中的位置,即锚布局。

    你可以想象一下,每个 Item 都有 7 条不可见的辅线:左(left)、水平中心(horizontalCenter)、 上(top)、下(bottom)、右(right)、垂直中心(verticalCenter)、基线(baseline)。如下图所示:


    使用 anchors 布局时,除了对齐锚线,还可以指定上(topMargin)、下(bottomMargin)、 左(leftMargin)、右(rightMargin)四个边的留白。如下图所示:


    而如果你想懒省事儿,也可以使用 margins 属性将四个边的留白设置成一样。

    锚布局是最灵活的一种 Qt Quick 布局方式,使用它你可以随意摆布界面上那些可见元素,不过,如果你的界面元素很多,它也将是代码量最大的一种布局方式。


    二、各种例子

    例子1,两个矩形在窗口左侧,无间距:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
             100
            height: 100
            color: "blue"
            anchors.left: parent.left
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.left: rect1.right
        }
    }
    


    例子2,上面的两个矩形挨得太紧了,要留点间距,可以通过指定 anchors.leftMargin 的留白来实现:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
             100
            height: 100
            color: "blue"
            anchors.left: parent.left
            anchors.leftMargin: 20
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.left: rect1.right
            anchors.leftMargin: 60
        }
    }
    


    例子3,同时在上方也留点间距:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
             100
            height: 100
            color: "blue"
            anchors.left: parent.left
            anchors.leftMargin: 20
            anchors.top: parent.top
            anchors.topMargin: 40
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.left: rect1.right
            anchors.leftMargin: 60
            anchors.top: parent.top
            anchors.topMargin: 40
        }
    }
    


    例子4,一个矩形水平居中,另一个矩形垂直居中:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
             100
            height: 100
            color: "blue"
            anchors.horizontalCenter: parent.horizontalCenter
            anchors.top: parent.top
            anchors.topMargin: 40
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.verticalCenter: parent.verticalCenter
            anchors.right: parent.right
            anchors.rightMargin: 40
        }
    }
    


    例子5,centerln 表示将一个 Item 居中放置到一个 Item 内;fill 表示充满某个 Item:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
            color: "blue"
            anchors.fill: parent
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.centerIn: parent
        }
    }
    


    例子6,三个矩形摆放成"三头犬"的形式:

    import QtQuick 2.9
    import QtQuick.Window 2.2
    import QtQuick.Controls 2.4
    
    Window {
        visible: true
         600
        height: 480
        title: qsTr("Hello World")
    
        Rectangle {
            id: rect1
             100
            height: 100
            color: "blue"
            anchors.centerIn: parent
        }
    
        Rectangle {
            id: rect2
             100
            height: 100
            color: "red"
            anchors.top: rect1.bottom
            anchors.topMargin: 40
            anchors.right: rect1.left
            anchors.rightMargin: -50 // 可以使用负值
        }
    
        Rectangle {
            id: rect3
             100
            height: 100
            color: "green"
            anchors.top: rect1.bottom
            anchors.topMargin: 40
            anchors.left: rect1.left
            anchors.leftMargin: 50
        }
    }
    


  • 相关阅读:
    django.db.utils.OperationalError: no such table: auth_user
    Python 爬虫 去掉网页注释,去掉网页注释
    Python 爬虫实例(6)—— 爬取蚂蚁免费代理
    HTTPSConnectionPool(host='xxxxx', port=443): Max retries exceeded with url:xxxxxxxx (Caused by NewConnectionError('<urllib3.connect,Max retries exceeded with ,(Caused by NewConnectionError
    requests.exceptions.MissingSchema: Invalid URL 'xxxxxxxxxxxxx': No schema supplied. Perhaps you meant xxxxxxxxxxxxx
    redis安装和配置(一)
    Python 统计代码的行数,Python脚本 统计代码
    Python 实现根据不同的程序运行环境存放日志目录,Python实现Linux和windows系统日志的存放
    Changing SID Server 2012
    [转]VMware Workstation网络连接的三种模式
  • 原文地址:https://www.cnblogs.com/linuxAndMcu/p/13524932.html
Copyright © 2011-2022 走看看