Porting other faction's UI feature

From Total War Modding

This tutorial talks about how to create a custom twui based on other vanilla UI

Do not try to use twui unless you're confident with your scripting. In many cases, you can't make the twui do what you want because we don't understand many of the twui callbacks (especially from the ones before the Wh3) and you have to use the script for that. So practice scripting, or get a team member who is good at it.

Synopsis

Let's say I want to create a new feature for Wurrzag based on his dancing. Huh, what does dancing have to do with Total War and how are we going to represent it? Maybe I should focus on the rhythm of the dancing and fitting the perfect harmony. And for that, we should Harmony feature used by Cathay.


(I'm going to skip all the pooled resource parts, look at other tutorials if you don't have any ideas)

Getting Original Code

Harmony.png

First, you want to check the path and some component names by playing the Cathay and checking the path to the UI by using the component viewer. You can turn this feature on by checking the check box in the settings and pressing the ` button (the one on your upper left) in your keyboard

Twui.png


On hud_campaign_resource_bar_wh3.twui.xml or harmony.twui.xml, you'll find the twui parts responsible for it. Now it's time to copy it and make our own.

Making own twui

Now for Hierarchy, we want to copy 'Root' and all harmony-related parts. So the hierarchy part will look like below.

Harmony hierarchy.png
  1. Now for the component part, we want to copy every component mentioned in the hierarchy, including the root.
  2. After that, we want to change the pooled resource name and effect bundle name into what we have set.
  3. As a final step, we want to feed the hairy robot a twui we made to change the GUID
Guid regen.png

Congratulations, now you just finished your own twui. Now we have to show it to people via script. Put the twui made this way into your pack.

Scripting

Now write some script like the one below.


 cm:add_first_tick_callback(                                                                       
    function()
       if cm:get_local_faction_name(true) == "wh_main_grn_orcs_of_the_bloody_hand" then--put your faction name. It's just for showing UI so it should use cm:get_local_faction thing
           local parent_ui = find_uicomponent(core:get_ui_root(), "hud_campaign", "resources_bar_holder", "resources_bar");--where your TWUI will reside
           local result = core:get_or_create_component("rhox_dancer_harmony_holder", "ui/campaign ui/rhox_dancer.twui.xml", parent_ui) --put your path to the twui
           if not result then
               script_error("Rhox dancer: ".. "ERROR: could not create harmony ui component? How can this be?");
               return false;
           end;
       end
    end
 )

Apply this script to the mod, and start the game as Wurrzag and check whether it works.

Rhythm.png

Congratulations! You still have to set the script, and DB effect to really make it interesting, but the job on the twui side is done.

If it's not working, check the following things

  1. The component is not created, even in the component viewer: Check the script, and whether your twui has the correct structure. If you've set up all correctly, check the callbacks of the TWUI components. Very rarely some of them have 'destroy callbacks' in them
  2. Game CTDs: Check the hierarchy and whether your component has all the components listed in the hierarchy
  3. Things are not showing properly: Check the DBs and references of the DBs in the twui are correct.