Areaportal/ru

From Valve Developer Community
Jump to: navigation, search
Toolsareaportal.gif
Открытый areaportal (зелёный контур).
Закрытый areaportal.

Areaportal (ареа-портал) — брашевая сущность, func_areaportal, func_areaportalwindow, которую можно использовать для 'изолирования' листьев и управления видимостью.

Ареа-порталы служат двум разным целям: усечению геометрии и удалению целых областей из отрисовки.

Ареа-порталы похожи на дверные проёмы, которые либо открыты, либо закрыты. Когда Areaportal закрыт, он блокирует видимость геометрии и объектов, расположенных в области за ним. Когда он открыт, геометрия становится видимой. Ареа-порталы можно динамически открывать и закрывать во время игры. Обычно, они настраиваются на открытие и закрытие набором брашей trigger_multiple с помощью системы ввода/вывода или связыванием с сущностью двери.

Свойства

trigger_multiple можно использовать для открытия и закрытия ареа-порталов, чтобы скрывать зоны на уровне.

Ареа-порталы:

  • связаны с сущностью func_areaportal;
  • должны состоять только из одного браша. Иначе, они будут выдавать ошибку компиляции vbsp;
  • должны использовать материал tools\toolsareaportal, покрывающий все стороны браша;
  • не должны содержать деформированных поверхностей, иначе будет выдана ошибка vbsp;
  • должны использоваться для запечатывания всех зон, с которыми соприкасаются, чтобы избежать утечек;
  • это объём, а не отдельные поверхности. Ареа-порталы могут быть любого размера, но обычно они состоят из тонких брашей по размеру зон (дверных проёмов), которые они соединяют;
  • создают новый вис-лист по своему объёму;
  • можно настроить на открытие или закрытие, в зависимости от логики сущности, или путём преобразования их в сущность двери.

areaportal_window

Сущность func_areaportalwindow ведёт себя как обычный ареа-портал, с добавлением затухания и закрытия в зависимости от удалённости игрока. Это позволяет избежать «резкого» открытия ареа-портала.

Конструкция

Конструкция основного ареа-портала.
  1. Создайте объём из одного браша, полностью запечатав пространство между двумя зонами, которыми вы желаете управлять. Это может быть несколько ареа-порталов, соприкасающихся гранями. Не создавайте порталы с более, чем шестью сторонами.
  2. Если портал соединяет две области, например, дверной проём, сделайте браш размером с него, и такой же толщиной, как и стены, с которыми он соприкасается. Если область представляет собой открытое пространство, то толщина может быть любой (типичные размеры сетки: 8, 16, 32 и т. д.).
  3. Наложите материал Tool textures#Optimisation tools\toolsareaportal на все грани браша.
  4. Преобразуйте браш в сущность func_areaportal или func_areaportalwindow.
  5. Установите значение ключа Initial State (изначальное состояние) так, чтобы оно не блокировало видимость, когда этого не должно быть. Если нужно связать портал с наименованной дверью, установите его Initial State в то же состояние, что и для двери, и внесите имя двери в строку портала Name of Linked Door (имя связываемой двери). Если дверь закрыта, изначальное состояние портала также должно быть закрытым, и наоборот.
PlacementTip.png Совет по размещению: Если ареа-портал связан с наименованной дверью, убедитесь, что он тоньше, чем сама модель двери, иначе её не будет видно, когда портал будет закрыт.

Влияние на производительность

Отрисовка каркаса ареа-портала в движке. Рисуется только та геометрия листьев, которая видна через ареа-портал. Та же сцена с отключённым ареа-порталом. Отрисовывается вся геометрия листьев.

Открытые порталы (не важно, открыты они всегда, или же по команде) ведут себя, как шторки для видимой сквозь них геометрии. Подобно окну дома, движок отрисовывает только те листья, которые непосредственно видны через портал. То есть, область за ним обрезается по размеру окна, уменьшая величину отображаемой геометрии и улучшая производительность. Вдобавок ко всему, часть модели (prop) вообще не отрисовывается, когда она видна под усечённым конусом (или видимым углом). Это делает открытые порталы весьма полезными для управления видимостью геометрии моделей.

Открытый Areaportal сильно ограничивает видимость модели.

