Категории
Самые читаемые
onlinekniga.com » Компьютеры и Интернет » Программирование » Adobe Flash. Создание аркад, головоломок и других игр с помощью ActionScript - Гэри Розенцвейг

Adobe Flash. Создание аркад, головоломок и других игр с помощью ActionScript - Гэри Розенцвейг

Читать онлайн Adobe Flash. Создание аркад, головоломок и других игр с помощью ActionScript - Гэри Розенцвейг

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 39 40 41 42 43 44 45 46 47 ... 90
Перейти на страницу:

// Передвигаем лису влево.

dx = -riverSpeed;

fox.gotoAndStop("right");

} else {

// Клавиша не нажата.

dx = 0;

fox.gotoAndStop("still");

}

// Передвигаем лису и отслеживаем,

// чтобы она не вышла за границы экрана.

fox._x += dx;

if (fox._x < 150) fox._x = 150;

if (fox._x > 400) fox._x = 400;

// Увеличиваем скорость движения байдарки.

if (riverSpeed < 20) riverSpeed += .5;

}

Скорость игры увеличивается с помощью функции moveFox, в результате байдарка постепенно набирает скорость. Функция newRock аналогична функции dropNewApple предыдущей игры и даже немного проще, поскольку при появлении камня выбор ограничен только одним клипом.

function newRock() {

// Проверяем, прошло ли достаточно времени.

if (timeSinceLastRock > 5) {

// Проверяем, превышено ли максимальное число камней.

if (lastRock < totalRocks) {

// Новая скала появляется с вероятностью 10 %.

if (Math.random()<.1) {

// Создаем новую скалу. lastRock++;

lastRock++;

attachMovie("rocks", "rock"+lastRock, lastRock);

_root["rock"+lastRock]._x = Math.random()*250+150;

_root["rock"+iastRock]._y = 450;

// Решаем, какой кадр показать.

f=int(Math.Random()*_root["rock"+lastRock]._totalFrames)

_root["rock"+lastRock].gotoAndStop(f);

// Сбрасываем счетчик времени

// до появления следующего камня.

timeSinceLastRock = 0;

// Запоминаем, что с новым камнем

// столкновений не было.

_root["rock"+i].hit = false;

}

}

}

// Уменьшаем время до появления следующего камня.

timeSinceLastRock++;

}

Обратите внимание, что для каждого нового камня переменная hit принимает значение false. Это обозначает, что байдарка ни разу не столкнулась с данным камнем. Это условие проверяется функцией moveRock перед тем, как разрешить столкновение. В случае столкновения переменная hit соответствующего клипа принимает значение true и второй раз удариться об этот камень байдарка уже не может.

Обратите внимание, что по сравнению с игрой "Поймай яблоко" меняются и координаты области попадания (столкновения). Столкновение может произойти в области с размерами 60 пикселов по горизонтали и 25 пикселов по вертикали в обе стороны от центра. Эта область примерно соответствует форме байдарки (рис. 9.8).

Рисунок 9.8. Область возможного столкновения показана прямоугольником. Поскольку контроль пересечения с камнем ведется по центру клипа «rocks», то реальная область столкновения выглядит несколько меньше

Количество столкновений сохраняется в переменной spills. После шести столкновений игра переходит к кадру с меткой «lose», и игра считается завершенной. При этом происходит вызов функции removeAll, которая будет рассмотрена далее.

function moveRocks() {

// Проверяем все камни.

for (i=firstRock;i<=lastRock;i++) {

// Определяем координаты камня.

x = _root["rock"+i]._x;

y = _root["rock"+i]._y.riverSpeed;

// Выясняем, вышел ли камень из поля зрения.

if (y < -50) {

removeRock(i);

// Проверяем, что с камнем не было столкновений.

} else if ((_root["rock"+i].hit == false) and (Math.abs(y-fox._y) < 60) and (Math.abs(x-fox._x) < 25)) {

spills += 1;

// Столкновение.

_root["rock"+i].hit = true;

// Переворачиваем байдарку.

fox.gotoAndPlay("spill");

// Останавливаем байдарку.

riverSpeed = 0;

// Игра закончена?

if (spills > 5) {

removeAll();

gotoAndPlay("lose")

}

}

// Продолжаем перемещать камень.

_root["rock"+i]._y = y;

}

}

Как и функция removeApple, функция removeRock предназначена для проверки того, является ли данный камень последним. В этом случае игра переходит к кадру с меткой «win».

function removeRocks(n) {

// Убираем со сцены клип камня.

_root["rock"+n].removeMovieClip();

// Увеличиваем счетчик для первого камня.

firstRock = n+1;

// Проверяем, был ли этот камень последним.

if (n == totalRocks) {

removeAll() ;

gotoAndPlay("win");

}

}

В предыдущем фрагменте кода указаны два случая завершения игры. В обоих случаях вызывается функция removeAll, которая убирает с экрана все оставшиеся скалы и клип лисы. Иначе эти элементы останутся на экране даже после завершения игры.

function removeAll() {

// Убираем со сцены все объекты.

for (i=firstRock;i<=lastRock;i++) {

_root["rock"+1].removeMovieClip();

}

fox.removeMovieClip();

}

