한국어
Qt
 

Qt Installer Framework는 Linux, Microsoft Windows 및 OS X와 ​​같이 Qt가 지원하는 플랫폼 용 설치 프로그램을 만드는 데 필요한  솔루션(도구 및 유틸리티)을 제공한다.

 

Qt Installer Framework은 적어도 다음 플랫폼들을 지원한다.

Microsoft Windows XP, 이상

Ubuntu Linux 11.10, 이상

OS X 10.7, 이상

 

프레임 워크는 Qt로 구축 된 응용 프로그램을 포함하여 모든 종류의 응용 프로그램을 설치할 수 있도록 설계되었다.

미리 정의 된 페이지에 위젯을 추가하거나 사용자에게 추가 옵션을 제공하는 등 설치 프로그램을 사용자 정의 할 수 있으며 스크립트를 작성하여 설치 프로그램에 조작을 추가 할 수 있다.

 

사용 사례에 따라 최종 사용자에게 오프라인 또는 온라인 설치 프로그램 또는 둘 다를 제공 할 수 있다.

 
이번 글에서는 간단한 오프라인 설치프로그램을 제작해보고자한다.
 
먼저 Qt Installer Framework 을 설치해보자.
 
다운로드 페이지를 방문하여 다운로드 받거나 Qt를 이미 설치한 경우라면 Qt가 설치된 디렉토리에서 MaintenanceTool.exe를 실행 시켜서 Qt Installer Framework을 추가 설치한다.
install.png

 

일반적으로 Qt가 설치된 디렉토리의 Tools에 설치한다.

 

설치를 완료하였다면 환경변수에 사용될 tool의 경로를 추가해준다.

path.png

 

이제 적당한 곳에 작업 디렉토리를 하나 만들고 Qt Installer Framework 이 설치된 곳에 examples중 tutorial 디렉토리를 복사해온다. 그리고 적당한 이름으로 디렉토리 이름을 바꿔주자.

 

필자의 경우 ExamplePackage로 바꿨다. 디렉토리 구조는 아래 그림과 같을 것이다.

directorys.png

 

디렉토리에는 config 및 packages라는 하위 디렉토리가 있어야한다.

 

Config Directory & config.xml

설치프로그램을 만드는데 기본적인 설정 정보를 가지고 있으며 config.xml 에는 아래와 같은 구조로 작성한다.

<?xml version="1.0" encoding="UTF-8"?>
<Installer>
    <Name>Your application</Name>
    <Version>1.0.0</Version>
    <Title>Your application Installer</Title>
    <Publisher>Your vendor</Publisher>
    <StartMenuDir>Super App</StartMenuDir>
    <TargetDir>@HomeDir@/InstallationDirectory</TargetDir>
</Installer>

 

몇 가지 기본이 되는 정보들을 설명하면

Title은 제목 표시 줄에 표시될 설치 프로그램 이름.

Version은 응용 프로그램 버전 번호.

Name은 페이지 이름과 소개 텍스트에 추가되는 응용 프로그램 이름.

StartMenuDir은 Windows 시작 메뉴에서 제품의 기본 프로그램 그룹 이름.

 

Packages Directory

모든 컴포넌트들은 Packages디렉토리라고하는 루트 디렉토리에 배치해야하며,

각 컴포넌트 디렉토리 이름은 모든 구성 요소를 식별하는 도메인과 같은 형태 이어야한다. (예 : com.vendor.root)

컴포넌트 디렉토리에는 data 및 meta라는 서브 디렉토리들이 존재한다.

 

Meta Directory

meta 디렉토리에는 배치 및 설치 프로세스에 대한 설정을 지정하는 파일이 들어 있고 이 파일들은 설치 프로그램에서 추출하지 않는다. (즉, 최종 설치할 파일들은 아니다)

디렉토리에는 적어도 패키지 정보 파일(package.xml)과 스크립트 정보(.qs), 사용자 인터페이스 파일(.ui) 및 번역과 같이 패키지 정보 파일(package.xml)에서 참조하는 모든 파일이 있어야한다.

 

