Фанфары! Горны! Барабаны… и прочая торжественная музыка!
Наконец-то я закончил работу над основной частью функционала моей компьютерной флэш игры.
УРА!
Я работал над ней полтора года… До этого года два морально готовился к этому. И, хоть игра еще не до конца готова, ее уже можно смотреть, пробовать и играть.
Если кому-то будет интересно – добро пожаловать на:
Если Вы хотите принять участие в разработке этого безусловно самого амбициозного и масштабного проекта, можете присылать свои пожелания и рекомендации на maniak |сабачка| tut.by
Поворот объекта за мышью реализуется очень просто. Надо просто в каждом кадре присваивать свойству _rotation клипа игрока (объекта) арктангенс угла положения мыши на экране относительно этого клипа. Наверное, прочитав предыдущее предложение, Вы погрустнели. Но это не беда. Я и сам до конца не понимаю этого. Добрые индусы, писавшие Flash, позаботились о том, что бы класс Math содержал готовую функцию atan2 (), которую мы и будем использовать для нахождения этого арктангенса угла..
_root.onEnterFrame = function ()
{
rotateObject ();
}
Вначале мы добавляем клип с игроком на экран. Затем создаем объект game, в котором будем хранить всю информацию об игре. Обратите внимание как мы связываем добавленный клип игрока, с свойством clip объекта game.player. Теперь мы можем использовать это свойство если захотим провести какую-либо операцию с клипом на сцене. О свойствах flexibility и allowedError мы поговорим чуть ниже, а пока давайте перейдем к разбору функции rotateObject ().
Итак, пресловутая функция atan2, о которой я вкратце упоминал в начале статьи. Именно она будет делать основную работу и нам совершенно неважно как она ее будет делать, потому что на выходе мы будем получать именно тот угол, на который надо повернуть наш клип игрока, что бы он смотрел прямо на указатель мыши. Пожалуйста, почитайте в help’е Flash о том как она работает, мы же только коснемся тех параметров, которые надо передавать в эту функцию. Итак, первый параметр – это расстояние по оси Y от объекта игрока до Y координаты мыши, второй параметр – это расстояние по оси X от объекта игрока до X координаты мыши. Как расстояние определяется на прямой линии? Правильно, вычитанием одной координаты из другой. Это мы и делаем прямо при внесении параметров в функцию, т.е. налету.
В принципе, на этом можно было бы и остановится, так как мы уже имеем угол, на который надо поворачивать наш игровой объект. Мы этот угол можем присваивать свойству _rotation нашего клипа и он будет поворачиваться. Но в таком случае это будет происходить мгновенно.
Если Вы хотите добавить немного реалистичности в процесс поворота, то вам надо несколько замедлить этот процесс. И вправду ведь, невозможно повернутся мгновенно, в природе все происходит с определенной задержкой.
Итак, следующие строки кода, начиная с объявления переменной errorAngle замедляют и управляют процессом поворота. errorAngle – это величина, показывающая, на сколько отличается текущий угол поворота объекта от угла, на который надо повернуть объект, что бы он смотрел прямо на мышку. Дальше происходит проверка на то, на сколько ошибка отклонения больше или меньше реального угла поворота, и если она отличается на величину allowedError, то делается коррекция, т.е. объект поворачивается по или против часовой стрелке.
Flexibility влияет на то, как быстро объект будет поворачиваться. В флэш играх это очень важный показатель, влияющий на верткость объекта. Так, например, меняя этот показатель от меньшего к большему можно сделать несколько самонаводящихся ракет с различной степенью маневренности.
allowedError это то допустимое значение ошибки отклонения при котором поворот происходить не будет. Т.е. она позволяет создать некий коридор (например, до 5 градусов), при котором поворот происходить не будет.
Не думал что получится столько букв, но надеюсь, эти комментарии хоть как-то помогут Вам разобраться в происходящем. Если нет, рекомендую к прочтению книгу «Flash. Трюки» O’Relly. Приведенный в данной статье метод полностью основывается на одном из трюков этой книги.
Исходник с примером поворота объекта мышью во Flash (.fla):
Одной из первых задач, которые должен решить начинающий программист флэш игр – это то, как заставить героя (будь то космический корабль, воин или черепашка ) двигаться по экрану не только в пределах обозначенных разрешением монитора (например 1024х768), но и за ними.
Как же это сделать?
Давайте посмотрим на проблему со стороны. У нас есть герой, у нас есть экран монитора. Если герой перемещается в какую-либо сторону он неуклонно двигается к границе экрана, рано или поздно достигнет ее и скроется за ней. Но это недопустимо.
Следовательно, герой вообще не должен перемещаться, он должен стоять на месте. В то же время весь мир во круг него должен двигаться. Таким образом будет достигнута иллюзия перемещения героя по местности, намного превышающей размеры монитора.
Давайте посмотрим более подробно, как это можно реализовать с помощью Flash.
1. Добавляем экземпляр клипа героя на сцену, размещая его посередине экрана (в библиотеке должен быть клип с именем player).
2. Добавляем экземпляр клипа локации на сцену. Это может быть просто пустой клип, к которому потом можно будет добавлять другие клипы, которые будут создавать атмосферу игрового уровня (например, если вы делаете космический экшн, можно будет добавить звезды, астероиды, планеты и прочие элементы).
1
_root.attachMovie(“location”, “location”, 0);
Обратите внимание: клип игрока расположен над клипом с локацией.
Теперь, когда у нас есть оба клипа на сцене, надо заставить двигаться клип с локацией, для создания иллюзии передвижения.
3. Давайте создадим объект game, в котором будем хранить все данные об игре:
Теперь, мы имеем удобные ссылки, которые можем использовать для обращения к клипам практически из любого места кода. А вот собственно и сам механизм передвижения клипа локации:
где: RAD_DEG – это константа, позволяющая переводить значение выраженное в радианах в градусы (RAD_DEG = 180 / Pi);
game.player.speed – скорость движения объекта (посмотрите, ранее мы присвоили этому свойству значение 1, т.е. скорость равна 1 пиксель / кадр);
game.player.clip._rotation – угол поворота клипа игрока на сцене, он определяет в какую сторону будет двигаться локация.
Поместив данную функцию в обработчик onEnterFrame мы добьемся того, что с наступлением каждого нового кадра, локация будет перемещаться по оси x и y в соответствии с углом поворота клипа игрока и его скорости.
Новый год прошел, хлопушки отгремели, шампанское выпито… самое время вновь взятся за работу. Вот я уже взялся. И у меня есть чем похвастаться. Теперь в Cassiopeia игроки смогут пользоватся навигационной картой и перемещатся между 16-ю локациями. В настоящий момент игрок ничем не ограничен и может попасть в любую локацию сразу же. Но! Что его ждет там?
Пока что ничего особого, кроме холодных звезд и кучи врагов. Каждая локация отличается двумя характеристиками: уровнем пиратства и технологическим уровнем развития. Эти две характеристики влияют на количество пиратов (врагов) в области и оборудованием установленным на их кораблях. Таким образом, у нас получается набор локаций с различным уровнем сложности.
С радостью сообщаю что подходит к концу 4 фаза разработки игры, в рамках которой я пытался уделить больше внимания графическим элементам, улучшить дизайн и в целом «картинку» игры.
В рамках 5-ой фазы внимание будет уделено повышению играбельности.
Итак, что я хочу внедрить:
1. Добавление возможности использования различного вида оружия
1.1. Различные виды лазера (4 шт)
1.2. Различные виды ракет (3 шт)
1.3. Различные виды щита (3 шт)
2. Подсчет очков (денег) за сбитые корабли врага.
3. Добавление возможности производить апгрейд корабля.
3.1. Экран апгрейдов.
3.1.1. Картинка корабля со слотами.
3.1.2. Доступные улучшения (в трех секциях: лазер, ракеты, щиты).
3.1.3. Кнопки Применить и Закрыть.
3.2. Игра не становится на паузу во время апгрейда.
4. Создание стартового меню.
4.1. Элемент меню – Начать игру.
4.2. Элемент меню – Доска счета.
4.3. Элемент меню – Об игре.
5. Создание анимации гиперпространственного прыжка.
Будем надеятся что в процессе у меня не возникнет особых проблем, особенно на уровне архитектуры приложения.
Комментарии