QML은 Qt에서 제공하는 UI를 만드는 프로그래밍 언어입니다. JSON과 유사하고 JavaScript를 사용할 수 있습니다. C++ 언어 대신 QML을 이용하면 C++을 사용하지 않고도 현대적인 고급 UI를 쉽게 개발할 수 있습니다.
이런 걸
배워요!
QML을 이용한 현대적인 UI 개발
QML과 C++ 을 이용한 UI 개발
Qt UI 개발을 위한 QML,
입문부터 실습까지 자세하게 알려드려요.
Qt 프레임워크에서 현대적인 고급 UI를
쉽게 개발할 수 있는 프로그래밍 언어입니다.
QML(Qt Modeling Language)은 Qt 프레임워크에서 제공하는 프로그래밍 언어입니다. QML은 Qt 프레임워크에서 UI 개발을 위해 사용할 수 있는 프로그래밍 언어로, 현대적인 고급 UI를 쉽게 구현할 목적으로 사용할 수 있습니다.
Qt 프레임워크를 이용해 GUI 프로그램을 개발할 때, UI 부분의 디자인 로직과 기능 부분의 기능 로직을 구분해서 볼 수 있습니다. 이중에서도 QML은 디자인 로직에 해당하는 UI를 개발할 때 C++의 대안으로 선택할 수 있는 언어입니다. 특히 QML로 UI를 개발하게 되면 디자인 로직과 기능 로직을 완벽히 분리할 수 있어 소스코드 재사용성을 높일 수 있습니다.
QML을 사용해 디자인 로직을 개발하면 C++을 사용해 개발하는 것보다 훨씬 쉽고 빠르게 UI를 구현할 수 있습니다. 또한 Flickable, Gesture, Animation, 3D 등 현대적인 고급 GUI 기술을 쉽게 적용할 수 있습니다.
프로그래밍 언어를 처음 배울 때 주로 하는 “Hello World” 출력 예제를 살펴볼까요? QML이 얼마나 간결한 언어인지를 쉽게 알 수 있습니다.
import QtQuick
Window {
width: 300
height: 200
visible: true
title: qsTr("QML 예제소스코드")
Text {
x: 80
y: 70
text: "Hello World"
font.pixelSize: 25
}
}
QML 예제 소스코드
QML 예제 소스코드 실행화면
QML은 쉽고 간단합니다. 개발자가 아니더라도 쉽게 이해할 수 있습니다. 그러므로 디자이너와 개발자는 QML 코드를 이용해 서로 대화가 가능며 서로 아이디어를 공유할 수 있습니다.
따라서 QML을 이용하면 디자이너와 개발자가 서로 같은 개발 툴을 갖고 협력함으로써 이전보다 개발 기간을 단축할 수 있게 됩니다.
1️⃣
Qt에서 QML을 이용해 현대적인 고급 UI/UX를 쉽게 구현하려는 분 (개발자, 디자이너)
2️⃣
디자인 로직과 기능 로직을 분리함으로써 소스코드 유지보수성, 재사용성을 높이고자 하는 분
✅
선수 지식으로 C++ 언어 및 Qt 프레임워크 기초 지식을 이해하고 있어야만 이 과정을 학습하실 수 있습니다.
이론과 실전을 한번에
QML 문법 외에 실전 능력까지 향상시킬 수 있도록 강의를 구성하였습니다. 모든 섹션별 이론 학습 후에는 실전 예제를 강의를 따라 직접 구현해가며 배울 수 있는 수업이 준비되어 실무 능력을 높일 수 있습니다.
온라인의 벽을 넘어서
지식공유자의 모습을 강의 화면에 함께 담았습니다. 생생한 라이브 코딩과 함께 진행되는 수업을 통해 마치 오프라인 수업을 듣는 느낌으로 언제 어디서나 학습하여 보세요.
섹션1. What is QML
QML은 Qt Framework에서 제공하는 인터프리터 언어입니다. 이번 시간에서는 QML은 어떤 특징과 장점이 있는지 살펴봅니다.
섹션2. QML의 Syntax 및 구조
QML의 구조와 문법을 배웁니다. 그리고 실습 예제를 통해서 QML을 사용하는 방법에 대해서 배우는 섹션입니다
섹션3. Type
Type이란 Qt의 QWidget과 같은 개념입니다. 이번 섹션에서는 Type이 무엇인지 배우고 QML에서 제공하는 Type중에서 자주 사용하는 Type을 중심으로 배웁니다. 그리고 실습 예제로 Accessible 타입을 이용해 버튼 Type을 구현해 보도하는 시간입니다.
섹션4. Events
터치, 마우스, 키보드등과 같이 사용자 인터페이스상에서 발생하는 Event 처리를 어떻게 구현해야 하는지 배우는 섹션입니다. 그리고 QML에서 Signal 을 구현하는 방법에 대해서 배웁니다. 실습 예제에서는 Signal 과 Method(함수)를 연결하는 예제를 통해서 Signal을 다루는 방법을 자세히 배웁니다.
섹션 5. Loader type을 이용한 Dynamic UI 구현하기
UI에서 사용자가 특정 영역을 동적으로 변화시키는 방법을 배웁니다. 예를 들어 A라는 GUI화면에서 특정 조건을 만족하는 경우 B화면으로 전환해야 하는 방법을 배웁니다. 따라서 이번 섹션을 통해서 동적으로 화면을 구현하는 방법에 대해서 배웁니다. 마지막 실습 예제에서는 Loader 타입을 이용해 동적으로 화면을 바꾸는 방법을 예제로 다루는 시간입니다.
섹션 6. Canvas
그림판과 같이 화면상에 이미지, 선, 도형, 텍스트을 표시하기 위한 방법에 대해서 배웁니다. 예제로 Color를 선택해 그림판에 그림을 그릴 수 있는 예제에 대해서 다루오 보도록 하겠습니다.
섹션 7. Graphic Effects
Blur, Blend, Color 등과 같은 Effect를 이미지 상에 사용하는 방법에 대해서 배웁니다.
섹션 8. Module Programming
버튼, 콤보박스와 같이 GUI상에서 자주사용하는 모듈을 모듈화를 시키는 것과 같이 사용자가 정의한 Type을 모듈하는 방법에 대해서 배웁니다. 그리고 직접 실습 예제를 통해서 QML을 모듈화해 구현해보는 방법에 대해서 알아봅니다.
섹션 9. QML에서 JavaScript 사용
QML에서 JavaScript 함수 사용 방법에 대해서 배웁니다. 그리고 JavaScript 파일을 QML에서 Import하는 방법에 대해서 알아봅니다. 실습 예제에서는 계산기 구현을 통해서 JavaScript를 사용하는 방법에 대해서 자세히 배울 수 있습니다.
섹션 10. Dialog
QML에서 다이얼로그를 사용하는 방법에 대해서 배웁니다. 그리고 실습 예제로 Color를 선택하는 다이얼로그를 직접 구현해 봄으로써 다이얼로그 사용 방법에 대해서 배울 수 있습니다.
섹션 11. Layout
QML에서는 Anchors 외에도 RowLayout, ColumnLayout, GridLayout, Layout 등과 같은 Layout을 사용할 수 있습니다. 이번 시간에는 다양한 Layout의 사용방법에 대해서 배웁니다.
섹션 12. Type Positioning
Type Positioning이란 화면 상에 Type들을 표시하기 위한 방법을 배웁니다. 예를 들어 타입들을 배치할 때 가로로, 세로로 또는 바둑판과 같은 모양으로 Type들을 배치하는 방법에 대해서 배웁니다.
섹션 13. Qt Quick Controls
Qt Quick Controls는 Button, Dial, CheckBox, BusyIndicator등 화면을 구성하는데 필요한 GUI 인터페이스를 제공합니다. 이번 섹션에서는 Qt Quick Controls를 사용하는 방법에 대해서 배웁니다.
Q. 이론, 문법 외에 실제로 쓰이는 다양한 예제도 접할 수 있을까요?
네. 가능합니다. 각 섹션별 이론 수업 후 예제를 통해 직접 강사와 코딩하는 과정이 준비되어 있어 현업에서 QML로 실전 프로그래밍을 할 때의 노하우를 함께 배울 수 있습니다.
Q. 학습하는 강의 내용을 참고할 만한 자료나 교재가 있을까요?
Qt 개발자 커뮤니티(qt-dev.com)에서 운영자로 활동하고 있습니다. Qt 및 QML과 관련한 정보를 이 사이트에서 얻으실 수 있습니다.
Q. 강의를 듣기 전 배워야 할 게 있을까요?
C++과 Qt에 대한 기초 지식이 있어야 수강할 수 있는 강의입니다. Qt에 대한 경험이 없으신 분들은 지난 "Qt 프로그래밍" 강의를 미리 들으시고 이 강의를 수강하시는 것을 권장합니다.
Q. 수업 내용은 어느 수준까지 다루나요?
QML 기초부터 다양한 활용 분야에 해당하는 고급 내용까지 다룹니다.
💾 참고 사항
학습 대상은
누구일까요?
QML을 이용해 UI를 개발하시려는 분
Qt 프레임워크에서 QML을 이용해 UI를 개발하시려는 분
선수 지식,
필요할까요?
C++
Qt
수강생 수
801
수강평 수
61
강의 평점
4.6
강의 수
9
근무경력
현: Embedded 분야 Senior software developer
LG전자, VS사업부 IVI선행플랫폼/모듈개발
SW마에스트로, SW 멘토
강의경력
삼성전자, Qt & QML 강의
LG전자, Qt & QML 분야 사내 강사
한컴아카데미 Qt 강의 출강
다수의 IT기업 Qt 강의 출강
저서
Qt 프로그래밍
Qt Quick 프로그래밍
Qt5 프로그래밍 가이드
MeeGo 프로그래밍 완벽 가이드
Qt 실전 프로그래밍
SW커뮤니티 운영
Qt 개발자 커뮤니티 운영자 ( www.qt-dev.com )
전체
47개 ∙ (9시간 8분)
가 제공되는 강의입니다.