Data Directory

데이터 디렉토리에는 설치 프로그램에서 설치할 파일들을 넣는다. 파일들은 7z 아카이브 형식으로 압축 되어야하며, 응용 프로그램과 모든 종속성, 이미지 등을 포함해야한다.

Qt Installer Framework와 함께 제공되는 archivegen 도구 나 7zip 아카이브를 생성하는 다른 도구를 사용할 수 있다.

 

이제 data디렉토리에 넣을 파일들을 준비해야 하는데 Qt 응용프로그램 배포(windows) 에서 배포 tool을 다루는 법을 소개했다. 이제 응용프로그램 및 종속성 파일들을 7zip을 통해 압축한다.

7zip_archive.png

 

압축된 파일을 data디렉토리로 복사한다.

data_directory.png

 

시작 - 명령프롬프트(cmd)를 실행하고 작업디렉토리(ExamplePackage)로 이동한다.

 

com.vendor.product로 식별되는 패키지가 포함 된 helloWorldInstaller.exe라는 설치 프로그램을 만들기위해 다음 명령처럼 입력한다.

 

binarycreator.exe -c config\config.xml -p packages helloWorldInstaller.exe

 

binarycreator 툴은 -c 옵션의 config.xml를 참조하여 -p 옵션의 packages 디렉토리를 설치 프로그램이름으로 만들어 낼 것이다.
installer.png

 

만들어진 설치프로그램을 실행 하면 설치가되고
setup.png

 

설치된 디렉토리의 Qt 어플리케이션(helloWorld.exe)을 실행하면 기대하던 hello world 글자를 볼 수 있다.
helloworld.png

 

Qt가 설치되어있지 않은 윈도우계열 다른 운영체제에서도 설치 및 실행이 잘된다.

windows7_64bit.png

 

참고 페이지: http://doc.qt.io/qtinstallerframework/index.html

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 86175
39 Qt 응용프로그램에서 Lottie Animation사용 file makersweb 2021.05.30 885
38 앱을 종료할 때 QML 바인딩 오류를 피하는 방법 makersweb 2021.08.08 499
37 QML 에서 QR코드 생성 file makersweb 2021.08.20 897
36 QML 코딩 규칙 makersweb 2021.09.05 3275
35 QML에서 Websocket 서버와 통신 file makersweb 2021.09.18 834
34 Qt 응용프로그램에서 PDF 문서 렌더링 file makersweb 2021.09.23 679
33 안드로이드용 Qt 6.2 makersweb 2021.10.02 505
32 QML에서 앵커(anchors)로 위치 지정 file makersweb 2021.10.05 3881
31 Qt 6의 C++ 프로퍼티 바인딩 예제 makersweb 2021.11.01 857
30 Qt Android 앱에 AdMob 배너달기 file makersweb 2021.12.04 395
29 Qt Bluetooth Low Energy 개요 makersweb 2022.02.13 678
28 Binding 타입으로 객체 속성 간 묶기 makersweb 2022.03.04 428
27 성능 고려 및 제안 사항 makersweb 2022.03.07 511
26 VirtualKeyboard 스타일 커스터 마이징 makersweb 2022.03.13 464
25 Qt로 작성된 iOS 앱에서 시리얼 통신 file makersweb 2022.04.30 867
24 단일 인스턴스 Qt 응용 프로그램(Single-instance Application) makersweb 2022.06.23 706
23 HTTPS URL을 연결할 때 SslHandshakeFailedError 오류 makersweb 2022.07.31 362
22 Qt 6.4에 추가될 Qt Quick 3D Physics file makersweb 2022.08.07 346
21 Qt 스마트 포인터 (QSharedPointer, QScopedPointer, QPointer) makersweb 2022.08.18 1152
20 clazy 로 13개의 시그널, 슬롯 오류 해결 makersweb 2022.08.23 578