한국어
Qt
 

QML and Qt Quick QML 전역 객체 (Global Object)

makersweb 2019.04.10 23:02 조회 수 : 1057

QML에는 JavaScript의 전역객체 뿐만아니라 내장된 QML전용의 몇가지 전역객체를 제공한다. QtQuick 모듈이 import되었다면 추가 import없이 QML에 로드 된 모든 전역객체 및 helper method, enum등을 사용할 수 있다.

 

"Qt"객체는 유틸리티 함수, 속성 및 Qt 네임 스페이스에서 사용 가능한 enum을 포함한 전역 객체이다. 인스턴스화를 할 필요없다. 즉, new를 이용한 객체를 생성하지 않는다. 이것을 사용하려면 다음의 예처럼 사용할 수 있다.

import QtQuick 2.12
import QtQuick.Controls 1.4

Text{
    text: Qt.md5("https://makersweb.net")
    font.pixelSize: 25
    font.family: fonts.currentText
    color: Qt.rgba(0, 0.5, 1, 1)
}

ComboBox{
    id: fonts
    width: 150
    model: Qt.fontFamilies()
}

Qt_object.png

Enums

Qt 라이브러리 전체에서 사용되는 enum을 사용할 수 있다. 예를 들면 Qt.Key_Q, Qt.Key_1, Qt.Key_Enter 처럼 key 타입을 나타내는 열거형등을 사용할 수 있다. 

 

동적객체 생성 함수

다음 함수를 사용하면 파일이나 문자열에서 QML 항목을 동적으로 만들 수 있다. 

Qt.createComponent(url)

Qt.createQmlObject(string qml, object parent, string filepath)

 

다음은 문자열에서 QML 항목을 동적생성하는 예제이다.

import QtQuick 2.12
import QtQuick.Window 2.12

Window {
    id: window
    visible: true
    width: 640
    height: 480

    // 문자열 QML코드
    property string qmlstring: {
        "
        import QtQuick 2.12

        Rectangle{
            anchors.centerIn: parent
            width: 300
            height: 100
            border.width: 1

            Text {
                id: title
                anchors.centerIn: parent
                font.pixelSize: 20
                text: qsTr('makersweb.net')
            }
        }
        "
    }

    Text{
        text: "click me"
        font.pixelSize: 25
        anchors.centerIn: parent

        MouseArea{
            anchors.fill: parent
            onClicked: {
                // 문자열 QML코드를 동적으로 생성
                Qt.createQmlObject(qmlstring, window)
            }
        }
    }
}

 

clickme.png

makersweb.png

 

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 86193
179 Qt 응용프로그램에 Web 구성 요소를 표시 with Servo file makersweb 2024.04.27 170
178 Qt Creator 에서 GitHub Copilot 사용하기 file makersweb 2024.04.13 412
177 QtQuick 애플리케이션에 Rive 애니메이션 통합 makersweb 2024.03.31 493
176 클라우드용 Qt file makersweb 2024.01.16 699
175 QRhi 에 대해서 file makersweb 2023.12.29 574
174 Android 애플리케이션 서명 구성 file makersweb 2023.12.17 542
173 QML의 사용자 정의 Image makersweb 2023.09.17 608
172 Base64로 인코딩된 파일을 복원 makersweb 2023.08.06 489
171 QML에서 D-Bus 통신 file makersweb 2023.03.15 715
170 Qt 하이브리드 애플리케이션(Hybrid App) 개발 file makersweb 2023.02.08 1040
169 Widgets(C++) 기반의 기본 스타일을 Dark 테마 및 Material 디자인 스타일로 바꾸기 file makersweb 2023.01.28 1321
168 OpacityMask 예제 file makersweb 2023.01.26 661
167 QProcess 예제 (프로그램 재시작) file makersweb 2023.01.25 951
166 하드디스크 드라이브 여유 공간 계산 file makersweb 2023.01.15 550
165 Qt Property(속성) 시스템 makersweb 2023.01.08 1898
164 VTK 를 사용해서 강력한 시각화(3D, Plotting, Chart)Qt 응용프로그램 개발하기 file makersweb 2022.10.16 1676
163 QProcess 보안 권고 리뷰 file makersweb 2022.09.18 602
162 QMake 프로젝트를 CMake 프로젝트로 변환 with qmake2cmake makersweb 2022.09.17 1025
161 Qt Safe Renderer 개요 file makersweb 2022.09.08 551
160 clazy 로 13개의 시그널, 슬롯 오류 해결 makersweb 2022.08.23 579