한국어
Qt
 

Rive는 대화형 벡터 애니메이션을 만들 수 있는 이미지 파일 형식이다. Rive와 비교하여 로티(Lottie) 에는 몇 가지 단점이 있다.

  • Lottie 파일은 실행 시 저장소와 메모리 모두에서 상당히 큰 경향이 있다. 이는 특히 임베디드 장치에서 문제가 될 수 있다.
  • Lotie는 소프트웨어 개발자의 개입 없이 대화형 애니메이션을 만드는 것은 불가능하다.

RiveQtQuickPlugin

RiveQtQuickPlugin 은 QtQuick 프로젝트 내에서 Rive 애니메이션을 쉽게 로드하고 표시할 수 있는 플러그인 라이브러리다. BasysKom에서 rive-cpp 라이브러리를 기반으로 QtQuick 통합하기 위해 이 오픈소스 프로젝트를 시작했다. BasysKom은 현재 계속 QtQuickPlugin을 작업 중이지만 이미 QtQuick/QML 애플리케이션에 다음 기능을 제공한다.

Rive 및 Qt 의 빠른 통합
간단한 QML 유형을 사용하여 QtQuick/QML 애플리케이션에서 Rive 애니메이션을 가져오고 조작할 수 있다.

Dynamic Interaction
Rive 애니메이션의 도움으로 사용자 상호작용에 반응하여 생동감 넘치는 사용자 인터페이스를 만든다. Rive 애니메이션은 마우스 호버나 터치 이벤트에 직접 반응할 수 있으므로 개발자가 아무것도 구현할 필요가 없다.

주요 Qt 버전 및 플랫폼 지원
소프트웨어 및 하드웨어 렌더링이 포함된 Qt5.15.2+
소프트웨어 및 하드웨어 렌더링이 포함된 Qt6.5+

QtQuick/QML 애플리케이션에서 다음과 같이 간편하게 Rive 애니메이션을 표시할 수 있다.

import QtCore
import QtQuick
import QtQuick.Layouts
import QtQuick.Controls
 
import RiveQtQuickPlugin

...
        RiveQtQuickItem {
            id: riveItem
            anchors.fill: parent
            fillMode: RiveQtQuickItem.PreserveAspectFit
 
            // not used by software backend
            renderQuality: RiveQtQuickItem.Medium
            postprocessingMode: RiveQtQuickItem.SMAA
 
            fileSource: ":/assets/travel-icons-pack.riv"
        }
...

플러그인은 LGPLv3+로 출시되었으며 현재 작업 중인 일이 몇 가지 있다.

  • 하드웨어 렌더링을 위한 앤티앨리어싱
  • 외부 Rive-Library로 GCC 지원
  • QML 인터페이스 개선
  • 플러그인 문서(QML에 대한 인터페이스가 양호한 상태인 경우)
번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 110102
140 싱글 샷(Single-Shot) 시그널/슬롯 연결 makersweb 2021.05.12 2685
139 응용프로그램 자동실행 설정 (on Windows) makersweb 2021.05.08 2665
138 Qt 6 에서 프로퍼티 바인딩 makersweb 2021.04.03 2922
137 QML과 JavaScript 의 숫자 관련 내장된 함수 makersweb 2021.03.28 4164
136 Qt 5 코드를 Qt 6로 포팅하기 위해 도움이 되는 Clazy Framework file makersweb 2021.03.01 3067
135 C++로 작성한 클래스를 QML에서 생성 file makersweb 2021.02.10 8316
134 Qt MQTT의 pus/sub 튜토리얼 file makersweb 2021.02.06 4570
133 Qt 를 사용하거나 기반으로 하는 응용프로그램 file makersweb 2021.01.30 7020
132 Loader를 사용하여 동적으로 QML 로드 makersweb 2021.01.19 4185
131 QThread 및 QMutex 예제 makersweb 2021.01.12 4124
130 그래픽 소프트웨어에서 디자인 내보내기 (Exporting Designs from Graphics Software) j2doll 2020.12.25 2381
129 Qt5Compat 라이브러리를 사용하여 Qt5에서 Qt6로 포팅 [2] makersweb 2020.12.05 2857
128 Qt Quick Controls 2에 네이티브 데스크탑 스타일 추가 file makersweb 2020.11.23 3245
127 QML 바인딩 끊김 진단 makersweb 2020.11.08 2987
126 QML과 코루틴(Coroutines) makersweb 2020.11.03 2603
125 Qt 6의 비동기 API makersweb 2020.10.19 3410
124 QRandomGenerator 클래스를 사용하여 난수(random values) 생성 makersweb 2020.10.17 3865
123 Qt 6에서 QList 변경사항 makersweb 2020.10.08 3179
122 Qt 6.0의 개발 호스트 및 대상 플랫폼 makersweb 2020.09.16 4257
121 main함수 명령줄 옵션 해석 makersweb 2020.09.01 4958