diff --git a/help/taseditor-ru/AdvancedFeatures.html b/help/taseditor-ru/AdvancedFeatures.html index e66140a1..fee863ac 100644 --- a/help/taseditor-ru/AdvancedFeatures.html +++ b/help/taseditor-ru/AdvancedFeatures.html @@ -194,7 +194,7 @@


-

При запуске этого скрипта FCEUX зарегистрирует функцию doCopy() на событие нажатия кнопки Run function(registermanual). Теперь при каждом нажатии этой кнопки будет запускаться код этой функции, который состоит из девяти строк. Сначала функция получает от тасэдитора информацию о Выделении, и если оно не пустое (то есть выделен хотя бы один кадр в Piano Roll), то запускается цикл "for", перебирающий все выделенные кадры по порядку, начиная с первого и заканчивая последним. Для каждого выделенного кадра функция запрашивает у Тасэдитора Ввод первого игрока (и сохраняет в переменную joypad1data), затем делает заявку на изменение Ввода второго игрока в этом же кадре. Все заявки накапливаются в памяти Тасэдитора до завершения цикла for, после чего они все разом исполняются с помощью вызова applyinputchanges(). В итоге Ввод второго джойстика в выделенных кадрах будет совпадать с Вводом первого джойстика.

+

При запуске этого скрипта FCEUX зарегистрирует функцию doCopy() на событие нажатия кнопки Run function(registermanual). Теперь при каждом нажатии этой кнопки будет запускаться код этой функции, который состоит из девяти строк. Сначала функция получает от Тасэдитора информацию о Выделении, и если оно не пустое (то есть выделен хотя бы один кадр в Piano Roll), то запускается цикл "for", перебирающий все выделенные кадры по порядку, начиная с первого и заканчивая последним. Для каждого выделенного кадра функция запрашивает у Тасэдитора Ввод первого игрока (и сохраняет в переменную joypad1data), затем делает заявку на изменение Ввода второго игрока в этом же кадре. Все заявки накапливаются в памяти Тасэдитора до завершения цикла for, после чего они все разом исполняются с помощью вызова applyinputchanges(). В итоге Ввод второго джойстика в выделенных кадрах будет совпадать с Вводом первого джойстика.

Этот весьма простой скрипт уже представляет из себя полезный инструмент, который может пригодиться вам при создании ТАСов  с управлением двумя игроками одновременно. После запуска этого скрипта вы во время ТАСинга сможете выделять в Piano Roll ряд кадров и нажимать кнопку Run function (или хоткей "Run Manual Lua function") для синхронизации обоих игроков. Когда в результате действий этого скрипта изменится Ввод, произойдёт естественное усечение Гринзоны и добавление записи в Журнал Истории, чтобы при необходимости вы могли откатить произведённые скриптом изменения. Таким образом вы получаете полностью интегрированную в Тасэдитор фичу, логику которой запрограммировали сами.

Хотя вы можете успешно ТАСить и без знания языка Lua, его использование может значительно сэкономить вам время и даже натолкнуть на неочевидные решения при оптимизации Ввода и анализе игрового Вывода.

diff --git a/help/taseditor-ru/Controls.html b/help/taseditor-ru/Controls.html index bfcb26ae..d923aa77 100644 --- a/help/taseditor-ru/Controls.html +++ b/help/taseditor-ru/Controls.html @@ -189,7 +189,7 @@


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


-

Когда эмулятор стоит на паузе, нажатие средней кнопки снимет паузу (аналогично нажатию хоткея Pause). Более того, если в Piano Roll есть зелёная стрелка, при щелчке по средней кнопке запустится добегание к зелёной стрелке (аналогично нажатию хоткея Restore Playback).

+

Когда эмулятор стоит на паузе, нажатие средней кнопки снимет паузу (аналогично нажатию хоткея Pause). Более того, если в Piano Roll за пределами Гринзоны находится зелёная стрелка, при щелчке по средней кнопке запустится добегание к зелёной стрелке (аналогично нажатию хоткея Restore Playback).

Если перед щелчком зажать клавишу Shift, запустится добегание к ближайшему Маркеру.

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


diff --git a/help/taseditor-ru/FM3format.html b/help/taseditor-ru/FM3format.html index d901e1bb..6ca9dc4e 100644 --- a/help/taseditor-ru/FM3format.html +++ b/help/taseditor-ru/FM3format.html @@ -209,7 +209,7 @@

4 байта

-

unsigned int32

+

unsigned int32

FM3 version

@@ -217,7 +217,7 @@

4 байта

-

unsigned int32

+

unsigned int32

saved modules

