한국어
Qt
 

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

makersweb 2019.04.10 23:02 조회 수 : 1056

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 86163
48 그래픽 소프트웨어에서 디자인 내보내기 (Exporting Designs from Graphics Software) j2doll 2020.12.25 416
47 Binding 타입으로 객체 속성 간 묶기 makersweb 2022.03.04 428
46 QtQuick 애플리케이션에 Rive 애니메이션 통합 makersweb 2024.03.31 477
45 앱을 종료할 때 QML 바인딩 오류를 피하는 방법 makersweb 2021.08.08 498
44 QML과 코루틴(Coroutines) makersweb 2020.11.03 581
43 OpacityMask 예제 file makersweb 2023.01.26 653
42 QML에서 D-Bus 통신 file makersweb 2023.03.15 707
41 QML에서 Websocket 서버와 통신 file makersweb 2021.09.18 834
40 Qt 응용프로그램에서 Lottie Animation사용 file makersweb 2021.05.30 885
39 QML 에서 QR코드 생성 file makersweb 2021.08.20 896
38 QML 바인딩 끊김 진단 makersweb 2020.11.08 915
37 [Qt] Google Play의 향후 요구 사항을 준수하는 방법 [2] j2doll 2019.07.29 978
» QML 전역 객체 (Global Object) file makersweb 2019.04.10 1056
35 ShaderEffect QML Type을 이용한 버튼 클릭 효과 file makersweb 2020.05.22 1095
34 Qml에서 커튼효과 구현 예제 - Shader Effects file 운영자 2018.12.05 1115
33 웹기반 Qt Design Viewer [2] file makersweb 2019.10.23 1308
32 tslib의 ts_calibrate를 응용해서 Qt로 터치보정기능 구현 file makersweb 2019.04.06 1370
31 QML과 JavaScript 의 숫자 관련 내장된 함수 makersweb 2021.03.28 1411
30 Qt Quick 3D 소개 makersweb 2019.11.09 1448
29 QML에서 undefined를 확인하는 방법 makersweb 2017.11.29 1489