Розробка програмних модулів
Диаграмма классов разработанного приложения представлена на рисунке 3.6.
Рис. 3.6. Диаграмма классов разработанной платформенной игры
В таблице 3.1 представлено описание классов приложения, в таблице 3.2 – описание некоторых переменных.
Таблица 3.1. Описание объектов программы
Таблица 3.2. Описание переменных программы
Фрагменты листингов представлены в Приложении А.
Framework XNA Game Studio поддерживает различные способы организации сетевого взаимодействия игр. XNA Game Studio предоставляет через пространства имен Microsoft.Xna.Framework.GamerServices и Microsoft.Xna.Framework.Net набор функций и компонентов, позволяющих создавать главные узлы многопользовательских игр (к которым могут подключаться другие игроки), поддерживать соединения и обмен сообщениями между игроками и главным узлом, и включает многие дополнительные возможности, такие как встроенная поддержка для голосовых коммуникаций. Главным узлом игры может быть один из игроков в одноранговых играх, или серверная машина, если используется подход клиент/сервер. Вот четыре этапа создания главного узла: 1. Зарегистрировать игрока (с локальным или удаленным профилем). 2. Создать сессию, установить ее свойства, включая доступные слоты. 3. Подождать, пока другие игроки подключатся и будут готовы. 4. Сменить состояние сессии на «Игра запущена». Аналогичным образом можно разделить создание игрового клиента на четыре простых этапа, которые подходят как для одноранговых, так и для клиент/серверных игр: 1. Зарегистрировать игрока (с локальным или удаленным профилем). 2. Найти какую-нибудь сессию со свободными слотами для подключения. 3. Подключиться к сессии. 4. Сменить состояние игрока на «Готов». Рассмотрим создание сессии в XNA Game Studio детально. Класс XNA Framework NetworkSession представляет многопользовательскую сессию, и используется для создания, поиска, присоединения и завершения сессии. Он также предоставляет набор свойств, которые позволяют собирать информацию о текущей сессии. Для создания новой сессии используется метод NetworkSession.Create, получающий до пяти параметров: · Тип сессии, который может быть NetworkSessionType.Local (нет сети, используется для игр на разделенном экране, работает только на Xbox 360), NetworkSessionType.SystemLink (соединение двух машин, Xbox 360 или PC, в одной и той же подсети), NetworkSessionType.PlayerMatch (позволяет соединение через серверы LIVE) и NetworkSessionType.Ranked (используется для оцененных коммерческих игр, прошедших сертификацию Xbox LIVE). · Максимальное количество локальных (на той же машине) игроков. · Количество в сессии слотов для игроков (от 2 до максимального количества в 31 игрок). · Количество закрытых слотов (необязательный параметр), устанавливающее сколько слотов резервируется для игроков, присоединяющихся по приглашениям. Если это число равно количеству слотов сессии, сессия будет принимать только приглашенных игроков. · Свойства сессии (необязательный параметр): коллекция определяемых программистом свойств, которые можно использовать для определения любых специфичных для игры значений, таких как уровень сложности игры или ограничение времени сессии. Эти свойства, хранящиеся как класс NetworkSessionProperties, также применяются для фильтрации результатов, когда вы ищете сессию для подключения. Чтобы создать сессию необходимо определить несколько закрытых переменных уровня класса и метод CreateSession в классе NetworkHelper: private NetworkSession session = null; // Игровая сессияprivate int maximumGamers = 2; // Могут играть только двоеprivate int maximumLocalPlayers = 1; // Нет разделенного экрана, // только удаленные игроки public void CreateSession(){ if (session == null) { session = NetworkSession.Create(NetworkSessionType.SystemLink, maximumLocalPlayers, maximumGamers); }}Создать многопользовательскую игровую сессию гораздо XNA проще. Однако, для работы этой сессии, чтобы она надлежащим образом обрабатывала сетевые пакеты, необходимо вызывать ее метод Update в каждом обновлении игрового цикла. Для этого необходимо включить метод Update в класс NetworkHelper: public void Update(){ if (session!= null) session.Update();}Лучший способ вызывать этот метод в каждом игровом цикле — включить следующую строку в начало метода Game1.Update: networkHelper.Update();
|