Как сделать пиксельную текстуру unreal engine 4

Добавил пользователь Евгений Кузнецов
Обновлено: 28.08.2024

Автор: Александр Блинцов. Специализируется на Unreal Engine. В Pixonic является клиентским разработчиком и отвечает за разработку и поддержку технической стороны нового сетевого мобильного шутера.

Четвертая версия движка вышла в 2014 году и распространялась по подписке за $19 в месяц. Но уже через год Epic Games сделала его бесплатным, после чего Unreal Engine 4 начали использовать не только студии, но и инди-разработчики.

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

Стоит обратить внимание на демки из лаунчера Epic Games (вкладка Learn/Изучить). Там можно найти очень много проектов на разные темы. Причём это практически полноценные прототипы игр, с логикой и графикой.

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

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

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

Может показаться, что редактор перегружен функционалом, но в этом и плюс: всё необходимое находится в одном месте. Хотя создавать хороший контент (модели, звуки, текстуры и т.д.) всё равно придётся в сторонних программах.

Зато в UE4 есть инструменты для прототипирования, благодаря которым можно собрать билд игры вообще без использования других программ. Например, с помощью Brush’ей можно смоделировать базовый мир и предметы. А уже потом поменять их на более качественные или оставить как есть, если стилистика проекта позволяет.

В Unreal Engine 4 есть Blueprints — специальный инструмент визуального программирования. Он позволяет строить логику игры с помощью блок-схем из нод. Инструмент достаточно наглядный, простой и интересный в работе. Например, оба скрипта на скриншотах ниже создают мигающую лампочку.

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

Звучит слишком хорошо, чтобы быть правдой. Подвох в том, что несмотря на низкий порог входа и наглядность, блюпринты — полноценный инструмент объектно-ориентированного программирования (ООП).

В итоге игру можно написать только на блюпринтах (причём не только одиночную, но и сетевую) и во многих случаях разницы в производительности не будет. Хотя зависит от самой игры.

В Unity, кстати, тоже есть аналогичный инструмент. Он называется Playmaker, но стоит 45 долларов.

Предположим, у вас уже готов прототип игрового мира и механика геймплея. Теперь нужно импортировать модели и настроить материалы к ним, чтобы всё выглядело как нужно. Мы обойдёмся готовыми ассетами.

Движок поддерживает .fbx и .obj форматы 3D-моделей, а также все популярные форматы текстур. Импортировать их достаточно просто — можно даже закинуть всё в папку с проектом, и импорт произойдёт автоматически.

Ещё важно настроить материалы, то есть шейдеры. Обычно они пишутся кодом в других программах, но в Unreal Engine 4 и на этот случай есть визуальный инструментарий, который позволяет описать инструкции шейдера нодами. Может показаться запутанным, но на самом деле для простых материалов присоединить нужные текстуры и получить реалистичный вид не так сложно.

В самом начале ознакомления с игровым движком Unreal Engine 4 передо мной возник вопрос: каким образом покрасить модель (актера/актора, как это там называется) хотя бы того же пола, который возник после создания проекта? А как покрасить что-то другое? Так вот.

Материал - это та штука в Unreal Engine 4, которой можно что-либо покрасить. Самое простое создание материала - из текстуры. Текстура - это, проще говоря, картинка. Да, просто картинка с расширением jpeg, png и подобными.

А теперь, собственно, о том, как создать самый простой материал.

Выбираем картинку, загружаем к себе.

Epic Games выпустила подробную документацию по созданию реалистичных персонажей в игровом движке Unreal Engine 4. В качестве примера приведён персонаж Дуплет (ранее Твинбласт) из игры Paragon, MOBA от Epic на PC и PS4.

Создание аутентичных, правдоподобных персонажей является фундаментальной задачей для многих современных 3D художников и разработчиков игр. В течение последних нескольких лет Epic привносит в UE4 новые функции рендеринга, которые улучшают шейдинг кожи, глаз, волос и других атрибутов персонажа.

Цель данной документации - дать возможность любому человеку научиться создавать такие же материалы и модели, как это делает команда Epic. Чтобы начать работу, откройте лаунчер и загрузите проект со вкладки Learn. Когда вы его откроете, нажмите Play в Editor и покрутите бюст героя в реалтайме.

Перевод - Photorealistic Character Unreal Engine 4

Для получения дополнительной информации о технологиях, используемых для создания персонажей, обратитесь к этому лайфстриму от Epic Games: Tech & Techniques Behind Creating the Characters for Paragon - ссылка.

Skin Shading

Кожа представленного ниже персонажа сделана благодаря UE4 Subsurface Profile.

Создание персонажа в Unreal Engine 4 - Изображение 1

Это специальный метод используется для рендера реалистичной кожи или воска, он аналогичен методу "Subsurface", но имеет принципиальное отличие в том, как он визуализирует: Subsurface Profile основан на пространстве экрана. Рендеринг экранного пространства более эффективен для отображения тонких эффектов слоёв кожи, где рассеивание при отражении является вторичным эффектом, которое наблюдается только в нескольких случаях, например, на ушах.

Обратите внимание на использование Material Functions для настройки основы материала кожи. Это делается как многоразовый авторский подход к созданию материалов для персонажей из Paragon. Таким образом, художники могут стандартизировать подходы к созданию определенных типов поверхностей, зная, что изменение одной функции будет обновлять все элементы, в которых она используется.

Skin Shader Textures

Текстуры, используемые на коже персонажа, имеют разрешение 4K и первоначально были получены благодаря сканированию лица актера. Текстуры были затем очищены и изменены художниками из Epic. Эта настройка кожи использует пять текстурных карт: Diffuse, Roughness, Specularity, Scatter и Normal.

Диффузная текстура поставляет базовый цвет для материала. Если приблизить 4K, то можно заметить крошечные капилляры. Любое потемнение морщин будет подчеркивать Normal Map.

Карта Roughness сохраняется в альфа канале Diffuse карты. Это общий метод, используемый для уменьшения количества текстур. Обратите внимание, что шероховатость увеличивается в местах с порами и морщинами. Это заставляет эти области казаться менее блестящими, подчеркивая глубину Diffuse и Normal карт.

Карта отражений отвечает за то, как материал будет реагировать на свет. Текстура отображает только свет со сцены, а не объекты + свет, как это делает Reflection Map. Важно отметить, что значение по умолчанию для отражения - 0.5. Эта карта должна отражать свет в тех местах, где кожа немного растянута, а уменьшать этот параметр она должна в тех местах, где мы не хотим видеть отражение, например, в центре пор и около морщин.

Карта рассеивания отвечает за то, как много света будет рассеиваться на поверхности кожи. Темные участки, такие как щеки, практически не будут рассеивать свет, в то время как светлые зоны носа и ушей, изображенные на фото, будут рассеивать свет. Цвет рассеивания управляется в Subsurface Profile Asset.Normal Map

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

Hair Shading

Обрабатывается в Unreal Engine 4 Hair Shader Model. Этот шейдер - модель PBS, основанная на исследованиях Steve Marschner, Eugene dEon и Hanika Johannes, и в настоящее время используется Weta Digital.

Чтобы начать работу с шейдером, установите параметр Shading Model вашего материала на Hair.

Создание реалистичного персонажа в Unreal Engine 4

Волосы и блики

В реальном мире волосы обладают несколькими бликами: один представляет собой цвет света, а другой является смесью цвета волос и светлого цвета. Для упрощения мы будем называть эти блики первичными и вторичными. UE4 Hair Shader показывает очень реалистичный результат с теми же эффектами.

Создание персонажа в Unreal Engine 4 - Изображение 2

1. Более светлые волосы являются первичными бликами. 2. Более яркие и рыжие волосы представляют вторичные блики.

Алгоритм аппроксимации, используемый в UE4 Hair, создаёт эти эффекты аналогично тому, как они сделаны в реальном мире. Когда свет попадает на волосяной фолликул, он не просто отталкивается от поверхности. Волосы просвечиваются, они позволяют пропускать через них некоторый свет, после чего свет отталкивается и выходит за пределы. Шейдер для волос достигает такого результата благодаря трем возможным путям движения света, как показано на анимированном GIF ниже:

