Создание приложений, Инструментарий, POSE
Большинство Palm программистов обычно пишут на С (С++),однако существуют компиляторы для других языков: Java, Pascal, Basic, SmalTalk, Assembler. Для Палм, есть много различных сред разработки, Самая популярные GUI IDE это CodeWarrior, так-же есть Falch.Net, VFDIDE, and PilotMAG - все эти "визуальные" среды разработки имеют редактор кода с синтаксической подсветкой кода и др. функции. (управление проектом, отладчик,...) компилируют они с помощью PRC-Tools. стоят от 20-30$. Самая популярная некоммерческая среда это PRC-Tools (набор утилит - командная строка). Большинство разработчиков предпочитают PRC-Tools,, т.к. это бесплатно, популярно, и этот продукт поддерживается официально Palm. Инсталляция PRC-Tools напоминает инсталляцию ФИДО на домашнем компе, - нужно установить 4 независимых софта, и правильно их настроить, что-б они вместе работали, вобщем придется повозится. Советую найти ФАК по этому делу. В качестве напутствия для программистов можно сказать, что Палм это очень открытая платформа, как для разработчиков Софта так и для разработчиков железа. Во первых Palm Computing создала сообщество разработчиков, Palm Alliance Program - сообщество Палм программистов, там можно получить ROM файлы практически с любой версией PalmOS. также можно получить "debug" ROMs с отладочными версиями PalmOS (для системных программистов)
На сайте palm.com всегда доступна полная документация по Палм ОС а также различные FAQ, Knowledge Base и конференции. Написано много книг и публикаций для программистов, в интернете можно найти кучу исходных тестов по различным направлениям. Также для простоты создания программ, Palm Computing создала бесплатный PalmOS Emulator (POSE) – эмулятор ОС Палм для тестирования Палм приложений на настольном компьютере.
POSE – эмулятор КПК с любой версией PalmOS (работает под Windows, Mac, Unix). Для его работы нужен только ROM файл с PalmOS, его можно “вытащить” из КПК либо скачать из интернета, что намного проще (см. ссылки). Разработчик запускает POSE и видит на мониторе настоящий КПК – можно мышкой кликать на экране КПК как стилусом (даже писать граффити), можно запускать приложения. (можно встретить еще “CoPilot“ - это тоже самое, предшественник POSE)
Преимущества POSE: 1. Процесс загрузки приложения в POSE намного быстрее чем в реальный КПК, что намного ускоряет процесс тестирования. Не нужно каждый раз синхронизироваться. 2. В POSE можно сохранять текущее состояние КПК, а потом к нему возвращаться. 3. Source-Level отладка намного проще с POSE. 4. В POSE можно делать скриншоты, и применять Gremlins – искусственный «неопытный» пользователь. 5. С помощью POSE можно увидеть различные КПК с PalmOS разных версий с различным размером памяти, без наличия самого КПК. Итак, POSE это MustHave для любого PalmOS программиста.
Чтобы создать простое приложения для PalmOS 3.1 с помощью PRC-Tools, необходимо установить CygWin(2.01), PRC-Tools(), PilRc for Win32, PalmOs SDK 3.5, PalmOS Emulator. Дополнительные сведения об установке можно найти в интернете.
Простое Приложение состоит из 3 файлов - *.c, resource.h, *.rcp(файл с ресурсами), Каждое Palm приложение имеет уникальный CreatorID, это 4 байта, например «MyAp». Палм использует CrID для того что-бы различать приложения и его файлы. Если два приложения имеют одинаковый CrID то одно из них может затереть второе при синхронизации, либо повредить файлы другого приложения. Для каждого приложения которое «выходит в мир» нужно регистрировать CreatorID на сайте Palm.com. После компиляции и сборки мы получаем файл с расширением prc – готовое приложение для PalmOS, его можно поместить в эмулятор для тестирования (или инсталлировать в КПК через HotSync).
Выполнение приложений PalmOS однозадачная ОС т.е. активным бывает только одно приложение, когда пользователь переключатся на др. приложение то предыдущее завершает свою работу.
Всегда работает UIAS (User Interface Application Shell) это такой процесс (часть ядра) который сразу при старте запускает какое ни будь приложение, ждет его завершения и запускает другой, обычно первым он запускает Launcher.
Приложения в Palm почти такие же как в Windows. Точка входа в Palm приложение – функция PilotMain. В качестве параметров к ней самый важный это код запуска - LaunchCode, т.к. Palm иногда может запустить приложение не сцелью запуска, а с целью «сообщить» что-то важное или «узнать» что-то от приложения (например reset или синхронизация или в случае глобального поиска). SysAppLaunchCmdNormalLaunch это код обычного запуска т.е. приложение должно показать свой интерфейс. В PalmOS есть аналог командной строки, параметры передаются при вызове приложения в PilotMain. Приложения могут запускать другие приложения с разными LaunchCode, a также можно послать всем приложениям в системе какой-то LaunchCode, чтоб они выполнили определенное действие.
на рисунке показано схема работы приложения.
После того как приложение создало свой интерфейс(FrmGotoForm), оно в бесконечном цикле передает управление Ядру (EvtGetEvent) ожидая события (прикосновение стилуса или нажатие кнопки или системные события). Здесь все работает как в Windows – Если произошло событие, определить кому оно предназначено. Например если событие произошло на форме приложения - вызвать обработчик FormEvtHandler. При закрытии приложения поступает событие – AppStopEvent. Управление Питанием PalmOS автоматически управляет питанием, при этом приложения ни как не участвуют в этом. Хотя приложение может вкл/выкл дисплей, выполнить ресет, или работая с регистрами аппаратуры КПК замедлить работу КПК, тем самым продлить жизнь батареек. Существует 3 режима питания: Doze mode – Режим бездействия, Дисплей включен, активно какое либо приложение, но оно ничего не выполняет. Процессор готов к работе но не выполняет инструкций (halted). Активируется сразу после вызова EvtGetEvent. (пользователь не прикасается стилусом экрана, и не нажимает кнопки)
Sleep mode – Режим «сна». Активируется Если Doze mode по времени продолжается дольше установленного тайм-аута. Выключены: Дисплей, дигитайзер, главные часы, работают: контролер прерываний. Все устройства PDA переводятся на режим экономии питания, система ждет событий от кнопок либо от часов реального времени.
Running mode – Режим активной работы, Дисплей включен, активно какое либо приложение, процессор выполняет инструкции. Все устройства готовы к работе либо работают. Обычно это EvtGetEvent возвращает какое-то событие и приложение его обрабатывает. (пользователь работает стилусом, жмет на кнопки, или приложение выполняет работу)
В Running mode КПК находится 5%-10% от времени проведенного в Doze mode, это объясняется тем, что пользователь обычно большую часть времени изучает информацию на дисплее нежели производит действия. В активных играх это конечно не соблюдается т.к. пользователь постоянно жмет на кнопки или тычет стилусом в экран. Для того чтобы приложения не противоречили этой стратегии нужно придерживаться определенных правил. (в SDK)
PalmOS GUI PalmOS это графическая операционная система обладающая средствами для для создания практически любого GUI. Базовые элементы GUI - это Форма (Form), Диалог, Меню, и различные элементы такие как: кнопки, флажки, списки, поля с текстом, селекторы, таблицы, картинки.
Интерфейс обычно создается в виде словесного описания в *.rpc файле (который компилируется PilRC.exe). В этом файле вы описываете какие формы будет показывать приложение и какие элементы (кнопки, надписи...) будут отображаться на форме. Для программистов на Win Api можно сказать проще: - для Палм приложения нужно создавать файл ресурсов со всеми диалогами, картинками и строками. Этот файл имеет почти такой-де синтаксис как и для WinApi. при создании PRC файла ресурсы линкуются в него.
Форма Обычно Палм приложение содержит несколько Форм и одно Меню, форма может занимать только часть экрана (т.е. диалог), двигать формы стилусом нельзя. Интерфейс в Палм модальный, т.е. активна может быть только одна форма, для переключения м/д форм нужно делать FrmGotoForm или FrmPopupForm. не модальность бессмысленна на маленьком экране, вносит осложнения для пользователя и требует больших усилий со стороны ОС, следовательно и большего количества кода.
События которые происходят на форме (нажатие кнопки, ввод буквы, команда меню выделение строки списка) приходят в процедуру – обработчик сообщений формы (FormEvtHandler рис) c параметром event – структура с информацией о событии. event->eType – тип события:
Меню Меню а Палм существует для того чтобы снять нагрузку с Формы и убрать все второстепенные элементы интерфейса в меню. Однако нужно помнить что, для того чтобы добраться до меню пользователь делает 3 клика стилусом, поэтому там обычно находятся редко употребляемые команды. Command Shortkut – это ускоряет выполнение комманд из меню
Меню создается в файле ресурсов как и формы, а при описании формы можно указать какое меню использует форма. Каждая строка меню представлена текстом и командой(номер) которая будет послана приложению - для быстрого доступа к командам из меню приложение может использовать Command Toolbar для того чтобы вставить туда пиктограммы наиболее частых команд
Ограничения Palm GUI: 1. Для элементов интерфейса отсутствует такое понятие как Disabled. 2. Меню не всегда видно на экране. 3. Отсутствуют: StatusBar, TAB control, Контекстные меню (нужно делать самому), 4. Нет контекстной помощи, подсказок (ToolTips). В PalmOS каждый диалог может иметь свой HELP диалог, который открывается поверх старого если кликнуть на?
Интерфейс можно создавать динамически, а также создавать нестандартные элементы, но это довольно сложная задача.
При работе с fiel ds (editBox) приходится сталкиваться с непривычными моментами, например: многострочному полю можно установить текст по FldSetTextHandle(filed, Handle ) после этого о Handle можно «забыть» т.к. им управляет сам editBox. Получить его обратно можно по FldGetTextHandle но чтобы он стал полностью вашим нужно еще сделать FldSetTextHandle(filed, NULL). Иначе Handle нельзя удалять. Аналогичная комбинация действий в Windows выглядит по другому, SetWindowText копирует текст к себе в буфер, и после этого оригинальный буфер ни как не привязан к editBox ‘у – его можно удалять, а получение текста обратно не накладывает никаких ограничений. Подобные тонкости являются частью стратегии управлением памяти, к ним быстро можно привыкнуть (после WinAPI).
Графика В PalmOS также существует набор функций для работы с простейшей графикой: точки, линии, круги, прямоугольники, заливка, инверсия, картинки. Функции из группы Window Manager также позволяют следить за состоянием Графики – устанавливать цвет пера, заливки, текущий шрифт. Для быстрой графики можно писать прямо в видео буфер.
PalmOS 4.0 поддерживает 1-, 2-, 4- 8 и 16-битовые цвета и оттенки а PalmOS 3.0 – 4 градации серого. Сервис ОС В этой главе я перечислю некоторые возможности PalmOS которыми пользуются все приложения.
В начале следует сказать о Системных Менеджерах (Managers) это компоненты ОС которые выполняют различные задачи, например DataBase Manager, Memory Manager. Для программиста, менеджер это группа функций относящиеся к нему, первые 2ве-3 буквы имени функции - это абривиатура имени менеджера, например DmOpen, MmAloc. Если знать все префиксы то удобно читать исходный код программ.
Для более детального изучения Менеджеров обязательно нужно прочитать соответствующий раздел в «Palm OS® Programmer's Companion vol. 1» (на сайте palm.com), документация написано хорошо, также я рекомендую всем программистам которые перешли на PalmOS с др. системы прочитать 2 главу «Good Design Practices», это обзор наиболее важных моментов для PalmOS приложения, эту главу нужно читать несколько раз. Итак «Good Design Practices» - must read всем программерам под Палм.
(1) System Features Аналог переменных окружения в ДОС (типа PATH, SET значения), т.е. глобальное значение (только 4 байта)которое можно установить и до полного ресета они будут установлены. В PalmOS есть системные значения типа версии ОС - sysFtrNumROMVersion, или версии библиотеки при написании приложений нужно проверять версию ОС, т.к. программа может использовать функции которых нет в старых верисиях. Устанавливается или считывается Feature с помощью CrID (кто создал этот фтр). Для получения системных Feature в качестве CrID используется sysFtrCreator. Этим сервисом удобно пользоваться если необходимо хранить какие ни будь 2-3 числовых настройки, или если функции доступа к файлам временно недоступны (например из хаков)
Preferences Аналог реестра в Windows. Это общий файл для хранения настроек приложения(PrefGetAppPreferences). так-же Есть системные Preferences - там хранятся значения типа формата даты, времени ед. измерения PrefGetPreference(prefTimeFormat)
(2) Звук SoundManager позволяет генерировать простые сигналы, разной частоты и длительности. PalmOS, начиная с версии 3.5 поддерживает воспроизведение стандартных MIDI-звуков.
(3) Notifications Используя Notification Feature Set приложение может получать различные уведомления о системных событиях. Notifications это те-же launch code. Уведомления могут получать не только приложения но и библиотеки и хаки (см. хаки). вставка/извлечение доп. Модуля, удаление файла, изменение настроек экрана, сети, времени, подключение/откл. от сети, спячка, ресет, синхронизация.
(4) Attentions and alarms Приложения может поставить «будильник» для себя, когда время подойдет то Palm сообщит приложению что время пришло, если приложение закрыто то PalmOS запустит его. Attention Manager может не запускать приложение, а только показать диалог с сообщением от этого приложения, и если пользователь захочет то может отложить это событие на пару минут.
Reset, и Жесткий Reset Приложение может самостоятельно делать Reset - это отчистка Dynamic RAM памяти, проверка целостности Storage RAM, потом дефрагментация памяти, Жесткий Reset это обнуление всей памяти (уничтожение всей файловой системы) и создание файловой системы заново, потом туда копируются приложения.
(5) Комуникации Infra Red, Serial Port, Network – это 3 основных типа коммуникаций в PalmOS, InfraRed и SerialPor - приложение может пользоваться инфракрасным портом на нескольких уровнях – высокий уровень это например - пересылка файлов, низкий уровень эта работа с портом напрямую. Network – можно используя TCP/IP протокол работать с интернетом или локальной сетью, присутствует Berkley Sockets функции. Можно работать в Асинхроном или Синхроном режимах (неблокируемые вызовы и блокируемые) Совместимость версий Этот вопрос очень важный для PalmOS, сейчас самые распространенные версии 3.0 – 4.0. Концептуальной разницы в них нет, главное отличие это сревис ОС для приложений (так называемый Feature Set – наборы сервисов). Palm OS SDK содержит главу Compatibility Guide – в которой объясняется различие версий., Приложение должно проверять версию чтобы быть уверенным что необходимый сервис присутствует в данной версии Palm OS, и не запускаться в случае неподдерживаемой версии. Например Alarm Manager присутствует не во всех версиях. Расширения PalmOS Как уже ранее говорилось все приложения вызывают функции PalmOS для выполненеия каких либо действий (в Windows такой набор функций называется WinAPI), например открытие файла, вывод на экран, ввод/вывод. Но PalmOS так устроена что в ней можно переопределять поведение этих функций. в Windows тоже можно подменить любую API функцию, но в PalmOS этот механизм упрощен и офиально поддерживается на уровне системы.
Рассмотрим на пример что происходит при открытии файла: при вызове DmOpenDatabase (открытие файла) вызывается функция с номером sysTrapDmOpenDatabase в специальной таблице указателей. Этот механизм называется - Palm OS trap dispatch mechanism – т.е. когда вызывается функция то на самом деле приложение обращается к trap dispatch механизму и просит его вызвать такой-то номер функции (а параметры передаются в стеке). Эту таблицу указателей можно спокойно изменять с целью подмены функций. Подменить системную функцию может любое приложение (например CyrHack, оно видно в системе как приложение но подменяет ряд функция для русификации PalmOS). Но есть еще специальный вид приложений для PalmOS – это Хаки (от слова hach, а фициальное название System Extention), это проложения которые созданы по спецификации HackMaster API (независимый стандарт). Это стандарт который облегчает создание Хаков, а так-же делает более безопасным их присутствие в системе. Согласно этому стандарту за всеми хаками в системе следит Менеджер Хаков. Это обычное приложение в котором можно посмотреть сисок всех хаков, настроить их, и активизировать.
Программирование хаков требует более глубокого знания системы.
Воспользуйтесь поиском по сайту: ©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|