Наклейки

From Valve Developer Community
< Ru
Jump to navigation Jump to search
English (en)Русский (ru)Translate (Translate)
Info content.png
This page has not been fully translated.

You can help by finishing the translation.

Also, please make sure the article tries to comply with the alternate languages guide.
Наклейка, размещенная создателем карты мира.
Следы от пуль сгенерированные игрой автоматически.

Когда игрок стреляет из своего оружия в стену, на ней остается след, который называется наклейка (decal). Легче всего представить это как невидимый объект, прикрепленный к поверхности. Плакаты, дырки от пуль, буквы на стенах могут быть созданы с помощью наклеек. Наклейки "прилипают" к объектам, на которые они помещены. К примеру налейка на лестнице каскадом спроецируется вниз, а не будет висеть в воздухе. Вы можете так же использовать наклейки для нанесения трафаретных букв на стены, чтобы помечать какие-либо места на вашей карте.

Note.pngПримечание:Каждая наклейка влияет (проецируется) только на один объект (мир(en) - это тоже один большой объект)

Создать наклейку не сложно: это обычный материал, у которого есть альфа-канал и который использует DecalModulate(en) шейдер.

До того как читать дальше эту статью, рекомендуем вам ознакомится со статьей про создание материалов(en).

Обычные наклейки

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

Исходные цвета Исходный альфа-канал Наклейка в игре

Параметры материала

Настройки материала(en) для наклейки выглядят примерно так:

LightmappedGeneric(en)
{
	$basetexture(en)	decals\mydecal
	$decal		1
	$decalscale	0.1
	$translucent(en)	1

	$modelmaterial decals\mydecal_model
}
$decal <bool(en)>
Помечает материал как наклейку. Без этой метки найклейку нельзя будет прикрепить к объекту и спроецировать на него.
$decalscale <float(en)>
Параметр, который отвечает за разрешение наклейки. По умолчанию 1 пиксель изображения принимается за один дюйм в игре. Если исходная текстура наклейки 128 пикселей по ширине, то её ширина в игре при настройке $decalscale 0.1 будет 12.8 дюймов в игре.
Tip.pngСовет:Наклейка не может быть отображена с бо́льшим разрешением, чем поверхность к которой она прикреплена. Оверлеи(en) могут, но они сильнее нагружают процессор.
$translucent <bool>
См. $translucent(en).
$modelmaterial <material>
Материал VertexLitGeneric(en), который будет применяться к моделям.
$decalfadeduration <float>
Время исчезновения наклейки. Требует $vertexcolor(en).
$decalfadetime <float>
Задержка перед исчезновением наклейки.
$decalsecondpass
Если выключено, то всегда рендерить эту наклейку поверх остальных. Если две наклейки с этим параметром установленным в true пересекаются, то они ведут себя также, как наклейки без этого параметра.
$fogscale <float>
Note.pngПримечание:Найдено в L4D2 decals/checkpoint01_black.vmt (использует DecalModulate шейдер)

Наклейки не поддерживают $bumpmap(en) и $envmap(en).

Наклейки на моделях

Note.pngПримечание:Наклейки, которые должны проецироваться на модели(en) (например кровь) должны использовать VertexLitGeneric(en) или DecalModulate(en) шейдер. LightmappedGeneric(en) будет работать только с элементами мира(en).

Hammer

  • Наклейки могут быть помещены на браши(en) в Hammer с помощью инструментов оверлеев(en) или декалей(en). Эти наклейки будут отображаться сразу после загрузки карты.
  • Объект info_projecteddecal(en) может быть использован для проецирования наклейки на любые браши или модели.

C++

Наклейки могут быть созданы на клиенте с помощью функции C_BaseEntity::AddDecal(). Изнутри она вызывает AddStudioDecal() или AddBrushModelDecal() в зависимости от того, является ли энтити брашем или моделью. Параметры для этих функций:

void C_BaseEntity::AddDecal( const Vector& rayStart, const Vector& rayEnd, const Vector& decalCenter,
				int hitbox, int decalIndex, bool doTrace, trace_t& tr, int maxLODToDecal );

void C_BaseEntity::AddBrushModelDecal( const Ray_t& ray, const Vector& decalCenter,
				int decalIndex, bool doTrace, trace_t& tr );

void C_BaseEntity::AddStudioDecal( const Ray_t& ray, int hitbox, int decalIndex,
				bool doTrace, trace_t& tr, int maxLODToDecal );

Это может быть достигнуто и на сервере с помощью функции engine->StaticDecal:

void IVEngineServer::StaticDecal( const Vector &originInEntitySpace, int decalIndex, int entityIndex, int modelIndex, bool lowpriority );

Индексы наклеек могут быть получены вызовом decalsystem->GetDecalIndexForName или UTIL_PrecacheDecal():

int IDecalEmitterSystem::GetDecalIndexForName( char const *decalname ); // Действующие имена наклеек определены в scripts/decals_subrect.txt
int UTIL_PrecacheDecal( const char *filename, bool preload );

Использование модуляции

Для наклеек, предназначенных для имитации выбоин или вмятин на поверхности, шейдер DecalModulate(en) (mod2x) оказывается крайне подходящим: он осветляет целевые пиксели для каждого исходного пикселя, который имеет цвет светлее серого (>128), и затеняет целевые пиксели для каждого исходного пикселя, который имеет цвет темнее серого. Этот эффект может быть использован для придания ощущения глубины, при применении к поверхности.

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

Далее, создайте альфа-канал, который будет определять маску для наклейки. Так как модуляция не может иметь точное среднее значение корректно, маска обязательна для предотвращение появления границы (обводки) вокруг наклейки.

Tip.pngСовет:You can avoid "bordering" without creating an alpha channel simply by using BGR888 format instead of DXT1 when you create your VTF. Left 4 Dead 2 It has also been observed in Left 4 Dead 2(en) that DXT1 compressed textures using DecalModulate shader (such as blood splatters and "graffiti wall writing") with background colors RGB 124 126 124 are considered alpha, alleviating "bordering". L4D2's vtex(en) will output that specific color from the source image pixels are gray RGB 127 127 127. This solution may also apply to other engines (and other versions of vtex) that use RGB 124 126 124 as the color indicating alpha in-game, but needs further testing.
Нужно сделать: Try converting source images with background colors RGB 127 127 127 with vtex found in other games other than L4D2 and see if it results in a background with RGB 124 126 124. Also, does RGB 124 126 124 apply to other versions of the Source engine as alpha for DXT1 compression?
Исходные цвета Исходный альфа-канал Наклейка в игре

Наконец, вы должны создать материал, который использует DecalModulate(en) шейдер. Ни $translucent, ни $decal в этот раз не понадобятся.

См. также