Благодаря таким преимуществам в производительности, ареа-порталы часто используются в состоянии всегда открыт. Всегда открытый портал создаётся путём установки ключа "Initial State" (изначальное состояние) сущности func_areaportal в значение «Open» (открыт). Открытые порталы используются на входе в другие области, содержащие большое число листов и геометрии. Например, такой портал, размещённый в конце коридора, выходящего на более широкое пространство, может дать существенный прирост производительности. Пока игрок смотрит сквозь дверь изнутри, будут отрисовываться только те листья с геометрией, которые видны непосредственно через проём.

Излишества

Будьте осторожны, и не создавайте слишком много видимых порталов. Каждый из них съедает ресурсы, и если портал отсекает недостаточно деталей, отрисовка сцены без него ускорится!

На скомпилированной карте ареа-порталы не образуют брашей, поэтому нет ограничений на их размер. Это может быть полезно, когда у вас переполненный BSP и вы используете множество Hint-брашей.

Компиляция

Вид сверху на утечку ареа-портала (слева) и полностью герметичную область (справа).

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

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

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

Обнаружение ошибок компиляции

Ошибки компиляции ареа-порталов выводятся функцией VBSP. Если произойдёт утечка, вы увидите это:

Brush <brush number>: areaportal brush doesn't touch two areas
done

(Браш <номер браша> не касается двух областей). Порой, такие сообщения обнаружить труднее, чем сообщения об утечке, но vbsp создаёт pointfile, который делает поиск местоположения утечки порталов таким же простым, как и поиск обычных утечек геометрии.

Icon-Bug.pngОшибка:Если на вашей карте нет таких сущностей, как, например, info_player_start, ареа-порталы (да и, в общем, остальная часть карты) будут создавать странные утечки. Чтобы этого избежать, убедитесь, что на вашей карте есть хотя бы одна сущность.
Tip.pngСовет:Приложение glview можно использовать для отображения ареа-порталов, которые будут показаны как серые поверхности. (Инструмент устарел, и не рекомендуется к использованию).

Ареа-порталы и вода

Создавая ареа-порталы с водой, нужно использовать два отдельных ареа-портала.

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

Объединение

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

Tip.pngСовет:Чтобы посмотреть, объединены или нет порталы в движке, наберите в консоли команду r_DrawPortals 1.

Сквозной взгляд

Видимость между первым и вторым листом остаётся неизменной.

Ареа-порталы отсекают только те области, между которыми они расположены. Посмотрите на рисунок справа: отбрасываются только помещения внутри здания, а видимость между первым и вторым листом сохраняется, поскольку они соединены по краям.

Это можно исправить, поставив два ареа-портала по краям здания.

Консольные команды

Вы можете отлаживать и тестировать порталы прямо в игре, используя некоторые специфичные для них консольные переменные:

r_DrawPortals 0/1
Если установлено значение "1", границы портала (между двумя областями) окрашиваются в зелёный цвет. Иногда несколько порталов объединяются в один. Если портал открыт, рисуется вторая зелёная коробка, показывающая отсекаемое пространство.
mat_wireframe 0/1/2/3
Рисует геометрию в виде каркаса, что позволяет легко видеть эффекты ареа-порталов на карте. Лучше всего использовать значения "1" или "2", так как параметр "3" может скрыть фактически отрисовываемую геометрию.
r_portalscloseall 0/1
Значение "1" принудительно закрывает все порталы (без возможности их открыть). Отменяется переменной r_portalsopenall 1. (Пробуйте это, когда кажется, что порталы зависли. Помогает понять, глючит ли их закрывание.)
Note.pngПримечание:Этой команды не существует в: Team Fortress 2 Counter-Strike: Global Offensive
r_portalsopenall 0/1
Значение "1" принудительно открывает все порталы (без возможности их закрыть).
Tip.pngСовет:Используйте консольную команду BindToggle, чтобы разрешить переключать консольные переменные одной клавишей.

В многопользовательском режиме

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

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

Относительно окклюдеров

Ареа-порталы похожи на окклюдеры в том смысле, что они помогают управлять видимостью. Их основные отличия:

  • Окклюдеры скрывают только геометрию моделей (prop). Ареа-порталы скрывают все объекты.
  • Ареа-порталы должны полностью запечатывать область (не допускать утечки), в то время как окклюдеры могут стоять где угодно внутри области.
  • Окклюдеры более затратны на объект, чем открытые ареа-порталы.
  • Окклюдеры имеют элементы управления размером объектов, которые они будут скрывать, в зависимости от площади экрана.
Note.pngПримечание:Браши ареа-порталов и окклюдеров не должны пересекаться (соприкасаться), иначе они будут работать неправильно.

См. также