Как скопировать тайминг рошана в доте 2
Рошан — самый сильный нейтральный крип на карте, который живет в рошпите на реке между силами света и тьмы.
После смерти Рошана выпадает Аегис, затем через некоторое время Рошан возрождается — с Аегисом и сыром. Затем к Аегису и сыру прибавляется Рефрешер или Аганим.
Чаще всего Рошан убивается всей командой после успешного файта на 13-15+ минутах игры. Тролль или Урса могут забирать Рошана в одиночку, при наличии необходимых предметов.
Автоматизация рутины в DotA 2 или читы?
Привет, в этой статье будут рассматриваться легальные способы получить преимущество перед противником с помощью таких простых средств, как NodeJS, Electron и React, при этом обходя бан стороной. На эксперименты меня вдохновила другая статья Визуализация времени возрождения Рошана и желание автоматизировать часть рутины. Стоит заметить что сейчас будут рассматриваться инструменты не модифицирующие каким либо нечестным способом игру - все API открыты, данные получены честным путём, никакого вмешательства в процесс игры не происходит. Под катом будет несколько картинок и немного кода.
Пример использования в демо режиме игры
Весь исходный код расположен на Github, с ним можно ознакомится, лайкнуть, форкнуть, предложить изменения. Писал его левой пяткой правой ноги, прямо во время игры, поэтому просьба не ругаться сильно за стилистику.
Если честно, то я ничего нового не придумал, уже всё до меня придумали и даже есть готовые приложения, которые примерно тоже самое умеют.
Дальнейшими знаниями можно пользоваться, как во имя добра - делать инструменты для студий аналитики, киберспорта, стримов Twitch, тренировок команд и т.д., так и во имя зла - написания читов, выбор за вами.
Disclaimer: Автор не несёт ответственности за применение вами знаний полученных в данной статье или ущерб в результате их использования. Вся информация здесь изложена только в познавательных целях. Особенно для компаний разрабатывающих MOBA, чтобы помочь им бороться с читерами. И, естественно, автор статьи ботовод, читер и всегда им был.
В итоге созданные инструменты умеют:
Отслеживать игровое время
Воспроизводить звуки до начала важных событий
Отображать текущие показатели золота (GPM)
Отслеживать время возрождения рошана
Собирать данные о любимых героях противника
Какие ещё можно сделать улучшения:
Отображать историю средних показателей противника
Добавить ретроспективный анализ игры по её окончанию
Добавить больше звуковых/визуальных уведомлений
Дать возможность отслеживать "ультимейты"
Добавить больше визуальных данных во время просмотра киберспортивных игр
Добавить подробнейшие руководства прямо во время игры
С чего всё начиналось
У Dota 2 неожиданно есть GSI (Game State Integration), который придумали для интеграции сторонних приложений / оверлеев (наложение картинки поверх игры) и синхронизации этих самых оверлеев с игрой в реальном времени. Это говорит о том, что можно получать состояние игры и дальше что - то с ним делать. Для интеграции с NodeJS есть готовое решение в виде библиотеки. Для работы GSI сервера, в первую очередь, нужно создать файл конфигурации в "Steam\steamapps\common\dota 2 beta\game\dota\cfg", в этом файле прописываются настройки, например, такие:
Собственно, после запускается код слушателя, который как раз и позаимствован из сторонней библиотеки NodeJS
Сервер получения данных об игровом мире готов.
Данные, которые не дают преимущества
Во время рейтингового матча в Dota 2, GSI отдаёт обрезанные данные, из полезного доступно
Прошедшее количество секунд с начала игры
Игровое время в секундах
Если просматривать реплей или чужую игру, то доступно гораздо больше информации - вся она описана тут. Что-ж, самая важная информация нам уже доступна - GPM, игровое время, Id героя.
После получения информации мы должны с ней что - то поделать, например, отрисовать или предупредить о наступившем моменте в игре.
UI, Оповещения, Electron
Для UI решено было использовать Electron и внутри этого электрона запускать React. Идея заключается в том, чтобы рисовать Electron приложение поверх игры (оверлей). Исходник оверлея можно найти тут, немного задержимся на нём - есть пару особенностей.
Для начала нужно настроить окно, в котором будет всё отображаться:
Сначала у меня не получалось поверх доты что - то вывести, пока не наткнулся на настройку в файле machine_convars.vcfg (Dota 2) под названием "dota_mouse_window_lock", которую нужно выставить в "0", а в самой игре (либо в тех же файлах конфигурации) настроить режим отображения в окне без рамки.
UI написан с использованием React, поэтому решено его было загружать прямо с dev сервера разработки (да, я ленивый):
Если dev сервер не успел загрузиться, то мы попробуем ещё разок через 3 секунды, вот для этого и нужен setTimeout.
Всё, с overlay закончили, теперь UI часть.
Styled-Components, Typescript, Хуки, - стильно, модно, молодёжно
В UI был выбран мой любимый стек: TS, CRA (Styled только для одного/двух классов использовался - рисовать то особо нечего). После того, как GSI Dota2 отправил данные на express сервер, их нужно передать на фронт. Пишется простая GET ручка для отдачи данных. Затем на фронте пишется хук, который раз в секунду запрашивает эти данные и дальше они попадают сразу во все остальные хуки. То есть в приложении каждую секунду запускаются все хуки - это важный факт, ведь иногда понадобится хранить время запуска хука, чтобы случайно его не запустить несколько раз (если этого не делать, то у вас произойдёт в лучшем случае два оповещения подряд, в худшем случае взрыв из оповещений). Логика получения данных:
Теперь, когда есть все данные на фронте, можно написать хук для звуковых оповещений, что пора бы пойти (за 30 секунд до начала оповещает) забрать руны богатства, появляющиеся на каждой минуте кратной пяти (5, 10, 15, 20 минута):
Запись о последнем воспроизведении (setLastIntervalPlay) нужна чтобы не повторить оповещение случайно дважды.
И вот уже в игре одно преимущество, может быть оно несущественное, но как мне кажется неплохо управляет вниманием команды. Что - ж можно пойти дальше и сделать такую же кнопку возрождения рошана, как из прошлой статьи:
Хук useRoshanSpawn для кнопки
С рошаном всё немного запутаннее, чем с рунами - он может возрождаться в интервале от 9 до 12 минут. То есть у него есть состояния:
Точно мёртв (прошло до 9 минут с момента смерти)
Он жив или мёртв (прошло от 9 до 12 минут с момента смерти)
Он точно жив (прошло свыше 12 минут с момента смерти или это начало игры)
Поэтому у таймера есть три визуальных состояния:
Кнопка - для запуска таймера
Таймер тикает и сообщает о том что роша точно мёртв
Таймер тикает и сообщает о том что роша возможно жив, а возможно мёртв
И одно звуковое оповещение: Рошан будет в состоянии Шредингера через 30 секунд (то есть, и жив, и мёртв одновременно - пока не проверишь, не узнаешь). Также есть возможность сбросить таймер, ведь если мы проверили и узнали, что он жив - то таймер больше не нужен, а нужна кнопка о том чтобы сообщить о новой смерти рошана. Из минусов - иногда забываешь запускать таймер, было бы здорово в будущем это тоже автоматизировать.
Обогащаем данные
Бенчмарки на героя Abaddon
Вся логика описана в хуке useBenchmark:
Узнаём предпочтения игрока
Было бы здорово получать информацию о том, на каких героях вероятнее всего будет играть противник, чтобы забанить, отобрать, законтрить их у него. Для этого нужно считывать память файл игры: "server_log.txt" и дальше распарсить его регуляркой, найти там ID ваших оппонентов, затем запросить историю игр в OpenDota или Dotabuff. У этого способа есть минусы - если оппоненты сделал свой игровой профиль скрытым в Dota 2, то никакой информации о нём вы не получите. Есть ещё один момент, который я забыл учесть - данные могут быть устаревшими, но в коде это легко исправляется добавлением фильтра по времени.
Attention: код по ссылке может совершить BSoD ваших глаз.
После, будет здорово это тоже вывести, поэтому решено было сделать отдельное React приложение на localhost:3002. Без дизайна выглядит оно совсем по страшному, но это уже был просто спортивный интерес и вообще я им не пользуюсь. В нём есть информация о прошлых десяти играх. Кнопочка "Ban this id", чтобы убирать друзей, с которыми играешь, из этой статистики и ссылка на Dotabuff профиль, если вдруг хочется подробностей.
Это приложение тоже можно было бы красиво оформить в виде Electron оверлея и запускать его на стадии выбора героев, но кажется я слишком много играю в игры и мало уделяю времени действительно полезным вещам :-)
Что ещё пробовалось:
Пробовался DLL Injection из прошлой статьи и чтение памяти с помощью Rust, но там был большой изъян в том, что все найденные указатели на структуры данных жили до обновления игры, поэтому эта идея была заброшена.
Парсинг Dota 2 реплеев - там не сложно, используется Protobuff и все структуры легко находятся на гитхабе. Вот только что дальше с этим огромным объёмом данных делать?
Вывод: интегрироваться с Dota2 не вызывает труда, можно делать быстрый анализ прямо во время игры, при просмотре киберспортивных игр можно сделать огромное количество красивого оверлея для Twitch стрима, также можно развивать эту тему в сторону ретроспективного анализа из реплеев, что скорее всего будет полезно профессионалам.
Надеюсь вам было интересно почитать про то, как я собрал на коленке читы (на самом деле хороший вопрос - читы это или нет?), да ещё и на JS, если есть орфографические или лексические ошибки, то пишите пожалуйста в ЛС, спасибо за внимание.
Тайминги Рошана и Аегиса в Доте
DotA 2 | Минутка знаний - разбираемся в таймере Рошана
Знаете ли вы как работает таймер на Рошана в режиме "спектатора"? Наверняка многие из вас обращали внимание на этот непонятный циферблат, который появился достаточно давно. В этой статье постараемся раз и навсегда развеять все неясности вокруг этого небольшого, но достаточно загадочного аспекта.
Мировое Dota сообщество недавно вновь подняло тему, в которой множество пользователей признались в своём непонимании принципов работы таймера на возрождение Рошана. Оказалось, что с такой проблемой сталкиваются не только обычные зрители, но и некоторые ПРО игроки:
EternalEnvy: "Я не понимаю как это работает LOL (LeagueOfLegends)"
По всей видимости, совсем незамеченным остался пост в блоге Cyborgmatt'a полугодичной давности, в котором он подробно описал принцип действия данного таймера. В преддверии сезона больших турниров и матчей постараемся доступно описать его механизм работы, дабы ни у кого не оставалось вопросов.
Как скопировать тайминг рошана в доте 2
Читы Dota 2, MapHack MH, Soft, Баги, Хаки Дота 2 запись закреплена
Очень часто в напряженных геймах аегис (крест), золото, сыр могут послужить неплохими бонусами для команды и попросту создать переломный момент. Поэтому сильные команды стараются контролить Рошана вардами, учитывать тайминг его перерождения, в следствии чего у Рошана происходят наиболее зрелищные и ожесточенные тимфайты. Для того чтобы не записывать (запоминать) время убийства Рошана, ставить варды и попросту вовремя чекать, мы предлагаем использовать таймер, который прост и максимально удобен.
Две кнопки (бинды настраиваемые):
"Старт" - запускает таймер
"Пауза" - ставит и снимает таймер с паузы (на случай если в игре ставится пауза)
Как пользоваться:
1. Запускаем таймер (до или после запуска Dota 2 - не имеет значения)
2. Настраиваем горячие клавиши если вы запустили первый раз.
3. Играем, по необходимости используем таймер и контролим Рошана.
Вся суть в 3 точках
По истечении восьми минут вместо восьмиминутного появляется второй циферблат, который и является непонятным для многих. Тут все внимание нужно обращать на внутренний таймер, показывающий остаток времени.
Количество неподвижных точек на внутренней оси показывает, сколько дополнительных минут будет задействовано - 1, 2 или 3 минуты соответственно. Исходя из этого меняется и сам циферблат.
Таймер с 1 точкой = Рошан появится с 8 по 9 минуту
На рисунке сверху показан пример с одной дополнительной минутой, то есть в данном случае Рошан появится в пределах одной минуты после прошедших 8. Красная полоса свидетельствует о том времени, которое останется неиспользованным (примерное время появления Рошана в этом случае
Таймер с 2 точками = Рошан возродится с 9 по 10 минуту
В данном примере вы можете видеть 2 неподвижные точки напротив друг друга (правая дуга является отрезком от 8 до 9 минут, левая - от 9 до 10 соответственно). Здесь Рошан появится на
9:40 после своей смерти.
Таймер с 3 точками = Рошан будет между 10 и 11 минутой
Последний оставшийся пример с 3 дополнительными минутами (приблизительное время появления Рошана здесь = 10:15). Главное - запомнить, что 1 неподвижная точка = 1 дополнительной минута и учитывать красные зоны незадействованного времени.
Первый таймер
Напомним, что с внедрением патча 6.79 изменилась механика респауна Рошана - теперь он появляется в случайном промежутке времени между 8 и 11 минутой после своей смерти. Это повлекло за собой необходимость в смене принципа работы таймера.
С первыми 8 минутами всё понятно - циферблат поделен на 8 отделов, каждый из которых означает 1 минуту игрового времени.
Читайте также: