인프런 영문 브랜드 로고
인프런 영문 브랜드 로고
개발 · 프로그래밍

/

데스크톱 앱 개발

[Level 2] Qt를 이용한 Python 프로그래밍: QML편

QML은 Qt에서 제공하는 UI를 만드는 프로그래밍 인터프리터 언어입니다. JSON과 유사하고 JavaScript를 사용할 수 있습니다. QML과 Python 함께 이용하면 현대적인 고급 UI를 쉽게 개발할 수 있습니다.

8명 이 수강하고 있어요.

Thumbnail

입문자를 위해 준비한
[Qt, QML] 강의입니다.

이런 걸
배워요!

  • QML의 기본 문법과 UI 구성 요소 활용: QML의 문법, 구조, 타입을 이해하고 이를 바탕으로 기본적인 UI 구성 요소를 활용하여 다양한 사용자 인터페이스를 설계하는 방법을 익힙니다.

  • 고급 UI 기능 구현: 동적 UI, 애니메이션, 상태 전환 등을 통해 더 생동감 있는 고급 UI를 구현하고, 애니메이션과 이징 커브를 활용하여 자연스럽고 매끄러운 사용자 경험을 제공하는 방법을 배웁니다.

  • Python과의 연동을 통한 확장성 있는 애플리케이션 개발: QML과 Python 간의 데이터 교환 및 상호 운용성을 이해하며, Python을 활용한 QML 타입 확장 및 통합을 통해 유연하고 확장성 있는 애플리케이션을 구축하는 방법을 학습합니다.

Python에서 QML 학습을 보다 쉽게 입문할 수 있도록 여러분을 위한
전문 강의를 제공합니다.

Qt 프레임워크 UI 구현, 
QML로 더 강력하게!

프로그래밍 언어 QML?

Qt 프레임워크에서 현대적인 고급 UI
쉽게 개발할 수 있는 프로그래밍 언어입니다. 

QML (Qt Modeling Language)은 Qt 프레임워크에서 제공하는 강력한 프로그래밍 언어로, UI 개발을 위한 최적화된 솔루션을 제공합니다. 이를 통해 현대적이고 세련된 고급 사용자 인터페이스를 효율적으로 구현할 수 있으며, 직관적이고 유연한 디자인 및 애니메이션 작업을 손쉽게 지원하여, 사용자 경험을 극대화하는 데 기여합니다.


Qt 프레임워크로 GUI를 개발할 때, UI 디자인 로직(QML)과 기능 로직(Python)을 명확히 구분하여 설계할 수 있습니다. 특히, QML은 UI 디자인 로직을 전담하는 언어로 활용될 수 있습니다. QML을 사용해 UI를 구현하면 디자인 로직과 기능 로직(Python)을 완전히 분리할 수 있어 코드의 재 사용성을 극대화하고 유지 보수성을 높이는 데 유리합니다.

QML을 활용하여 디자인 로직을 개발하면, 훨씬 더 간편하고 신속하게 UI를 구현할 수 있습니다. 또한, Flickable, Gesture, Animation, 3D와 같은 현대적인 고급 GUI 기술을 손쉽게 적용할 수 있어, 세련되고 직관적인 사용자 경험을 구현하는 데 있어 탁월한 선택이 됩니다.

쉬운 문법, 간결한 가독성
QML의 장점을 경험해보세요.

프로그래밍 언어를 처음 배울 때 주로 하는 “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을 활용하면, 디자이너와 개발자가 동일한 개발 도구를 바탕으로 협업할 수 있어, 이전보다 더욱 효율적으로 개발 기간을 단축할 수 있습니다.

이런 분들께 추천합니다 🙋‍♀

고급 UI/UX 구현

Qt에서 QML을 이용해 현대적인 고급 UI/UX를 쉽게 구현하려는 분 (개발자, 디자이너)

소스코드 재 사용성

디자인 로직과 기능 로직을 분리함으로써 소스코드 유지보수성, 재사용성을 높일 수 있습니다.

원할한 협업

QML과 동일한 도구를 통해 디자이너와 개발자가 효과적으로 소통하고 협력할 수 있습니다.

직관적이고 현대적인 UI 개발

QML을 통해 생동감 있고 매끄러운 사용자 인터페이스를 구축하고 싶은 분들에게 추천합니다.

Python과 QML을 통해 유연한 애플리케이션 개발

다양한 플랫폼에서 확장성 있는 애플리케이션을 구축하고자 하는 개발자에게 적합합니다.

애니메이션과 사용자 경험(UX)을 극대화

