Периодически мне задают вопросы по звукам в скриптах, хотя где-то я уже выкладывал на форуме соответствующую инструкцию. Сегодня хочу рассказать, как всё же сделать звуковую библиотеку и скриптом проигрывать из неё файлы с ожиданием окончания проигрывания.
Как известно, для проигрывания звуков в Trainz есть функция у абстрактного класса World
До Trainz 2012 это функция возвращала float значение соответствующее длине проигрываемого звукового файла. Достаточно было это значение только подставить в Sleep, и всё прекрасно работало.
Однако, с введением в Trainz 2012 эффекта Доплера длина звукового файла фактически перестала быть константой. В связи с этим, N3V Games отказались от привычной работы функции PlaySound, которая перестала возвращать значение соответствующее длине проигрываемого звукового файла. Значит, привычный способ реализации звуков, особенно зацикленных, больше не подходит. Как быть? Выходит, что знать длину звукового файла нам надо заранее. Есть разные способы реализации этого подхода, однако здесь я хочу поделиться тем способом, который я сделал для себя. Этот способ, на мой взгляд, наиболее универсален.
Первое что необходимо сделать, так это написать обёртку для функции PlaySound. Выглядеть она будет вот так:
Набор параметров здесь такой же, как и у оригинальной функции, кроме параметра subtime:
srcAsset - ссылка на актив, который содержит звуковые файлы. Одним словом, это наша библиотека звуков.
soundFile - Путь к звуковому файлу. Напоминаю, что это относительный путь от корня актива (где лежит config.txt)
volume - громкость проигрываемого звука. Значения от 0.0 - 1.0. Хочу обратить внимание, что 1.0 - это оригинальная громкость звукового файла. Значения выше 1.0 ставить нет смысла, ибо громкость выше не станет.
minDistance - расстояние в метрах от точки проигрывания звука, на котором затухание звука будет отсутствовать (громкость будет равна заданной в volume)
maxDistance - расстояние, на котором звук затухнет полностью. Это значение должно быть больше, чем minDistance
srcObject - это непосредственно объект, в котором находится точка привязки к звуку. (если скрипт у нас в этом объекте, то me)
att - имя точки привязки, от которой будет исходить звук. (имеет формат a.name)
subtime - дополнительный параметр позволяющий сокращать или удлинять длину звука для более плавного перехода одного звука к другому или в зацикленных звуках. Задаётся в секундах. Положительно значение уменьшает ожидание, отрицательное увеличивает.
Это функцию нужно просто скопировать в тот скрипт, откуда будет производиться проигрывание звука.
И так, модифицированная функция есть, теперь нужно создать звуковую библиотеку. По сути, это может быть абсолютно любой актив, содержащий звуки. Их можно положить в локомотив, тогда его актив будет звуковой библиотекой. Для кабины можно положить звуки в актив кабины, и тогда она будет звуковой библиотекой. А можно все звуки вынести в отдельный актив, откуда их и использовать и в кабине, и в локомотиве, и где бы то ни было ещё.
После создания актива со звуками, необходимо указать длины этих звуков, которые будет использовать модифицированная функция для создания паузы. Для получения длин звуков я рекомендую воспользоваться программой от agmike. Предлагаю немного модифицированный вариант.
В архиве папка с 3-мя файлами. Надо эту папку распаковать,звуковые файлы кинуть в неё же. Затем запустить run.cmd. После того, как программа завершиться, необходимо открыть блокнотом файл len.txt. В нём будут все длины файлов уже в том виде, в котором их необходимо будет вставить в config.txt файл звуковой библиотеки
Перейдём к config.txt файлу. В нём необходимо создать стандартный блок расширений extensions. Выглядит это вот так
Код:
extensions
{
}
Затем, внутри этого блока необходимо создать блок, который и будет содержать длины звуковых файлов. Это будет выглядеть так
Код:
extensions
{
sound-length-base
{
}
}
И уже в блок sound-length-base необходимо вставить то, что получилось в файле len.txt. Конечный вариант файла конфигурации будет выглядеть так
Останется только получить актив библиотеки в скрипте, который и будет передан в качестве первого параметра для модифицированной функции.
Если звуки у нас в том же активе в котором скрипт, то это можно сделать вызвав функция GetAsset. Она вернёт ссылку на актив, в котором выполняется скрипт.
Если же звуки лежат в отдельном активе, то его необходимо прописать в kuid-table config.txt того актива, в котором выполняется скрипт, и с помощью функции FindAsset вытащить на него ссылку.
Подробнее об этих функциях можно узнать на wiki разработчиков
Надеюсь, что эта статья поможет начинающим скриптерам .... и не только
Последний раз редактировалось jim_spb; 21.06.2020 в 04:25.
Сообщение от ArtyemLavrov
Soup wavdb = srcAsset.GetConfigSoup().GetNamedSoup("extensions" ).GetNamedSoup("sound-length-base");
лучше её получить заранее 1 раз, и потом везде использовать.
ArtyemLavrov, конфиги в trainz "на лету" в процессе игры не редактируются. А то что ты предполагаешь (что у разных локов объект скрипта подгружается один) - в корне не верно, каждая секция локомотива подгружает и инициализирует свой собственный экземпляр класса со своим собственным рефференсом на свою звуковую бибилотеку и её конфиг.
Последний раз редактировалось TRam_; 15.12.2016 в 19:48.