Unity sprite: Unity — Creating Sprites — Tutorialspoint
Редактор спрайтов Unity Sprite Editor, как с ним работать и чего можно добиться?
16.07.2018
Бывают такие ситуации когда текстура спрайта содержит не только один элемент, гораздо удобней объединить несколько изображений связанных друг с другом в одно изображение. Например, изображение может содержать составные части персонажа,
бег, прыжок , стрельба , состояние покоя. Для этих целей Unity предоставляет Sprite Editor, который позволяет с извлекать элементы составного изображения.
Убедитесь, что графический объект, который вы хотите отредактировать, имеет тип текстуры, заданный для Sprite (2D и UI).
Для текстур Sprite с несколькими элементами необходимо, чтобы режим Sprite был установлен на Multiple in Inector.
Откройте редактор спрайтов
1. Выберите 2D-изображение, которое вы хотите отредактировать, из Project View
Вы не можете редактировать спрайт, который находится в режиме просмотра из сцены.
2. Нажмите кнопку «Редактор спрайтов» в Инспекторе импорта и отобразится редактор спрайтов.
Установите режим Sprite в Multiple в Inspector Import Text, если ваше изображение имеет несколько элементов.
Вы можете видеть только кнопку «Редактор спрайтов», если для параметра «Тип текстуры» для выбранного изображения установлено значение «Спрайт».
Кроме составного изображения, вы увидите другие элементы управления в редакторе. Слайдер в правом верхнем углу управляет приближением, в то время как кнопка с цветными полосками слева от него изменяет отображение альфа-канала и обычного
вида изображения. Самый важный элемент управления это меню Slice в левом верхнем углу, который предоставляет опции для автоматической нарезки элементов изображения. Кнопки Apply and Revert позволяют вам сохранить или отменить сделанные
изменения.
Использование редактора
Самый простой способ использования редактора — идентифицировать элементы вручную. Если вы нажмете на изображение, вы увидите прямоугольную область выделения с ручками в углах. Вы можете перетащить ручки или края прямоугольника, чтобы
изменить его вокруг определенного элемента. Выделив элемент, вы можете добавить другой, перетащив новый прямоугольник в отдельную часть изображения. Вы заметите, что когда вы выбрали прямоугольник, в правом нижнем углу окна появится
панель:
Элементы управления на панели позволяют выбрать имя для спрайта и задать положение и размер прямоугольника по его координатам. Ширина границы, для левой, верхней, правой и нижней, может быть указана в пикселях. Существуют также настройки
для оси спрайта, которые Unity использует как начало координат и основную «опорную точку» графического объекта. Вы можете выбрать из нескольких позиций по умолчанию для прямоугольника.
Кнопка Trim рядом с пунктом меню Slice изменит размер прямоугольника так, чтобы он плотно касался края изображения на основе прозрачности. Границы поддерживаются только для системы пользовательского интерфейса, а не для 2D SpriteRenderer.
Автоматическая нарезка
Изоляция прямоугольников спрайтов работает хорошо, но во многих случаях Unity может сэкономить вам работу, обнаружив спрайты и извлекая их автоматически. Если вы нажмете на меню Slice на панели управления, вы увидите эту панель:
Если тип разреза установлен на «Автоматически», редактор попытается угадать границы элементов спрайтов по прозрачности. Вы можете установить пивот по умолчанию для каждого идентифицированного спрайта. В меню «Метод» вы можете выбрать, как
работать с существующими выборами в окне. Опция «Удалить существующий» просто заменит все, что уже выбрано, Smart попытается создать новые прямоугольники, сохранив или отредактировав существующие, и Safe добавит новые прямоугольники, не
изменив ничего уже на месте.
Параметры сетки по размеру ячейки или сетке по ячейкам также доступны для типа разреза. Это очень полезно, когда спрайты уже были выложены в обычном шаблоне во время создания:
Значения размера пикселя определяют высоту и ширину плиток в пикселях. Если вы выбрали сетку по количеству ячеек, Column & Row определяет количество столбцов и строк, используемых для нарезки. Вы также можете использовать значения
смещения, чтобы сдвинуть положение сетки в левом верхнем углу изображения и значения заполнения, чтобы немного вставить прямоугольники спрайтов из сетки. Pivot может быть настроен с одним из девяти предустановленных мест или может быть
установлено местоположение пользовательского поворота.
Обратите внимание, что после использования любого из методов автоматического разреза создаваемые прямоугольники все еще можно редактировать вручную. Вы можете позволить Unity обрабатывать грубое определение границ спрайта и шарниров, а
затем выполнять любую необходимую точную настройку самостоятельно.
2D джоинты в Unity: учимся использовать
В этой статье попробуем разобрать, что из себя представляют 2D джоинты, для чего они нужны и какие физические конструкции можно собирать с их помощью.
Джоинты
2D джоинты представляют собой обычные физические объекты, которым можно придавать силу, перемещать, бросать сталкивать и тд, в общем – делать все то, что мы обычно делаем с физическими объектами в Unity. Особенность же джоинтов в том, что с их помощью можно создавать связи с другими физическими объектами на сцене. В этом случае все действия, которые мы совершаем над одним объектом, будут также влиять на другие – связанные с ним объекты.
Все компоненты джоинтов можно найти во вкладке Component -> Physics 2D.
В отличие от джоинтов для 3D физики, джоинтов для 2D физики почти в два раза больше и каждый тип служит для своих целей, хотя принцип работы у них всех практически один и тот же.
Как это работает
Давайте взглянем на изображение ниже, где показаны общие для всех джоинтов настройки компонента.
Первое на что стоит обратить внимание это то, что все джоинты, при создании на сцене автоматически подключают компонент Rigidbody2D, без которого они не смогут работать.
Здесь, на изображении, специально не показано название компонента джоинта, так как эти настройки являются общими для них всех. Исключением является Target joint, который мы разберем в самом конце статьи.
Начнем с поля Connected Rigid Body. В это поле можно поместить любой физический объект с которым необходимо установить связь.
Далее поле Enable Collision, которое включает и отключает коллизии между джоинтом и присоединенным объектом.
Поле Anchor, представляет собой Vector2, в котором можно указать место расположения крепления джоинта относительно его Transform’а. Обычно место расположения джоинта указывают сразу при создании на сцене и поле Anchor оставляют без изменений.
Следующее поле Connected Anchor, также представляет собой Vector2, где уже в свою очередь необходимо указать конкретно точку крепления объекта к джоинту относительно самого Transform’а джоинта.
По умолчанию поле Auto Configure Connected Anchor включено и поэтому точка крепления объекта к джоинту указывается автоматически как “центр” самого объекта. К примеру, когда нужно “зацепить” объект за какой либо край, галочку напротив поля Auto Configure Connected Anchor необходимо снять и вручную установить “место зацепления”.
Поле Break Force указывает силу, при превышении которой произойдет разрыв соединения между джоинтом и объектом. По умолчанию стоит значение Infinity, при котором разрыва соединения не произойдет.
У большинства джоинтов также имеется поле Break Torque, где можно указать силу, при которой произойдет разрыв соединения при вращении. Также как и поле Break Force – по умолчанию имеет значение Infinity.
И так ,с основными настройками джоинтов мы разобрались. Попробуем теперь более подробно разобрать некоторые джоинты, с примерами их работы.
Fixed joint
“Фиксированный” джоинт – самый элементарный джоинт из всего списка, полностью фиксирует физический объект в определенном месте. В общем, можно описать работу этого джоинта, как если бы вы прибили объект гвоздем к стене – ни пошевелится, ни повернуться такой объект не может.
У этого джоинта помимо стандартных настроек Break Force и Break Torque есть новые поля Damping Ratio и Frequence, изменяя которые можно определить, как сильно объект фиксируется в точке. Оба поля принимают числовое значение, где 0 означает полную фиксацию объекта, вне зависимости от внешних воздействий на объект.
Hinge joint
Следующий Hinge joint, также фиксирует объект в точке, и в отличие от Fixed joint не прерывает “воздействия” физики на сам объект.
Этот джоинт позволяет применять силу для совершения вращения объекта, а также вводить ограничения на угол вращения. Для этого в компоненте есть поле Motor, где указаны две переменные – Motor Speed и Maximum Motor Force, для скорости вращения и максимальной силы, применяемой для совершения вращения. Ограничивать угол вращения можно в поле Angle Limits, где для этого введены две переменные – Lower и Upper Angle – нижнего и верхнего предела угла вращения.
Slider joint
Этот джоинт немного похож на предыдущий Hinge joint, он тоже позволяет применять силу к объекту. Разница в том, что Hinge joint это делает для вращения объекта, а Slider joint применяет эту силу, чтобы двигать объект под определенным углом.
Также этот джоинт имеет новое поле Angle, где можно указать под каким углом объект будет перемещаться.
Distance joint
Следующий джоинт, как и остальные, имеет стандартный набор настроек, а также новое поле Distance, где можно указать минимальное расстояние между джоинтом и объектом. Если собрать “цепь” из нескольких таких джоинтов, то можно получить отличный аналог веревки, которая не растягивается и не рвется.
Spring joint
Этот джоинт также имеет поле Distance, но в отличие от Distance joint – позволяет имитировать “пружину” при растягивании. Как и Fixed joint – имеет поля Damping Ratio и Frequency, где можно указать – как быстро и сильно необходимо фиксировать объект к джоинту.
Target joint
Особый джоинт из всего списка, которому нельзя указать объект для присоединения – у него просто нет такого поля. Дело в том что если раньше мы сначала определяли позицию джоинта на сцене и к нему уже крепили объект, то в случае с Target joint – сам объект и является джоинтом, и вместо крепления к другому джоинту, он крепится к определенной точке на сцене. Для этого у него есть новое поле – Target, представленное в виде Vector2, где можно указать локальную точку крепления относительно объекта.
По принципу работу он немного похож на Spring joint, в котором также есть поля Damping Ratio и Frequency.
Заключение
Все эти джоинты используется чаще всего, они подходят для создания самых разнообразных физических систем. Важно помнить, что джоинты – это физические объекты, поэтому обрабатывать их перемещения, вращение и другие действия необходимо в методе обработки FixedUpdate, с работой которого можно ознакомится, скачав исходник проекта, со всеми примерами джоинтов отсюда.
Unity — создание спрайтов — CoderLessons.com
Спрайты — это простые 2D-объекты, на которых есть графические изображения (так называемые текстуры ). Unity использует спрайты по умолчанию, когда движок находится в режиме 2D. При просмотре в трехмерном пространстве спрайты выглядят тонкими как бумага, потому что у них нет Z-ширины.
Спрайты всегда обращены к камере под перпендикулярным углом, если они не вращаются в трехмерном пространстве.
Всякий раз, когда Unity создает новый спрайт, он использует текстуру. Затем эта текстура применяется к свежему GameObject, и к нему прикрепляется компонент Sprite Renderer . Это делает наш gameObject видимым с нашей текстурой, а также дает ему свойства, связанные с тем, как он выглядит на экране.
Чтобы создать спрайт в Unity, мы должны снабдить движок текстурой .
Давайте сначала создадим нашу текстуру. Получите стандартный файл изображения, такой как PNG или JPG, который вы хотите использовать, сохраните его, а затем перетащите изображение в область ресурсов Unity.
Затем перетащите изображение из активов в иерархию сцен . Вы заметите, что как только вы отпустите кнопку мыши, в списке появится новый GameObject с именем вашей текстуры. Теперь вы также увидите изображение в центре экрана в режиме просмотра сцены .
Давайте рассмотрим следующие моменты при создании спрайта —
Перетаскивая из внешнего источника в Unity, мы добавляем актив .
Этот актив является изображением, поэтому он становится текстурой.
Перетаскивая эту текстуру в иерархию сцены, мы создаем новый GameObject с тем же именем, что и у нашей текстуры, с прикрепленным Sprite Renderer.
Этот рендерер спрайтов использует эту текстуру для рисования изображения в игре.
Перетаскивая из внешнего источника в Unity, мы добавляем актив .
Этот актив является изображением, поэтому он становится текстурой.
Перетаскивая эту текстуру в иерархию сцены, мы создаем новый GameObject с тем же именем, что и у нашей текстуры, с прикрепленным Sprite Renderer.
Этот рендерер спрайтов использует эту текстуру для рисования изображения в игре.
Теперь мы создали спрайт в нашей сцене.
На следующем уроке мы рассмотрим некоторые модификаторы для спрайтов, которые у нас есть.
Textures вселяют в ваши меши (Meshes), частицы (Particles) и интерфейсы жизнь! Это файлы изображений или видео, которые вы накладываете на объект или оборачиваете вокруг. Т.к. они очень важны, у них есть множество свойств. Шейдеры, которые вы используете для ваших объектов, ставят некоторые требования, для которых вам нужны определённые текстуры, но основной принцип заключается в том, что вы можете поместить любое изображения в ваш проект. Если он соответствует требованиям к размеру (указан ниже), он будет импортирован и оптимизирован для использования. Это распространяется и на многослойные .psd или .tiff файлы — они будут объединены при импорте, чтобы не занимать слишком много места. Учтите, что это объединение происходит внутри Unity и может быть отключено, таким образом, вы можете продолжать сохранять и импортировать ваши PSD файлы с раздельными слоями. Объединение не затрагивает сам файл. СвойстваTexture Inspector(инспектор текстур) выглядит несколько иначе, в отличие от большинства других: Инспектор разделён на 2 раздела, Импортер текстур (Texture Importer и предварительный просмотр текстуры. Texture ImporterВсе текстуры исходят из файлов изображений в вашей папке проекта (Project Folder). То, как они импортируются, задаётся в импортере текстур(Texture Importer). Вы можете изменить текстуру выбрав нужный файл текстуры в оке Project View и изменивTexture Importer в инспекторе (Inspector). Самым главным элементом инспектора является меню Texture Type, которое позволяет выбрать вам тип текстуры, которую вы хотите сделать из исходного файла изображения.
Базовые настройки текстуры
Normal map настройки в импортере текстур
Настройка GUI в импортере текстур
Настройка спрайта для импортера текстур
Настройки курсора в импортере текстур
Настройка Reflection в импортере текстур
Интересный способ добавить кучу визуальных деталей в ваши сцены, это использовать Cookies — черно-белые текстуры, которые вы можете использовать для придания освещению определённого вида. Это великолепно для создания движущихся облаков и создания впечатления густой листвы. Страница Свет содержит больше информации об этом, но главной частью этого является то, что для использования текстуры в роли куков, вам лишь надо установить Texture Type на Cookie. Настройки Cookie в импортере текстур
Настройки Lightmap в импортере текстур
Расширенные настройки текстуры в импортере
Переопределения для разных платформКогда вы собираете игру для разных платформ, вам следует подумать о разрешении текстур для целевой платформы, размере и качестве. Вы можете установить стандартные настройки и затем их изменить под определённую платформу. Стандартные настройки для всех платформ.
Если у вас в Texture Type указан Advanced, то тогда у меню Texture Format будут разные значения.
ios
Android
Пока вы не нацелены на определённое оборудование, вроде Tegra, мы рекомендуем использовать ETC1 сжатие. Если есть надобность, вы можете хранить внешний альфа канал и в то же время извлекать пользу из отпечатка текстуры поменьше. Если вы определённо намерены хранить альфа канал в текстуре, то RGBA 16-бит — вид сжатия поддерживаемый всеми производителями оборудования. Текстуры можно импортировать из DDS файлов, но на данный момент поддерживается только DXT или несжатый пиксельный формат. Если ваше приложение использует сжатие текстур, текстуры будут разжаты в RGBA 32 и храниться в памяти вместе со сжатыми. Таким образом, в данном случае вы теряете время на разжатие текстур и теряете память, храня из дважды. Также может быть негативное влияние на производительность рендеринга. Flash
ДеталиПоддерживаемые форматыUnity может прочесть следующие форматы файла: PSD, TIFF, JPG, TGA, PNG, GIF, BMP, IFF, PICT. Стоит заметить, что Unity может без проблем импортировать многослойные PSD и TIFF файлы. При импорте они будут автоматически объединены, но это произойдёт в самих ассетах, таким образом, вы ничего не потеряете, если будете нативно использовать эти типы файлов. Это важно, т.к. это вам позволяет иметь по одной копии на текстуру, которую вы используете и в Photoshop, и в приложении для 3D моделирования, и в Unity. Размеры текстурВ идеале размеры текстуры и в высоту, и в ширину должны быть степенью двойки. Вот эти размеры: 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048 и т.д. пикселей. Текстуры не обязаны быть квадратными, другими словами, ширина может не равняться высоте. Учтите, что каждая платформа может наложить своё ограничение на размер текстуры. В Unity возможно использовать текстуры и других (не равных степени двойки — “NPOT”) размеров. Текстура NPOT-размера обычно использует немного больше памяти может медленнее читаться графическим процессором, так что для производительности лучше всего использовать размеры степеней двойки везде, где только можно. Если платформа или графический процессор не поддерживает текстуры NPOT размера, то тогда Unity изменит их размеры до ближайших, равных степени двойки, что потребует ещё больше памяти и сделает загрузку медленнее (на практике, это всегда случается при сборке под Flash и с некоторыми более старыми Android устройствами). Обычно надобность в использовании текстур NPOT размеров возникает только при создании интерфейса. NPOT ассеты текстур могут быть отмасштабированы во время импорта используя опцию Non Power of 2, видимой, когда в Texture Type установлен Advanced. UV MappingПри нанесении(маппинге) 2D текстуры на 3D модель, проходит похожая на оборачивание операция. Это называется UV mapping и этот процесс производится в приложении для 3D моделирования. Внутри Unity вы можете изменить размер текстуры и передвинуть её используя материалы. Изменение размера Normal и Detail текстур особенно полезно. Mip MapsMim Maps (мип-мипы) — список уменьшающихся по прогрессии версий изображения, используемые для оптимизации производительности в реальном времени при работе с 3D движками. Объекты, расположенные далеко от камеры, используют уменьшенные версии текстур. Использование мип мапов требует на 33% больше памяти, но если их не использовать, то тогда может быть сильное падение производительности. Вас всегда следует использовать мипмапы для внутриигровых текстур; единственные исключения — текстуры, которые никогда не будут маленькими на экране (например, GUI текстуры). Normal Maps (карты нормалей)Карты нормалей используются для шейдеров с их использованием, чтобы у низкополигональных моделей создать эффект, что они содержат больше деталей. Unity использует карты нормалей закодированными в виде RGB изображения. У вас также есть вариант генерации карты нормалей из черно-белой карты высот изображения. Detail Maps (карты деталей)Если вы хотите создать террейн, вы обычно используете главную текстуру, чтобы показать, где трава, гравий и т.п. Если вам террейн приличного размера, то всё это будет очень размытым. Detail текстуры скрывают этот факт добавлением мелких деталей к текстуре по мере приближения к ней. При рисовании Detail текстур, нейтральный серый — невидимый, белый — делает текстуру в 2 раза ярче, а чёрный делает текстуру полностью чёрной. Reflections (Cube Maps)Если вы хотите использовать текстуры для карт отражения (например, использовать встроенные Reflective шейдеры), вам понадобится использовать Cubemap текстуры. Anisotropic filtering (Анизотропная фильтрация)Анизотропная фильтрация увеличивает качество текстуры видимой под высоким углом, немного увеличивая нагрузку рендеринга (нагрузка полностью идёт на видеокарту). Обычно увеличение уровня анизотропии является неплохой идеей для текстур земли и пола. В меню Quality Settings анизотропную фильтрацию можно применить ко всем текстурами или полностью отключить её. Нет анизотропии (слева)/ Максимальная анизотропия (справа) применённая для текстуры земли |
Оптимизация 2D игр на Unity
Этот пост будет периодически дополняться и обновляться.
Обновлено 09.10.2020
На Youtube куча уроков по созданию простейших 2D игр на Unity. Реально, сделать неплохой платформер можно за день, при наличии опыта и готовых ассетов. Но многие начинающие игроделы сделав проект и протестировать его на ПК, с ужасом наблюдают как их творение тормозит на мобильном устройстве.
В мануалах, что встречаются в сети, большинство советов собрано к версии Unity 4.6+, кроме того, они почти все на английском, что для некоторых является преградой. В этом посте, я постарался собрать те моменты, которые помогли мне избавится от лагов на iOS и Android. Но важно понимать — не все можно решить лишь настройками, очень важна и архитектура приложения, и подготовленные текстуры, и знание более оптимальных алгоритмов.
Что нужно предпринять, чтобы повысить производительность, поднять FPS, снизить CPU?
1. Кешируем все!
Все, что будет использоваться больше одного раза лучше закешировать. Операции типа GameObject.Find() или GetComponent() достаточно ресурсозатратны, а если они вызываются где-нибудь в цикле или в Update (), то производительность может упасть.
void Awake () {
_cachedTransform = transform;
}
void Update () {
_cachedTransform.localPosition = _newPosition;
}
Не используйте Resources.Load () каждый раз когда нужно в рантайме загрузить что либо, это тоже дорогая операция. Лучше при старте закешировать и работать с кешем. Ну и конечно, объединяйте в префабы.
2. Настройки графики
В Unity есть 6 стандартных пресетов настройки качества графики. Но так как мы говорим про оптимизацию для 2D и для мобильных устройств, то все что выше Simple нет смысла ставить. Конечно, если у вас есть какие-то специфические моменты, частицы, и т. д., то с параметры можно поэкспериментировать найдя оптимальный баланс.
3. Используем FrameRate
По-умолчанию FrameRate равен 30. И зачастую этого бывает достаточно. Но например, при создании UI где есть прокручивающие списки и движущие элементы, может появится дрожание или шлейф. Я это заметил при тестировании на iPhone, поэтому вручную повысил FrameRate. А понижая FrameRate на сценах или игровых меню, где ничего не двигается, можно значительно снизить CPU, а следовательно продлить жизнь батарее устройства. Пользователи не любят когда игра сжирает аккумулятор за час.
public int _frameRate = 60;
void Start () {
#if UNITY_IOS
QualitySettings.vSyncCount = 0;
#endif
}
void Update () {
#if UNITY_IOS
if (_frameRate != Application.targetFrameRate)
Application.targetFrameRate = _frameRate;
#endif
}
4. Атлас текстур
Определенно, нужно упаковывать все свои спрайты в атласы. Для этого есть как встроенный инструмент Sprite Packer, так и продвинутый TexturePacker. Для работы встроенного упаковщика, достаточно задавать теги в настройках импорта, объединяя текстуры и спрайты по смыслу и месту использования.
Таким образом уменьшается количество вызовов отрисовок ваших спрайтов. Проверить как идет отрисовка можно с помощью встроенного инструмента Frame Debugger.
5. Используем пул объектов
GameObject.Instantiate () — очень дорогая операция! Если есть возможность не использовать ее в процессе игры — не используйте. Для большого количества однотипных объектов надо использовать пул объектов. Один раз инициализировав определенное количество, например пуль, они будут использоваться снова и снова, вместо создания и уничтожения каждый раз. Урок по пулу объектов и готовый шаблон, для начала будет достаточно.
6. Меньше Update — больше событий
Метод Update () вызывается каждый кадр, FixedUpdate () в некоторых случаях еще чаще. Если у вас в этих местах происходит много различных проверок и действий, это можно сказаться на производительности. Я использую событийную модель: вместо проверки условия в Update (), когда происходит какое-либо действие, отправляется событие, а в нужном месте это событие «слушается» и обрабатывается в зависимости от переданных параметров. Для этого можно использовать менеджер событий о котором я писал ранее.
7. Выключаем неиспользуемые компоненты
Деактивируйте объекты которые не попадают в камеру и которые не видно на сцене. Это также повысит производительность. Можно использовать вот такой хак, чтобы автоматически деактивировать объекты которые выходят за определенные границы.
8. Настройки билда
Билд под конкретную платформу, тоже можно оптимизировать. Например, если акселерометр не используется в игре, его лучше вообще отключить. Кроме того, я не использую автовыбор графического API, а задаю его сам убирая все остальные, опять же, если вы не используете какие-то специфические функции из OpenGLES 3.0, а так второй версии вполне хватает, она уже давно протестирована. Включаем статичный и динамический батчинг, а для Android многопоточный рендеринг. Для iOS включаем Script Call Optimization в Fast but no Exceptions, но тут момент — если будет какое-то исключение, то игра крашится.
9. Используем Profiler
Не стоит обделять вниманием профайлер. Обязательно протестируйте свою игру и посмотрите, в какие моменты идет максимальная нагрузка. Эти места нужно оптимизировать в первую очередь. Большинство ответов можно найти на stackoverflow.com или форуме Unity, просто загуглив название метода который тратит больше всего ресурсов.
10. Использование материала для UI Image и SpriteRenderer
Если у вас сложный интерфейс и много компонентов, особенно UI Image, то они существенно будут влиять на FPS. Чтобы повысить производительность, улучшить плавность анимаций, можно применить такой хак: там где вы не используете маски, у картинок нужно задать материал Sprites-Default. Если это сделать вместе с маской, то маска не сработает и получите примерно такой варнинг:
Material Sprites-Default doesn’t have _Stencil property
Чтобы убрать эту ошибку нужно немного изменить стандартный шейдер, сделать новый материал и применить его там где есть маска, тогда все сработает. Ссылка на измененный шейдер.
Цена плавности — повышение CPU 🙁
11. Уменьшаем размер текстур
Отличная утилита которая позволяет снизить потребления памяти для текстур до 3х раз. Как это работает и ссылка на Github, в статье на Хабре.
12. Практическое руководство по оптимизации Unity игр
Подойдет как для 2D, так и для 3D. Много полезной информации которую в документации вряд ли найдешь. Тут и про инструменты, и про опыт. Рассказывает специалист по эксплуатации из Unity Technologies — очень интересно. Узнал про memory profiler и то, что Camera.main не закеширована О_О. Обязательно смотреть всем.
13. Используем оптимизированный код
Снова хочется посоветовать набор оптимизированных скриптов от Leopotam. Коллекции, сериализация, векторы и многое другое. Настоятельное рекомендую, к изучению и использованию.
14. Используем одинаковые материалы
Если на объектах стоят разные материалы, они не будут батчится и будет больше вызовов отрисовки. Соответственно, нужно по возможности использовать как можно меньше разных шейдеров и материалов. Для понимания, как работает начальная оптимизация графики 2D, на Lynda.com есть небольшой курс.
15. Размеры атласов и спрайтов
Для применения сжатия спрайтов на мобильных устройствах нужно использовать атласы с размерами кратными степени 2, т. е. 1024х1024, 2048х2048.
16. Используйте UI Profiler
В Unity 2017 появился UI Profiler! Крутая штука, теперь можно выяснить почему в интерфейсе много вызовов отрисовки, увидеть какие материалы на объектах и всё это оптимизировать. Особенно актуально, если у вас сложные интерфейсы со множеством элементов, которые например, прокручиваются в ScrollRect.
17. Уголок оптимизатора
На сайте Unity появился специальный раздел посвященный оптимизации — Optimization corner. Там и про UI, и профайлеры, и основные ошибки, в общем, стоит ознакомиться.
18. Несколько советов по оптимизации UI
Раннее уже упоминали про Camera.main, но в новой статье описаны ещё несколько интересных особенностей оптимизации UI.
19. Сборник советов от FunCorp
Хорошая статья про оптимизацию UI. Многое уже описано тут, но есть и замечания по новым компонентам, например TextMeshPro.
20. Оптимизация UI без кода
Статья от Banzai Games про основные способы не делать неправильно Unity UI. Есть и интересные замечания. Зачем только снова про древний текстовый компоненты говорить… Думаю уже все перебрались на TMP.
21. Оптимизация мобильных 3D-проектов
Хорошая статья про оптимизацию в 3D. Многое подойдет и для 2D. Рассмотрены все аспекты и UI, и текстуры, шейдеры, батчинг и т. д.
22. Топ-10 ошибок в оптимизации Unity
Хороший вебинар от юнитеков, рассмотрены частые ошибки совершаемые при оптимизиции, обзор инструментов по оптимизации, примеры с пояснениями.
Пока все. Тут не было про физику, потому что пока я ее не использовал. Возможно, в будущем добавлю. Пишите в комментариях ваши проверенные способы оптимизации для 2D игр под Unity.
Учимся делать 2D-игры с нуля
Курсы и туториалы по созданию двумерных игр — вторая статья из цикла «Разработка».
116 508
просмотров
Автор: Дмитрий Старокожев. Начал программировать на пятом курсе университета, влюбился в Objective-C и разработку под iOS, после чего попал в Pixonic. Работает ведущим разработчиком на проекте War Robots, а в свободное время преподаёт.
Вероятно, в ближайшее время кто-то из читателей этого цикла статей напишет первую строчку кода своего будущего прототипа. Потому что с движком мы уже определились и переходим к практике.
Учить программированию в одной статье нет смысла. К тому же, руководств в интернете множество. Многие наверняка будут делать свои первые прототипы в 2D — на этой теме и сконцентрируемся сегодня.
Если вы решили делать сразу в 3D, не спешите закрывать страницу — знания всё равно пригодятся. Приступим.
2D. Звучит олдскульно, правда? В наши дни разработка двумерных игр приобретает какой-то особый шарм. Чувствуешь себя ценителем, которому открылась недоступная другим истина. Но одного чувства прекрасного недостаточно — у разработки в 2D есть множество нюансов.
Очевидно, что главная особенность двухмерных игр — отсутствие третьего измерения. Как определить, кто ближе к зрителю: машина, куст или огромный боевой робот? Чтобы решить эту проблему, во всех 2D-движках предусмотрен механизм сортировки спрайтов — то есть двумерных графических объектов — по оси Z. Он может называться Z-order или Sorting Layers — в любом случае, с его помощью можно перемещать объекты со слоя на слой.
Другими словами, проблема уже решена за нас. Можно не тратить силы на изобретение велосипеда, а обратить свое внимание на особенности конкретных движков и жанров.
Звук и анимация
Для разработки прототипа звуки и анимация в большинстве случаев не так важны. Но нужно понимать, что работа с ними в 2D значительно отличается от 3D. В трёхмерном мире анимация скелетная: у каждой модели есть «скелет» (rig). Двигая его участки, разработчик анимирует модель.
А в 2D анимация создаётся покадрово: нужно создать атлас изображений, чтобы они стали последовательностью кадров анимации (sprite sheet). Уолт Дисней всё делал кистью и роллером, и это были шедевры (с). Этим же способом можно создавать очень красивых рисованных персонажей. Как в Cuphead, которая разрабатывалась на Unity.
Cuphead
А вот со звуком в 2D всё проще. Если при отрисовке мира отсутствие третьего измерения накладывает ограничения, то работа со звуком, наоборот, упрощается. Не нужно учитывать расстояние от слушателя (персонажа в игре) до источника звука — слушателем всегда будет выступать сам игрок.
Но нужна ли вообще прототипу музыка? Не думаю, что можно дать однозначный ответ (как и с анимацией). Давайте посмотрим на Hidden Folks. Это не просто 2D-игра, а настоящее произведение искусства.
Весь звук в Hidden Folks состоит из странных похрюкиваний и притопываний её разработчика, что само по себе USP — уникальное торговое предложение игры. Каждое прикосновение к экрану смартфона заставляет улыбнуться. Ладно, если запись похрюкиваний вам не подходит, в Asset Store Unity можно найти огромное количество платных и бесплатных ассетов для прототипа, а иногда и для релизной версии игры.
С чего начать
Рекомендации по выбору жанра можно прочитать в статье прошлого цикла. Здесь же мы будем говорить о некоторых путях, по которым можно пойти начинающему разработчику. Кому-то кажется, что вариантов не так много и обязательно надо закончить профильный университет с хорошей профессурой. Но если копнуть глубже, то обнаруживается бесконечный океан знаний, которые лежат прямо перед носом — остается только ухватиться за предоставленную интернетом возможность. Из доступного на ум сразу приходят:
- Туториалы.
- Онлайн-курсы.
Туториалы (tutorial) отличаются от курсов тем, что дают чёткий алгоритм действий для воспроизведения результата. Они не выходят за рамки поставленной задачи и отлично подходят, когда нужно сделать что-то конкретное, пока не пропал энтузиазм.
Туториалы
При первом поиске браузер выдаст миллионы ссылок с видеоуроками, статьями и готовыми проектами. Я подобрал несколько хороших вариантов по разным игровым жанрам. К тому же, среди других работ авторов можно найти ещё больше годного контента.
Есть YouTube-канал Brackeys. На нём — отличное вводное видео о том, с чего начать разработку платформера с плиточной графикой (tile based). Если сложно воспринимать на слух, можно включить английские субтитры.
Автор ролика приводит много примеров существующих проектов и объясняет, чем отличаются два различных подхода к созданию двумерных игр: sprite и tile based. В плейлистах канала можно найти староватый, но не потерявший актуальность туториал по созданию полноценного 2D-платформера с нуля — пошагово и со всем кодом, который можно повторить у себя и получить такой же результат.
На канале интересно практически каждое видео: даже если вы не планируете прямо сейчас врываться в разработку, стоит посмотреть хотя бы ролики о том, что нового появляется в Unity от версии к версии. Кстати, некоторые выпуски спонсирует сама Unity Technologies.
Еще один канал от энтузиаста — N3K EN. Можно найти ролики как по отдельным механикам или основам C # и Unity, так и плейлисты по разработке проектов с нуля. Например, создание прототипа Fruit Ninja за четыре часа в режиме реального времени со всем кодом.
Если учиться по видеороликам не очень нравится, есть хороший туториал в виде полноценной книги на английском языке. Она проведёт вас от установки Unity пятой версии до конца разработки двумерного скролл-шутера.
Наконец, есть официальные туториалы от Unity. Видео сопровождаются текстовыми описаниями и даже листингами программного кода. В процессе обучения создаётся roguelike RPG в tile based мире.
Чтобы в точности повторить результат, Unity сразу предлагает бесплатно скачать все ассеты этого проекта. Очень удобно и не надо ломать голову над тем, где взять симпатичные спрайты, а не разноцветные прямоугольники. В последнем ролике вы даже научитесь реализовывать управление персонажем под сенсорные экраны мобильных устройств.
Принимаясь за изучение нового туториала, не стоит волноваться о том, какую версию движка использует автор.
Unity везде ведёт себя похожим образом, а функции движка пятой версии доступны и в самой последней. Конечно, инструменты совершенствуются, но авторы обучающих материалов редко копают настолько глубоко, так что об этом можно не беспокоиться.
Курсы
Если нужно подтянуть навыки программирования, то на арену выходит старый и проверенный игрок — Code School. Всё происходит прямо в интерфейсе сайта, который выглядит свежо и удобно. И не чувствуешь на затылке укоризненный взгляд Лобачевского со старого портрета над доской с графиком дежурств. Точно стоит обратить внимание хотя бы на бесплатные курсы, чтобы понять, насколько удобен такой формат обучения.
Есть официальные курсы от Unity, не надо далеко ходить. Кажется, что они и дальше готовы инвестировать в это направление (а после курсов можно еще получить сертификат).
У GeekBrains есть два отличных курса, разбитых по уровням сложности. Раз уж мы говорим о 2D-играх, нас интересует первый. Оба курса требуют определенной алгоритмической подготовки, программированию там не учат, только разработке на Unity.
Вы научитесь делать игры в 2D буквально с нуля: на первом уроке установите движок, а на восьмом уже запустите проект на Android. Вы даже можете заметить меня в списке преподавателей и случайно попасть на мой поток.
Хотите узнать, насколько глубока кроличья нора? Я падаю, стул тоже падает, здесь всё в 2D, и мне это очень нравится. Присоединяйтесь.
Домашнее задание
Наступает время самостоятельной работы. Пора писать код своей первой игры!
- Определите главную механику. Например, у Tower Defence это строительство башен и волны врагов.
- Найдите туториал по главной механике или по жанру в целом.
- Реализуйте главную механику на практике, используя примитивную графику.
О нюансах 3D-игр и туториалах для них поговорим отдельно — в следующей статье.
Это статья из нашего большого проекта с vc.ru. Если выполнять все задания, можно — ни много ни мало — научиться делать видеоигры. И выиграть лимитированное издание PS4 Pro в конце каждого цикла статей.
Цикл «Разработка»:
Как создать 2D-платфомер на Unity с нуля. Курс для инди-разработчиков.
Melee и разрушаемые объекты.
Реализуем механику холодного оружия. Дополняем код и соответствующие контейнеры в префабе персонажа. Реализуем механику разрушаемых пропсов.
Домашка: самостоятельное повторение этапов лекции, сборка уровня с новой механикой
Время: 1 час лекция, 30 минут домашка
Модель данных игрока и текущей сессии.
Рассказываем о ScriptableObject как о хранилище данных и настроек. Проектируем и реализуем модель данных игрока, привязываем эти данные к игре. Реализуем бочку со взрывчаткой, которая ранит персонажа при ее взрыве. Дополнительное задание: на основе материалов с этой и предыдущей лекции реализовать механику аптечки.
Домашка: самостоятельное повторение этапов лекции, реализовать механику собираемого зелья здоровья
Время: 1 час лекция, 30 минут домашка
Мобы и базовый AI.
Рассказываем о неигровых персонажах и добавляем простой контроллер моба который который ранит персонажа при приближении. Рассказываем об агро рэнже и базовых поведениях.
Домашка: самостоятельное повторение этапов лекции, сборка уровня с новой механикой
Время: 1 час лекция, 30 минут домашка
Range атаки.
Рассказываем что такое проджектайл и настройки Bullet в разрезе физики и детекции коллизий. Реализуем рэнж оружие игрока (пистолет). Доп. задание: реализовать дробовик.
Домашка: самостоятельное повторение этапов лекции, реализация спецатаки «буря клинков»
Время: 1 час лекция, 30 минут домашка
Стреляющие противники и стратегии ИИ.
На основе компонентов и предыдущей лекции реализуем стреляющего моба. Рассказываем о стратегиях и стэйт машинах для AI. Реализуем простую модель поведения моба.
Дополнительное задание: реализовать такое поведение моба, чтобы стреляющий переходил в рукопашную при приближении персонажа.
Домашка: самостоятельное повторение этапов лекции, реализовать моба которым обладает melee и range атаками
Время: 1 час лекция, 30 минут домашка
Инвентарь. Модель данных и связывание.
Создаем модель данных инвентаря и ячеек быстрого доступа. Реализуем собирабельные ресурсы и механики патронов, ключей.
Доп. задание: собирабельная аптечка.
Домашка: самостоятельное повторение этапов лекции, реализовать механику собираемого зелья здоровья
Время: 1 час лекция, 30 минут домашка
Звук.
Обзор звуковой подсистемы Unity, реализация эмбиента уровня, программное воспроизведение звуков, компонент воспроизведения звука.
Домашка: самостоятельное повторение этапов лекции, добавить недостающие звуки в игру
Время: 1 час лекция, 30 минут домашка
Чистый код, связность, зацепление.
Лекция на тему хорошего кода: какие есть признаки, чего нужно придерживаться. Рефакторим созданные классы.
Дополнительное задание: отрефакторить один из старых классов.
Домашка: самостоятельное повторение этапов лекции, попробовать отрефакторить уже написанный код
Время: 1 час лекция, 30 минут домашка
Оптимизация листов спрайтов для Unity
Почему вам следует использовать оптимизированные спрайты
Думаю, вы уже знаете, что листы спрайтов повышают производительность вашей игры. Но с TexturePacker
вы можете сделать даже больше.
Unity создает для вас сетки спрайтов — они уменьшают количество перерисовки, просто не отрисовывая
прозрачные пиксели. Единственная проблема — качество сгенерированной сетки:
Unity 5.2.2.f1 против TexturePacker 4.0.0
TexturePacker поставляется с новым алгоритмом для создания лучших сеток.Как вы видите выше:
- Количество треугольников уменьшено на 69% — дополнительная мощность процессора
- Overdraw уменьшен на 30% — дает дополнительную мощность графического процессора
Что вы узнаете в этом руководстве
TexturePacker вместе с бесплатным TexturePackerImporter создает ресурсы таблицы спрайтов, которые можно напрямую использовать из Unity.
графический редактор или через скрипты.
Спрайты доступны через стандартный API Unity с использованием
Класс спрайтов —
дополнительный код выполнения не требуется ! Таблицы спрайтов также работают с классами пользовательского интерфейса Unity, но не поддерживают оптимизированные сетки спрайтов..
Это то, что вы получите:
- Повышенная производительность благодаря оптимизированным сеткам спрайтов
- Простое управление спрайтами
- Импорт / экспорт в 1 клик
- Никакого дополнительного кода времени выполнения или библиотеки не требуется
- Полностью автоматизированная нарезка спрайтов
- Экономит время
Создание листов спрайтов
Чтобы создать новый лист спрайтов, просто запустите TexturePacker и перетащите каталоги .
содержащий ваши спрайты в область спрайтов.TexturePacker сохраняет структуру каталогов в добавленном вами каталоге, что позволяет группировать и сортировать спрайты.
Новые спрайты в каталоге добавляются на лист, как только вы повторно входите в TexturePacker.
Выберите формат данных Unity — Texture2d в настройках справа.
Щелкните значок папки рядом с именем файла данных и выберите расположение в
Каталог Assets вашего проекта Unity —
сценарий TexturePackerImporter будет повторно импортировать лист спрайтов в ваш проект каждый раз, когда вы публикуете
обновленный лист с TexturePacker.
По умолчанию
TexturePacker 4 использует алгоритм упаковки «Многоугольник».
Он также хорошо работает с пользовательским интерфейсом . Изображение
, но вы должны установить
useSpriteMesh
до true
.
Вы также можете попробовать MaxRects при упаковке многоугольных спрайтов, это может обеспечить лучшие результаты упаковки в зависимости от ваших данных спрайта.
Упаковка полигонов — сложный процесс и требует времени. Вы можете ускорить процесс двумя способами:
- Увеличьте допуск трассировщика — это создаст менее сложные полигоны
- Use MaxRects — TexturePacker использует прямоугольники для упаковки, но по-прежнему использует оптимизированные сетки
Unity Importer в настоящее время несовместим с функцией Multipack TexturePacker.Если спрайт упакован на другой лист, связь с текстурой разрывается.
Наконец, нажмите «Опубликовать», чтобы создать лист спрайтов.
Оптимизация полигональных сеток
Вы можете влиять на качество сеток с помощью Tracer Tolerance. Более высокие результаты толерантности
меньше вершин, но больше перерисовки.
Наилучшая ценность для вашего проекта зависит от одного фактора: использования вашего процессора и графического процессора. Каждая вершина
для расчета требуется мощность процессора. С другой стороны: каждый дополнительный пиксель увеличивает рабочую нагрузку на графический процессор.
Если ваш проект имеет высокий уровень вычислений (ЦП) (ЦП) , но у вас все еще есть ресурсы на стороне графического процессора, выберите меньшее количество вершин
— увеличить допуск трассера .
Если ваш проект имеет высокий уровень графической подсистемы (GPU) , но у вас все еще есть ресурсы на стороне процессора, выберите более низкий перерасход.
— уменьшить допуск индикатора .
Следите за значениями, которые TexturePacker отображает в нижней части таблицы спрайтов. В следующем примере вы видите
что уменьшение перерисовки на дополнительные 2% дает больше, чем просто дублирование количества вершин.
Настройка допуска трассировщика: количество треугольников и перерисовка
Использование спрайтов
Чтобы включить импорт листов спрайтов TexturePacker в Unity, необходимо установить TexturePacker Importer,
которую вы можете бесплатно скачать из Unity Asset Store :
Импортер TexturePacker
Сценарий расширяет возможности Unity для чтения данных таблицы спрайтов, созданных с помощью TexturePacker, и для автоматического создания собственных ресурсов Unity, которые вы можете использовать с редактором Unity.
Код скрипта запускается только во время разработки.Он не становится частью вашего продукта или игры.
Импортируйте этот пакет в свой проект Unity, открыв ссылку сверху в Unity:
Плагин поставляется с некоторыми демонстрационными активами, но он идеален, если вы установите только TexturePackerImporter.dll.
Важно, чтобы dll находилась в папке Editor, чтобы гарантировать ее автоматическую загрузку редактором Unity.
TexturePackerImporter проверяет для каждого файла текстуры наличие соответствующего файла.tpsheet файл существует.
Это файл данных, написанный TexturePacker — он используется импортером Unity для разделения текстуры на отдельные спрайты.
Ресурсы и таблицы спрайтов автоматически обновляются в Unity при обнаружении изменений. Никакого ручного вмешательства не требуется!
Используйте символ рядом с элементом текстуры для отображения отдельных спрайтов.
Чтобы создать анимацию, просто выберите кадры и перетащите их на сцену.
Теперь вы можете использовать свои спрайты как обычно, прямо из редактора.
Конечно, вы также можете получить доступ к спрайту через API сценариев:
Редактор точек поворота
TexturePacker содержит простой в использовании редактор точек поворота с предварительным просмотром анимации в реальном времени.
Выберите свои спрайты на левой панели и нажмите Настройки спрайта вверху.
панель инструментов.
Точки поворота представлены кружком. Вы можете выбрать несколько фигур и переместить все точки поворота
сразу.
Используйте предварительный просмотр Anim на верхней панели инструментов, чтобы увидеть анимацию выбранных
спрайты.Изменения в точках поворота обновляются, пока вы их редактируете.
Правая панель содержит изменения для установки абсолютных и абсолютных точек поворота.
относительные координаты. Относительные координаты используют диапазон 0 — 1, где
0/0 находится в нижнем левом углу спрайта.
Поле со списком Predefined позволяет вам выбирать из стандартных позиций в
углы и центр спрайта.
Вы также можете установить значения по умолчанию для новых спрайтов, нажав кнопку со стрелкой на правой панели.
Редактор границ (9-патч, 3-патч)
TexturePacker также поддерживает редактирование границ спрайтов — также известных как спрайты с 9 или 3 фрагментами.
Вы можете использовать эту функцию для создания масштабируемых кнопок, полос и других объектов с определенным растяжением.
Спрайт разрезается на 3 (x или y направление) или 9 частей (x и y направление).
Части спрайта по углам закреплены. Остальные растягиваются при изменении размера спрайта.
Вы можете включить настройку границы для отдельных спрайтов в настройках Sprite.
на верхней панели инструментов.
Перетащите зеленые линии, чтобы разделить 9 сегментов спрайта с 9 участками.
Переместите неиспользуемые линии вверх / вниз или влево / вправо, чтобы создать спрайты с 3 участками.
Unity UI
Классы пользовательского интерфейса Unity по умолчанию игнорируют информацию о многоугольной сетке и просто используют прямоугольные спрайты.
В результате вы можете видеть некоторые артефакты от других спрайтов с включенной упаковкой полигонов.
Простое решение избавиться от этих артефактов — установить
useSpriteMesh
до true
.
Применение точек поворота и размеров к объектам изображения пользовательского интерфейса
Unity автоматически копирует части свойств спрайта в изображение пользовательского интерфейса при создании.
Проблема в том, что Unity не копирует все значения и, что еще хуже, копирует
не обновлять значения при изменении таких деталей спрайта, как точка поворота или размер.
Мы добавили небольшой инструмент, который поможет вам обновить объекты UI Image.
Вы можете найти его в контекстном меню пользовательского интерфейса. Это называется Set Native Size + Pivot:
Обновление объектов изображения пользовательского интерфейса с помощью точек поворота и размеров изображения
Как мне получить доступ к спрайту на листе спрайтов из кода?
Если вы разместите спрайт на листе спрайтов, его нельзя будет загрузить отдельно, как Resources.Загрузите
.
Одним из преимуществ таблицы спрайтов является повышение скорости за счет загрузки всех спрайтов в кучу вместо чтения каждого файла по отдельности.
Поэтому вызов Resources.LoadAll
— это правильный способ загрузить спрайт.
лист и получить доступ ко всем спрайтам, которые на нем находятся.
Недостатком Unity API является то, что Resources.LoadAll
возвращает массив вместо словаря.
Поэтому вам нужно перебрать Sprite []
и сравнить имена спрайтов, чтобы найти конкретный спрайт.
Еще лучшим решением было бы составить словарь самостоятельно:
Как импортировать таблицы спрайтов — Unity
Настройки по умолчанию для импорта спрайтов часто делают графику размытой. Я собираюсь поговорить о том, как импортировать 2D-пиксельное искусство, чтобы ваша графика была красивой и четкой, а затем покажу вам, как нарезать листы спрайтов.
Импорт 2D-спрайтов
Создайте новый 2D-проект. Если у вас есть 3D-проект, вы все равно можете это сделать, но Unity использует лучшие настройки по умолчанию для 2D-проекта, когда вы импортируете графику, если это 2D-проект.
Создайте новую папку в папке Assets с именем Sprites . В Project Explorer щелкните правой кнопкой мыши и выберите Create> Folder .
Если у вас большой проект с большим количеством папок, я предлагаю пронумеровать папки так, чтобы ваши наиболее часто используемые были в первую очередь, и чтобы вы разработали систему. Тогда ваш мозг привыкает к порядку, в котором расположены папки, и вы тратите меньше времени на поиск файлов и папок — это помогает иметь такую систему и в команде: если люди создают новые папки, это предотвращает потерю вещей.
Затем добавьте свои спрайты в новую папку Sprite .
Выберите только что импортированный спрайт. Вы увидите Import Settings в Inspector .
Выше приведены настройки импорта по умолчанию, которые вы увидите, если ваш проект — 2D. Ниже я установил свой:
Я кратко рассмотрю различные моменты и способы их установки:
- Тип текстуры — всегда используйте спрайт для 2D-пиксельной графики
- Sprite mode — если это одиночный спрайт, используйте Single. Если это лист спрайтов, используйте Несколько
- Pixels Per Unit — Установите ширину и высоту вашего спрайта. Если ваш спрайт 14 x 14, установите его на 14. Если это лист спрайта, установите его на ширину и высоту одной плитки на листе. Если вы экспортировали свой спрайт больше, чем его собственный размер, скажем, в 2x или 3x, тогда вам нужно будет указать размер, который вы экспортировали, а не собственный размер.
Ваша жизнь будет намного проще, если ваши спрайты будут квадратными.Я только один раз пробовал с прямоугольником, и в этом случае это сработало, когда я установил количество пикселей на единицу равным ширине спрайта, но не считаю это правилом, которое будет работать каждый раз, только один опыт.
- Тип сетки — оставляю в покое
- Extrude Edges — я оставлю это в покое
- Pivot — Здесь расположен ваш объект. Если вы оставите точку поворота в центре и переместите спрайт на 0, 0, центр вашего спрайта будет в 0, 0
- Generate Physics Shape — Честно говоря, я никогда не смотрел на это.В документации говорится, что он предназначен для использования с компонентом Tilemap Collider и Physics 2D . Я всегда оставлял его в покое, но вы можете попробовать отключить его, это, вероятно, оптимизирует вашу игру, если вам это действительно не нужно.
- Advanced — Расширенные настройки никогда не трогал
- Wrap Mode — Оставьте как есть
- Фильтр Режим — Билинейный сделает пиксель-арт размытым. Вы хотите использовать баллов (без фильтра).
- Максимальный размер — Уменьшение размера позволяет оптимизировать текстуры для игры и значительно повысить производительность, особенно для текстур в трехмерных играх. Я взял 3D-игру, которая почти не запускалась на PS3 из-за низкой частоты кадров, и заставил ее работать с высокой частотой кадров, просто уменьшив размеры текстур. Обычно я советую использовать как можно меньшее количество. Речь идет о буквальном размере текстуры в пикселях. Если лист спрайтов сжат, возможно, вам придется увеличить его.
- Алгоритм изменения размера — я не трогаю
- Формат — этого не трогаю
- Сжатие — Установите значение «Нет» для пиксельной графики.В 3D-игре, если вы хотите оптимизировать, вы можете попробовать сжатие, если оно не оказывает заметного влияния на внешний вид вашей игры. Конечно, это частично будет зависеть от ракурса вашей камеры. Сверху вниз / от третьего лица вы меньше заметите сжатие текстур. От первого лица вы заметите это намного больше.
Если это один спрайт, все готово. Если это таблица спрайтов, читайте дальше.
Разделка листа спрайтов
Итак, вы хотите нарезать лист спрайтов. Предположим, вы правильно установили Import Settings , как указано выше, в том числе Sprite Mode , установленным на Multiple.
Затем вы хотите щелкнуть Sprite Editor в разделе Import Settings .
Появится такой экран:
Теперь нам нужно нарезать этот лист спрайтов. Щелкните вверху, где написано Slice.
Для типа проще всего использовать сетку по количеству ячеек . Просто укажите количество строк и столбцов.
Мне нравится делать мои листы спрайтов плотными, поэтому я никогда особо не использовал смещения или отступы.Я полагаю, что заполнение — это если вы добавите пустое пространство вокруг ваших плиток в листе спрайтов, и я предполагаю, что вы хотите, чтобы этот интервал был равномерным вокруг каждой плитки. Если у вас есть отступ в 1 пиксель на листе спрайтов, поместите его туда.
Наконец, как только вы установили точку поворота , нажмите срез. Имейте в виду, что вы, вероятно, захотите использовать один и тот же стиль поворота для каждого спрайта в вашей игре, иначе вы можете получить странные ошибки, так что имейте это в виду.
После того, как вы нарежете, вы должны увидеть слабые линии сетки вокруг ваших спрайтов.
Если вас устраивает сетка, нажмите Применить. Если нет, просто нарежьте его снова.
Если вы посмотрите на обозреватель проекта , где находится ваш спрайт, вы заметите маленькую стрелку рядом со своим спрайтом. Нажмите стрелку.
Вы увидите, что все ваши индивидуальные спрайты разложены. Теперь вы можете перемещать их по отдельности в свою сцену, чтобы создавать анимацию и настраивать игру.
Нравится:
Нравится Загрузка…
Вкратце, таблица спрайтов — это способ упаковки изображений в одно изображение, которое затем используется для создания анимации и графики спрайтов, поскольку при этом используется мало памяти и повышается производительность игр. Создание GameObject и добавление компонентов
Импорт листа спрайтов
Теперь Unity будет обрабатывать ken-sprite-sheet.png как лист спрайтов с несколькими кадрами анимации. Нарезка листа спрайтов
Здесь я изменил значение Pivot с Center на Bottom. Когда вы изменяете Pivot на Bottom, это означает, что точка поворота устанавливается в центре нижней части спрайта, а тип нарезки в этом конкретном случае должен быть установлен автоматически.
|
Elringus / SpriteDicing: расширение Unity для повторного использования областей текстуры спрайтов
Этот плагин используется в Naninovel — расширении движка визуальных новинок для Unity.Проверьте это в Asset Store!
Установка
Используйте UPM для установки пакета по следующему URL-адресу git: https://github.com/Elringus/SpriteDicing.git#package
или загрузите и импортируйте SpriteDicing.unitypackage вручную.
Минимальная поддерживаемая версия Unity: 2019.3
Описание
Sprite Dicing — это расширение редактора для игрового движка Unity, которое позволяет разбивать набор больших текстур спрайтов на небольшие части, отбрасывать идентичные, запекать их в текстуры атласа, а затем плавно реконструировать исходные спрайты во время выполнения для рендеринга.
Этот прием позволяет значительно уменьшить размер сборки в случаях, когда используется несколько текстур с одинаковыми областями. Рассмотрим тип игры визуального романа, где у вас есть несколько текстур для каждого персонажа, каждая из которых отображает разные эмоции; большая часть пространства текстур будет занята идентичными данными, и только небольшая область будет отличаться:
Эти исходные пять текстур имеют общий размер 17,5 МБ . После нарезания кубиками результирующая текстура атласа будет содержать только уникальные фрагменты размером всего 2.4 МБ . Теперь мы можем отказаться от пяти исходных текстур и использовать атлас для рендеринга исходных спрайтов, эффективно сжимая данные исходных текстур на 86,3% .
Как использовать
- Создайте актив
DicedSpriteAtlas
, используя команду менюAssets -> Create -> Diced Sprite Atlas
, выберите его; - Укажите
Входную папку
— каталог проекта, содержащий исходные текстуры для обработки. Вы можете просто перетащить папку из окна иерархии проекта в поле; - Нажмите кнопку
Build Atlas
и дождитесь завершения процедуры генерации; - Сгенерированные спрайты появятся внутри актива атласа; выберите любой из них и перейдите на сцену.
Опции поколения Atlas
Вы можете дополнительно настроить параметры создания атласа через окно инспектора редактора.
Опция | Описание |
---|---|
Размер сгенерированных данных | Общий объем данных сгенерированных спрайтов (вершины, UV и треугольники). Уменьшить за счет увеличения размера блока кубиков. |
Поворот по умолчанию | Относительное положение точки поворота в диапазоне от 0 до 1, считая от нижнего левого угла.Можно изменить после сборки для каждого спрайта индивидуально. |
Сохранить оригинал | Сохранять ли исходный поворот спрайтов (можно использовать для анимации). |
Разделение данных спрайтов | Следует ли сохранять ресурсы спрайтов в отдельной папке вместо добавления их в качестве дочерних элементов объекта атласа. |
Предельный размер Atlas | Максимальный размер одной сгенерированной текстуры атласа; будет генерировать несколько текстур при достижении лимита. |
Силовой квадрат | Сгенерированные текстуры атласа всегда будут квадратными. Менее эффективен, но необходим для сжатия PVRTC. |
пикселей на блок | Сколько пикселей в спрайте соответствует единице измерения в мире. |
Размер кубика | Размер одной нарезанной кубиками единицы. |
Прокладка | Размер границы пикселей, добавляемой между соседними нарезанными кубиками единицами внутри атласа.Увеличьте, чтобы предотвратить артефакты размытия текстуры (обычно появляются в виде тонких промежутков между нарезанными кубиками единицами). Большие значения потребуют больше места для текстуры, но дадут лучшие результаты по борьбе с просачиванием. В большинстве случаев рекомендуется минимальное значение 2. Когда 2 недостаточно, чтобы предотвратить кровотечение, рассмотрите возможность добавления немного UV Inset перед увеличением заполнения. |
УФ-вставка | Относительная вставка UV-координат нарезанных кубиками единиц. Может использоваться в дополнение к (или вместо) Padding для предотвращения артефактов размытия текстуры.Не будет занимать пространство текстуры, но более высокие значения могут визуально исказить конечный результат. |
Папка ввода | Папка ресурсов с исходными текстурами спрайтов. |
Включить вложенные папки | Следует ли рекурсивно искать текстуры во входной папке. |
Добавить имена | Добавлять ли имена спрайтов к имени подпапки; например: SubfolderName.SpriteName . |
Все приведенные выше описания доступны в виде всплывающих подсказок при наведении курсора на соответствующие параметры конфигурации в редакторе.
UI
Чтобы использовать нарезанные кубиками спрайты в пользовательском интерфейсе (например, компонент Image
), включите Use Sprite Mesh
.
Анимация
Для анимации можно использовать нарезанные кубиками спрайты. Не забудьте включить Keep Original Pivot
при создании атласа, чтобы сохранить относительные положения сгенерированных спрайтов. Пример анимации нарезанных кубиками спрайтов доступен в проекте в сцене «Анимация».
Unity Addressables и SpriteAtlas: как эффективно использовать спрайты
Используете ли вы в игре Unity UI или Sprite Renderers ?
Тогда вы, возможно, слышали о функции Unity SpriteAtlas…
SpriteAtlas помогает сократить количество вызовов отрисовки в игре при рендеринге пользовательского интерфейса или спрайтов в Unity.
Тем не менее, атласы спрайтов трудно приручить, они могут откусить вам руку.
Например, одна ссылка на спрайт SpriteAtlas заставит вас загрузить весь атлас в память , даже если вам нужен только один спрайт… или даже если вы не используете активно сам спрайт.
Просто ссылка может резко увеличить использование памяти и время загрузки.
Вы хотите, чтобы высказать свое мнение о том, как Unity управляет памятью вашего атласа спрайтов, чтобы вы не ограничивали бюджет производительности игры.
Что ж, вы можете сделать именно это, используя super Unity Addressables и SpriteAtlas wombo combo .
Могут ли они работать вместе?
Вы уверены, что могут.
TL; DR :
- Отметьте только свой SpriteAtlas как адресный актив
- Используйте AssetLoadAsync для загрузки определенного спрайта из адресуемого атласа спрайтов…
- Через AssetReferenceAtlasedSprite , ИЛИ
- Через жестко закодированную переменную путь, например « myspriteatlaskey [myspritename]
- Использовать адресацию.Отпустите, чтобы выгрузить спрайт.
Кто такой Ральф и почему Ральф в ярости?
Летом солнечный вторник.
Вы просыпаетесь и по какой-то причине чувствуете себя очень счастливым.
Вы так счастливы, что начинаете петь придуманную песню о том, как сегодня вы собираетесь улучшить архитектуру своей игры.
Решение принято. Вы больше не принимаете дерьмо.
Итак, вы читаете документацию и решаете, что делать дальше: вы собираетесь поместить тяжелые спрайты в один SpriteAtlas.
Вы думаете, что это, должно быть, отличная идея .
Как и ожидалось, вам удастся сократить:
- Вызовы Draw на 10x
- Использование памяти (RAM + Flash).
Итак, вы нажимаете кнопку отправить и прекращаете работу.
Это был отличный день… и вы награждаете себя пиццей с ананасами *.
* Моя итальянская подруга этого не одобряет.
Однако, когда вы собираетесь спать, ваш телефон звонит… громко.
«Чт… Кто это?» , спросите вы дрожащим голосом.
«Я твой босс, Ральф. Ты провалился в игру. Вы консервированы навсегда ».
Эти слова оглушают вас на очень долгие 5 секунд, теряя при этом одно очко выносливости.
«Ч… ай что ..?» Вы едва успеваете спросить, как по спине пробегает зловещий холод, а по лбу стекает холодный пот.
«Нет, шучу, тебя еще не уволили. Но давай сюда и исправь сбой, который происходит на экране счета », — говорит Ральф перед отключением.
Сильно трясясь с симптомами сибирской лихорадки, вы загружаете свой компьютер и ждете 10 минут, пока Unity загрузит ваш проект.
Нетерпеливый, вы попадаете на экран счета и БАМ.
Использование памяти резко возросло…
, потому что Unity загрузила весь атлас спрайтов в самый неподходящий момент.
После некоторой отладки вы поняли, что упустили единственную ссылку на спрайт, который даже не нарисовали.
Эта ссылка на спрайт была как раз там.
Улыбаясь вам.
Жду подходящего момента, чтобы навлечь на тебя неприятности.
И… тот спрайт действительно получил .
Но вы исправили это и усвоили БОЛЬШОЙ урок:
Проблема: поведение по умолчанию для Unity SpriteAtlas
Когда вы ссылаетесь на спрайт, который живет в SpriteAtlas, вы загружаете весь атлас в память, а затем используете конкретную область своего спрайта. берет.
Неоптимальная упаковка спрайтов и ссылки на них могут иметь неприятные побочные эффекты, такие как сбои и увеличение времени загрузки.
Первое, что вы захотите сделать в Unity при работе с атласами спрайтов, — это спроектировать ваши атласы спрайтов таким образом, чтобы максимизировала экономию ваших спрайтов .
Это означает, что вы хотите упаковать спрайты, которые вы используете одновременно.
Но даже если вы идеально упакуетесь спрайтами, у вас все равно могут возникнуть проблемы.
Например, вы можете загрузить весь атлас спрайтов слишком рано… когда вы действительно не можете себе этого позволить.
Представьте, что у вас есть сложная система пользовательского интерфейса с ТОННАМИ спрайтов и атласов спрайтов… такая игра, как The Sims с более чем 4000 расширений и миллионами различных спрайтов предварительного просмотра предметов.
Вот правда: вы не можете заплатить цену за одновременную загрузку всех этих атласов спрайтов в память. И все же вам нужно загружать их при определенных взаимодействиях с пользователем.
Плохие новости: простое обращение к ним на потом («на всякий случай») фактически сразу загрузит их в память, в результате чего злой финальный босс Ральф уволит вас.
Но вы можете сохранить свою зарплату: мы можем использовать Addressables для загрузки / выгрузки ваших спрайтов в атласы спрайтов по запросу , независимо от того, какие ссылки у вас есть.
Вкратце: позвольте вам выбрать, когда и как загружать эти атласы спрайтов.
Повышение уровня: Unity SpriteAtlas & Addressables
[Сначала проверьте преимущества Unity Addressables, если вы мало знаете об адресных объектах]
Загрузка / выгрузка спрайтов из атласов спрайтов становится простой с Addressables.
Просто отметьте SpriteAtlas (а не отдельные спрайты) как адресный актив.
Это комбинация wombo , которую вы ищете:
public class AddressableImage: MonoBehaviour
{
общедоступный AssetReferenceAtlasedSprite addressableSprite;
IEnumerator Start ()
{
var image = GetComponent ();
yield return new WaitForSeconds (6);
var asyncOperationHandle = addressableSprite.LoadAssetAsync ();
yield return asyncOperationHandle;
изображение.спрайт = asyncOperationHandle.Result;
yield return new WaitForSeconds (6);
image.sprite = null;
Addressables.Release (asyncOperationHandle);
}
}
Позвольте мне перевести это с C # на английский…
Он гласит:
Письмо в Unity
Уважаемый Unity,
Спасибо, что не загружаете этот атлас спрайтов автоматически, как по умолчанию.
Я знаю, что вы всегда говорите мне использовать Addressables, если я хочу контролировать жизненный цикл его памяти, так что именно это я и сделал (строка 3).
Теперь время пришло. Загрузите этот спрайт асинхронно (строки 11/14) и назначьте его этому благословенному изображению пользовательского интерфейса (строка 17).
Но не забывайте: через несколько секунд я попрошу вас выгрузить все это из памяти, когда она мне больше не понадобится (строка 22).
Спасибо,
Ваш счастливый подписчик на Unity Pro
Результат?
Вы, , платите цену только , когда она вам действительно нужна, потому что Addressables позволяет вам управлять этой памятью самостоятельно.
Сделать это теперь проще, чем когда-либо, благодаря возможности ссылки на подактив (как в инспекторе, так и в коде).
Используя адресацию со спрайтовыми атласами, вы сократите количество вызовов отрисовки и время загрузки.
Более высокая производительность, в свою очередь, привлечет ваших игроков к вашей игре.
Что дальше?
Если вы хотите узнать больше о разработке высокопроизводительных игр, которые уважают границы вашей памяти, прочтите мою публикацию Unity Addressables Tutorial.
Отличный, обещаю.
Happy #gamedev
~ Ruben
спрайтов, документация TextMesh Pro
TextMesh Pro позволяет включать спрайты в текст с помощью тегов форматированного текста. Спрайты представляют собой обычные растровые текстуры, поэтому убедитесь, что их разрешение достаточно высокое.
Sprite Asset
Для использования спрайтов необходим атлас текстур. TextMesh Pro использует собственные ресурсы для управления ими. Вы можете использовать столько атласов спрайтов, сколько захотите, но имейте в виду, что использование нескольких атласов для каждого текстового объекта приводит к множественным вызовам отрисовки для этого объекта.Таким образом, вы обычно используете один атлас.
Создание объекта-спрайта
Во-первых, вы должны предоставить текстуру атласа спрайтов. Его тип текстуры должен быть Sprite (2D и UI) , а его Sprite Mode должен быть Multiple .
Атлас спрайтов.
Используйте Unity Sprite Editor , чтобы разделить текстуру на отдельные спрайты.
Импортируйте настройки ресурса спрайта по умолчанию.
Затем вы можете создать новый актив через Asset / Create / TextMeshPro — Sprite Asset .Вы должны сделать это при выбранном атласе текстуры. Это создает новый актив спрайта на основе выбранной текстуры. Вы должны сохранить эту исходную текстуру, но вы можете изменить ее тип обратно на обычную текстуру, потому что данные спрайта Unity больше не нужны.
Использование спрайтов
Чтобы использовать ресурс спрайта, поместите его в папку Resources / Sprites . Это позволяет TextMesh Pro найти его. Вы также можете настроить один ресурс спрайта в качестве источника по умолчанию для спрайтов.
Актив Sprite.
Ресурс спрайта сохраняет ссылку на свою исходную текстуру. У него также есть собственный материал, который используется для рендеринга спрайтов.
Список спрайтов
Здесь вы можете просмотреть данные каждого спрайта в атласе и при необходимости скорректировать их. Список спрайтов разделен на страницы, по которым вы можете перемещаться с помощью кнопок вверху и внизу. Вы также можете отфильтровать список по именам спрайтов. Щелкните запись, чтобы сделать ее активной.Это позволяет редактировать, копировать и удалять его.
Актив спрайта по умолчанию.
Имя спрайтов сгенерировано автоматически. Вы можете изменить их на все, что захотите, но обязательно сделайте их уникальными. Вы можете использовать эти имена для идентификации спрайтов с помощью тегов форматированного текста, помимо их идентификатора.
Значения X , Y , W и H определяют прямоугольную область персонажа в атласе спрайтов. Смещения OX и OY управляют размещением спрайта, определяемым в его верхнем левом углу относительно его исходной точки на базовой линии.Значение ADV определяет, как далеко продвинуться вдоль базовой линии перед размещением следующего глифа. Наконец, SF — это масштабный коэффициент, который вы можете использовать для регулировки размера спрайта.
Гамасутра: Блог Рубена Торреса Бонета
Следующее сообщение в блоге, если не указано иное, было написано членом сообщества Гамасутры.
Высказанные мысли и мнения принадлежат автору, а не Gamasutra или ее материнской компании.
[Прочтите исходное сообщение в блоге на Unity Sprites: плотно прилегающие или полностью прямоугольные?]
Что выбрать для спрайтов в Unity: плотно прилегающий или полный прямоугольник ?
Вы знаете, эти графические элементы вы используете во ВСЕХ своих играх …
В конце концов, вы, скорее всего, используете рендереры спрайтов. Или, по крайней мере, изображения пользовательского интерфейса.
В этом посте вы узнаете разницу между этими двумя типами сеток.И когда использовать каждый.
Больше никаких предположений. Точно знайте, что делаете.
СОДЕРЖАНИЕ
1 Что такое тип сетки спрайтов?
2 Почему полно-прямоугольные спрайты Unity не так уж хороши
3Are Tight Sprites Superior?
4 (Несколько) причин для использования полно-прямоугольных спрайтов
5Что дальше?
Что такое тип сетки спрайтов?
Прежде чем мы начнем, я говорю об этом:
Unity Sprite Mesh Тип
Я знаю, это вариант, на который легко не обращать внимания.В конце концов, у вас есть много опций в настройках импорта спрайтов.
Тип сетки спрайта — это то, как Unity будет отображать ваш спрайт в вашей игре.
Традиционный способ их рендеринга — full rect mode. Это означает, что ваши спрайты визуализируются как полный четырехугольник с прозрачными областями.
Unity Sprite: прямоугольная сетка
Однако более эффективный подход — это построить более плотную сетку вокруг вашего спрайта .
Это означает, что вы будете визуализировать свой спрайт не как прямоугольник, а как двумерный многоугольник.
Итак, зачем вам создавать более сложные формы?
Посмотрим, почему.
Почему полно-прямоугольные спрайты Unity не так уж хороши
Хорошо, первое самое большое преимущество рендеринга полных четырехугольников …
Рисовать квад так же легко, как дышать. И для вашего процессора, и для вашего графического процессора.
Но вот самый большой недостаток …
При рисовании полных квадратов вы визуализируете обширную поверхность, полную прозрачных фрагментов .См. Предыдущее изображение: все, что находится вне круга, прозрачно … но также визуализировано.
Проблема?
Рендеринг большой поверхности влечет за собой серьезную перерисовку.
И перерисовка — один из самых серьезных убийц производительности.
Overdraw всегда охотится за невинными играми, чтобы убить их частоту кадров. Особенно опасно это на мобильном телефоне.
Что может быть лучше, чем рендеринг полного прямоугольника?
Ну, рендеринг многоугольника, который лучше соответствует вашему спрайту.Другими словами, делаем нашу форму немного более плотной 🠙 ‚
Являются ли плотные спрайты лучше?
Вы можете установить тип сетки как плотный в любом из ваших спрайтов.
Фактически, в настоящее время это должно быть значение по умолчанию.
Когда вы это сделаете, Unity нарежет ваши спрайты, чтобы вы минимизировали прозрачную область, которую вы визуализируете.
Unity Sprite: плотная сетка
Вы визуализируете меньше пикселей. Ваша графическая карта благодарит вас за более высокую частоту кадров.
Отличная сделка.
Примечание: чтобы использовать плотные сетки в изображениях пользовательского интерфейса, вам необходимо активировать опцию « Use sprite mesh » в компоненте изображения пользовательского интерфейса (кредиты yasirkula). Доступно с 2018.3.
(Несколько) причин для использования полноразмерных спрайтов
Обычно бывает ОЧЕНЬ немного случаев, когда вы должны использовать полные протезы.
Но вот несколько:
- Производительность вашей игры составляет с привязкой к вершинам , и у вас много спрайтов на экране.
- Ваша платформа практически не страдает от проблем с отрисовкой.
Это окупается, если отрезает прозрачные области от ваших спрайтов настолько сильно, насколько это возможно.