Факультет "Информатика и системы управления"
Методические указания к лабораторной работе
по курсу "Распределенные системы обработки информации"
Разработка приложений для мобильного устройства.
Москва, 2009
Получить знания об основах создания MIDP приложений для мобильных устройств на языке Java. Познакомиться с библиотеками javax.microedition. Применить полученные знания для создания MIDP приложений.
Ознакомиться с теоретическим материалом, представленным в приложениях к данным методическим указаниям и примерами программ. Ознакомиться с текстом задания к лабораторной работе.
Задание 1. Создать игру, реализованную как MIDP приложение.
1. Создать меню игры, содержащее пункты:
1.1. запуск игры
1.2. уровень сложности и другие настройки.
2. В игре должны подсчитываться набранные очки и лучший результат сохраняется в течение игры.
Игра выбирается самим студентом.
Задание 2.
Создать сервер обмена текстовыми сообщениями.
1. Создать сервер, которые будет получать данные от клиента в виде строк и выводить на экран мидлета.
2. Сервер должен быть многопоточным, т.е. обслуживать одновременно с несколько клиентов.
3. Для завершения работы клиент должен послать строку «exit».
Создать клиента для сервера обмена сообщениями.
1. Клиентское приложение должно иметь поле для ввода данных для отправки.
По выбору студента приложение может выполнять функции и сервера, и клиента одновременно, либо могут быть реализованы, как два отдельных приложения.
Отчет должен содержать:
1. Постановку задачи, решаемой отлаженной программой.
2. Руководство пользователя отлаженной программы, содержащее описание интерфейсов всех функций программы.
3. Листинг программы с необходимыми комментариями.
1. Что такое MIDP?
2. Структура MIDP?
3. Для чего нужен класс MIDlet и его методы?
4. Каким образом осуществляется взаимодействие MIDP приложения с пользователем?
5. Для чего нужен класс Canvas и его методы?
MIDP приложение имеет строгую структуру, которая описана ниже. Приложение, которое может быть запущено на телефоне, называется мидлетом (midlet). Мидлеты обязательно запаковываются в JAR архив, причем в одном JAR – архиве могут находится сразу несколько мидлетов. Архив с мидлетам(и) называется MidletSuite (набор мидлетов)
Набор мидлетов состоит из JAR – архива, содержащего мидлет(ы), вспомогательные классы и ресурсы (например файлы с картинками и т.п.); JAR – манифеста (JAR Manifest), который представляет собой файл, находящийся в JAR – архиве (файл manifest.mf в папке META-INF в корне архива); дескриптора приложения (Application Descriptor) – это файл с тем же именем, что и JAR – архив и расширением JAD.
Манифест и дескриптор содержат атрибуты приложения в формате имя_атрибута:значение_атрибута.
Некоторые из атрибутов должны присутствовать обязательно и при этом совпадать в дескрипторе и манифесте. Если это условие не будет выполнено, то приложение не запустится и даже не установится на приборе, для которого оно предназначено.
Заполнение обязательных атрибутов берет на себя программное средство, предназначенное для разработки MIDP приложений (KToolbar из J2MEWTK и Forte for Java CE). Кроме того, это средство предоставляет возможность добавления и редактирования атрибутов.
Мидлет может получить значение любого атрибута с помощью метода мидлета:
getAppProperty(String key)
Ниже приведены некоторые атрибуты, которые могут быть полезны разработчику.
· MIDlet-<n>:<name>,<icon>,<class> -описание n-ого мидлета в наборе. Здесь name – имя мидлета, icon – «иконка» (файл в формате PNG), class – файл класса, расширяющего (extends) класс MIDlet (фактически тот класс, который будет «исполняться»). При открытии на приборе набора мидлетов, на экране высвечивается список мидлетов в нем, в котором представлены имена мидлетов с соответствующими иконками.
Пример: MIDlet-1: worm,/liqWorm/worm.png,liqWorm.worm
· MIDlet-Version:<version> -версия набора мидлетов в формате xx.yy.zz.
Пример: MIDlet-Version: 0.1.0
· MIDlet-Info-URL:<URL> -URL, по которому можно найти информацию о наборе мидлетов.
Пример: MIDlet-Info-URL: xdimas@yahoo.com
· MIDlet-Description:<description> -описание набора мидлетов.
Пример: MIDlet-Description: My first MIDlet!
· MIDlet-Vendor:<vendor> -информация о разработчике мидлета.
Пример: MIDlet-Vendor: xDimas
Необходимо отметить, что способы установки набора мидлетов на прибор, для которого тот предназначен, не оговаривается в рамках стандарта J2ME.
Для создания и тестирования мидлетов необходимо сказать последнюю версию J2ME_wireless_toolkit с сайта разработчика: http://java.sun.com/j2me/index.jsp
Необходимо отметить, что MIDP является не просто урезанным вариантом J2SE (Java2 Standard Edition). Здесь появляются свои особенности, продиктованные особенностями устройств, для которых мидлеты предназначены.
Класс, который будет являться мидлетом, должен расширять (extends) класс MIDlet (аналогично классу Applet при разработке аплетов). Этот класс должен иметь конструктор без параметров. Класс MIDlet имеет методы, предназначенные для управления жизненным циклом мидлета. Так для того, чтобы сообщить виртуальной машине (ВМ) о том, что мидлет завершается (фактически завершает выполнение мидлета) используется метод: notifyDestroyed(), а чтобы сообщить мидлету о том, что он будет завершен, ВМ вызывает метод: destroyApp(bolean uconditional).
Мидлет, в отличие от аплета, может находится в состоянии паузы (paused - например, когда дисплей занят каким-нибудь сообщением и т.п.). Чтобы сообщить мидлету о том, что он переходит в состояние паузы, ВМ вызывает метод мидлета: pauseApp(), а чтобы войти в состояние паузы, мидлет использует метод: notifyPaused().
Когда мидлет входит в активное состояние (выход из паузы и начало работы мидлета), вызывается его метод: startApp().
Важно помнить, что этот метод может вызываться несколько раз за время выполнения мидлета.
Класс, расширяющий MIDlet может объявлять (implements) различные интерфейсы, например интерфейс Runnable .
Для взаимодействия с пользователем в MIDP присутствуют классы Display и Displayable (точнее его наследники).
Объект класса Display создается ВМ и за все время работы мидлета для него присутствует только один объект этого класса. Получить его можно при помощи статического метода:
static Display Dispaly.getDisplay(MIDlet m)
Объект класса Display оперирует с объектами класса Displayable. Объекты класса Displayable предназначены непосредственно для взаимодействия с пользователем (т.е. для вывода на экран, обработки нажатий клавиш и т.п.). Для работы с этими объектами в классе Displayесть два метода:
void setCurrent(Displayable d)
Displayable getCurrent()
Сам класс Displayable объявлен как абстрактный, так что работать можно только с его потомками. Их два – это классы Canvas и Screen.
Потомки класса Screen определяют набор визуальных компонент для высокоуровнего взаимодействия с пользователем (формы, поля ввода, списки и т.п.). Надо отметить, что этот набор весьма примитивен и предоставляет минимум (однако достаточный) возможностей для взаимодействия с пользователем. Использовать этот набор в приложениях, требующих интерактивности (например в играх), не представляется возможным, но некоторые компоненты все же удобно использовать во вспомогательных целях (например поле ввода для ввода имени игрока в таблицу рекордов, меню и т.п.). Подробно рассматривать этот набор здесь не будем.
Класс Canvas предназначен для низкоуровнего взаимодействия с пользователем. В нем определен набор методов для обеспечения перерисовки содержимого экрана, получения информации о нажатии кнопок и т.п. Остановимся подробнее на некоторых особенностях использования класса Canvas.
Необходимо помнить о том, что на разных приборах, на которых может быть запущен мидлет, могут быть различные размеры дисплея. Для их получения используются методы:
int getHeight()
int getWidth()
Перерисовка содержимого экрана осуществляется ВМ самостоятельно и когда она будет выполнена, точно сказать нельзя. Можно лишь сообщить ВМ о том, что необходимо обновить содержимое экрана вызовом метода:
void repaint()
или
void repaint(int x, int y, int width, int height)
Можно принудить ВМ к немедленному выполнению перерисовки вызовом метода: void serviceRepaints()
Когда ВМ осуществляет перерисовку содержимого экрана, вызывается метод: void paint(Graphics g)
Объект g связан с изображением, которое будет выведено на экран. Использование объектов класса Graphics происходит так же, как и при работе с аплетами.
Необходимо заметить, что метод paint объявлен как абстрактный и поэтому для работы с объектом класса Canvas разработчик должен создать класс, расширяющий Canvas и определяющий метод paint.
Получить объект класса Graphics, который отвечает за перерисовку экрана, как это можно сделать для аплета методом: Graphics Applet.getGraphics(), для потомков класса MIDlet прямым способом невозможно. Можно попытаться сохранить объект, поступающий в качестве параметра в метод paint, но делать это не рекомендуется.
MIDP предоставляет элегантный метод для синхронизации перерисовки экрана с ходом выполнения основной программы. В классе Display присутствует метод: