한국어
Qt
 

QML and Qt Quick OpacityMask 예제

makersweb 2023.01.26 21:03 조회 수 : 6549

OpacityMask을 사용하면 소스 아이템을 다른 아이템으로 마스킹할 수 있다.

import QtQuick
import QtQuick.Window
import Qt5Compat.GraphicalEffects

Window {
    visible: true
    width: 500
    height: 400
    title: qsTr("QtQuick GraphicalEffects")

    Rectangle {
        id: area
        anchors.fill: parent
        color: "white"

        Rectangle {
            id: punchHole
            width: 400
            height: 300

            anchors.centerIn: parent

            color: "yellowgreen"

            layer.enabled: true
            layer.effect: OpacityMask{
                maskSource: Rectangle {
                    width: punchHole.width
                    height: punchHole.height
                    radius: 15
                }
            }

            /* Internel Content */
            Text {
                font.pixelSize: 20
                text: qsTr("This property allows the effect output pixels to be cached \n in order to improve the rendering performance.")
                anchors.centerIn: parent
                color: "black"
                horizontalAlignment: Text.AlignHCenter
            }
        }
    }
}

 

OpacityMask.png


다음과 같은 이미지를 넣어보자.

sky.jpg

단지 Image 아이템을 사용하고 source를 지정하면 된다.

import QtQuick
import QtQuick.Window
import Qt5Compat.GraphicalEffects

Window {
    visible: true
    width: 500
    height: 400
    title: qsTr("QtQuick GraphicalEffects")

    Rectangle {
        id: area
        anchors.fill: parent
        color: "white"

        Image {
            id: punchHole
            width: 400
            height: 300

            anchors.centerIn: parent

            source: "qrc:/sky.jpg"

            layer.enabled: true
            layer.effect: OpacityMask{
                maskSource: Rectangle {
                    width: punchHole.width
                    height: punchHole.height
                    radius: 15
                }
            }

            /* Internel Content */
            Text {
                font.pixelSize: 20
                text: qsTr("This property allows the effect output pixels to be cached \n in order to improve the rendering performance.")
                anchors.centerIn: parent
                color: "greenyellow"
                horizontalAlignment: Text.AlignHCenter
            }
        }
    }
}

 

OpacityMask1.png

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 116970
60 QOpenGLWidget 을 투명하게 적용 file makersweb 2020.02.05 5176
59 컨테이너에 적재된 객체를 편리하게 삭제하기 makersweb 2019.09.18 5173
58 Base64로 인코딩된 파일을 복원 makersweb 2023.08.06 5171
57 Qt Quick 3D 소개 makersweb 2019.11.09 5166
56 MCU용 Qt에 대해서 makersweb 2019.08.22 5156
55 Qt로 XML 파싱 : Qt 6에서 업데이트된 (Parsing XML with Qt: Updates for Qt 6) [1] j2doll 2020.01.16 5137
54 2020년에 변경되는 Qt 오퍼 (Qt offering changes 2020) [2] j2doll 2020.01.31 4987
53 Qt 하이브리드 애플리케이션(Hybrid App) 개발 file makersweb 2023.02.08 4962
52 Qt로 작성된 iOS 앱에서 시리얼 통신 file makersweb 2022.04.30 4940
51 Qt Quick Controls 2에 네이티브 데스크탑 스타일 추가 file makersweb 2020.11.23 4918
50 Qt for Embedded Linux 화면출력 makersweb 2019.10.17 4892
49 qInstallMessageHandler를 이용한 디버그 메세지 출력 제어하기 makersweb 2019.02.25 4792
48 QProcess 예제 (프로그램 재시작) file makersweb 2023.01.25 4762
47 Visual Studio Code용 Qt 확장팩 file makersweb 2024.10.09 4705
46 클라우드용 Qt file makersweb 2024.01.16 4646
45 표를 만들고 PDF문서로 출력하기 file makersweb 2018.09.30 4633
44 QML에서 D-Bus 통신 file makersweb 2023.03.15 4581
43 Qt 6의 비동기 API makersweb 2020.10.19 4574
42 QML 전역 객체 (Global Object) file makersweb 2019.04.10 4551
41 Android 애플리케이션 서명 구성 file makersweb 2023.12.17 4538