Занятие 1. Соглашения Windows по пользовательскому интерфейсу
(Продолжительность занятия 60 минут)
Одно из основных преимуществ операционной системы Windows — стандартный интерфейс всех приложений. Пользователь, знакомый с одним приложением этого семейства, легко изучит другие.
Например, в большинстве Windows-приложений строка меню (оно расположено в верхней части окна) начинается с меню File, продолжается дополнительными меню — например, Edit и Tools — и завершается меню справочной системы (Help). Возможно, название Documents нравится Вам больше, чем File, или Вы сочтете, что меню Help лучше смотрится слева. В принципе, ничто не мешает Вам откорректировать свою программу, но отклонение от общепринятых соглашений сделает ее менее удобной. Если Вы измените стандартный формат, пользователю при каждом переключении между Вашей и другими приложениями придется вспоминать, что где находится и как называется.
Четко определенная структура меню — всего лишь первый шаг на пути превращения Вашей программы в удобную рабочую среду. Другие правила не касаются пользовательских интерфейсов; это и поведение приложения на разных платформах, и возможность одновременного запуска нескольких копий приложения. На первом занятии рассказывается о нормативах, определяющих соответствие приложений архитектуре Windows.
OLE Drag-and-Drop
Пользователи, хорошо знакомые с интерфейсом Windows, обрадуются, узнав, что могут применять в Вашем приложении уже знакомые методы для создания, перетаскивания и активизации объектов.
Функция OLE drag-and-drop («перетащить и отпустить») позволяет перемещать данные на рабочем столе и в окне Windows Explorer, а также между любыми другими приложениями, поддерживающими этот протокол (рис. 12.1).
Поддерживая ее, Вы уподобите интерфейс Вашего приложения стандартному для Windows и для других программ, применяющих возможности OLE.
В результате пользователям легче освоить его, а приложению проще работать с другими программами, поддерживающими OLE.
Рис. 12.1 Копирование таблицы Microsoft Excel в документ Microsoft Word средствами функции OLE Drag-and-Drop
Реализация функции OLE Drag-and-Drop
В этом упражнении Вы средствами Visual Basic создадите приложение, которое поддерживает механизм перетаскивания объектов.
> Добавление средств поддержки перетаскивания
> Поддержка перетаскивания объектов из одного приложения в другое
Тестирование на всех Windows-платформах
Если Вы хотите создавать программы на базе интерфейса Win32 (Win32 API), Вам нужно протестировать их на всех Windows-платформах.
Это исключит вероятность использования функций (или класса функций) Win32 API, которые поддерживаются только на одной платформе. Например, интерфейс графических устройств (GDI) в Windows NT работает с 32-битной системой координат, которая недоступна в Windows 95. Применение 32-битных координат в приложении под управлением Windows 95 приведет к неверному результату.
Запуск нескольких экземпляров приложения
Вполне возможно, что пользователь попытается запустить несколько копий Вашего приложения. Это не всегда желательно, особенно если программа не рассчитана на работу в таком режиме — например, если она использует глобальные данные, при запуске нескольких экземпляров возникнет путаница.
Обработка нескольких экземпляров приложения
Возможны два способа предотвращения проблем, связанных с одновременной работой нескольких копий приложения:
В любом случае в стартовом коде Вашей программы следует проверить выполнение нескольких копий.
Запуск нескольких экземпляров параллельно не всегда нежелателен. Например, если такая возможность предусмотрена разработчиком, разные копии приложения могут взаимодействовать между собой или совместно использовать ресурсы.
Проверка одновременного выполнения нескольких экземпляров приложения
Обнаружить одновременное выполнение нескольких экземпляров можно, например, вызвав функцию Visual Basic FindWindow при первом запуске приложения. Она проверяет, запущены ли уже его копии. Этот способ работает почти всегда, но он не самый эффективный — например, если пользователь быстро откроет подряд две копии программы, функция FindWindow может дать неверный ответ.
Альтернатива этому методу — использование свойства Prevlnstance объекта Арр. Оно позволяет проверить, была ли уже запущена копия данного приложения.
Private Sub Form_Load()
' Проверка наличия выполняющейся копии приложения
If Арр.Prevlnstance = True Then
MsgBox "Это приложение уже запущено.", vbCritical, "MyApp"
End
End If
End Sub
> Проверка наличия работающей копии программы в Visual Basic
Private Sub Form_Load( ) If Арр.Prevlnstance Then MsgBox "Эта программа уже запущена." Unload Me End If End Sub
После запуска программы на экране появится форма Fonnl.
На экране появится созданное Вами в Visual Basic окно с сообщением, информирующем, что один экземпляр приложения уже запущен.
Целостность интерфейса Windows
Стратегия разработки приложения и его пользовательского интерфейса должна органично вписываться в концепцию интерфейса Windows. Для этого необходимо снабдить приложение следующими элементами:
Вот еще несколько советов.
Например, для открытия файла воспользуйтесь стандартным диалоговым окном, а не модернизированной Вами версией File Open.
Системные константы, определяющие цвета, позволяют Вам использовать в своем приложении пользовательскую цветовую схему. Один из вариантов приведен в таблице.
Константа Visual Basic |
Описание |
VbWindowBackground |
Цвет фона окна |
VbMenuText |
Цвет текста меню |
VbInfoText |
Цвет текста оперативных подсказок по элементам интерфейса |
VbInfoBackground |
Цвет фона оперативных подсказок по элементам интерфейса |
Возможно, часть экрана будет занята панелью задач, поэтому не следует рассчитывать, что Вашей форме или окну приложения будет доступен весь экран.
Использование реестра Windows
Перечисленные ниже элементы следует регистрировать в реестре Windows.
Если Вы не сделаете этого, система каждый раз будет предлагать пользователю самому указать приложение для открытия файлов этого типа.
Для идентификации объектов могут применяться как большие (32х32 пиксела), так и маленькие (16х16 пикселов) значки, поэтому Вашему приложению необходимы обе версии значков. Система умеет создавать стандартные значки, но в большинстве случаев лучше сделать это самому.
Это операции (например, Edit, Open или Play), которые пользователь вправе выполнить над объектом. Вам следует включить в реестр соответствующие команды для всех типов данных Вашего приложения. Например, если программа воспроизводит аудиофайлы, для звуковых объектов следует зарегистрировать команду Play. Эти команды, в частности, входят в контекстное меню объекта: оно появляется, когда пользователь щелкает объект правой кнопкой мыши.
Пользовательскую информацию следует помещать в раздел реестра HKEY_CURRENT_USER, а иные данные - в HKEY_CURRENT_MACH1NE. Эти элементы реестра предназначены для хранения сведений, которые ранее содержались в INI-файлах Windows 3.1. Если Вы переносите старые приложения на новую Windows-платформу, откажитесь от lNI-файлов и воспользуйтесь для хранения информации реестром.
Поддержка системных правил именования файлов
В Windows 95 разрешены длинные (до 255 символов) имена файлов и пути в формате универсальных правил именования (Universal Naming Convention, UNC) типа \\имя_сервера\cетевое_имя.
Длинные имена файлов
Для поддержки длинных имен файлов необходимо, чтобы все диалоговые окна приложения могли отобразить достаточную часть имени файла, не ограничиваясь только форматом 8.3 (в нем отводится восемь символов под имя и три — под расширение). Windows 95 трактует расширение «.3» как отдельное поле типа. Обязательно также предусмотрите возможность отображения документов и файлов данных большими и малыми значками.
Универсальные правила именования
Благодаря поддержке UNC-путей, пользователи могут напрямую просматривать сеть и открывать файлы, не назначая символы сетевым ресурсам. Кроме того, UNC-пути облегчают приложениям работу с данными. Например, некоторые программы сохраняют список документов, прежде открывавшихся пользователем. Если приложение сохраняет путь с именем диска (например, N:\), файл не будет найден без предварительного назначения сетевому ресурсу символа N:. Сохранив информацию в форме UNC-пути, приложение сумеет подключиться к сетевому ресурсу, не запрашивая пользователя о местонахождении файла.
«Интеллектуальные» программы установки и удаления
Снабдите свое приложение «интеллектуальной» программой установки, предусмотрев в ней выполнение следующих операций:
Мастер Setup Wizard
Мастер установки Setup Wizard, включенный в состав Visual Basic, на основании анализа файла проекта составляет необходимый программе установки список файлов с зависимостями. Кроме того, он сжимает эти файлы и создает программу установки (для жесткого диска или дискет). Вся регистрация клиентской части, в том числе и проверка версий файлов, выполняется автоматически. Это особенно важно при установке DLL- или ОСХ-файлов на клиентский компьютер. Мастер может включить в установочный комплект и другие файлы, например изображение логотипа компании или заставку для отображения динамики процесса установки. Все параметры можно сохранить в шаблоне для повторного использования.
> Знакомство с мастером установки
В этом упражнении Вы средствами мастера Visual Basic Setup Wizard создадите дистрибутив приложения.
C:\ProgramFiles\DevStudio\VB\samples\PGuide\Controls\Controls.vbp
Создание утилиты удаления приложения
Пользователи должны иметь возможность без труда удалить Ваше приложение. Установка типичного приложения иногда влечет множество изменений в системе, включая создание значков и папок, регистрацию специальной информации в реестре, смену путей и добавление файлов (например, DLL) в системный каталог. В результате пользователь не может избавиться от приложения, просто удалив несколько файлов. Специальная утилита значительно облегчает восстановление системы в исходное состояние. Обычно утилита удаления приложения удаляет:
Мастер Setup Wizard автоматически регистрирует приложения в Windows 95, поэтому удалить программу пользователь может утилитой Add/Remove Programs Панели управления Windows 95. Это средство позволяет избавиться от всех ссылок, каталогов и значков программных групп, а также автоматически отслеживает файлы, используемые несколькими приложениями, — они не удаляются, если нужны для работы других приложений.
Создание программы установки
В этом упражнении Вы с помощью мастера Visual Basic Setup Wizard создадите программу установки приложения.
> Создание программы установки
c:\ProgramFiles\DevStudio\VB\samples\PGuide\calc\Calc.vbp
> Тестирование программы установки
Запустится калькулятор — программа-пример Visual Basic, поставляемая вместе с Visual Basic 5.0
> Удаление приложения
Обратите внимание на исчезновение элемента Calc из меню Programs Windows 95.
Объемность элементов интерфейса
Для многих элементов управления интерфейса Windows используется выделение и затенение, за счет чего они выглядят объемными (рис. 12.2). Это облегчает работу пользователя — например, когда он щелкает объемную кнопку, она «вжимается» совсем как настоящая. Чтобы соответствовать интерфейсу Windows, Ваше приложение должно применять объемные элементы управления.
Рис. 12.2 Элементы управления, которые выглядят объемными
Резюме
Приложения, разработанные с учетом стандартных правил построения пользовательского интерфейса, гораздо проще освоить. Приведенные ниже рекомендации помогут Вам создать приложение в соответствии со стандартом ОС семейства Windows. Обеспечьте поддержку механизма перетаскивания объектов. Тестируйте Ваше приложение на всех Windows-платформах. Проверяйте наличие нескольких выполняющихся копий приложения.
Разрабатывайте приложения с учетом требований пользовательского интерфейса Windows.
Используйте реестр Windows.
Поддерживайте системные правила именования файлов. Создавайте интеллектуальные программы установки и удаления. Придайте элементам интерфейса своих приложений объемный вид.