@@ -288,8 +288,8 @@
  • бит 5 – в файле сохранена История Выделений

  • -

    При сохранении проекта Тасэдитор поочерёдно вызывает все модули, требующие сохранения данных. В зависимости от настроек компактного сохранения каждый модуль осуществляет выборочную сериализацию своих данных в файловый поток. Порядок сохранения модулей всегда одинаков (Маркеры, Закладки, Гринзона, История, Piano Roll, Выделение). При загрузке проекта Тасэдитор вызывает модули в той же очерёдности, и они загружают свои данные из файлового потока, перемещая вперёд указатель на текущую позицию в файле.

    -

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

    +

    При сохранении проекта Тасэдитор поочерёдно вызывает все модули, требующие сохранения данных. В зависимости от настроек компактного сохранения каждый модуль осуществляет выборочную сериализацию своих данных в файловый поток. Порядок сохранения модулей всегда одинаков (Маркеры, Закладки, Гринзона, История, Piano Roll, Выделение). При загрузке проекта Тасэдитор вызывает модули в той же очерёдности, и они загружают свои данные из файлового потока, перемещая вперёд указатель на текущую позицию в файле.

    +

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


    diff --git a/help/taseditor-ru/Glossary.html b/help/taseditor-ru/Glossary.html index 91a15c66..dfefc262 100644 --- a/help/taseditor-ru/Glossary.html +++ b/help/taseditor-ru/Glossary.html @@ -64,146 +64,159 @@


    -

    Input – Ввод

    +

    Input – Ввод

    Данные о действиях игрока, воспринимаемые игрой и влияющие на её поведение.

    Из-за многозначности слова "Ввод" среди русскоязычных ТАСеров чаще используется англицизм "Инпут", который можно перевести как "Вводимые данные".

    ТАСинг базируется на допущении, что поведение игры однозначно зависит от Ввода игрока и начального состояния игры, и ни от чего более (т.н. детерминизм).

    Примеры существующих типов Ввода: нажатие кнопки джойстика, наклон аналогового стика, прикосновение стилуса, крик в микрофон и т.д.

    В Тасэдиторе используется представление Ввода в формате "последовательность кнопочных состояний".

    +

    Замечание: когда игрок не нажимает ни одной кнопки, этот факт так же является Вводом.


    -

    Output – Вывод

    +

    Output – Вывод

    Данные, выдаваемые игрой в ответ на Ввод игрока.

    Из-за многозначности слова "Вывод" в данном Руководстве используются слова "результат", "реакция игры" и т.п.

    -

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

    +

    Процесс игры в любую видеоигру можно представить в виде зацикленного взаимодействия между субъектом (игроком) и объектом (игрой).

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


    -

    Walkthrough – Прохождение (прохождение видеоигры)

    -

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

    +

    Walkthrough – Прохождение (прохождение видеоигры)

    +

    Последовательность действий для успешного завершения игры.

    +

    Эта последовательность вводится в игру с помощью устройства ввода (например, джойстика). Последовательность может быть либо исполнена вживую (real-time – в реальном времени), либо приготовлена в виде воспроизводимых данных (например, журнал нажатых кнопок). Во втором случае эту последовательность можно редактировать.


    -

    Speedrun – Пробег

    -

    Соревновательное прохождение на скорость. Часто используется англицизм "cпидран".

    +

    Speedrun – Пробег

    +

    Прохождение с целью самого быстрого завершения игры.

    +

    Часто используется англицизм "cпидран".

    В некоторых играх присутствует встроенный режим под названием "Speedrun" или "Time Attack", при котором игра ведёт учёт затраченного времени на прохождение. Для других игр можно использовать внешний таймер, измеряя время в секундах или TV-кадрах (обычно подразумевается 60 кадров в секунду).


    -

    TAS (Tool-Assisted Superplay / Tool-Assisted Speedrun) – ТАС

    -

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

    +

    TAS (Tool-Assisted Superplay / Tool-Assisted Speedrun) – ТАС

    +

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

    Процесс создания ТАСа называется ТАСингом, а авторы зовутся ТАСерами.

    -

    Целью ТАСа может быть не только спидран, но и развлекательный видеоролик (playaround).

    +

    Благодаря редактированию Ввода ТАСер освобождается от некоторых человеческих ограничений (например, слабой реакции) и может направить все усилия на создание крайне неординарных прохождений видеоигр. Это может быть не только спидран, но и развлекательный видеоролик (playaround).

    ТАСы распространяются:


    -

    Movie – Мувик (фильм)

    +

    Movie – Мувик (фильм)

    Контейнер для хранения Ввода и сопутствующих данных.

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

    Также мувиком называется файл (movie file), в котором хранится Ввод и сопутствующие данные.


    -

    Lag – Лаг (задержка)

    -

    Особая ситуация в игре, вызванная повышенной нагрузкой на процессор.

    -

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

    -

    Наличие лага в кадре определяется эмулятором после окончания обработки данного кадра. Если во время обработки кадра игра опросила Ввод, считается, что лага в кадре нет. Если игра не опросила Ввод – лаг в кадре есть. В Тасэдиторе кадры с лагом отмечаются красными строками. Рисовать Ввод на этих кадрах бесполезно.

    +

    Lag – Лаг (задержка)

    +

    Превышение нормы при задержке между Вводом и Выводом.

    +

    При зацикленном взаимодействии между игроком и игрой обычно устанавливается режим Ввода и Вывода через равные промежутки времени, например, ровно 60 раз в секунду.

    +

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

    +

    Лишние задержки не выгодны при создании спидрана. Поэтому лаг зачастую выступает в качестве одного из факторов, который нужно учитывать во время создания Ввода. Обычно требуется минимизировать количество кадров с лагом.

    +

    Наличие лага в кадре определяется эмулятором сразу после окончания обработки данного кадра. Если во время эмуляции кадра игра опросила Ввод, считается, что лага в кадре нет. Если игра не опросила Ввод – лаг в кадре есть. В Тасэдиторе кадры с лагом отмечаются красными строками. Рисовать Ввод на этих кадрах бесполезно.


    -

    Desync – Рассинхронизация (расхождение)

    -

    Отличие Вывода от ожидаемого образца.

    +

    Desync – Рассинхронизация (расхождение)

    +

    Отличие Вывода от ожидаемого образца, в результате чего действия игрока расходятся с логикой игры.

    Может произойти в случае, если Ввод проигрывается на другой игре, другом эмуляторе или с другими настройками синхронизирования. Также может произойти, если эмулятор не обеспечивает детерминизм должным образом.


    -

    Segment – Участок

    -

    Условная единица разбиения мувика на логические составляющие.

    +

    Segment – Участок

    +

    Часть мувика, соответствующая промежутку времени между двумя игровыми событиями.

    Разбиение мувика на участки – это разложение большой задачи на мелкие подзадачи.

    -

    Границы участка определяются игровыми событиями. Начальное событие отсекает все предыдущие задачи и концентрирует внимание ТАСера на ближайшем наборе условий. Конечное событие служит для оценки оптимальности всех вариантов решения текущей задачи.

    +

    Размер участка измеряется в кадрах, а границы участка определяются игровыми событиями. Начальное событие отсекает все предыдущие задачи и концентрирует внимание ТАСера на ближайшем наборе условий. Конечное событие служит для оценки оптимальности всех вариантов решения текущей задачи.

    Подробнее: Процесс ТАСинга


    -

    Optimization – Оптимизация

    -

    В ТАСинге: Процесс постепенного улучшения целевых характеристик мувика.

    -

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

    -

    Оптимизация ТАСа заключается в редактировании Ввода и оценке получающегося Вывода. Когда ТАСер получает от игры более предпочтительный результат, он оставляет текущий Ввод в качестве основного, пока не найдёт ещё более оптимальный Ввод. В финальном ТАСе для каждой подзадачи оставлен наилучший вариант решения.

    +

    Optimization – Оптимизация

    +

    Процесс поиска оптимального (наилучшего) решения задачи на текущем участке.

    +

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

    +

    Оптимизация ТАСа заключается в редактировании Ввода и оценке получающегося Вывода. Когда ТАСер получает от игры более предпочтительный результат, он отмечает текущий Ввод в качестве основного, пока не найдёт ещё более оптимальный Ввод. В финальном ТАСе для каждой подзадачи оставлен наилучший вариант решения.

    Подробнее: Методология ТАСинга


    -

    Improvement – Улучшение

    -

    Возможность решить задачу более оптимально. Например, достичь такого же результата с меньшими затратами, или улучшить результат без увеличения затрат.

    -

    Примеры улучшений в ТАСинге: использование неиспользованного таймсэйвера, повышение эффективности использования таймсэйвера, повышение развлекательности мувика без потери скорости.

    +

    Improvement – Улучшение

    +

    Возможность решить задачу более оптимально.

    +

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


    -

    Timesaver – Таймсэйвер (экономия времени)

    -

    Жаргонный термин, используемый для обозначения ключевой категории трюков в спидранах.

    -

    При создании спидрана ТАСеру необходимо использовать все не запрещённые возможности для максимально быстрого прохождения игры. В первую очередь это грамотная шлифовка Ввода, во вторую – поиск и применение трюков. ТАСер пытается использовать все известные ему трюки максимально эффективно, чтобы его рекорд скорости нельзя было легко побить.

    +

    Timesaver – Таймсэйвер

    +

    Внутриигровой трюк, позволяющий сэкономить время.

    +

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

    Примеры таймсэйверов: фичи игры, баги игры, манипуляция удачей.

    -

    Иногда ТАСер сознательно отказывается от использования некоторых таймсэйверов, в этом случае для его ТАСа отводится отдельная категория на сайте. Например: спидран SMB без использования кнопки B (отказ от фичи), спидран Sonic the Hedgehog без прохождения сквозь стены (отказ от бага).

    +

    Замечание: иногда ТАСер сознательно отказывается от использования некоторых таймсэйверов, в этом случае для его ТАСа отводится отдельная категория на сайте. Например: спидран Super Mario Bros без использования кнопки B (отказ от фичи), спидран Sonic the Hedgehog без прохождения сквозь стены (отказ от бага).


    -

    Feature – Фича (особенность)

    -

    Запланированный разработчиками аспект игры, который необходимо учитывать в качестве фактора оптимальности при создании Ввода мувика.

    -

    Некоторые фичи не существенны для простого игрока, но существенны для ТАСера. Поэтому перед оптимизацией Ввода рекомендуется провести исследования игрового движка.

    +

    Feature – Фича (особенность)

    +

    Запланированный аспект игры.

    +

    Некоторые фичи не существенны (а иногда и незаметны) для простого игрока, но существенны для ТАСера. Поэтому перед оптимизацией Ввода рекомендуется провести исследования игрового движка.

    Примеры существеных для ТАСера фич: ускорение при ранении (damage boost), вынужденное ожидание при подсчёте очков, наличие субпикселей у координат персонажа, особенности искусственного интеллекта врагов и т.д.


    -

    Bug – Баг (ошибка)

    -

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

    -

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

    -

    Многие баги обнаруживаются даже при обычной игре без использования инструментов. Некоторые же требуют тщательного исследования поведения игры и изучения её исполняемого кода.

    +

    Bug / Glitch – Баг / Глюк (ошибка)

    +

    Незапланированный аспект игры.

    +

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

    +

    Многие баги обнаруживаются даже при обычной игре без использования инструментов. Некоторые требуют тщательного исследования поведения игры и изучения её исполняемого кода.

    Примеры багов: упрощённая проверка коллизий, отсутствие проверки испорченных данных в сохранении, непредусмотренное изменение ячеек оперативной памяти, ошибка в порядке очерёдности проверок и т.д.


    -

    Luck Manipulation – Манипуляция удачей

    -

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

    -

    По сути любая оптимизация Ввода является манипуляцией с игровыми фичами. Но некоторые аспекты игры кажутся обычным игрокам особенно непредсказуемыми. Алгоритмы их функционирования нарочно скрыты разработчиками от невооружённого глаза, игроку они показаны как случайные и неконтролируемые.

    -

    Однако на самом деле все аспекты видеоигр являются детерминированными (однозначно зависящими от Ввода). Использование инструментов и вдумчивого анализа позволяет выявить скрытые закономерности и использовать их при создании Ввода мувика.

    -

    А в некоторых случаях вместо исследования алгоритмов достаточно воспользоваться методом перебора, натыкаясь на удачный исход событий методом проб и ошибок, а затем оставляя в мувике именно тот Ввод, который приводит игру к удачному результату.

    +

    Luck Manipulation – Манипуляция удачей

    +

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

    +

    По сути любые эксперименты с изменением Ввода являются манипуляцией с игровыми фичами. Но некоторые аспекты игр кажутся обычным игрокам особенно непредсказуемыми. Алгоритмы их функционирования нарочно скрыты разработчиками от невооружённого глаза, игроку они показаны как случайные и неконтролируемые.

    +

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

    Подробнее: Нелинейный ТАСинг (пример манипуляции)


    -

    Subpixels – Субпиксели (дробная часть пикселя)

    +

    Subpixels – Субпиксели (дробная часть пикселя)

    Наличие не только целых, но и дробных значений у координат персонажа в игре.

    В общем случае ТАСеру следует понимать отличие между экранными координатами спрайта и реальными координатами физического объекта в игре. Только в простейших играх эти координаты совпадают, обычно же на экран выводится приблизительное положение вещей, где проекции всех объектов выравнены по сетке пикселей. Чтобы узнать реальные координаты (и другие скрытые от глаз игрока данные), нужно просматривать ячейки оперативной памяти эмулируемой платформы. Это делается с помощью просмотрщика памяти (Memory Watch) или Lua.


    -

    Recording – Запись

    -

    Один из видов создания Ввода в мувике.

    +

    Recording – Запись

    +

    Один из способов создания Ввода в мувике.

    Заключается в последовательном добавлении Ввода в конец мувика, одновременно с просмотром промежуточных результатов.

    +

    Другим способом является рисование Ввода непосредственно в мувике.

    Подробнее: Панель инструментов, Методология ТАСинга, Традиционный метод ТАСинга


    -

    Rerecording – Перезапись (повторная запись)

    -

    Один из видов редактирования Ввода в мувике.

    +

    Rerecording – Перезапись (повторная запись)

    +

    Один из способов редактирования Ввода в мувике.

    Заключается в последовательном изменении Ввода, начиная с определённого кадра, одновременно с просмотром промежуточных результатов.

    +

    Другим способом является непосредственная модификация Ввода в мувике.

    Подробнее: Методология ТАСинга, Традиционный метод ТАСинга, Счётчик перезаписей


    -

    Multitracking – Мультитрекинг (многодорожечная запись)

    +

    Multitracking – Мультитрекинг (многодорожечная запись)

    Один из способов записи Ввода при прохождении игр в режиме нескольких игроков.

    Заключается в поочерёдной записи Ввода на одном участке для каждого игрока отдельно.

    +

    Другим способом является запись Ввода для всех игроков сразу.

    Подробнее: Панель инструментов


    -

    Turbo – Турбо (повышенная скорость)

    +

    Frame Advance – Frame Advance (покадровая эмуляция)

    +

    Пошаговая эмуляция игры минимальными порциями (единицами измерения времени) – кадрами.

    +

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

    +


    +

    Turbo – Турбо (повышенная скорость)

    Ускорение эмуляции игры до максимально возможной скорости.

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

    -

    С помощью настроек эмулятора можно гибко варьировать скорость эмуляции, замедляя или ускоряя её при необходимости. Под Турбо понимается максимально возможная скорость эмуляции. Этот предел зависит от скорости вашего компьютера.

    +

    С помощью настроек эмулятора можно гибко варьировать скорость эмуляции, замедляя или ускоряя её при необходимости. Под Турбо понимается максимально возможная скорость эмуляции. Этот предел зависит от производительности вашего компьютера.

    Подробнее: Панель инструментов, Нелинейный ТАСинг, Полуавтоматический ТАСинг


    -

    Savestate – Сэйв (сохранение)

    +

    Savestate – Сэйв (сохранение)

    Снимок состояния эмулируемой платформы.

    -

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

    +

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


    -

    Piano Roll – Piano Roll (перфолента)

    -

    Особый тип визуального представления данных, похожий на представление в виде таблицы.

    -

    Подобный интерфейс используется в редакторах музыки (MIDI-секвенсорах и MOD-трекерах). Его имя и принцип действия унаследован из физического аналога (давно существовавшие свёртки перфорированной бумаги для механических клавесинов).

    +

    Piano Roll – Piano Roll (перфолента)

    +

    Тип визуального представления данных, похожий на представление в виде таблицы.

    +

    Этот интерфейс используется в редакторах музыки (MIDI-секвенсорах и MOD-трекерах). Его имя и принцип действия унаследован из физического аналога (давно существовавшие свёртки перфорированной бумаги для механических клавесинов).

    В Piano Roll Тасэдитора отображаются и редактируются данные мувика (Ввод и Маркеры), а также отображаются некоторые данные эмулируемой игры (текущий кадр, Журнал лага, Закладки и т.д.).

    Каждая строка Piano Roll соотносится с одним кадром мувика.

    -

    Подробнее: Интерфейс Piano Roll, Piano Roll

    +

    Подробнее: Интерфейс Piano Roll, Спецификации Piano Roll


    -

    Playback cursor – Курсор Проигрывателя

    -

    Текущий проигрываемый кадр мувика. События этого кадра отображаются в окне эмулятора в виде скриншота, а в Piano Roll соответствующая строка обозначается голубым цветом и значком "Play" (голубая стрелка).

    +

    Playback cursor – Курсор Проигрывателя

    +

    Указатель на текущий проигрываемый кадр мувика.

    +

    События этого кадра отображаются в окне эмулятора в виде скриншота, а в Piano Roll соответствующая строка обозначается голубым цветом и значком "Play" (голубая стрелка).

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

    Подробнее: Интерфейс Piano Roll, Навигация Курсором Проигрывателя


    -

    Greenzone – Гринзона (зона мгновенного доступа)

    +

    Greenzone – Гринзона (зона мгновенного доступа)

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

    -

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

    -

    Подробнее: Панель инструментов, Настройка программы, Гринзона

    -

    Selection – Выделение

    +

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

    +

    Подробнее: Панель инструментов, Настройка программы, Спецификации Гринзоны

    +


    +

    Selection – Выделение

    Набор строк Piano Roll, отмеченных специальным цветом (обычно синим).

    Любая строка (и, соответственно, любой кадр мувика) является либо выделенной, либо не выделенной.

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

    Самый верхний выделенный кадр называется Курсором Выделения.

    -

    Курсор Выделения автоматически следует за процессом редактирования Ввода, поэтому с его помощью можно осуществлять навигацию по местам редактирования.

    +

    Курсор Выделения автоматически следует за процессом редактирования Ввода.

    Подробнее: Интерфейс Piano Roll, Навигация Курсором Выделения


    -

    Marker – Маркер

    -

    Жёлтая отметка для кадра в Piano Roll, акцентирующая на нём внимание.

    +

    Marker – Маркер

    +

    Жёлтая отметка для строки в Piano Roll, акцентирующая внимание на этом кадре.

    Маркером можно отметить любой кадр в Piano Roll. С помощью установки и удаления Маркеров можно повысить наглядность и удобство работы.

    Цели использования Маркеров:

    -

    Подробнее: Интерфейс Piano Roll, Маркеры

    +

    Подробнее: Интерфейс Piano Roll, Спецификации Маркеров


    -

    Note – Заметка

    +

    Note – Заметка

    Однострочная текстовая запись, прилагаемая к каждому Маркеру.

    Подробнее: Интерфейс Piano Roll, Управление, Продвинутые возможности


    -

    Bookmark – Закладка

    -

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

    -

    Закладки могут использоваться для навигации Курсором Проигрывателя, но в Тасэдиторе они в основном используются для хранения ответвлений.

    -

    Подробнее: Панель инструментов, Закладки и ответвления

    +

    Bookmark – Закладка

    +

    Номерная отметка для кадра мувика.

    +

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

    +

    Закладки могут использоваться для навигации Курсором Проигрывателя, но в основном они используются для хранения ответвлений.

    +

    Подробнее: Панель инструментов, Спецификации Закладок


    -

    Branch – Ответвление

    -

    Резервная копия мувика, хранящая его состояние на момент создания Закладки.

    -

    Текущий мувик заменяется на требуемое ответвление с помощью загрузки соответствующей Закладки.

    +

    Branch – Ответвление

    +

    Копия мувика, хранящая его состояние на момент создания Закладки.

    +

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

    С помощью ответвлений можно одновременно хранить в проекте несколько разных мувиков и мгновенно переключаться между ними:

    -

    Подробнее: Панель инструментов, Настройка программы, Закладки и ответвления

    +

    Подробнее: Панель инструментов, Настройка программы, Спецификации ответвлений


    -

    Project – Проект

    +

    Project – Проект

    Контейнер для хранения рабочих данных при использовании в Тасэдиторе.

    Также проектом называется файл (project file), в котором хранятся рабочие данные пользователя.

    Подробнее: Продвинутые возможности


    -

    Lua – Lua

    -

    Интерпретируемый язык программирования, использующийся во многих ТАСерских эмуляторах для визуализации данных и создания индивидуальных инструментов.

    +

    Lua – Lua

    +

    Интерпретируемый язык программирования, использующийся во многих ТАСерских эмуляторах.

    +

    Полезен для создания индивидуальных инструментов и визуализации данных.

    Подробнее: Продвинутые возможности, Луа-автоматизация, Lua-функции


    -

    Bot – Бот (робот)

    -

    Средство для автоматизации определённых действий.

    -

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

    -

    Сами по себе боты не способны создать экстраординарное прохождение видеоигры. Их практично использовать только для исчерпывающего перебора вариантов на коротком участке мувика. И в большинстве случаев ТАСеру проще перебрать варианты вручную, интуитивно отсеивая тупиковые варианты в уме, чем заниматься написанием бота и долгим ожиданием результатов полного перебора.

    +

    Bot – Бот (робот)

    +

    Средство для автоматизации действий.

    +

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

    +

    В наши дни практично использовать ботов только для исчерпывающего перебора вариантов на коротком участке мувика. И в большинстве случаев ТАСеру проще перебрать варианты вручную, интуитивно отсеивая тупиковые варианты в уме, чем заниматься написанием бота и долгим ожиданием результатов полного перебора.

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


    -

    Pattern – Шаблон

    -

    В Тасэдиторе: заданная последовательность значений Ввода для одной (любой) кнопки.

    -

    Подробнее: Продвинутые возможности, Шаблоны

    +

    Pattern – Шаблон

    +

    Заданная последовательность значений Ввода для одной (любой) кнопки.

    +

    Подробнее: Продвинутые возможности, Спецификации шаблонов




    diff --git a/help/taseditor-ru/Ideas.html b/help/taseditor-ru/Ideas.html index f852a6b1..623ca985 100644 --- a/help/taseditor-ru/Ideas.html +++ b/help/taseditor-ru/Ideas.html @@ -189,7 +189,7 @@
  • Данные в Гринзону собираются в начале каждого кадра (перед эмуляцией) по следующему принципу: если в массиве Гринзоны ячейка с номером, равным текущему кадру, пустует, или же позиция головы Гринзоны меньше номера текущего кадра, то ячейка массива заполняется информацией о текущем состоянии игры (из эмулятора), а голова Гринзоны при необходимости перемещается вперёд.
  • Для экономии памяти Гринзона периодически разреживается, удаляя сэйвы (но не информацию о лаге) некоторых ранних кадров, от которых Курсор Проигрывателя ушёл достаточно далеко. Подробнее см. Настройка программы.
  • Вся Гринзона сохраняется и загружается из файла проекта. После загрузки проекта Тасэдитор восстанавливает состояние Курсора Проигрывателя с помощью Гринзоны.
  • -
  • При любом изменении Ввода текущего мувика из Гринзоны удаляется информация о кадрах, идущих после первого изменённого кадра. Это реализуется с помощью уменьшения позиции головы Гринзоны, но сама устаревшая информация из массива не удаляется. Обычно одновременно с этим перемещается Курсор Проигрывателя, чтобы он всегда находился внутри Гринзоны (чтобы на экране FCEUX никогда не отображалось неактуальное состояние игры).
  • +
  • При любом изменении Ввода текущего мувика из Гринзоны удаляется информация о кадрах, идущих после первого изменённого кадра. Это реализуется с помощью уменьшения позиции головы Гринзоны и удаления устаревшей информации из массива (но без освобождения памяти, так как на место старых сэйвов вскоре будут записаны новые данные примерно того же размера). Обычно одновременно с этим перемещается Курсор Проигрывателя, чтобы он всегда находился внутри Гринзоны (чтобы на экране FCEUX никогда не отображалось неактуальное состояние игры).
  • При создании Закладки в неё копируется информация из соответствующего кадра Гринзоны. При загрузке ответвления этой Закладки из неё копируется информация в соответствующую ячейку Гринзоны, и при необходимости передвигается позиция головы.
  • Информация из Гринзоны используется при раскрашивании строк Piano Roll. Информация о лаге (Журнал лага) отображается не только для кадров, содержащихся в Гринзоне, но и для отсутствующих в ней кадров. Если в Гринзоне нет информации о лаге на определённом кадре, то предполагается, что этот кадр без лага.
  • Информация о лаге собирается в Гринзону одновременно со сбором текущего состояния игры, то есть перед началом эмуляции текущего кадра. В этот момент эмулятор обладает информацией о лаге предыдущего кадра, поэтому на кадре с номером 000020 данные о лаге сохраняются в ячейку 19. Также именно в этот момент может сработать операция AdjustLag, которая сдвигает весь Ввод в последующих кадрах мувика на 1 кадр вверх или вниз. Ввод сдвигается вверх, если в Журнале лага на прошлом кадре был лаг, а теперь его не стало. Ввод сдвигается вниз, если в Журнале лага на прошлом кадре не было лага, а теперь он есть. Вместе с Вводом аналогично сдвигается и все последующие ячейки Журнала лага, чтобы красные строки Piano Roll по-прежнему соответствовали сдвинувшимся пропускам во Вводе. Кроме того, после операции AdjustLag Курсор Проигрывателя насильно возвращается на предыдущий кадр (в котором изменилась информация о лаге), чтобы проэмулировать его заново. Это реализуется не простой перемоткой назад, а усечением Гринзоны после предыдущего кадра.
  • @@ -233,6 +233,7 @@
  • Таким образом, зелёная стрелка не меняет своё положение, когда ещё до запуска эмуляции Гринзона усекается повторно (например, ТАСер изменил Ввод на кадре 90, а затем на кадре 80, но зелёная стрелка так и осталась на кадре 100).
  • Также зелёная стрелка не меняет своё положение, когда Гринзона усекается во время добегания, и эмулятор в этот момент не стоит на паузе.
  • Зелёная стрелка не меняет своё положение при операциях AdjustLag, Branch, Record.
  • +
  • При нажатии средней кнопки мыши запускается добегание к зелёной стрелке, если она находится за пределами Гринзоны.

  • diff --git a/help/taseditor-ru/NonlinearTASing.html b/help/taseditor-ru/NonlinearTASing.html index 89387757..85da8f57 100644 --- a/help/taseditor-ru/NonlinearTASing.html +++ b/help/taseditor-ru/NonlinearTASing.html @@ -77,7 +77,7 @@


    Так как все создаваемые варианты прохождения участка автоматически сохраняются в Журнале Истории, у ТАСера-новичка может возникнуть соблазн не сохранять варианты в Закладки, а просто один раз дойти до конечного события, а затем экспериментировать с этим Вводом, постепенно улучшая его (а если вместо улучшения получилось ухудшение – сразу же откатывать изменения с помощью Ctrl + Z). Такой способ ТАСинга крайне не рекомендуется, так как он не позволяет вам мыслить далеко за рамками первоначального варианта (из-за подсознательного страха потерять имеющийся лучший вариант, если уйти от него слишком далеко). Даже если в результате последнего изменения Ввода у вас получилось ухудшение прохождения участка, нужно не откатываться к старому варианту, а пытаться разобраться в причинах ухудшения и продолжать осмысленную модификацию, чтобы получить улучшение.

    -

    Чтобы не бояться, что предыдущее успешное прохождение участка затеряется в глубинах Журнала Истории, рекомендуется поступать так же, как делают в традиционном методе – отвести специальный слот для лучшего варианта прохождения участка и каждый раз ставить эту Закладку на конец участка, когда результат стал ещё лучше.

    +

    Чтобы не бояться, что предыдущее успешное прохождение участка затеряется в глубине Журнала Истории, рекомендуется поступать так же, как делают в традиционном методе – отвести специальный слот для лучшего варианта прохождения участка и каждый раз ставить эту Закладку на конец участка, когда результат стал ещё лучше.

    Точно так же нужно поступать с перспективными вариантами прохождения участка, которые в чём-то лучше, а в чём-то хуже друг друга. Если вы сохраняете все альтернативные варианты в отдельные Закладки, вы можете со спокойной душой удалять их из мувика или изменять до неузнаваемости – для возврата к ним вам потребуется всего одно нажатие клавиши, а не долгий поиск по Журналу Истории.


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

    @@ -91,16 +91,16 @@

    Пункты 3 и 4. Одним махом вы рисуете зажатие кнопки R на протяжении пары десятков кадров.

    Пункт 5: Отпустили паузу эмуляции (средняя кнопка) и заметили, что Марио пробежал только до X=30, а потом остановился и стоит бесконечно долго. Ставим эмулятор на паузу и возвращаемся к пункту 2.

    Пункт 2. Очевидно, ошибка в том, что надо дольше жать R.

    -

    Пункты 3 и 4. Дорисовали зажатие кнопки R ещё на сотню кадров, чтобы уж точно хватило.

    +

    Пункты 3 и 4. Дорисовали зажатие кнопки R ещё на сотню кадров, чтобы уж наверняка хватило.

    Пункт 5: Отпустили паузу эмуляции и увидели, как Марио пробежал до X=100 и даже дальше.

    Пункты 6, 7 и 8: Поставили эмулятор на паузу и отвели Курсор Проигрывателя немного назад, на кадр с X=100. Это будет конец участка, допустим, это оказался кадр с номером 200.

    -

    Пункт 2. Очевидно, надо ещё держать B.

    -

    Пункты 3 и 4. Дорисовали зажатие кнопки B параллельно столбику из нажатий R на участке от начального Маркера до конечного. Курсор Проигрывателя во время рисования отпрыгнул в начало участка, а на его месте в конце участка осталась зелёная стрелка.

    -

    Пункт 5: Отпустили паузу эмуляции (средняя кнопка) и увидели, как Марио пробежал быстрее, достиг X=100 и бежит дальше. Если вы не нажали на паузу самостоятельно, эмулятор остановится на кадре с зелёной стрелкой.

    -

    Пункты 6, 7 и 8: Отвели Курсор Проигрывателя на кадр с X=100, допустим, это кадр с номером 150. Зелёная стрелка напоминает, что в прошлый раз концом участка был кадр 200, значит новый вариант прохождения лучше старого. Можно даже не считать, на сколько кадров было улучшено прохождение, а просто выделить регион кадров от Курсора Проигрывателя до зелёной стрелки и увидеть размер Выделения в панели Splicer.

    +

    Пункт 2. Очевидно, надо бы ещё держать B во время бега.

    +

    Пункты 3 и 4. Дорисовали зажатие кнопки B параллельно столбику из нажатий R на участке от начального Маркера до конца участка или даже дальше. Курсор Проигрывателя во время рисования отпрыгнул в начало участка, а на его месте в конце участка осталась зелёная стрелка.

    +

    Пункт 5: Отпустили паузу эмуляции (средняя кнопка) и увидели, как Марио пробежал быстрее, достиг X=100 и бежит дальше. Если вы не нажали на паузу самостоятельно, эмулятор автоматически остановится на кадре с зелёной стрелкой.

    +

    Пункты 6, 7 и 8: После остановки эмулятора отводим Курсор Проигрывателя на кадр с X=100. Допустим, это кадр с номером 150. Зелёная стрелка напоминает, что в прошлый раз концом участка был кадр 200, значит новый вариант прохождения лучше старого. Можно даже не считать, на сколько кадров было улучшено прохождение, а просто выделить регион кадров от Курсора Проигрывателя до зелёной стрелки и увидеть размер Выделения в панели Splicer.

    Пункт 2. Надо бы поэкспериментировать с прыжками и т.д...

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

    -

    Кроме того, вы можете сосредоточиться на первой части участка, мысленно определив подучасток, задачей которого будет наибыстрейшее получение максимума горизонтальной скорости. Для создания такого подучастка нужно перемотать Курсор Проигрывателя на кадр, в котором скорость достигает максимума в текущей стратегии прохождения участка, а затем просто начать редактирование Ввода над этим кадром. При усечении Гринзоны зелёная стрелка перескочит на этот кадр, автоматически обозначив конец подучастка, и вы сможете сравнивать результат новой стратегии с результатом старой.

    +

    Кроме того, вы можете сосредоточиться на первой части участка, мысленно определив подучасток, задачей которого будет, например, наибыстрейшее получение максимума горизонтальной скорости. Для создания такого подучастка нужно перемотать Курсор Проигрывателя на кадр, в котором скорость (согласно окну Memory Watch) достигает максимума в текущей стратегии прохождения участка, а затем просто начать редактирование Ввода над этим кадром. При усечении Гринзоны зелёная стрелка перескочит на этот кадр, автоматически обозначив конец подучастка, и вы сможете, как обычно, сравнивать результат новой стратегии с результатом старой.


    Процесс создания Ввода в нелинейном методе представляет собой постоянное чередование редактирования и просмотра участка. Анализ ситуации происходит как во время просмотра, так и во время редактирования.

    Оптимальное соотношение времени на редактирование и просмотр формируется само по себе в процессе ТАСинга. Более того, это соотношение может меняться в процессе работы над проектом. Чем больше вы ТАСите одну игру, тем лучше вы ощущаете её закономерности. Поэтому ближе к концу своего мувика вы сможете интуитивно предсказывать результаты изменений Ввода ещё во время редактирования, или даже раньше – во время обдумывания их в голове. А просмотр участка будет нужен только для подтверждения догадки.

    @@ -109,7 +109,7 @@

    Способы просмотра результатов Ввода на участке: