한국어
Qt
 

QML에는 Grid, Row 및 Column 외에도 앵커 개념을 사용하여 아이템을 상대적으로 배치하는 방법을 제공한다. 이 앵커링 시스템을 사용하면 서로 다른 아이템의 앵커 라인 간의 관계를 정의할 수 있다. 다시말해 하나의 아이템은 다른 아이템(부모 아이템 또는 형제 아이템)을 기준으로 앵커 라인에 배치할 수 있다.

각 아이템에는 앵커 라인이라고 하는 7개의 가상 라인이 있으며 아래 이미지는 그 중 6개를 나타낸것이다.

1.png

7번째 앵커인 baseline 은 텍스트 아이템의 텍스트가 놓이는 가상의 선이다. g나 y와 같은 문자의 경우 디센더가 baseline 아래로 내려간다. 텍스트가 아닌 아이템의 경우 top과 동일하다.

이 7개의 앵커 라인 속성 중 하나를 사용하여 항목을 배치할 수 있다.

다음의 간단한 예제에서 rect2의 왼쪽 가장자리는 rect1의 오른쪽 가장자리에 바인딩된다.

...
// width, height 등의 속성 정의가 생략되었다.

Rectangle { id: rect1; ... }
Rectangle { id: rect2; anchors.left: rect1.right; ... }

...

이렇게 배치된다.

2.png

앵커의 다른 조합을 사용하여 원하는 다른 직사각형 배치를 할 수 있다. 크기도 조절할 수 있다.

Example 1

(0, 0)에 녹색 사각형이 있다. 바로 아래에 파란색 사각형을 정렬해보자.

3.png

파란색 직사각형의 top 앵커 라인을 녹색 직사각형의 bottom 앵커 라인과 정렬되고 파란색 직사각형의 left 앵커 라인을 녹색 직사각형의 left 앵커 라인이 각각 정렬된다. 다음은 이것을 구현한 코드이다.

...
Rectangle {
    id: greenRect
    width: 100
    height: width/2
    color: "green"
}

Rectangle {
    id: blueRect
    width: 150
    height: width/2
    color: "blue"
    anchors{
        left: greenRect.left
        top: greenRect.bottom
    }
}
...

Example 2

파란색 사각형을 녹색 사각형의 오른쪽에 정렬시켜보자.

4.png

이번에는 파란색 직사각형의 left 앵커 라인을 녹색 직사각형의 right 앵커 라인에 맞추고 파란색 사각형의 top 앵커라인은 정확히 녹색 사각형의 verticalCenter (수직방향 중앙)에 배치한다.

...

    Rectangle {
        id: greenRect
        width: 100
        height: width/2
        color: "green"
    }

    Rectangle {
        id: blueRect
        width: 150
        height: width/2
        color: "blue"
        anchors{
            left: greenRect.right
            top: greenRect.verticalCenter
        }
    }

...

Example 3

여러 아이템들간의 앵커를 지정하여 레이아웃을 제어할 수 있다.

5.png

Rect2는 Rect1의 오른쪽과 Rect3의 왼쪽에 고정된다. 윈도우의 크기가 늘어나고 줄어듬에 따라 파란색 사각형이 늘어나고 축소된다.

Window{
    visible: true
    width: 640
    height: 480

    Rectangle { id: rect1; width: 100; height: parent.height; color: "green"; anchors.left: parent.left }
    Rectangle { id: rect2; height: parent.height; color: "blue"; anchors.left: rect1.right; anchors.right: rect3.left }
    Rectangle { id: rect3; width: 100; height: parent.height; color: "green"; anchors.right: parent.right }
}

Example 4

매우 유용한 두개 속성 fillcenterIn

6.png

centerIn 을 사용하면 verticalCenter와 horizontalCenter 앵커 조합을 한 것 처럼 완전히 중앙에 정렬된다. fill 의 경우 설정한 아이템의 크기로 완전히 채운다. 즉 대상 아이템의 left, right, top, bottom 앵커를 left, right, top, bottom 로 설정하는 것과 같은 편리함을 제공한다. 일반적으로 verticalCenter 및 horizontalCenter 를 제외한 모든 앵커 라인은 완전히 정렬된다.

...
Rectangle {
    id: textBox
    border.width: 1
    width: textItem.paintedWidth
    height: textItem.paintedHeight

    anchors.centerIn: parent
}

Text {
    id: textItem
    text: qsTr("anchors centerIn and fill textBox.")
    font.pixelSize: 22

    anchors.fill: textBox
}
...

Example 5

아이템간의 앵커에 대해 여백과 오프셋을 지정할 수 있다. 마진은 아이템의 앵커 외부에 남겨둘 빈 공간의 양을 지정한다.

7.png

앵커 여백을 설정하여 아이템을 정렬해보자.

8.png

...
Rectangle {
    id: rect1
    border.width: 1
    width: 100
    height: width

    anchors.centerIn: parent
}

Rectangle {
    color: "lightgreen"
    anchors{
        fill: rect1
        topMargin: 20
        leftMargin: 20
        rightMargin: 20
        bottomMargin: 20
    }
}
...

Example 6

옵셋은 중앙 앵커 라인을 기준으로 위치를 조작할 수 있다. 앵커 옵셋은 horizontalCenterOffset, verticalCenterOffset 및 baselineOffset을 사용하여 지정된다.

9.png

...
Rectangle {
    id: rect1
    border.width: 1
    width: 100
    height: width

    anchors.centerIn: parent
}

Rectangle {
    width: 100
    height: width
    color: "lightgreen"
    anchors{
        centerIn: rect1
        horizontalCenterOffset: rect1.width/2
        verticalCenterOffset: rect1.height/2
    }
}
...
번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 85855
139 멀티 스레드환경, 스레드에 안전한 이벤트처리 makersweb 2016.10.27 4994
138 C++로 구현된 모델을 QML의 ListView에서 참조 file makersweb 2019.09.07 4915
137 Qt 멀티 스레드 프로그래밍 시 유의해야 할 몇 가지 makersweb 2020.01.13 4867
136 Qml 기본 컴포넌트 강좌 (3) - 배치(positioning) 컴포넌트 file 운영자 2019.02.10 4866
135 QNetworkAccessManager를 통해 HTTP POST 하는 예제 makersweb 2019.01.17 4761
134 Qt응용프로그램 실행 시 콘솔창(터미널)같이 띄우기 file makersweb 2019.01.16 4482
133 Windows에서 Qt D-Bus를 사용하여 프로세스간 통신(IPC) file makersweb 2019.05.02 4478
132 라즈베리파이4에 대한 Qt 5.14.1 크로스컴파일 [1] file makersweb 2020.02.12 4449
131 QML에서 동적으로 텍스트 다국어 처리 file makersweb 2018.11.04 4199
130 Qt기반의 오픈소스 프로젝트들 - 2 운영자 2019.07.21 4002
129 QPA 플러그인과 EGLFS file makersweb 2017.11.21 3926
128 열거형(enum)을 QML에서 사용하는 방법과 문자열(QString)로 얻기 makersweb 2019.08.20 3879
127 Qt 3D Studio 시작하기 file makersweb 2018.01.11 3821
126 Qt 를 사용하거나 기반으로 하는 응용프로그램 file makersweb 2021.01.30 3792
» QML에서 앵커(anchors)로 위치 지정 file makersweb 2021.10.05 3791
124 Qt Logging Rule, Qt 프레임워크 로그 출력 makersweb 2017.01.13 3699
123 Qml에서 키보드 입력 이벤트 핸들링 file makersweb 2018.08.09 3580
122 Qt Bluetooth를 이용한 시리얼(Serial) 통신 file makersweb 2019.02.17 3561
121 Qt Version확인 방법 makersweb 2018.03.29 3514
120 QML, 이미지, 폰트등을 바이너리 리소스로 만들기 makersweb 2019.06.24 3505