К сведению

Данная игра содержит два кадра, обозначающих конец игры. Первый кадр имеет метку «lose» и содержит сообщение для игроков, которые столкнулись с большим количеством камней и проиграли игру. Второй кадр, помеченный как «win», содержит сообщение для тех, кто миновал все камни. Кадры отличаются только текстом. Оба кадра содержат кнопку «Play» для перезапуска игры.

Другие возможности

Так как столкновение замедляет скорость игры, она представляет собой идеальный вариант игры на время. Начало игры можно обозначить при помощи объекта date (см. раздел «Аналоговые часы» в главе 6). Теперь вы будете знать, сколько игроку требуется времени для прохождения игры. На скорость байдарки может влиять не только столкновение со скалой. Соответственно изменив код, вы можете сделать так, чтобы байдарка набирала скорость только при движении вперед. Это сделает игру более захватывающей.

Вы можете создать другой вариант данной игры: попробуйте изменить направление движения объектов, вместо байдарки используйте машину или велосипед, а реку замениие дорогой. Получится хорошая игра-гонка.

Гонки

Исходный файл: Racing.fla

Чтобы сделать из игры "Сплав на байдарке" игру "Гонки", надо просто изменить графику и ничего больше. Замените байдарку на машину. Замените кадры с поворотами, чтобы показывать поворот колес машины, а не поворот байдарки в другом направлении. Замените кадр перевернувшейся лодки на кадр автокатастрофы и т. д.

Однако мы можем использовать похожую технику для создания гоночных игр разных типов. Вместо вида на дорогу сверху мы можем сделать вид с водительского места. Дорога движется к игроку (см. рис 9.9).

Рисунок 9.9. В игре гонки дорога движется по направлению к игроку

Задача проекта

Главная задача этой игры – создание иллюзии глубины. Хотя экран по-прежнему двумерный и никаких реальных трехмерных кодов не используется, игрок тем не менее должен чувствовать, что дорога входит в экран, а не ползет по нему сверху вниз.

В дополнение мы примем небольшой набор правил. На дороге есть отметки, которых водителю необходимо коснуться, чтобы заработать очки. Чем быстрее водитель едет, тем большего числа потенциальных отметок он может коснуться, прежде чем закончится время игры. Но чем быстрее он едет, тем больше у него шансов не успеть поймать метку до того, как она уйдет. К тому же, если водитель дотронулся до границ дороги, он замедляет ход и уменьшает свою потенциальную возможность заработать очки, поскольку на меньшей скорости ему попадается меньше меток.

Подход

Иллюзия глубины может быть достигнута простым использованием перспективы. На рисунке 9.9 показано, что границы дороги нарисованы диагонально по направлению к нижним углам экрана. Хотя ширина дороги предполагается постоянной, глазу кажется, что дорога спереди у" же.

В дополнение к линиям, все элементы игры должны появляться с некоторого расстояния. Это означает, что они должны двигаться не только сверху вниз, но и в стороны. Сыграйте прямо сейчас, чтобы посмотреть, как движутся камни по краям дороги и дорожные метки, похожие на звезды.

Три типа элементов движутся в этой игре: камни по сторонам дороги, звездообразные "бонусы"-метки на дороге и центральная линия дороги. В зависимости от скорости машины камни движутся по экрану вниз быстрее или медленнее. Движение камней в сторону – разбегание, создающее иллюзию перспективы, – происходит с той же скоростью, что и вниз.

Звездообразные метки располагаются ближе к центру экрана, поэтому они движутся в стороны не так быстро, как вниз; скорость их движения в стороны составляет половину от значения скорости движения вниз. Это соответствует перспективе, заданной сторонами дороги. Центральная линия просто движется прямо вниз.

Все эти элементы повторяются в игре раз за разом. Например, как только камень достигает нижней границы экрана, он снова появляется на горизонте и опять движется к игроку.

В дополнение к движению трех элементов игры мы также изменяем их масштаб. Таким образом, объекты, которые предполагаются далекими, выглядят меньше и увеличиваются по мере приближения.

Наша цель не в том, чтобы создать перспективу, реальную до последнего пиксела, а в том, чтобы достаточно к ней приблизиться, предоставив возможность воображению пользователя довершить остальное и почувствовать себя въезжающим в экран.

Подготовка ролика

Фон и линии, обозначающие границы дороги, – неподвижные элементы. Но для камней и звездообразных меток нужны клипы. Клип центральной линии – это просто линия, но расположенная таким образом, чтобы центральная точка клипа была на вершине линии.

Машина сама по себе нуждается в трех кадрах: прямое движение, левый и правый повороты, которые используются, чтобы показать, что машина поворачивает.

Клипы камней и бонусных меток должны быть помещены под нижней границей экрана и названы "SideObject" и "bonus". Клип машины следует поместить внизу экрана и назвать "car". Кроме того, слева находится клип "actions". Во всех четырех клипах содержатся сценарии.

1 ... 39 40 41 42 43 44 45 46 47 ... 90
Перейти на страницу:
На этой странице вы можете бесплатно читать книгу Adobe Flash. Создание аркад, головоломок и других игр с помощью ActionScript - Гэри Розенцвейг.
Комментарии