UI를 더욱 자연스럽고 매력적으로 만드는 고급 애니메이션 기법을 배우고 싶은 분들에게 추천드립니다.

강의 목표 💡

  • QML을 이용해 현대적인 고급 UX/UI를 개발하는 방법을 배울 수 있습니다.

  • QML을 사용하며 디자인 로직(QML)과 기능 로직(Python)을 완벽히 분리하는 방법에 대해서 배울 수 있습니다.

  • 섹션별로 이론을 공부하고 다양한 실무 예제를 중심으로 코드를 직접 작성해볼 수 있기 때문에 실무에서 필요한 QML 개발 능력을 자연스럽게 배울 수 있습니다.

이 강의만의 특징 📖

실전까지 생각한 강의

실전 능력까지 향상시킬 수 있도록 강의를 구성하였습니다. 모든 섹션별 이론 학습 후에는 실전 예제를 강의를 따라 직접 구현해가며 배울 수 있는 수업이 준비되어 실무 능력을 높일 수 있습니다.

온라인의 벽을 넘어서

지식공유자의 모습을 강의 화면에 함께 담았습니다. 생생한 라이브 코딩과 함께 진행되는 수업을 통해 마치 오프라인 수업을 듣는 느낌으로 언제 어디서나 학습하여 보세요.

강의구성 📖 - 이런 내용을 배워요

섹션 1. 강의를 시작하며
본 강의에 앞서, 전체 학습 과정을 개괄하는 섹션입니다. 이 섹션에서는 강사 소개와 더불어 각 섹션별로 학습할 주요 내용을 요약하여 제공하므로, 여러분들이 강의의 전반적인 흐름을 파악할 수 있습니다.

섹션 2. 강의자료
이 섹션에서는 섹션 3부터 본격적으로 시작되는 강의에서 사용되는 모든 예제 소스코드 파일들이 압축된 파일로 제공되며 파일을 다운로드할 수 있습니다. 이 섹션은 수업의 일환이 아닌 자료 제공을 목적으로 제공되는 섹션입니다.

섹션 3. 개발 환경 구축
이번 섹션에서는 Qt를 활용한 Python 프로그래밍을 위한 개발 환경을 설정하는 방법을 심도 있게 탐구합니다. 또한, 소스 코드를 작성하기 위한 IDE로서 Visual Studio Code의 활용 방안도 살펴봅니다.

섹션 4. What is QML
QML은 Qt Framework에서 제공하는 인터프리터 언어입니다. 이번 시간에서는 QML은 어떤 특징과 장점이 있는지 살펴봅니다.

섹션 5. QML의 Syntax 및 구조
QML의 구조와 문법을 배웁니다.  그리고 실습 예제를 통해서 QML을 사용하는 방법에 대해서 배우는 섹션입니다.

섹션 6. Type 
Type이란 Qt의 QWidget과 같은 개념입니다. 이번 섹션에서는 Type이 무엇인지 배우고 QML에서 제공하는 Type중에서 자주 사용하는 Type을 중심으로 배웁니다. 그리고 실습 예제로 Accessible 타입을 이용해 버튼 Type을 구현해 보도하는 시간입니다. 

섹션 7. Event
터치, 마우스, 키보드등과 같이 사용자 인터페이스상에서 발생하는 Event 처리를 어떻게 구현해야 하는지 배우는 섹션입니다. 그리고 QML에서 Signal 을 구현하는 방법에 대해서 배웁니다. 실습 예제에서는 Signal 과 Method(함수)를 연결하는 예제를 통해서 Signal을 다루는 방법을 자세히 배웁니다.

섹션 8. Loader type을 이용한 Dynamic UI 구현하기 
UI에서 사용자가 특정 영역을 동적으로 변화시키는 방법을 배웁니다. 예를 들어 A라는 GUI화면에서 특정 조건을 만족하는 경우 B화면으로 전환해야 하는 방법을 배웁니다. 따라서 이번 섹션을 통해서 동적으로 화면을 구현하는 방법에 대해서 배웁니다. 마지막 실습 예제에서는 Loader 타입을 이용해 동적으로 화면을 바꾸는 방법을 예제로 다루는 시간입니다.

섹션 9. Module Programming 
버튼, 콤보박스와 같이 GUI상에서 자주사용하는 모듈을 모듈화를 시키는 것과 같이 사용자가 정의한 Type을 모듈하는 방법에 대해서 배웁니다. 그리고 직접 실습 예제를 통해서 QML을 모듈화해 구현해보는 방법에 대해서 알아봅니다. 

