Больше, чем «последовательность PNG»: как создавалась 2D-анимация для Tangle Tower

Рассказ разработчика игры.

Разработчик Том Виэн в треде в Твиттере рассказал о поэтапном создании анимации для Tangle Tower. Он кратко описал каждый шаг, который делают разработчики, чтобы персонажи в игре начали двигаться. Также Виэн поделился инструментами, которые команда применяет в рабочем процессе. Например, вся анимация рисуется во Flash. Мы выбрали из треда главное.

Первый шаг для анимирования персонажей — это создание поз. К ним можно приступать только после того, когда будет готов финальный вариант облика героя.

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

Затем эти статичные позы импортируются в Unity в формате PNG. После для каждого диалога подбирается набор поз, которые помогут правильно выразить персонажа. Герои немного покачиваются, когда произносят фразу — это добавляет динамики в разговор.

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

Когда черновой вариант готов и согласован, начинается работа над финальной версией каждой анимации.

Кроме нескольких вариантов положения головы разработчики сразу же создают по 11 вариантов глаз и рта. По словам Виэна, в итоге получается 121 комбинация.

Но есть проблема, которая связана с невозможностью проиграть Flash-анимацию внутри Unity. Чтобы справиться с этим, разработчики используют FlAn Exporter, который Виэн создал ещё в 2012 году.

Интерфейс программы
Интерфейс программы

FlAn Exporter разбивает изображение из Flash на разные части и сохраняет их в виде PNG. Также он сохраняет всю информацию, которая нужна для того, чтобы восстановить анимацию. По словам Виэна, так файлы занимают намного меньше места, чем обычные PNG. Unity позволяет расположить все элементы в едином пространстве максимально плотно друг к другу. Для этого разработчики используют инструмент TexturePacker.

Больше, чем «последовательность PNG»: как создавалась 2D-анимация для Tangle Tower
Вот так выглядит набор всех элементов одного персонажа
Вот так выглядит набор всех элементов одного персонажа

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

Ниже представлена анимация с UV-данными. Когда вы видите мерцание, это значит, что происходит смена одной части персонажа на другую.

Затем разработчики накладывают элементы из набора, созданного ранее. При экспорте авторы могут вручную регулировать размер частей. Благодаря этому финальная анимация получается настолько качественной.

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

Несмотря на движения, персонажи всё ещё выглядят статично. Чтобы исправить это, разработчики применяют эффект boiling, который позволяет имитировать особенность классической анимации — в каждом новом кадре форма объектов немного отличается, из-за чего изображение «дрожит».

Когда отдельные анимации готовы, их нужно объединить в последовательные диалоги. Виэн создал инструмент, используя таймлайн в Unity — это позволяет собирать разговоры, отталкиваясь от продолжительности записанных дорожек. С помощью этого инструмента можно также отредактировать и исправить позу, глаза и рот.

There’s a window to help show/edit which pose, eyes and mouth are being shown on a frame, each of which can be controlled independently – thanks nested timelines! Another big advantage over simple PNG sequences. The talking mouths even have their own internal timelines (19/20) https://t.co/uwZFcurEir
Больше, чем «последовательность PNG»: как создавалась 2D-анимация для Tangle Tower
Есть специальное окно, в котором можно увидеть и отредактировать позу, рот и глаза в кадре. Ими можно управлять независимо друг от друга с помощью встроенных таймлайнов! Это ещё одно большое преимущество перед простой анимации, которая состоит из последовательности PNG. У каждого рта есть собственный таймлайн

И разработчикам пришлось создавать таким способом все 385 разговоров в игре.

Now @SFBDim just has to timeline all 385 conversations…

And this is the end result. A lot of work to get here from pretty much the whole team, but I really think it paid off, and we’re very happy with the way it looks in the game!

END THREAD (20/20) https://t.co/WSjmSbRihp
Больше, чем «последовательность PNG»: как создавалась 2D-анимация для Tangle Tower
Теперь @SFBDim нужно выстроить по таймлайну все 385 разговоров... И это финальный результат. На это ушло много сил всей команды, но я думаю, что это того стоило, и мы очень довольны тем, как это выглядит в игре.
8686
53 комментария

Также Виэн написал для Unity проигрыватель FlAn, который интерпретирует данные анимаций и восстанавливает с использованием спрайтовА мог бы взять Spine, а потом легко и удобно менять слоты у скинчиков в анимации.

10
Ответить

У них, видимо, в студии был аниматор-старовер который привык к флэшу.

У них очень негибкий деревянный метод, который наладывает вагон костылей сверху. Чуть что в сторону кастомизации, добавления анимации и их метод разваливается. С атласами у них вообще говно с маслом.

Ребята из Spine, Puppet2D, DragonBones плачут от таких статей.

13
Ответить

Кратко, здесь покадровая анимация, которую Spine никогда не превзойдет. И игрушка выглядит от этого потрясающее. 

1
Ответить

Настоящий DTF-вец всегда знает как лучше сделать

1
Ответить

А мог бы купить крест Доминика Торетто

Ответить

Это нездоровая наркомания. Есть Puppet2D, есть DragonBones, есть много чего.

Всё вышеописанное это что-то на уровне "делаем 2д анимацию для Unity в 3ds max". Можно ли так? Да, можно. Но смысл?

8
Ответить

Разработчики используют Flash уже 18 лет

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

3
Ответить