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

«В Waves of Steel пауза замедляет игру в 0,000000001 раза от обычной скорости», — рассказал в BlueSky разработчик Крис Уайсигер. «Иными словами, для того, чтобы в игре прошла одна секунда, потребуется три года реального времени. Я сделал так, потому что слышал, что у Unity есть специальное поведение, когда скорость игры равна на 0, и хотел его избежать».
«Я создаю хобби-проекты на Unreal Engine, и иногда поступаю немного глупо», — поделился в соцсетях Томми Хануса. «Я устанавливаю масштаб времени на .000001, чтобы игрок/тестировщик мог выйти из паузы и полетать по игровому миру (с безумной скоростью примерно в 5000000) на случай, если он захочет мне что-нибудь показать».
Многие разработчики говорили мне, что они просто при нажатии на паузу устанавливают масштаб времени на 0, при этом обеспечивая обычную работу некоторых функций, например, UI меню.
Так много оттенков

У пауз есть и ещё один аспект, о котором я не задумывался: существуют разные типы пауз. Например, при нажатии на кнопку Start игра может встать на паузу и показать меню паузы. Но что, если игрок отключил контроллер? Что, если он открыл инвентарь игры? Что, если он нажал на кнопку гида Xbox и перешёл к гиду? Существуют разные виды пауз, а в некоторых играх их целая куча.
«Во Frontier я работал над разными играми, в том числе над Kinectimals для Xbox 360», — написал мне на почту разработчик Эндрю Джиллет. «Лично я не занимался этой частью игры, но припоминаю, что у нас было примерно семь разных уровней «паузы». Например, игра должна была вставать на паузу при отключении камеры Kinect и на другой тип паузы, когда игрок открывал системное меню Xbox».
Пользователь BlueSky Dreamless рассказал, что эти разные виды пауз могут вызывать у разработчиков серьёзные проблемы.
«В эпоху Xbox/PS2 мы реализовали паузу для обычного геймплея с исключениями, не позволяющими ставить игру на паузу во время QTE и тому подобного. Когда настала пора выпускать игру, мы прочитали чеклисты технических требований и вынуждены были добавить особую паузу для ситуации, когда игрок отключает контроллер. Эти две паузы конфликтовали и приводили к багам».
Фотокарточку нежно храню
Наверно, мой любимый способ реализации паузы — заморозка времени и создание скриншота экрана, который игра потом использует в качестве фона UI меню паузы, что позволяет разработчикам выполнять под прикрытием этого изображения всякие махинации, например, не рендерить врагов или вообще перенести игрока в пустую комнату.
«Обычно я делаю скриншот геймплея в момент нажатия на паузу, а затем отрисовываю его под всем, что есть в меню паузы, без отрисовки самих объектов. В основном это делается для освобождения памяти, но на самом деле это не так уж необходимо для того стиля игр, которые я делаю» — делится разработчик DW O’Boyle.
«В большинстве игр студии Vlambeer и Minit / Disc Room я делаю скриншот (с отключенным UI), а затем или перемещаюсь в совершенно другую пустую комнату, или деактивирую всё, оставив скриншот в качестве фона. При снятии с паузы происходит возврат к местоположению игрока. Иногда возникает задержка в один кадр, потому что для скриншота нужно отключить UI», — пишет Ян Виллем Нийман.
Когда один из комментаторов отметил, что этот трюк всегда казался ему «грязным хаком», Нийман сказал, что во всех играх, над которыми он работал, использовалась «приличная доля таких хаков».
Все когда-то совершают ошибку
Для меня важным выводом из всех этих ответов стало то, что в общем случае пауза в игре — не самая сложная фича в работе над проектом. Однако всё равно стоит с умом подходить к её реализации и обеспечивать достаточный объём тестирования, если в игре есть особенности, которые могут вызывать проблемы в случае приостановки времени.
Разработчик Калибан Дарклок сообщил мне в Bluesky, что на ранних этапах своей карьеры многие создатели игр ошибаются при реализации функции паузы, что может приводить к проблемам, но и становится важным моментом обучения.
«Когда я впервые реализовывал паузу в игре, каждый игровой объект в каждом кадре проверял, включена ли пауза, что снижало производительность во всей игре. Сегодня все мои объекты выстроены в иерархию, а состояние паузы проверяет только один объект на её вершине».
«Когда большинство разработчиков реализует паузу впервые, они создают неуклюжие, кошмарные системы, зато уясняют этот урок на всю оставшуюся жизнь».
ссылка на оригинал статьи https://habr.com/ru/articles/1026940/