섹션 10. QML에서 JavaScript 사용 
QML에서 JavaScript 함수 사용 방법에 대해서 배웁니다. 그리고 JavaScript 파일을 QML에서 Import하는 방법에 대해서 알아봅니다. 실습 예제에서는 계산기 구현을 통해서 JavaScript를 사용하는 방법에 대해서 자세히 배울 수 있습니다. 

섹션 11. Type Positioning 
Type Positioning이란 화면 상에 Type들을 표시하기 위한 방법을 배웁니다. 예를 들어 타입들을 배치할 때 가로로, 세로로 또는 바둑판과 같은 모양으로 Type들을 배치하는 방법을 배웁니다. 더불어 많은 Type들이 순서대로 배치했을 때, 특정 Type의 정보를 얻어오는 방법도 배웁니다.

섹션 12. Anaimation
Animation은 GUI요소에 Animation을 쉽게 적용할 수 있는 방법을 제공합니다. 예를 들어 버튼이 나타났다 사라질 수 있습니다. 이 때 Animation을 사용할 수 있습니다. 버튼이 사라질 때 1초동안 사라질 수 있습니다. 즉 Opacity 값이 100% 에서 0%로 바뀌데 특정 시간을 줄 수 있습니다.

이러한 Animation을 이용하면 GUI상에 Effect와 같은 효과를 줄 수 있습니다. 그리고 화면 전환 시 부드럽게 화면이 전환 될 수 있는 Effect를 구현 할 수 있습니다. 따라서 이번 섹션에서는 GUI 요소에 Animation을 사용할 수 있는 방법에 대해서 배웁니다.

섹션 13. Animation과 Easing curve를 이용한 Ball Bounding 예제 구현
Easing Curve란 Animation상에 특정 옵션을 사용함으로써 좀더 세련된 Effect를 사용할 수 있습니다. 예를 들어 10초 동안 Animation이 동작할 때 특정 시간 구간에 가속을 하도록 함으로써 다양한 Effect를 구현할 수 있습니다.
이번 섹션에서는 실습 예제를 통해서 Animation상에 Easing curve를 사용하는 방법에 대해서 배웁니다.

섹션 14. State 와 Transition
State는 조건을 말합니다. Transition은 행동을 말합니다. 예를 들어 ON/OFF 스위치에서 ON과 OFF가 조건이고 ON에서 OFF로 바뀌는 것을 행동(Transition) 으로 정의할 수 있습니다. State와 Transition을 사용하면 상당히 복잡한 행동들을 그룹화해 해당 조건이 바뀔 때 일괄적으로 바뀌게 함으로써 GUI의 복잡한 구현을 좀더 쉽게 구현할 수 있는 방법에 대해서 배웁니다.

섹션 15. State 와 Transition을 이용한 Image Viewer 예제 구현
이번 섹션에서는 이전 섹션에서 배운 State와 Transition을 이용해 Image Viewer를 구현해보는 섹션입니다.

섹션 16. Model and View
Model과 View는 GUI상에 많은 양의 데이터를 보여줄 때 사용합니다. 예를 들어 100개의 데이터를 표로 보여질 때 데이터는 Model에 저장하고 View는 Model에 저장된 데이터를 어떤 방식으로 GUI상에 표시하는 종류를 말합니다. View는 표 또는 Tree 모양이 될 수 있습니다. 이번 섹션에서는 Model과 View를 사용하는 방법에 대해서 배웁니다.

섹션 17. Model and View를 이용한 Chess Game 구현
Model과 View를 활용하여 Chess Game의 Knight를 예시로 구현하는 방법에 대해 심도 있게 학습합니다.

섹션 18. QML 과 Python 간 Integration
QML에서 Python의 특정 클래스에서 함수를 호출하는 방법과 Python에서 QML에서 특정 JavaScript 함수를 호출하는 방법을 배웁니다. 그리고 실습 예제를 통해서 QML과 Python간 함수 호출과 데이터를 전달하는 방법을 구현을 통해 배울 수 있습니다.

섹션 19. QML과 Python 간 리스트 데이터 교환
Python에서 대량의 리스트 데이터를 QML에게 전달하는 방법을 배웁니다. 그리고 실습 예제로 Python에서 List에 저장된 데이터를 가공해 QML에 전달해 UI상에 표시하는 방법에 대해서 배웁니다.

섹션 20. Python을 이용한 새로운 QML Type 구현
QWidget 에서 QPainter를 이용해 2D 그래픽 요소를 QWidget 상에 표시했던것과 같이 Python에서 제공하는 QQuickPaintedItem 클래스를 이용해 QPainter를 이용해 2D 그래픽 요소를 QML의 Type상에 표시할 수 있는 방법에 대해서 배웁니다.

