Поскольку большинство сред разработки, которые мы будем обсуждать в данной книге, произведены в Microsoft, не удивительно, что они используют для создания, отладки и поставки приложений одни и те же инструменты. Такими инструментами являются эмулятор устройства Pocket PC, программа для соединения мобильного устройства с настольным компьютером ActiveSync, программа для создания поставочного комплекта приложения CabWiz, программа для соединения среды разработки с эмулятором через ActiveSync, Emulator ActiveSync Connection Tool, а также набор небольших программ, помогающих при отладке приложения, объединенных в набор Windows Mobile Developer Power Toys.
Также существует некоторый набор рекомендаций по разработке и оформлению пользовательского интерфейса ваших программ. Эти правила не зависят от среды разработки. Именно они и будут обсуждаться в этой главе.
Эмулятор является очень важным звеном при создании приложений для Pocket PC. Конечно, приложение можно отлаживать и на самом устройстве, но это крайне неудобно, особенно если устройство установлено в специальный держатель для подключения Pocket PC к стационарному компьютеру. Отладка на эмуляторе позволяет выявить большую часть логических ошибок, которые были допущены при разработке приложения.
В этом разделе речь пойдет об эмуляторе, который входит в состав Microsoft SDK for Pocket PC 2003. Следует учитывать, что другие эмуляторы могут отличаться меньшей или большей поддержкой того или иного оборудования, сервисов и библиотек операционной системы. Впрочем, то же самое можно сказать и о самих устройствах.
После установки Microsoft Windows Pocket PC 2003 SDK эмулятор можно будет запускать как из среды eMbedded Visual C++ 4.0 (Service Pack 2), так и из среды Visual Studio.NET 2003. Однако его можно запустить и как независимое устройство и пользоваться им для самостоятельного изучения.
При установке SDK в главном меню компьютера создается соответствующая группа программ (рис. 2.1).
Рис. 2.1. Группа ярлыков Pocket PC 2003 SDK.
В этой группе можно отыскать пиктограмму Pocket PC 2003 Emulator, которая позволяет запускать эмулятор как самостоятельное устройство (рис. 2.2):
Рис. 2.2. Запущенный эмулятор Pocket PC 2003.
Щелкнув правой клавишей мыши на пиктограмме эмулятора, и выполнив в контекстном меню команду Свойства, можно заметить, что эмулятор запускается командным файлом emul.cmd. Полный текст файла приведен ниже.
start "" "C: \Program Files\Common Files\Microsoft Shared\Windows CE Tools\ Platman\
bin\PBEmulator.exe" /MemorySize 64 /Fastbackground /Skin "C: \Program Files\Windows CE
Tools\wce420\POCKET PC 2003\Emulation\pocket_pc_emulator_skin.xml" /CEImage
«C: \Program Files\Windows CE Tools\wce420\POCKET PC 2003\Emulation\ PPC_2003_WWE.bin»
/VMName «POCKET PC 2003 – POCKET PC 2003 Emulator» /HostKey 165
Внимательный просмотр этого файла показывает, что в нем просто производится вызов одного файла с несколькими ключами. Эти ключи рассмотрены в списке, приведенном ниже.
♦ /Video – необязательный параметр. Он устанавливает размеры экрана в пикселах и глубину цвета в битах. Эти параметры не будут приняты во внимание, если для эмулятора будет применена обложка (skin), которая предусматривает свои собственные настройки размера и глубины цвета. Аргументы должны быть записаны в виде ширинахвысотахглубина. Ширина страницы должна быть в пределах от 80 до 1024 пикселов, высота – от 64 до 768 пикселов, глубина цвета может принимать значения 8, 16 или 32.
♦ /Ethernet – необязательный параметр. Он позволяет включать или отключать работу контроллера Ethernet в эмуляторе. С этим ключом можно использовать значения None, Shared, Virtualswitch или адрес media access control (MAC) реальной платы адаптера на стационарном компьютере. Этот способ используется, если на компьютере установлено больше одного сетевого адаптера. Эмулятор по умолчанию будет использовать первый найденный адаптер, и если нужно использовать другой адаптер, то нужно указать его MAC-адрес. Предназначение остальных значений приведено ниже.
• None – в эмуляторе недоступна сетевая карта.
• Shared – эмулятор использует ту же сетевую карту (тот же IP-адрес), что и стационарный компьютер. При этом эмулятор может посылать запросы по сети и получать информацию в ответ на эти запросы, но он не воспринимает сетевые сообщения, причиной которых является не он сам.
• Virtualswitch – эмулятор получает свой собственный IP-адрес при помощи DHCP и начинает работать как полноценный хост в сети, доступный как для исходящих, так и для входящих сетевых сообщений.
♦ /Skin – необязательный параметр. Он указывает, какую нужно использовать обложку. В качестве параметра должен быть указан файл XML, в котором описана обложка эмулятора в соответствующем стандарте.
♦ /CEImage – обязательный параметр. Он задает полное имя файла ядра эмулятора. Собственно говоря, файл ядра и есть сам эмулятор.
♦ /MemorySize – необязательный параметр. Он задает количество памяти, используемой ядром для работы. Значение указывается в мегабайтах. Оно должно быть кратно четырем и находиться в промежутке от 32 до 256 Мбайт. Для Pocket PC 2003 это значение не должно быть менее 64 Мбайт.
♦ /Fastbackground – необязательный параметр. Он задает высокий приоритет для процесса эмулятора, когда его окно не обладает фокусом ввода.
♦ /HostKey – необязательный параметр. В качестве аргумента задается десятичный код клавиши, в сочетании с которой будут срабатывать «горячие клавиши» эмулятора, нажимаемые на клавиатуре стационарного компьютера. Более подробно горячие клавиши эмулятора будут рассмотрены ниже.
♦ /VMName – необязательный параметр, который позволяет задавать текст, отображаемый на заголовке окна. Параметр представляет собой строку, которая должна быть помещена в кавычки. Если обложка эмулятора задает свой собственный текст заголовка, то этот параметр будет проигнорирован.
♦ /VMID – необязательный параметр, который позволяет задавать глобальный уникальный идентификатор (GUID) эмулятора. Используя этот параметр, разработчик может запускать одновременно несколько разных конфигураций эмулятора.
Для того, чтобы эмулятор мог быть запущен на машине разработчика и для его эффективной работы, стационарный компьютер и его программное обеспечение должны удовлетворять некоторым минимальным требованиям, которые перечислены в следующем списке.
♦ Операционная система: Microsoft Windows 2000 Professional или Windows 2000 Server с установленным Service Pack 2, Microsoft Windows XP Home Edition или Windows XP Professional.
♦ Процессор Intel Pentium II или старше с частотой не менее 400 МГц.
♦ Не менее 196 Мбайт оперативной памяти.
♦ Сетевая карта или установленный Microsoft Loopback Adapter.
ВНИМАНИЕ!
Сетевая карта должна быть подключена к сети. Неподключенная сетевая карта не распознается как корректное устройство. При этом, если у вас установлена неподключенная сетевая карта, но работает модемное подключение к Интернету, то это вполне устраивает эмулятор.
Компонент Microsoft Loopback Adapter предназначен для имитации наличия на компьютере сетевой платы, в то время, когда реальный физический сетевой адаптер на машине отсутствует. Процедура установки Microsoft Loopback Adapter приведена в следующем списке.
1. Открыть папку Пуск ► Настройка ► Панель управления.
2. Запустить инструмент Установка оборудования и нажать кнопку Далее.
3. Утвердительно ответить на вопрос, подключено ли устройство к компьютеру, и нажать кнопку Далее.
4. В новом диалоговом окне выбрать последний пункт из списка Добавление нового устройства.
5. Выбрать вариант Установка оборудования, выбранного из списка вручную.
6. Выбрать из списка пункт Сетевые платы и нажать кнопку Далее.
7. Выбрать значение Адаптер Microsoft замыкания на себя и нажать кнопку Далее.
После того, как устройство будет установлено, из контекстного меню пиктограммы Сетевое окружение нужно выполнить команду Свойства. После этого в открывшемся диалоговом окне следует отыскать установленный адаптер. Скорее всего, он будет обозначен как Подключение по локальной сети. В его контекстном меню тоже нужно выполнить команду Свойства. В диалогом окне свойств нового подключения нужно установить флажок Virtual PC Emulated Ethernet Switch. Этот протокол еще пригодится в дальнейшем.
Конечно, эмулятор не настолько функционален, как настоящий Pocket PC. Основные ограничения эмулятора приведены в соответствующем списке.
1. Единственным протоколом, по которому эмулятор может связываться с внешними устройствами, является TCP\IP.
2. Эмулятор поддерживает только один процессор x86. Соответственно, все приложения, которые выполняются на эмуляторе, должны быть собраны для этой платформы. Это накладывает ограничения на всякого рода тонкие настройки и оптимизацию быстродействия и памяти, поскольку на реальном устройстве с процессором ARM на уровне машинных команд быстродействие будет совершенно другим. Разработчик не может использовать эмулятор для запуска никаких программ для Pocket PC, если у него нет их исходного кода.
3. Эмулятор не поддерживает контактный экран Pocket PC. Вместо этого в эмуляторе применяется мышь стационарного компьютера.
4. Эмулятор не поддерживает запись звука, независимо от того, снабжен ли микрофоном и программой для звукозаписи стационарный компьютер.
5. Клавиатура эмулятора поддерживает только английскую раскладку, независимо от установленных на стационарном компьютере и эмуляторе региональных настроек.
Несколько сочетаний клавиш позволяют получить быстрый доступ к функциям эмулятора.
♦ Сочетание Host + F выводит на экран диалоговое окно, позволяющее сделать существующую на стационарном компьютере папку каталогом общего пользования, который на эмуляторе будет опознаваться как карта дополнительной памяти. Наличие разделяемого каталога позволяет легко перемещать файлы между эмулятором и стационарным компьютером.
♦ Сочетание Host + P позволяет приостановить и возобновить работу эмулятора.
♦ Сочетание Host + R инициирует жесткую перезагрузку эмулятора с потерей информации и настроек.
♦ Сочетание Host + T позволяет выполнить мягкую перезагрузку эмулятора.
♦ Сочетание Host + F4 завершает работу эмулятора.
ВНИМАНИЕ!
При завершении работы с эмулятором вы можете выбрать из выпадающего списка в окне диалога завершения работы пункт Save Emulator State. В этом случае текущее состояние эмулятора, включая установленные соединения и запущенные программы, будет сохранено в специальном файле на диск. При последующем запуске эмулятора его состояние будет восстановлено. Это может значительно ускорить работу с эмулятором. Файлы состояния записываются в каталог C: \Documents and Settings\Имяпользователя\Application Data с расширением. vsv (например, {31F6C796-7FD5-43AC-A8C2-A7CDB8C00A3B}.vsv). Удаление этих файлов ведет к потере сохраненного состояния.
В приведенном выше сочетании горячих клавиш клавиша Host – это та клавиша, код которой задан ключом /HostKey командной строки эмулятора.
Список возможных кодов клавиш приведен в табл. 2.1.
Между эмулятором и средой разработки существует соответствующий программный слой. Эта технология обеспечивает взаимодействие среды разработки с реальным устройством или эмулятором. Этот программный слой называется Platform Manager и позволяет среде разработки установить сетевое соединение с устройством (эмулятором), загрузить на него файлы и произвести основные операции отладки на уровне приложения. Сам пакет Platform Manager и вспомогательные инструменты отладки располагаются в каталоге C: \Program Files\ Common Files\Microsoft Shared\Windows CE Tools\Platman\bin\wce420. Каждый из инструментов Platform Manager и каждая среда разработки Microsoft, предназначенная для работы с Pocket PC или Windows CE, имеет в меню команду Configure Windows CE Platform Manager…, которая позволяет настроить запуск нужного эмулятора и в интерактивном режиме отредактировать ключи командной строки.
Теперь следует перейти в папку C: \Program Files\Common Files\Microsoft Shared\ Windows СЕ Tools\Platman\bin\wce420 и запустить программу cefilevw.exe. Эта программа позволяет просматривать папки эмулятора и копировать файлы на эмулятор. Но сейчас следует обратить особое внимание не на функциональность этой программы, а на пункт меню Connection ► Configure Windows СЕ Platform Manager. После выполнения этой команды на экран будет выведено диалоговое окно (рис. 2.3).
Рис. 2.3. Выбор устройства для настройки.
В списке нужно выбрать пункт Pocket PC 2003 Emulator, после чего следует нажать кнопку Properties. На экране появится очередное окно настройки (рис. 2.4).
Рис. 2.4. Окно настройки эмулятора Pocket PC 2003.
В выпадающем списке Transport нужно выбрать значение TCP\IP Transport For Windows CE, а в списке Startup Server выбрать значение Emulator Startup Server. После нажатия на кнопку Configure, которая относится к списку Startup Server, еще одно окно настройки будет выведено на экран (рис. 2.5).
Рис. 2.5. Окно конфигурации стартовых параметров эмулятора.
В этом окне можно выбрать параметры, с которыми будет запускаться эмулятор.
♦ Параметр Device ► Image позволяет указать, какое ядро эмулятора будет загружено. Разработчик может использовать одно из трех стандартных ядер – Pocket PC 2003 или два ядра Pocket PC 2003 Phone Edition с разными сетевыми устройствами.
♦ Параметр Video ► Skin позволяет указать, какая обложка будет выбрана для эмулятора. На обложке для Phone Edition есть дополнительные кнопки дозвона и прекращения связи.
♦ Параметр System ► HostKey позволяет установить клавишу HostKey.
♦ Параметр Communication позволяет задать параметры связи эмулятора с внешним миром.
• Значение Ethernet позволяет установить NAT. Проблемы настройки Virtual Switch будут рассмотрены позже.
• Значение Serial Port 1 позволяет соединить первый COM-порт эмулятора с реальным портом рабочей станции или маппировать его на файл.
• Значение Serial Port 2 позволяет соединить второй COM-порт эмулятора с реальным портом рабочей станции или маппировать его на файл.
• Значение Parallel Port позволяет соединить параллельный порт эмулятора с реальным портом рабочей станции.
После настройки всех необходимых параметров нужно закрыть окно нажатием кнопки OK. В окне настройки устройства нужно нажать кнопку Test. Это приведет к запуску эмулятора с заданными параметрами, и через две-три минуты будет установлено соединение. Данный факт будет сопровождаться громким звуком, а кнопка Cancel в окне Testing Device Connection сменится кнопкой OK.
Теперь эмулятор настроен и готов к работе.
ActiveSync – это инструмент, предназначенный для связи мобильного устройства (Pocket PC) с настольным компьютером (рис. 2.6).
Рис. 2.6. Окно ActiveSync.
На рисунке показана настольная часть ActiveSync. На мобильном устройстве, естественно, работает второй компонент этого приложения.
ActiveSync автоматически отслеживает наличие присоединенного к компьютеру мобильного устройства и, при наличии физического соединения, устанавливает связь и выполняет синхронизацию настольного компьютера и Pocket PC. Таким образом, основное назначение ActiveSync – это автоматизированная синхронизация различных баз данных Pocket Outlook и папок на мобильном компьютере с соответствующими базами данных и папками на настольном компьютере. Кроме этого, при помощи ActiveSynс выполняются операции, перечисленные в следующем списке.
1. Резервное архивирование данных и настроек мобильного устройства, с сохранением файла архива на настольном компьютере. Восстановление данных с настольного компьтера на мобильный.
2. Установка и удаление программ на мобильном компьютере, с ведением базы данных установленных программ на настольном компьютере.
3. Импорт и экспорт таблиц баз данных.
Таким образом, ActiveSync является очень полезной программой, и с ней могут взаимодействовать приложения, созданные для работы на мобильном компьютере. Для этого в состав SDK включены соответствующие библиотеки, заголовочные файлы и примеры. Их можно найти в папке C: \Program Files\Windows CE Tools\wce420\POCKET PC 2003\Activesync.
Но есть одна серьезная проблема. По умолчанию ActiveSync упорно не желает работать с эмулятором, как с настоящим устройством. Для того чтобы эмулятор мог установить связь и взаимодействие с ActiveSync настольного компьютера, необходимо предпринять заметные усилия по настройке.
Для настройки соединения эмулятора и ActiveSync на стационарном компьютере необходимо проделать последовательность действий, приведенную в следующем списке.
1. Необходимо установить и настроить Microsoft Loopback Adapter.
2. Установить Microsoft.NET Framework 1.1 SDK на стационарный компьютер. Установочный комплект можно взять с сайта Microsoft бесплатно. Если в системе установлена среда Visual Studio.NET, то и SDK тоже установлен.
3. Настроить соответствующим образом Platform Manager.
• Надо убедиться, что при настройке транспорта TCP\IP был взведен флажок Use Fixed Address.
• При настройке Startup Server нужно выбрать Emulator Starup Server и для параметра Communication ► Ethernet выбрать значение Virtual Switch.
• Протестировать Platform Manager.
4. Необходимо протестировать соединение эмулятора с ActiveSync. Для этого нужно выполнить команду Пуск ► Программы ► Microsoft Pocket PC 2003 SDK ► Pocket PC 2003 SDK. На экран будет выведено окно командного интерпретатора. В командной строке нужно набрать команду EmuASCfg.exe /РРС и нажать клавишу Enter. В результате эмулятор будет запущен, а в окне командного интерпретатора будет выведена соответствующая инфомация (рис. 2.7).
Рис. 2.7. Окно командного интерпретатора после выполнения команды.
ВНИМАНИЕ!
Команду EmuASCfg.exe/РРС необходимо выполнять каждый раз, когда необходимо установить соединение эмулятора с ActiveSync.
Установочный комплект для любого приложения должен выполнять некоторые вполне определенные действия, позволяющие развернуть приложение на устройстве. Перечень необходимых действий приведен в списке.
1. Распаковать установочные файлы, если они запакованы.
2. Создать папки, в которые будут копироваться установочные файлы, если такие папки отсутствуют на устройстве.
3. Скопировать файлы в определенные конфигурацией установки папки.
4. Если нужно, то создать какие-либо файлы.
5. При необходимости удалить какие-либо файлы.
6. Внести необходимые изменения в конфигурационные файлы устройства.
7. Внести необходимые изменения в файл реестра на устройстве.
8. Обеспечить достаточную интеллектуальность процесса установки. Установочный комплект должен понимать, сохранять уже имеющиеся на устройстве файлы и настройки или заменить их.
9. Обеспечить необходимую интерактивность установки. Пользователь должен иметь возможность выбрать, куда именно будет установлена программа, а в некоторых случаях – выбрать, в каком составе будет установлена программа.
Большинство этих задач решается при помощи механизма AppInstall (установка приложений), частью которого является программа CabWiz, создающая установочные пакеты (файлы с расширением. cab), которые затем могут быть установлены на Pocket PC.
Более предметно применение инструмента CabWiz будет рассмотрено в следующих главах, а в этом разделе будет приведена некоторая информация, которая может понадобиться для создания установочных пакетов.
Программа CabWiz.exe находится в каталоге C: \Program Files\Windows CE Tools\ wce420\POCKET PC 2003\Tools. Файл СabWiz.exe необходимо запускать с соответствующими ключами в командной строке.
cabwiz.exe «inf_file» [/dest dest_directory] [/err error_file][/cpu cpu_type [cpu_type]]
[/platform platform_label [platform_label]]
Расшифровка ключей приведена ниже.
В параметре inf_file указывается полное имя конфигурационного файла (включая путь, взятый в кавычки) с расширением. inf, в котором содержится вся информация, на основе которого программа CabWiz создает установочный комплект. Папка, в которую будут помещены созданные файлы с расширением. cab, указывается в параметре dest_directory. Если этот параметр не указан, то файлы. cab будут помещены в папку, в которой находится конфигурационный файл. Имя файла, в который будет записываться отчет об ошибках при создании установочного комплекта, указывается при помощи ключа error_file. Если этот параметр не задан, то программа будет выводить ошибки и предупреждения в окно сообщений на экране. При помощи ключа cpu_type разработчик может указать перечень типов процессоров, для каждого из которых будут создаваться установочные файлы. Возможные значения этого параметра соответствуют названиям папок в каталоге C: \Program Files\Windows CE Tools\wce420\POCKET PC 2003\Target. Например, для создания установочных файлов, которые будут запускаться на эмуляторе, следует выбрать значение /cpu ARMV4 X86. Параметр platform_label определяет типы платформ, для каждой из которых будет создан файл. cab. Возможные значения этого параметра приведены в табл. 2.2.
Этот пакет дополнительных утилит может быть очень полезен при отладке, особенно если применять инструменты разработки, которые выпускались не компанией Microsoft, а сторонними производителями. В этом разделе будут подробно рассмотрены все основные утилиты этого пакета.
Эта утилита позволяет вывести экран Pocket PC в окно настольного компьютера. В это окно передаются все движения мыши, при помощи чего имитируется работа стилуса, и клавиатурный ввод. Несмотря на то что при работе Remote Display происходит замедление работы, это очень полезная утилита, без которой иногда просто не обойтись. Утилита имеет режимы масштабирования изображения, поэтому экран Pocket PC отображается корректно даже на больших мониторах. Внешний вид окна программы показан на рис. 2.8.
Рис. 2.8. Окно ActiveSync Remote Display.
Эта утилита командной строки предназначена для копирования файлов и каталогов на устойство, подключенное в данный момент к ActiveSync. Учитывая то, что сам пакет ActiveSync имеет средство для визуального копирования файлов, эта утилита вряд ли может быть названа самой полезной из состава Mobile Developer Power Toys.
Синтаксис запуска утилиты приведен ниже.
CeCopy [ключи командной строки] <источник> <приемник>
Ключ командной строки /is указывает утилите, что необходимо перезаписывать имеющиеся файлы, а ключ /s заставляет в процессе копирования учитывать подкаталоги, копируя информацию с воспроизведением иерархической структуры вложенности. Так, команда cecopy /s *.dll dev: \windows копирует все файлы с расширением. dll из текущего каталога в каталог windows на Pocket PC.
Утилита Convert_PPC_DAT_to_SP_XML позволяет из текущего файла. cab для Pocket PC генерировать файл для создания установочного файла, который можно использовать на смартфонах.
Этот инструмент позволяет воспроизвести на устройстве ситуацию эктремального пользовательского ввода в разных режимах и довести при помощи этого краш-теста устройство до зависания или перезагрузки. При этом программа ведет подробный файл отчета и в момент краха устройства снимает копию экрана и сохраняет ее. Также в лог-файле сохраняются текущие параметры распределения памяти.
Программа позволяет измерить устойчивость приложения при большом потоке сигналов пользовательского ввода и время реакции приложения на пользовательский ввод данных.
Hopper имитирует нажатия стилусом на управляющих элементах окон и ввод данных с программной клавиатуры устройства.
Это весьма полезная программа для отладки приложений на устройстве. Эта утилита выводит на экран список процессов, загруженных модулей и распределения памяти устройства. Внешний вид запущенной программы показан на рис. 2.9.
Рис. 2.9. Окно программы JShell.
Для того чтобы запустить программу, ее необходимо скопировать на устройство и затем запустить с соответствующими ключами командной строки или без них. Ключи командной строки приведены в следующем списке.
♦ Ключ -r
♦ Ключ -f заставляет приложение выводить информацию каждые 60 с, запуская программу с приоритетом реального времени.
♦ Ключ -m активирует утилиту mi и выводит результаты в файл отчета каждые 4 часа. Файл отчета записывается с именем miXXX.txt в каталог \Му Documents, где XXX это номер файла-отчета.
♦ Ключ -w позволяет запустить команду win и записывать результаты в файл отчета каждые 4 часа. Файл отчета записывается с именем winXXX.txt в каталог \Му Documents, где XXX это номер файла-отчета.
Когда вы запускаете программу без ключей командной строки, то она запускается с графическим интерфейсом пользователя (см. рис. 2.9), и можно вручную запустить одну из команд. Для того чтобы команда была выполнена, необходимо нажать кнопку «!». Результат выполнения команды выводится в окно JShell.
Предназначение всех команд приведено в следующем списке.
♦ Команда win выводит список всех окон.
♦ Команда gi proc отображает список всех активных в системе процессов.
♦ Команда кр # позволяет завершить выполнение процесса с номером, указанным в качестве параметра #.
♦ Команда gi thrd позволяет отобразить список потоков.
♦ Команда gi mod позволяет вывести список модулей (DLL).
♦ Команда gi mod «хх» позволяет вывести список модулей (DLL), имена которых начинаются с подстроки хх.
♦ Команда mi отображает информацию о распределении памяти.
♦ Команда mi full отображает подробную информацию о распределении памяти.
♦ Команда s <арр>
Это простой командный интрепретатор, выводящий на экран консольное окно (рис. 2.10).
Рис. 2.10. Окно командного интерпретатора.
Содержимое каталога arm необходимо скопировать в каталог Windows на самом Pocket PC и затем нужно запустить файл cmd.exe. Список возможных команд выводится на экран, если набрать команду help и нажать клавишу Enter.
Эта утилита состоит из двух частей. Программу bugtrap.exe необходимо скопировать на устройство в каталог Windows, а программу RapiDbg.exe – запустить на рабочей станции. Естественно, при отладке надо установить соединение при помощи ActiveSynс. После запуска на рабочей станции программа RapiDbg.exe свяжется с устройством и отобразит на экране отладочную информацию (распределение памяти, запущенные процессы и потоки), и останется в режиме ожидания, отслеживая и отображая весь пользовательский ввод, который будет происходить на Pocket PC. Окно программы на рабочей станции показано на рис. 2.11.
Рис. 2.11. Окно программы с выводом отладочной информации.
Эта консольная программа позволяет с рабочей станции запустить программу на Pocket PC, если установлено соединение ActiveSync.
К примеру, на рабочей станции в консоли можно выполнить команду RAPI_Start iexplore.exe http://yandex.ru/, а на Pocket PC будет запущен Pocket Explorer и загружена первая страница поисковой системы.
Эта программа предназначается исключительно для смартфонов. После запуска она передает на смартфон клавиатурный ввод с рабочей станции.
Вся остальная книга будет посвящена именно программированию, поэтому в данном разделе будут кратко освещены общие вопросы, связанные с созданием интерфейса пользователя для Pocket PC.
Главным фактором, с которым приходится считаться при создании пользовательского интерфейса для программ, запускаемых на мобильных устройствах, является размер. Экран Pocket PC по площади на порядок меньше, чем экран современного настольного компьютера. Тем не менее функционально приложения для Pocket PC часто сравнимы по функциональности с приложениями для рабочей станции. Значит, органов настройки и управления должно быть столько же, а разместить их надо на куда меньшей площади.
Часто при решении этого конфликта между стремлением к реализации серьезной функциональности и малым размером экрана в жертву приносится размер элементов управления и разборчивость их обозначений. Мне запомнилось, как я установил на свой Pocket PC триальную версию одного из коммерческих органайзеров и удалил ее после первого же запуска. Причина столь резкого отказа от «мощной функциональности планирования и организации множества задач в одной программе» была проста. Органайзер нужен пользователю для облегчения жизни, а не для усложнения ее. В ситуации, когда пользователю приходится разбираться, на какую из вкладок, идущих в два ряда с двух сторон экрана надо нажать, чтобы получить нужный результат, любой из нас предпочел бы стандартный дизайн и возможности Microsoft Outlook. Именно поэтому Грег Кейзер (Greg Keyser), руководитель группы разработки мобильных устройств корпорации Microsoft, посвятил свое выступление на конференции Microsoft Mobile DevCon 2004 вопросам создания пользовательского интерфейса. Основные его советы приведены ниже.
1. Выводите на экран только ту информацию, которая нужна пользователю для выполнения текущей операции. Обычно отображается гораздо больше информации, чем нужно пользователю в данный конкретный момент. Примером может быть записная книжка «Контакты». Когда вы смотрите на список контактов, попытка отобразить в нем для каждого контакта ВСЮ информацию закончилась бы плохо даже в настольном компьютере, а на Pocket PC в действие вступает закон минимализма, который требует показывать только то, что крайне необходимо (рис. 2.12).
Рис. 2.12. Список «Контакты».
Поскольку этот список чаще всего вызывают, чтобы освежить в памяти телефон, то на первую страницу списка выводится имя и телефон (или имя и адрес электронной почты).
2. Ограничив выводимую информацию в объеме, оставьте пользователю возможность самому определить, что конкретно (например, телефон или адрес электронной почты) будет отбражено на экране.
3. Пользователь должен затрачивать как можно меньше усилий для ввода данных.
• Следует группировать наиболее важные поля ввода так, чтобы они располагались первыми в списке.
• Поскольку для ввода в Pocket PC используется программная клавиатура, нужно располагать поля ввода таким образом, чтобы они не были скрыты выведенной на экран клавиатурой.
• Если возможно, следует предлагать пользователю выбрать значение из списка, а не вводить его в поле.
• Следует минимизировать необходимые для редактирования перемещения курсора и нажатия стилусом.
4. При создании интерфейса пользователя нужно привязывать все элементы управления к узлам сетки с шагом 4x4 пиксела.
5. Левое и правое поля страницы должны занимать не менее 8 пикселов.
6. Элементы управления в высоту должны быть не менее 20 пикселов.
7. При создании окон настройки (рис. 2.13) следует придерживаться определенных правил.
Рис. 2.13. Типичное окно настройки.
• Не стоит применять меню.
• Все органы управления должны уместиться в пределах окна. Следует избегать использования линеек прокрутки.
• Не следует применять более трех вкладок.
• Нужно оставить справа поле размером не менее 8 пикселов.
8. Помните, что при работе с контактным экраном владелец устройства может использовать не только стилус, но и пальцы.
• Области для нажатия стилусом или пальцами должны быть контрастны и иметь хорошо видимую границу.
• Область для нажатия стилусом должна занимать не менее 5 пикселов по горизонтали и вертикали.
• Область для нажатия пальцем должна занимать не менее 10 пикселов по горизонтали и вертикали. На рис. 2.14 показано окно калькулятора, работа с которым возможна и без стилуса.
Рис. 2.14. Окно калькулятора.
9. При создании надписей не следует использовать наклонный шрифт, а жирный шрифт можно применять только для выделения заголовков или разделов.
10. Нужно помнить о возможности перевода приложения на другой язык. Следует учитывать, что длина терминов на другом языке может быть больше или меньше, чем на русском или английском языке.
На этом можно закончить вводную часть и перейти к созданию своих первых приложений для Pocket PC.