Смотрите таблицу ниже, в которой описывается каждая часть процесса.

Направление роста (от корня до кончика) волосяного фолликула.

Только отражающийся луч, отталкивающийся от поверхности. Это создаёт первичный блик.

Путь, по которому свет проходит сквозь волос и выходит с другой стороны. Это то, как свет рассеивается в объеме волос.

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

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

Волосы и их прозрачность

Hair Shader использует Masked Blend Mode вместо прозрачности. Masked Blend Mode даёт бинарный результат - поверхности либо полностью непрозрачны, либо полностью прозрачны. Noisy Dither Pattern постоянно перемещается по поверхности, становясь непрозрачной в более плотных местах. Dither используется как способ смешивания Masked Transparency, но работает только когда TemporalAA активен.

Создание персонажа в Unreal Engine 4 - Изображение 3

Создание персонажа в Unreal Engine 4 - Изображение 4

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

Edge Masking

Настройка Edge Mask Unreal Engine 4

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

Урок Unreal Engine 4 - Создание персонажа

Создание волос для игрового персонажа

Перед тем как создать геометрию волос, следует посмотреть, как команда Epic конструирует волосы для игровых персонажей.

Геометрия волос

Данная геометрия создана с помощью нескольких плейнов, расположенных по всей поверхности головы, что является стандартным решением во многих real-time движках.

Нет никаких жестких правил для детализации геометрии волос вашего персонажа, но следует отметить, что Дуплет использует около 800 отдельных плейнов, в общей сложности около 18000 треугольников. Также обратите внимание, что материал для волос установлен двусторонний в свойствах Material Node Properties.

Урок Unreal Engine 4 -создание реалистичного персонажа

Текстуры волос

При использовании UE4 Hair шейдера конечный результат достигается следующими текстурами: Diffuse, Depth, Alpha, Root и Unique ID. В Epic эти текстуры обычно генерируются с помощью системы волос 3ds Max, которая проецирует имитируемые волосы на кусок геометрии. Однако есть много других вариантов для подобных результатов.

Диффузная текстура отвечает за базовый цвет самих волос. Желательно оставлять эту текстуру неокрашенной, а цвет задавать в самом движке, особенно это полезно в тех случаях, если волосы персонажа будут иметь разные цвета.

Альфа текстура обеспечивает прозрачность тех участков, где нет текстуры волос.

Текстура Root является маской для изменения цвета волос от корня до кончика. Полезна при осветлении или затемнении волос по их длине.

Текстура глубины используется как основа для изменения цвета или значений шейдера для волос на различных глубинах.

Текстура The Unique ID просто дает уникальное значение от 0 до 1 (от черного до белого) для каждой пряди на заданной части геометрии волос. Это используется для обеспечения различной вариации волос.

Свойства Hair Shader

Когда вы будете использовать Hair Shader, то увидите новые свойства, доступные в ноде материала: Scatter, Tangent и Backlit.

Scatter

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

Тем не менее, рассеивание света по-прежнему имеет решающее значение для того, насколько реалистичными окажутся волосы в игре. Чтобы контролировать это, Hair Shader имеет параметр Scatter, который заменяет Metallic основного нода шейдера и ограничивается значениями от 0.0 до 1.0. Scatter контролирует, сколько света проходит на всех волосах персонажа, как если бы это была одна поверхность.

Devgam, девгам, devgamcom

devgam, девгам, devgamcom

Важно отметить, что Scatter должен быть светлее для светлых волос и темнее для более темных волос. В реальном мире более темные волосы будут поглощать больше света. С практической точки зрения, если вы пытаетесь создать светловолосого персонажа, то вы заметите, что изменение диффузной текстуры или цвета недостаточно; Вам также придется увеличить значение Scatter.

Tangent

Tangent Unreal Engine 4

Свойства Tangent заменяют свойства Normal на шейдере волос. Tangent вычисляется как вектор, который проходит параллельно каждой пряди волос, направленный назад к корню. Цель Tangent заключается в том, чтобы помочь настроить правильное анизотропное отражение. Если вы не знакомы с этим, то анизотропное отражение - это то, что происходит, когда свет отскакивает от поверхности с микро-порезами, например, шлифованный металл.

Волос Unreal Engine 4

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

Tangent может отображаться одним из двух способов: автоматически или с помощью карты Flow. Автоматический метод просто требует, чтобы текстуры для каждого листа волос были ориентированы таким образом, чтобы корень был направлен вверх, а кончики - вниз. Если волосы короткие, и никакие плейны не изгибаются и слишком сильно скручиваются, то этот метод является адекватным. Он используется и на персонаже, представленном в этом уроке (мужчина).

Flow Maps

Другой метод требует создания Flow карты. Это будет полезно, если волосы вашего персонажа длинные, а также они должны казаться изгибающимися и завитыми больше, чем фактическая геометрия, или если отдельные участки текстуры для волос ориентированы по-разному (не сверху вниз, как описано выше). В проекте Photoreal Character Bust вы можете найти неиспользованную Flow карту с именем T_Hair_Flow. Ниже приведено сравнение этой карты и финального результата.

Unreal Engine 4 - создание фотореалистичного персонажа

Реалистичный персонаж в Unreal Engine 4 - Devgam

Здесь вы можете увидеть, как текстурирована Flow Map на примере волос Сойки (Sparrow). Обратите внимание, что карта используется только на некоторых участках, а не на всей голове.

Использование Pixel Depth Offset и Hair Shader

Pixel Depth Offset (PDO) не является свойством, уникальным для Hair Shader. С точки зрения непрофессионала, PDO заставляет пиксели отдаляться от камеры, создавая искусственное ощущение глубины. Так как волосы состоят из простых плейнов, как описано в разделе "Волосы и геометрия", использование PDO может обеспечить ощущение глубины формы волос в целом.

Unreal Engine 4 - урок создания персонажа

Как создать волосы в Unreal Engine 4

Редакция Devgam

Благодарим наших читателей и подписчиков за проявленный интерес. Поделитесь постом в социальных сетях.

Клиент импортирует картинку с помощью анриловской функции Import Texture2D(я так же делал свою). После этого я передаю её на сервер и потом на Repnotify или на мультикаст, без разницы. Вызовется только на сервере, клиентам не чего не приходит. На сервере текстура есть, она находиться в Engine/Transient.Texture2D. Есть ли способ реплицировать как то другим клиентам? Уже несколько дней сижу. Любая помощь


Сериализация Texture2D. Сохранение Texture2D
Есть два сериализуемых класса: public class NameModBuf < public string nameModuls; .


RenderTexture в Texture2D
Добрый день подскажите как можно преобразовать RenderTexture в Texture2D? Внутри RenderTexture не.

Импорт иконки из exe в texture2d
Добрый день. У меня возникла проблема, когда я попытался импортировать иконку из exe файла код.

A2 = (Texture2D)Resources.Load("Cub_");
Не работает скрипт нужна помощь public Texture2D a2; void Update () < a2 =.

Массив Texture2D
Как сделать массив текстур Texture2D? :)

snzhkhd,
1. У вас другие (какие-либо) значения реплицируются?
2. Если вы просто вызовите какой-либо метод на сервер, а с сервера на клиент, то ответ будет у клиента получен?

snzhkhd, Ок, я попробовал такую штуку у себя сделать, и действительно, картинку не так легко передать.

Вот список условий, при котором можно ссылаться на какой-либо объект по сети.

То-есть, картинка не может быть отправлена, так как она не находится в файлах игры (Content).

Можно попробовать реализовать отправку картинок по веб-сокету, нужно будет разворачивать свой сервер и довольно много логики проделать. Раньше была библиотека UWebSocket, сейчас автор ее удалил почему-то, и похоже что внедрил ее в какой-то document

Читайте также: