한국어
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

번호 제목 글쓴이 날짜 조회 수
33 QML에서 동적으로 텍스트 다국어 처리 file makersweb 2018.11.04 53
» Qt Installer Framework - 패키징, 설치프로그램 제작 file makersweb 2018.10.14 88
31 Qt 응용프로그램 배포(windows) file makersweb 2018.10.10 91
30 소스코드에서 환경변수 가져오기와 설정하기 makersweb 2018.10.08 40
29 표를 만들고 PDF문서로 출력하기 file makersweb 2018.09.30 60
28 Qml에서 키보드 입력 이벤트 핸들링 file makersweb 2018.08.09 139
27 Qml 어플리케이션 정적 빌드 file makersweb 2018.07.27 142
26 Qt Bluetooth 관련 기능 확인 사항 makersweb 2018.07.10 132
25 Qml 및 C++개발시 유용한 팁 makersweb 2018.04.06 376
24 Qt Version확인 방법 makersweb 2018.03.29 366
23 초보자를 위한 첫번째 프로젝트 - QML로 만드는 Hello World file makersweb 2018.03.16 597
22 Windows에서 라즈베리파이3 Qt 어플리케이션 개발 및 원격 실행 file makersweb 2018.02.23 1301
21 Windows에서 라즈베리파이3용 Qt5.10.0 크로스컴파일 file makersweb 2018.02.23 2074
20 Windows환경에서 mingw로 Qt 5.10 정적(static)빌드 file makersweb 2018.02.01 1110
19 다국어 지원 어플리케이션 개발 file makersweb 2018.01.27 320
18 Qt 어플리에이션 전역에 폰트 설정 makersweb 2018.01.24 402
17 Qt 3D Studio 시작하기 file makersweb 2018.01.11 347
16 QPA 플러그인과 HTML5 Backend file makersweb 2017.12.27 47
15 임의의 메모리 영역(QImage)에 QPainter를 이용하여 그리기 makersweb 2017.12.19 268
14 QML에서 undefined를 확인하는 방법 makersweb 2017.11.29 115