Разработка модулей мультиплеера для совместного VR опыта

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

От иммерсивных приложений до игровых миров и 3D-сцен

Наша выделенная команда для VR/AR/MR-разработки, Unity-продакшна и 3D-моделирования и анимации с собственными кейсами и презентациями.

Посетить персонализированный сайт
Показано 1 из 1 услугВсе 242 услуг
Разработка модулей мультиплеера для совместного VR опыта
Сложная
~2-4 недели
Часто задаваемые вопросы
Наши компетенции
Какие этапы разработки игры?
Последние работы
  • image_games_mortal_motors_495_0.webp
    Разработка игры для компании Mortal Motors
    671
  • image_games_a_turnbased_strategy_game_set_in_a_fantasy_setting_with_fire_and_sword_603_0.webp
    Пошаговая стратегия в фэнтези сеттинге With Fire And Sword
    860
  • image_games_second_team_604_0.webp
    Разработка игры для компании Second term
    490
  • image_games_phoenix_ii_606_0.webp
    3D-анимация — тизер для игры phoenix 2.
    533

tags: [vr-ar]

Разработка модулей мультиплеера для совместного VR опыта

Мультиплеер в VR — это не просто синхронизация позиций и состояний. Это синхронизация двух рук, головы, взгляда, захватов, физических объектов — всё одновременно, с латентностью не более 50–80 мс, иначе пользователи видят «дёрганые» аватары и теряют ощущение совместного присутствия. При этом всё это должно работать на мобильном железе Quest с ограниченной пропускной способностью.

Готовые сетевые решения — Photon Fusion, Photon PUN2, Mirror, Netcode for GameObjects (NGO) — каждое имеет свои компромиссы для VR. Выбор стека на старте определяет архитектурные решения на весь проект.

Photon Fusion и VR: почему Server Mode лучше Shared Mode

Photon Fusion поддерживает два режима: Shared Mode (peer-to-peer с одним хостом) и Server Mode (выделенный сервер Photon). Для VR предпочтителен Server Mode, даже если проект небольшой.

В Shared Mode один из игроков — хост, и через него проходит весь трафик. В VR это означает: если хост двигает руки (а он делает это 72–90 раз в секунду), его собственные данные обрабатываются локально, а остальные игроки получают их с RTT хоста. При нестабильном соединении хоста вся сессия страдает. В Server Mode нет единой точки отказа — Photon Cloud берёт на себя ретрансляцию и авторитетную обработку состояний.

Конкретная настройка: NetworkRunner с GameMode.Server, FixedUpdateNetwork вместо Update для детерминированной физики. Для трансформов рук используем NetworkTransform с InterpolationDataSource.Predicted — предсказание на стороне клиента снижает воспринимаемую латентность.

Синхронизация аватаров: IK и скрытие собственного тела

Главная техническая проблема VR-аватаров в мультиплеере — у других игроков есть full body avatar с анимацией, у локального игрока его нет (он видит только руки от первого лица). Синхронизировать нужно позиции головы и двух кистей — и из этих трёх точек восстановить позу тела для других игроков.

Решение — Full Body IK с ограниченным числом контрольных точек. В Unity это Animation Rigging package с TwoBoneIKConstraint для рук и MultiParentConstraint для туловища. Голова (HMD position) → туловище через эвристическое смещение вниз (~0.3 м) → руки через IK к позициям контроллеров. Это не физически точно, но убедительно выглядит при нормальных движениях.

Сетевой трафик: три трансформа (голова + 2 руки) × 7 floats (pos + rot) × 90 fps = ~7.5 KB/s на игрока без компрессии. С NetworkTransform и квантизацией в Photon Fusion — 1.5–2 KB/s. При 4–8 игроках — управляемо.

Синхронизация физических объектов

Подбираемые предметы, бросаемые объекты, двери — всё это физические риджидбоди. Фундаментальная проблема: у двух игроков физика симулируется независимо, и результаты расходятся. Один игрок кинул кубик в стену — у него он отскочил вправо, у второго — влево.

Подход 1: авторитетная физика на сервере. Все Rigidbody симулируются только на StateAuthority (в терминах Photon Fusion — у того, кто захватил объект). Остальные игроки интерполируют позицию. При захвате объект «передаётся» новому держателю через RequestStateAuthority. Минус — при передаче видна небольшая телепортация, если позиции разошлись.

Подход 2: клиентская физика с reconciliation. Каждый клиент симулирует физику локально, сервер периодически рассылает авторитетное состояние. При расхождении более порога — мягкое смещение к авторитетной позиции через Lerp. Лучше выглядит, но сложнее реализовать без артефактов.

На практике для VR-игр с физическими взаимодействиями используется подход 1 с добавлением ghost объекта — тонкой полупрозрачной копии, которая показывает авторитетную позицию, пока основной меш интерполируется.

Процесс разработки

Мультиплеерный модуль — отдельная задача, которую лучше закладывать на этапе архитектуры, а не добавлять к готовой одиночной игре. Ретрофит мультиплеера в готовый синглплеерный VR-проект — обычно +50–70% трудозатрат по сравнению с разработкой с учётом мультиплеера с начала.

Этапы: выбор сетевого стека и архитектуры → базовая синхронизация трансформов → аватары с IK → синхронизация физических объектов → игровая логика (очки, состояния, раунды) → тестирование под нагрузкой → оптимизация трафика.

Масштаб задачи Ориентировочные сроки
Базовый мультиплеер (2–4 игрока, только трансформы) 2–4 недели
Полноценные аватары с IK + физика объектов 6–10 недель
Масштабный мультиплеер (8+ игроков, кастомная логика) 3–6 месяцев

Стоимость рассчитывается после анализа требований: число игроков, тип взаимодействий, выбор платформы (Quest standalone, PCVR, кроссплатформа).