Процесс установки программы, который, как
Современные программы распространяются на компакт-дисках. Процесс установки программы, который, как правило, предполагает не только создание каталога и перенос в него выполняемых файлов и файлов данных с промежуточного носителя, но и настройку системы, для многих пользователей является довольно трудной задачей. Поэтому установку прикладной программы на компьютер пользователя обычно возлагают на специальную программу, которая находится на том же диске, что и файлы программы, которую надо установить. Таким образом, разработчик прикладной программы помимо основной задачи должен создать программу установки — инсталляционную программу.
Инсталляционная программа может быть создана точно так же, как и любая другая программа. Задачи, решаемые во время инсталляции, являются типовыми. Поэтому существуют инструментальные средства, используя которые можно быстро создать инсталляционную программу, точнее, установочный диск, не написав ни одной строчки кода.
Программа InstallShield Express
Одним из популярных инструментов создания инсталляционных программ является пакет
InstallShield Express. Borland настоятельно рекомендует использовать именно эту программу, поэтому она есть на установочном диске C++ Builder.
Процесс создания инсталляционного диска (CD-ROM) при помощи InstallShield Express рассмотрим на примере.
Пусть нужно создать инсталляционную дискету для программы "Сапер". Перед тем как непосредственно приступить к созданию установочной программы в
InstallShield Express, нужно выполнить подготовительную работу — составить список файлов, которые должны быть установлены на компьютер пользователя; используя редактор текста, подготовить rtf-файлы лицензионного соглашения (EULA — End User Licensia Agreement) и краткой справки (readme-файл). Список файлов программы "Сапер", которые должны быть перенесены на компьютер пользователя, приведен в табл. 9.1.
Таблица 9.1. Файлы программы "Сапер", которые нужно установить
на компьютер пользователя
Файл |
Назначение |
Куда устанавливать |
Saper.exe |
Программа |
Program Files\Saper |
Saper.chm |
Файл справочной информации |
Program Files\Saper |
Readme.rtf |
Краткая справка о программе |
Program Files\Saper |
Eula.rtf |
Лицензионное соглашение |
Program Files\Saper |
Новый проект
После того как будет составлен список файлов, нужно запустить InstallShield Express, из меню
File выбрать команду New и в поле Project Name and Location ввести имя файла проекта (рис. 9.1).
Рис. 9.1. Начало работы над новым проектом
После щелчка на кнопке ОК открывается окно проекта создания инсталляционной программы (рис. 9.2). В левой части окна перечислены этапы процесса создания и команды, при помощи которых задаются параметры создаваемой инсталляционной программы.
Команды настройки объединены в группы, название и последовательность которых отражает суть процесса создания инсталляционной программы. Заголовки групп пронумерованы. Настройка программы установки выполняется путем последовательного выбора команд. В результате выбора команды в правой части главного окна появляется список параметров. Команды, которые были выполнены, помечаются галочками.
Рис. 9.2. В левой части окна проекта перечислены этапы и команды процесса создания
инсталляционной программы
Структура
Команды группы Organize Your Setup (рис. 9.3) позволяют задать структуру программы установки.
Рис. 9.3. Команды группы Organize Your Setup
В результате выбора команды General Information в правой части окна раскрывается список, в который нужно ввести информацию об устанавливаемой программе.
Значения большинства параметров, за исключением тех, которые идентифицируют устанавливаемую программу и ее разработчика, можно оставить
без изменения. Параметры, значения которых нужно изменить, приведены в табл. 9.2.
Таблица 9.2. Параметры команды General Information
Параметр |
Определяет |
Значение |
Product Name |
Название устанавливаемой программы |
Sape r |
Product Version |
Версия устанавливаемой программы |
1.01.0001 |
INSTALLDIR |
Каталог компьютера пользователя, в который будет установлена программа |
[ProgramFilesFolder] Saper |
Следует обратить внимание на параметр INSTALLDIR. По умолчанию предполагается, что программа будет установлена в каталог, предназначенный для программ. Поскольку во время создания инсталляционной программы нельзя знать, как на компьютере пользователя называется каталог программ и на каком диске он находится, то вместо имени реального каталога используется его псевдоним— [ProgramFilesFolder]. В процессе установки программы на компьютер пользователя инсталляционная программа получит из реестра Windows имя каталога программ и заменит псевдоним на это имя.
Другие псевдонимы, которые используются в программе InstallShield Express, приведены в табл. 9.3
Таблица 9.3. Некоторые псевдонимы каталогов Windows
Псевдоним |
Каталог |
[Windows Volume ] |
Корневой каталог диска, на котором находится Windows |
[WindowsFolder] |
Каталог Windows, например C:\Winnt |
[SystemFolder] |
Системный каталог Windows, например C:\Winnt\System32 |
[ProgramFilesFolder] |
Каталог программ, например C:\Program Files |
[PersonalFolder] |
Папка Мои документы на рабочем столе (расположение папки зависит от версии ОС и способа входа в систему) |
Очевидно, что возможности инсталлированной программы определяются составом установленных компонентов. Например, если установлены файлы справочной системы, то пользователю в процессе работы с программой доступна справочная информация. Команда
Features (возможности) позволяет создать (определить) группы компонентов,
которые определяют возможности программы и которые могут устанавливаться по отдельности. Разделение компонентов на группы позволяет организовать многовариантную, в том числе и определяемую пользователем, установку программы.
В простейшем случае группа Features состоит из одного элемента Always Install. Чтобы добавить элемент в группу
Features, нужно щелкнуть правой кнопкой мыши на слове Features, из появившегося контекстного меню выбрать команду
New Feature Ins и ввести имя новой группы, например Help Files and samples. После этого в поле
Description нужно ввести краткую характеристику элемента, а в поле Comments — комментарий (рис. 9.4).
Рис. 9.4. Несколько элементов в группе Features обеспечивают возможность многовариантной установки
Команда Setup Types позволяет задать, будет ли пользователю во время установки программы предоставлена возможность выбрать (в диалоговом окне
Setup Type) вариант установки. Установка может быть обычной (Typical), минимальной (Minimal) или выборочной (Custom). Если устанавливаемая программа сложная, т. е. состоит из нескольких независимых компонентов, то эта возможность обычно предоставляется.
Для программы "Сапер" предполагается только один вариант установки —
Typical. Поэтому флажки Minimal и Custom нужно сбросить (рис. 9.5).
Рис. 9.5. Команда Setup Types позволяет задать возможные варианты установки программы
Выбор устанавливаемых компонентов
Команды группы Specify Application Data (рис. 9.6) позволяют определить компоненты программы, которые должны быть установлены на компьютер пользователя. Если в проекте определены несколько групп компонентов (см. команду Features), то нужно определить компоненты для каждой группы.
Рис. 9.6. Команды группы Specify Application Data
В результате выбора команды Files правая часть окна будет разделена на области (рис. 9.7). В области
Source computer's files можно выбрать файлы, которые необходимо перенести на компьютер пользователя. В области
Destination computer's folders надо выбрать папку, в которую эти файлы должны быть помещены. Для того чтобы указать, какие файлы нужно установить на компьютер пользователя, следует просто "перетащить" требуемые файлы из области
Source computer's files в область Destination computer's files. Если в группе
Features несколько элементов, то надо определить файлы для каждого элемента.
Рис. 9.7. Выбор файлов, которые нужно перенести на компьютер пользователя
Команда Object/Merge Modules позволяет задать, какие объекты, например динамические библиотеки или пакеты компонентов, должны быть помешены на компьютер пользователя и, следовательно, на установочную дискету. Объекты, которые нужно поместить на установочную дискету, выбираются в списке
InstallShield Objects/Merge Modules (рис. 9.8).
Рис. 9.8. Выбор объектов, которые должны быть установлены на компьютер пользователя
Конфигурирование системы пользователя
Команды группы Configure the Target System (рис. 9.9) позволяют задать, какие изменения нужно внести в систему пользователя, чтобы настроить систему на работу с устанавливаемой программой.
Рис. 9.9. Команды группы Configure the Target System
Команда Shortcuts/Folders позволяет указать, куда нужно поместить ярлык, обеспечивающий запуск устанавливаемой программы. В результате выбора этой команды в правой части окна открывается иерархический список, в котором перечислены меню и папки, куда можно поместить ярлык программы. В этом списке нужно выбрать меню, в которое должен быть помещен ярлык, щелкнуть правой кнопкой мыши и в появившемся списке выбрать команду
New Shortcut (рис. 9.10).
Рис. 9.10. В списке Shortcuts нужно выбрать меню, в которое должен быть помещен
ярлык запуска программы
Рис. 9.11. Выбор файла, для которого создается ярлык
Рис. 9.12. Ярлык создан, теперь можно выполнить его настройку
Затем, в диалоговом окне Browse for Shortcut Target, нужно выбрать файл программы (рис. 9.11), щелкнуть на кнопке
Open и ввести имя ярлыка. После этого можно выполнить окончательную настройку ярлыка, например, в поле
Arguments ввести параметры командной строки, а в поле Working Directory — рабочий каталог (рис. 9.12).
Настройка диалогов
Для взаимодействия с пользователем программа установки использует стандартные диалоговые окна. Разрабатывая программу инсталляции, программист может задать, какие диалоги увидит пользователь в процессе инсталляции программы.
Чтобы задать диалоговые окна, которые будут появляться на экране монитора во время работы инсталляционной программы, надо в группе
Customize the Setup Appearance (рис. 9.13) выбрать команду Dialogs и в открывшемся списке
Dialogs (рис. 9.14) отметить диалоги, которые нужно включить в программу установки.
Рис. 9.13. Команды группы Customize the Setup Appearance
Рис. 9.14. В списке Dialogs нужно отметить диалоги, которые должны появиться в процессе установки программы на компьютер пользователя
В таблице Properties (справа от списка диалогов) перечислены свойства выбранного диалога. Программист может изменить значение этих свойств и, тем самым, выполнить настройку диалога. Например, для диалога
Readme нужно задать имя файла (свойство Readme File), в котором находится краткая справка об устанавливаемой программе.
Для большинства диалогов можно определить баннер (свойство Banner Bitmap) — иллюстрацию, которая отображается в верхней части окна диалога. Формат файла баннера — BMP, размер — 499x58 пикселов.
В табл. 9.4 перечислены диалоговые окна, которые могут появиться во время работы инсталляционной программы.
Таблица 9.4. Диалоговые окна процесса установки
Диалоговое окно |
Назначение |
Splash Bitmap |
Вывод иллюстрации, которая может служить в качестве информации об устанавливаемой программе. Размер иллюстрации — 465x281 пиксел, формат — BMP |
Install Welcome |
Вывод информационного сообщения на фоне иллюстрации (размер 499x312 пикселов) |
License Agreement |
Вывод находящегося в rft-файле лицензионного сообщения. Позволяет прервать процесс установки программы в случае несогласия пользователя с предлагаемыми условиями |
Readme |
Вывод краткой информации об устанавливаемой программе |
Customer Information |
Запрашивает информацию о пользователе (имя, название организации) и, возможно, серийный номер устанавливаемой копии |
Destination Folder |
Предоставляет пользователю возможность изменить предопределенный каталог, в который устанавливается программа |
Database Folder |
Предоставляет пользователю возможность изменить предопределенный каталог, предназначенный для баз данных |
Setup Type |
Предоставляет пользователю возможность выбрать тип установки программы (Typical— обычная установка,
Minimal — минимальная установка, Custom — выборочная установка) |
Custom Setup |
Предоставляет пользователю возможность выбрать устанавливаемые компоненты при выборочной (Custom) установке |
Ready to Install . |
Вывод информации, введенной пользователем на предыдущих шагах, с целью ее проверки перед началом непосредственной установки программы |
Setup Progress |
Показывает процент выполненной работы во время установки программы |
Setup Complete . Success |
Информирует пользователя о завершении процесса установки. Позволяет задать программу, которая должна быть запущена после завершения установки (как правило, это сама установленная программа), а также возможность вывода содержимого Readme-файла |
Для того чтобы диалоговое окно появлялось во время работы инсталляционной программы, необходимо установить флажок, расположенный слева от названия диалогового окна. Для окон
License Agreement и Readme нужно задать имена rtf-файлов, в которых находится соответствующая информация.
В простейшем случае программа инсталляции мoжeт ограничиться выводом следующих диалогов:
Readme; Destination Folder; Ready to Install; Setup Progress; Setup Complete Success.
Системные требования
Если устанавливаемая программа предъявляет определенные требования к ресурсам системы, то, используя команды группы
Define Setup Requirements and Actions (рис. 9.15), эти требования можно задать.
Рис. 9.15. Команды группы Define Setup Requirements and Actions
Рис. 9.16. Параметры, характеризующие систему
В результате выбора команды Requirements на экране появляется таблица (рис. 9.16), в которую надо ввести значения параметров, характеризующих систему: версию операционной системы (OS
Version), тип процессора (Processor), объем оперативной памяти (RAM), разрешение экрана (Screen
Resolution) и цветовую палитру (Color Depth). Значения
характеристик задаются путем выбора из раскрывающегося списка, значок которого появляется в результате щелчка в поле значения параметра.
Если программа не предъявляет особых требований к конфигурации системы, то команды группы
Define Setup Requirements and Actions можно пропустить.
Создание образа установочной дискеты
Команды группы Prepare for Release (рис. 9.17) позволяют создать образ установочной дискеты (CD-ROM) и проверить, как работает программа установки.
Рис. 9.17. Команды группы Prepare for Release
Для того чтобы активизировать процесс создания образа установочной дискеты (CD-ROM), нужно выбрать команду Build Your
Release, щелкнуть правой кнопкой мыши на значке носителя, на который предполагается поместить программу установки, и из появившегося контекстного меню выбрать команду
Build (рис. 9.18).
Рис. 9.18. Активизация создания образа установочного CD-ROM
В результате этих действий на диске компьютера в папке проекта будет создан образ установочного диска. Если в качестве носителя выбран CD-ROM, то образ будет помещен в подкаталог
\Express\Cd_rom\DiskImages\Disk1.
Можно, не завершая работу с InstallShield Express, проверить, как функционирует программа установки. Для этого надо щелкнуть на одной из командных кнопок
Run или Test (рис. 9.19). Команда Run устанавливает
программу, для которой создана программа установки, на компьютер разработчика. Команда
Test только имитирует установку, что позволяет проверить работоспособность интерфейса.
Рис. 9.19. Используя команды Run и Test можно проверить, как работает программа установки
После того как программа установки будет проверена, можно создать реальный установочный диск. Для этого надо просто скопировать (записать) содержимое каталога \Express\Cd_rom\DiskImages\DisklHa CD-ROM.