Audio modding: Difference between revisions
| No edit summary | No edit summary | ||
| Line 128: | Line 128: | ||
| The Audio Mixer is a compatibility mod which facilitates custom VO. It is made possible by ChaosRobie's Dialogue_Event Merger tool. To get custom VO in game you can either build your Wwise project yourself or give the people maintaining the Audio Mixer your voice acting files and they will build it for you. The amount of voice acting do is entirely up to you. You could add custom audio for every Dialogue_Event for your character, or just the essentials. | The Audio Mixer is a compatibility mod which facilitates custom VO. It is made possible by ChaosRobie's Dialogue_Event Merger tool. To get custom VO in game you can either build your Wwise project yourself or give the people maintaining the Audio Mixer your voice acting files and they will build it for you. The amount of voice acting do is entirely up to you. You could add custom audio for every Dialogue_Event for your character, or just the essentials. | ||
| Below is a full list of all the different Dialogue_Events in the game. You can add custom voice acting for each of these. Some of them are self explanatory, for example `battle_vo_order_attack` is the Dialogue_Event for when you tell your unit to attack another unit in battle. To learn more about each Dialogue_Event refer to the Researching Dialogue_Events section of this wiki. | Below is a full list of all the different Dialogue_Events in the game. You can add custom voice acting for each of these. Some of them are self explanatory, for example `battle_vo_order_attack` is the Dialogue_Event for when you tell your unit to attack another unit in battle. To learn more about each Dialogue_Event refer to the Researching Dialogue_Events section of this wiki. | ||
Revision as of 19:46, 28 January 2024
WH3 Audio Modding After a long time, Audio modding is now possible. This is entirely down to the years of research into audio and work developing the tools by Ole and ChaosRobie.
The Basics
The Total War games use an audio engine called Wwise. It is a very powerful but complex system. In short Wwise produces these things called soundbanks (.bnk files). Soundbanks store the information about how audio is played in the game.
If you want to mod audio it would probably be a good idea to have some understanding of the basics of Wwise. Some of this is covered below, however for a more foundational understanding read the WWiser documentation.
Wwise Objects
In Wwise there things called objects. The most basic objects we will interact with are Events, Containers, Sounds, Actor Mixers.
Events
Everything apart from music and VO starts with an Event. The game will typically refer to the Events, either in script, anim.meta file or db.
There are two event types, Event and Dialog_Event. After the event there is a chain of object that leads you to the actual audio played.
For example this basic Event will play a random sound from a collection of two.
Karl_Eating_Goblin_Event => Karl_Eating_Goblin_Event_ActionPlay => Random Container => Soundx.mp3 and soundy.mp3.
They follow a basic pattern most of the time. Event => Action => Container (optional) => Sound(s)
The second event type is a Dialog_Event. It has nothing to do with dialog, its a lookup table that results in container or sound object.
| UnitVoiceActor | UnitType | SpottedFacton | Child | 
|---|---|---|---|
| Orc_Female_1 | Ranged | Human | 123 | 
| Orc_Male_1 | Ranged | DarkElf | 456 | 
| OrC_Male2 | Melee | Orc | 678 | 
When the Dialogue_Event is triggered, the game sets variables (States) which are used to lookup the child node, which typically points to a Container which in turn points to sounds.
So for example if you are playing as the Empire, and as Karl Franz, and you move on the campaign map, the game sees that you've just moved the big man. The Dialogue_Event for this particular condition is activated and follows the path of the provided variables, e.g. Culture: Empire, Voice Actor: Franz and plays the audio for Franz moving his army on the campaign map.
Containers
One type of Container is a Random Container. They are an organisational and control tool for sound objects. When triggered a Random Container would play one of its sounds, you guessed it, at random!
Sounds
Sound objects are how sound files are represented within WWise. Wwise uses .wav files, and exports them as .wem files.
Actor Mixer
Actor Mixers serve as an organisational and control tool for sound objects. It allows you to break sounds down into 'folders'. Mixers control who owns the sounds - if it's a UI sound, game sound, battle sound and so on. This is important to make the sound play as not all ActorMixer has their volume set at all times.
The Tools
The main tools used in audio modding are: Audio Explorer, Audio Project Compiler, Bnk Patcher, Dat Builder, File Converters, Dialogue Event Merger, Wwiser.
Some of these tools do the same thing just in different ways so you should read up on them individually.
Audio Explorer
The Audio Explorer is a tool for exploring the audio data in the game. It has many use cases, for example learning how Wwise works or browsing for specific sound files.
Learning Wwise
The tool allows pretty much all wwise objects to be explored. This is very useful to learn how you later can use the Audio Project Complier to add new sounds. Under extra you can pick between Events and Dialog_Events.
The left side shows the full graph of the selected event, while the right side shows a detailed view of the Wwise data of the selected node.
Finding Sounds
Using this tool its very easy to lean which sound file is linked to what event.
Say you want to make a mod that replaces all of Throggs diplomacy lines. Doing a search in the database will give you all the events used, you can then look that up in the events view.
If one takes the event "Play_Nor_Throgg_Dip_Dwf_Greet_Neg_02" which is for when Throgg talks to dwarfs, one can see that this is linked to the sound file "605570708.wem"
Researching Dialogue_Events
You can browse for specific Dialogue_Events to see what type of sounds they play in vanilla.
Let's say you want to make your own voice acting for a character of yours. You have looked through the list of all the Dialogue_Events, and you want to look more into what exactly the voice acting for the `battle_vo_order_attack` Dialogue_Event sounds like in vanilla.
So search the Audio Explorer for a Dialogue_Event e.g. `battle_vo_order_attack`.
Then browse to a voice actor of your choosing, for example Karl Franz. There you can see what his voice acting for this Dialogue_Event sounds like and make your own for your character in a similar vein.
Understanding Actor Mixers and Audio Bussess
All sounds have to be connected to a mixer (which in turn is connected to a bus). Not all busses have their volume set at all times. For example the UI and Battle bus is not both enabled at the same time. Because of this its important that the correct mixer is selected when adding new sounds. When selecting a Sound node on the left side, "Parent structure" is added on the right side. Here you can see the mixers and busses connected to the sound. you typically want to use the fist id of the first ActorMixer with an audio bus for the "RootAudioMixer" setting in your custom audio project.
Audio Project Compiler
NOTE: THIS TOOL IS CURRENTLY BEING REDEVELOPED. THE WIKI WILL BE UPDATED ONCE IT IS UPDATED.
The Audio Project Compiler is a tool within the AssetEditor which you can use to build custom audio.
New Non-VO Audio
Bnk Patcher
This tool is intended by anyone who wishes to use Wwise rather than the AssetEditor Audio Project Compiler to mod audio. There are some advantanges (and disadvantages) to using Wwise over the AssetEditor. The main advantage is that you can use the full set of features that Wwise offers which is vast. The AssetEditor audio tools are a very simple and much more user friendly tool.
CA use a custom version of Wwise for WH3 audio. Different versions of Wwise produce objects in different formats. The closest public release of Wwise to CA's version is 2019.2.15.7667. CA's version of Wwise produces a different header in their soundbanks, and produces some music objects in a different format to Wwise version 2019.2.15.7667. Therefore a patcher is required.
Wwise is free software which can be downloaded here.
The tool can be downloaded here.
Instructions
- Download the tool and open it in a code editor e.g. Visual Studio Code. - Add your input and output paths for your banks to `bnk_paths`. - Add the path of your wems to `wems_path`. - Specify whether you want to scramble the wems as well by changing `scramble_wems` to True of False. - Add any IDs that need replacing to `ids_to_replace`. - Run the script with Python.
Dialogue_Event Merger
This is an excellent tool created by ChaosRobie which enables VO. The Audio Mixer mod uses this to merge the new custom VO created within Wwise into the vanilla soundbanks.
Dat Builder
This tool is intended by anyone who wishes to use Wwise rather than the AssetEditor Audio Project Compiler to mod audio. It is a script to write the dat file necessary for custom non-VO audio.
The tool can be downloaded here.
VO Audio Modding
The Audio Mixer is a compatibility mod which facilitates custom VO. It is made possible by ChaosRobie's Dialogue_Event Merger tool. To get custom VO in game you can either build your Wwise project yourself or give the people maintaining the Audio Mixer your voice acting files and they will build it for you. The amount of voice acting do is entirely up to you. You could add custom audio for every Dialogue_Event for your character, or just the essentials.
Below is a full list of all the different Dialogue_Events in the game. You can add custom voice acting for each of these. Some of them are self explanatory, for example `battle_vo_order_attack` is the Dialogue_Event for when you tell your unit to attack another unit in battle. To learn more about each Dialogue_Event refer to the Researching Dialogue_Events section of this wiki.
Battle VO
This stuff happens in a battle. Plain and simple these events take place when a unit is interacted with by the player. There are some subsets within this that can pertain to what kind of unit it is.
The bare minimum needed:
battle_vo_order_attack battle_vo_order_generic_response battle_vo_order_halt battle_vo_order_move battle_vo_order_select battle_vo_order_withdraw battle_vo_order_withdraw_tactical
Situationally used and entirely unnecessary if you don't want to use them:
battle_vo_order_flying_charge battle_vo_order_formation_lock battle_vo_order_formation_unlock battle_vo_order_group_created battle_vo_order_group_disbanded battle_vo_order_guard_off battle_vo_order_guard_on battle_vo_order_melee_off battle_vo_order_melee_on battle_vo_order_fire_at_will_off battle_vo_order_fire_at_will_on battle_vo_order_skirmish_off battle_vo_order_skirmish_on battle_vo_order_special_ability battle_vo_order_change_formation battle_vo_order_change_ammo battle_vo_order_climb battle_vo_order_man_siege_tower battle_vo_order_move_ram battle_vo_order_move_siege_tower battle_vo_order_pick_up_engine battle_vo_order_short_order battle_vo_order_move_alternative battle_vo_order_attack_alternative battle_vo_order_bat_mode_capture_neg battle_vo_order_bat_mode_capture_pos battle_vo_order_bat_mode_survival battle_vo_order_bat_speeches battle_vo_order_battle_continue_battle battle_vo_order_battle_quit_battle
Conversational Battle VO
This is usually the chitter chatter that goes on between units.
battle_vo_conversation_allied_unit_routing battle_vo_conversation_clash battle_vo_conversation_def_own_army_murderous_prowess_100_percent battle_vo_conversation_def_own_army_murderous_prowess_75_percent battle_vo_conversation_dissapointment battle_vo_conversation_encouragement battle_vo_conversation_enemy_army_at_chokepoint battle_vo_conversation_enemy_army_black_arks_triggered battle_vo_conversation_enemy_army_has_many_cannons battle_vo_conversation_enemy_skaven_unit_revealed battle_vo_conversation_enemy_unit_at_rear battle_vo_conversation_enemy_unit_charging battle_vo_conversation_enemy_unit_chariot_charge battle_vo_conversation_enemy_unit_dragon battle_vo_conversation_enemy_unit_flanking battle_vo_conversation_enemy_unit_flying battle_vo_conversation_enemy_unit_large_creature battle_vo_conversation_enemy_unit_revealed battle_vo_conversation_enemy_unit_spell_cast battle_vo_conversation_environment_ground_type_forest battle_vo_conversation_environment_ground_type_mud battle_vo_conversation_environment_in_cave battle_vo_conversation_environment_in_water battle_vo_conversation_environment_weather_cold battle_vo_conversation_environment_weather_desert battle_vo_conversation_environment_weather_rain battle_vo_conversation_environment_weather_snow battle_vo_conversation_own_army_at_chokepoint battle_vo_conversation_own_army_black_arks_triggered battle_vo_conversation_own_army_caused_damage battle_vo_conversation_own_army_missile_amount_inferior battle_vo_conversation_own_army_missile_amount_superior battle_vo_conversation_own_army_peasants_fleeing battle_vo_conversation_own_army_spell_cast battle_vo_conversation_own_unit_artillery_fire battle_vo_conversation_own_unit_artillery_firing battle_vo_conversation_own_unit_artillery_reload battle_vo_conversation_own_unit_fearful battle_vo_conversation_own_unit_moving battle_vo_conversation_own_unit_routing battle_vo_conversation_own_unit_under_dragon_firebreath_attack battle_vo_conversation_own_unit_under_ranged_attack battle_vo_conversation_own_unit_wavering battle_vo_conversation_proximity battle_vo_conversation_siege_attack battle_vo_conversation_siege_defence battle_vo_conversation_storm_of_magic battle_vo_conversation_def_own_army_murderous_prowess_100_percent battle_vo_conversation_def_own_army_murderous_prowess_75_percent battle_vo_conversation_hef_own_army_air_units battle_vo_conversation_hef_own_army_low_stength battle_vo_conversation_lzd_own_army_dino_rampage battle_vo_conversation_skv_own_unit_spawn_units battle_vo_conversation_skv_own_unit_tactical_withdraw battle_vo_conversation_skv_own_unit_warpfire_artillery
Frontend
The frontend VO which plays when you select a faction to play as.
frontend_vo_character_select
Campaign VO
These are events which play on the campaign map.
campaign_vo_agent_action_failed campaign_vo_agent_action_success campaign_vo_attack campaign_vo_created campaign_vo_diplomacy_negative campaign_vo_diplomacy_positive campaign_vo_diplomacy_selected campaign_vo_move campaign_vo_move_garrisoning campaign_vo_move_next_turn campaign_vo_new_commander campaign_vo_no campaign_vo_no_short campaign_vo_post_battle_defeat campaign_vo_post_battle_victory campaign_vo_retreat campaign_vo_selected campaign_vo_selected_allied campaign_vo_selected_fail campaign_vo_selected_first_time campaign_vo_selected_neutral campaign_vo_selected_short campaign_vo_ship_dock campaign_vo_stance_ambush campaign_vo_stance_channeling campaign_vo_stance_default campaign_vo_stance_double_time campaign_vo_stance_land_raid campaign_vo_stance_march campaign_vo_stance_patrol campaign_vo_stance_set_camp campaign_vo_stance_settle campaign_vo_yes campaign_vo_yes_short campaign_vo_yes_short_aggressive campaign_vo_cam_disband campaign_vo_cam_disbanded_neg campaign_vo_cam_disbanded_pos campaign_vo_cam_skill_weapon_tree campaign_vo_cam_skill_weapon_tree_response campaign_vo_cam_tech_tree campaign_vo_cam_tech_tree_response campaign_vo_level_up campaign_vo_mounted_creature campaign_vo_recruit_units campaign_vo_retreat campaign_vo_special_ability campaign_vo_stance_astromancy campaign_vo_stance_muster campaign_vo_stance_raise_dead campaign_vo_stance_set_camp_raiding campaign_vo_stance_stalking campaign_vo_stance_tunneling
Campaign Conversational VO
Conversational VO that happens on the campaign map.
campaign_vo_cs_city_buildings_damaged campaign_vo_cs_city_high_corruption campaign_vo_cs_city_other_generic campaign_vo_cs_city_own_generic campaign_vo_cs_city_public_order_low campaign_vo_cs_city_riot campaign_vo_cs_city_under_siege campaign_vo_cs_confident campaign_vo_cs_enemy_region_generic campaign_vo_cs_forbidden_workshop_purchase_doomrocket campaign_vo_cs_forbidden_workshop_upgrade_doomflayer campaign_vo_cs_forbidden_workshop_upgrade_doomwheel campaign_vo_cs_forbidden_workshop_upgrade_weapon_teams campaign_vo_cs_hellforge_accept campaign_vo_cs_hellforge_customisation_category campaign_vo_cs_hellforge_customisation_unit campaign_vo_cs_in_forest campaign_vo_cs_in_mountains campaign_vo_cs_in_rain campaign_vo_cs_in_snow campaign_vo_cs_intimidated campaign_vo_cs_monster_pens_dilemma_ghrond campaign_vo_cs_monster_pens_dilemma_lustria campaign_vo_cs_monster_pens_dilemma_naggaroth campaign_vo_cs_monster_pens_dilemma_old_world campaign_vo_cs_monster_pens_event campaign_vo_cs_near_sea campaign_vo_cs_neutral campaign_vo_cs_on_sea campaign_vo_cs_other_character_details_panel_low_loyalty campaign_vo_cs_other_character_details_panel_neutral campaign_vo_cs_other_character_details_panel_positive campaign_vo_cs_post_battle_captives_enslave campaign_vo_cs_post_battle_captives_execute campaign_vo_cs_post_battle_captives_release campaign_vo_cs_post_battle_close_defeat campaign_vo_cs_post_battle_close_victory campaign_vo_cs_post_battle_defeat campaign_vo_cs_post_battle_great_defeat campaign_vo_cs_post_battle_great_victory campaign_vo_cs_post_battle_settlement_do_nothing campaign_vo_cs_post_battle_settlement_establish_foreign_slot campaign_vo_cs_post_battle_settlement_loot campaign_vo_cs_post_battle_settlement_occupy campaign_vo_cs_post_battle_settlement_occupy_factory campaign_vo_cs_post_battle_settlement_occupy_outpost campaign_vo_cs_post_battle_settlement_occupy_tower campaign_vo_cs_post_battle_settlement_raze campaign_vo_cs_post_battle_settlement_reinstate_elector_count campaign_vo_cs_post_battle_settlement_sack campaign_vo_cs_post_battle_settlement_vassal_enlist campaign_vo_cs_post_battle_victory campaign_vo_cs_pre_battle_fight_battle campaign_vo_cs_pre_battle_retreat campaign_vo_cs_pre_battle_siege_break campaign_vo_cs_pre_battle_siege_continue campaign_vo_cs_proximity campaign_vo_cs_sacrifice_to_sotek campaign_vo_cs_sea_storm campaign_vo_cs_spam_click campaign_vo_cs_summon_elector_counts_panel_open_vo campaign_vo_cs_tzarkan_calls_and_taunts campaign_vo_cs_tzarkan_whispers campaign_vo_cs_weather_cold campaign_vo_cs_weather_hot campaign_vo_cs_wef_daiths_forge gotrek_felix_arrival gotrek_felix_departure