섹션 21. 중첩 구조의 QML타입의 구현
단순히 Type을 구현할 때 계층 구조와 같은 Type을 구현할 필요가 있습니다. 예를 들어 Type 안에 하위에 여러 개의 Types을 구현해야 하는 경우가 있습니다. 이번 섹션에서는 Chart 라는 주제를 통해서 계층 구조의 Type을 구현하는 방법에 대해서 배웁니다.

👉 학습 후 달라진 여러분의 모습을 만나보세요.

  • 강의를 듣고 나면 QML을 자유자재로 활용할 수 있습니다. 또한 실전 프로젝트에서 QML을 사용하는 경우와 기존의 Python/Qt 방식인 QWidget을 사용할 경우 어떤 차이점이 있는지, 장단점이 무엇인지 파악할 수 있습니다.

  • 또한 QML을 사용해 프로젝트를 구현할 경우 구현한 소스코드의 디자인로직(QML 부분)과 기능로직(Python)을 완벽히 분리할 수 있어 작성한 코드의 재 사용성을 높일 수 있습니다.

Q&A 💬

수강 전 예비 수강생이 궁금해할 수 있는 질문과 답변을 3개 이상 작성해보세요.
뻔하거나 형식적인 답변보다는 지식공유자의 개성이 드러나는 답변을 권장합니다.

Q. 이론, 문법 외에 실제로 쓰이는 다양한 예제도 접할 수 있을까요?

네. 가능합니다. 각 섹션별 이론 수업 후 예제를 통해 직접 강사와 코딩하는 과정이 준비되어 있어 현업에서 QML로 실전 프로그래밍을 할 때의 노하우를 함께 배울 수 있습니다.

Q. 학습하는 강의 내용을 참고할 만한 자료나 교재가 있을까요?

현재 Qt 개발자 커뮤니티(qt-dev.com)에서 운영자로 활동하고 있습니다. Qt 및 QML과 관련한 추가 자료를 이 사이트에서 얻으실 수 있습니다.

Q. 강의를 듣기 전 배워야 할 게 있을까요?

Python 과 Qt에 대한 기초 지식이 있어야 수강할 수 있는 강의입니다. Qt에 대한 경험이 없으신 분들은 지난 "[Level 1] Qt을 이용한 Python 프로그래밍: 입문편" 강의를 미리 들으시고 이 강의를 수강하시는 것을 권장합니다.

Q. 수업 내용은 어느 수준까지 다루나요?

QML 기초부터 다양한 활용 분야에 해당하는 고급 내용까지 다룹니다.

수강 전 참고 사항

실습 환경

  • 운영 체제 및 버전(OS): 본 강의는 Windows 운영 체제에서 진행되며, macOS, Linux, Ubuntu 등 다양한 환경에서도 사용 가능합니다. 그러나 Windows를 사용하시기를 권장드립니다.


  • 개발 환경 구축에 필요한 소프트웨어는 수업 중에 함께 설치하는 시간을 마련하였으니, 컴퓨터와 운영 체제만 준비해 주시면 됩니다.

학습 자료

  • 수강 후 학습 참고 자료로 섹션2에서 이 강의 모든 예제 소스코드를 다운로드 받으실 수 있습니다.

질문하기

  • 수업 중 이해가 되지 않는 부분이나 궁금한 점이 생기면 주저하지 말고 질문해 주세요. 함께 논의하고 해결하는 과정이 학습에 큰 도움이 됩니다.

이런 분들께
추천드려요!

학습 대상은
누구일까요?

  • 직관적이고 현대적인 UI 개발에 관심이 있는 분

  • Python과 QML의 통합을 통해 유연한 애플리케이션을 만들고자 하는 분

  • 애니메이션과 동적 UI 구현을 통해 사용자 경험을 극대화하고 싶은 분

선수 지식,
필요할까요?

  • 기본 Python 프로그래밍 지식: Python의 기본 문법과 데이터 구조(리스트, 딕셔너리 등), 함수 정의 및 호출에 대한 이해가 필요합니다. 이러한 기초 지식이 있으면 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 )

커리큘럼

전체

80개 ∙ (11시간 55분)

수업 자료

가 제공되는 강의입니다.

  • 예제소스코드 (모든 섹션의 예제 소스코드)

강의 게시일: 
마지막 업데이트일: 

수강평

아직 충분한 평가를 받지 못한 강의입니다.
모두에게 도움이 되는 수강평의 주인공이 되어주세요!