Создаем гиперказуальную игру в стиле Fire Balls 3D на Unity
Рассказываем, как с помощью Unity легко и быстро написать гиперказуальную игру по типу Fire Balls 3D. С кодом и гифками!
4К открытий4К показов
Александр Ватолин
Геймдизайнер и преподаватель в Школе программистов МШП
Меня зовут Ватолин Александр, я геймдизайнер, а для этого почти всегда нужны знания в самых разных областях: от разработки до 3D-моделирования. Готов ими поделиться.
Сейчас расскажу, как создать мобильную игру на основе гиперказуалки Fire Balls 3D.
В чем соль
Мы сделаем работающий прототип с помощью декомпозиции другого проекта. Логичный вопрос, который сразу возникнет: зачем копировать другой проект, а не создавать свой?
И у нас на это 5 причин:
— Пригодится для портфолио;
— Важно уметь декомпозировать фишки из других проектов для удачной переработки идеи. А иногда и просто для того, чтобы понять, что пишет твой сосед по отделу;
— Такие проекты показывают ваши навыки как разработчиков с разных сторон. А за счет легкости сравнения с оригиналом становится понятно, насколько точно вы можете следовать ТЗ.
— Вы отрабатываете для себя новые решения. Сегодня мы познакомимся с DOTween, к примеру.
Вот, что я имею в виду, говоря о новых решениях: создавая свои проекты, мы стараемся пользоваться уже знакомыми средствами. А вот копируя, мы зачастую сталкиваемся с тем, что нашим арсеналом проблемы не решить. Тогда мы выходим на путь развития, где ищем новые инструменты. Так копирование и прокачивает наш арсенал, вынуждая изучать новое.
— Поиск ошибок: когда мы смотрим на решения других дизайнеров и разработчиков, очень легко найти проблемы собственных проектов. В любом случае, вы развиваете насмотренность, и в будущем сможете найти проблемы при первом же взгляде.
Где будем разрабатывать игру?
Нам нужна мобильная, гиперказуальная, с простой графикой. Unity тут просто идеально подходит.
Устанавливаем любую 19+ версию и готовим несколько модулей, которые пригодятся при разработке:
- Probuilder. Отличный пакет для постройки прототипов. Но он не поможет в постройке базовых моделей, если вы ничего не знаете о 3D.
- DOTween. Его реально найти в AssetStore. Он нам понадобится для создания основной анимации. Это очень мощный пакет, который удобен при разработке не слишком сложных игр. Если еще не знаете, что это, советую изучить!
- Любой шейдер для воды. Один из них вы увидите в конце статьи в материалах. Если есть свои любимчики, можете использовать любой другой.
Вот и все.
Начнем разработку
После создания проекта импортируем данные проекты и не забываем переключиться в File -> Build Settings на платформу Android.
Начнем с базовых вещей. Организация пространства папок может быть любая. Но лучше, если будет подобная структура:
Теперь построим платформу, состоящую из куба и цилиндра. Также нам понадобится установить камеру под нужный ракурс и создать Пустышку — она будет управлять башней из создаваемых блоков. Назовем ее Tower.
Пришло время создать первый скрипт, назовем его TowerBuilder и прикрепим его к нашей Пустышке.
Попробуем разобраться, что это за скрипт. Филды нам нужны для параметров скрипта, а именно:
towerSize — размер нашей башни.
SpawnPoint — местоположение точки появления. Именно здесь будет браться наша Пустышка.
towerBlock — Блок башни, наш цилиндр. Можете заметить, что он типа BlockTower, что не позволит поместить любой gameobject, и вынудит нас создать скрипт BlockTower и прикрепить к префабу блока.
towerBlocks — список, хранящий текущие блоки башни.
Метод Build() выстраивает башню при помощи двух вспомогательных методов:
BuildTower — устанавливает блоки в позиции.
GetSpawnPoint — рассчитывает координаты положения, учитывая сдвиги с каждым новым сдвигом.
Весь метод работает в цикле, таким образом выстраивая полностью башню.
Не забываем добавить к префабу башни MeshCollider(Vertex — on, trigger — on).
В итоге у нас получится башня в соответствии с нашими настройками.
Немного передохнем от скриптов и создадим модель нашей пушки, стреляющей снарядами.
Помимо пушки создадим префаб снаряда — простого шарика.Также внутри танка расположим Shot point — место, откуда будут вылетать снаряды.
Скрипт снаряда назовем Bullet и реализация (пока что) у него будет простая:
Этот скрипт позволит при создании снаряда запускать его в необходимую сторону. Почему шар летит влево, а не вперед? На самом деле мне просто было лень его переориентировать, да это и не особо важно. Зато это успешно привлекло ваше внимание и погрузило в скрипт.
Есть снаряд, являющийся префабом с данным скриптом. Осталось реализовать пушку. Пишем:
Тут все еще проще. У пушки есть параметры под позицию выстрела, снаряда, чем стрелять, а также времени перезарядки.
Цикл проверяет нажатие на экран (либо левый клик мыши), и если время превысило время перезарядки, производит выстрел. После этого происходит обнуление счетчика. За само производство снарядов отвечает метод Shoot().
Что у нас есть на данную минуту:
Вариация работы стрельбы. Прямо сейчас не видно, но высокая установка пушки оказалась плохой идеей, позже мы ее подвинем пониже
Теперь подготовим систему удаления блоков при столкновении. Будет много кода, так что готовьтесь.
Начнем с метода BlockTower , он лежит внутри пребафа блока башни, помните?
Тут есть просто система самоуничтожения, а также событие, к которому мы вернемся чуть позже. Просто напишите его, чтобы не возвращаться еще раз.
Вернемся к Bullet. Добавим систему проверяющую столкновение с блоком башни. Тут все просто, появится один if в OnTriggerEnter.
Однако у блоков башни должно быть: MeshCollider (Vertex — on, trigger — on).
Данное условие вызывает уничтожение блока и шарика. Работает это сейчас примерно так, что никуда не годится:
Пришло время реализовать систему опускания башни.
Реализация управляющей системы башни ( прикрепляем к Tower):
Попробуем разобраться, что тут происходит. Для начала вспомним событие BulletHit, которое создается при уничтожении блока башни. Оно является спусковым крючком, которое будет вызывать методы OnbulletHit().
А теперь подробнее:
— В Старте мы инициализируем механизм постройки башни, что более корректно с точки зрении ООП, ну и просто удобнее;
— Далее для каждого созданного блока мы подключаем OnBulletHit для события BulletHit. Многие отметят, что корректно помимо подписки на событие реализовать и отписку, которая и реализована в данном методе;
— Метод OnBulletHit убирает блок из списка блоков, обновляя информацию о башне, сдвигая ее вниз. Важный момент: мы уничтожаем нижний блок, поэтому логично сдвигать всю башню вниз. Однако если мы бы уничтожали не нижний блок, пришлось бы сдвигать только элементы, которые выше данного блока.
— Также тут можно заметить событие SizeUpdated, которое нам понадобится на этапе проектирования интерфейса.
Итак, башня реализована:
Реализация системы башни. К слову вот здесь уровень башни был поставлен ниже для удобства работы
Пришло время вспомнить о препятствиях и Probuilder. Нам понадобится Пустышка, которая станет центром вращения, а также несколько элементов препятствий. Это могут быть хоть классические кубы, но лично я использовал Arch из ProBuilder.
Для частей мы создадим скрипт ObstacleChapter, который оставим в стартовом варианте, на данном этапе он нам не понадобится.
Для Пустышки же создадим скрипт Obstacle, который реализует вращения данной структуры.
Скрипт уже потребует работы с DOTween, мы покажем один из методов, но внутри пакета их множество.
Если внимательно прочитать, то можно понять, что метод позволит вращать объект вокруг своей оси.
Следом у нас идет модификация On trigger Enter из Buller.cs
Новое условие проверяет столкновение с частями препятствий и реализует систему отталкивания. По сути, мы просто меняем направление толчка, откидывая шар в сторону камеры.
Последняя часть, которая добавит шарма, это простенький Ui. Создадим TMP )text-mesh-pro, установив canvas в мировой режим и расположив все элементы на сцене. Мои настройки вы сможете изучить на скриншоте:
Реализуем систему подписки на событие SizeUpdated из Tower.cs. По своей сути она просто берет размера списка блоков и выводит его на экран.
Что же у нас получилось:
А теперь попробуем разобраться, что мы сделали:
Рабочий прототип. Прототип — игра на кубах без особой графики и с голыми кор-механиками. Именно это нам и удалось сделать. Игра требует развития, и именно это и останется сделать, чтобы создать классный экземпляр себе в портфолио или новый игровой проект.
А какие улучшения можно внести ?
- Графика. Думаю, тут все просто, но все же перечислю: новые модели, цветовая палитра, работа над окружением, разноцветные платформы;
- Меню входа и выхода. Данный проект не предполагает сложного меню, однако оно явно не помешает;
- Система уровней. Переход со сцены на сцену, либо перестройка уровня на основе конфига с данными об уровнях. Любая система, которая вам покажется удачной.
- Наполнение контентом. Какой он тут может быть ? Простой, как и сама игра: другие уровни, несколько уровней препятствий, особые выстрелы пушкой.
Итого: мы успешно реализовали протопип игры, у которого может быть развитие. Буду рад, если поделитесь конечными результатами.
А теперь обещанные материалы:
- DOTween — http://dotween.demigiant.com/download.php
- Water Shader — https://assetstore.unity.com/packages/p/mobile-depth-water-shader-89541
- Unitypackage показанного прототипа — https://drive.google.com/file/d/1q-nfWqZHxVM8fNMbe0GNFIAhs4TWYHg1/view?usp=sharing
До встречи!
4К открытий4К показов