On Project Imp we were going to have these puzzles that had environmental objects that needed to be destroyed. The player would acquire the fire mages powers and then be able to disintegrate stuff magically with the orb they throw. Initially the only object that needed to disintegrate was a vine. However, there were 4 different vines each with different materials.
Starting out I didn't know how to deal with the multiple materials. I prepared for the worst case scenario, copy and pasting to each material, by creating a material function for the effect. The easy part was done and then serendipity struck! I started this task a week after GDC when the 2018 videos were released. That GDC Bill Kladis went over the material pipeline used on Fortnite for effects.
I learned a few things from this task. First I gained a greater familiarity with materials and how they interact with blueprints in Unreal. Second I got the chance to actually implement a pipeline which is especially surprising considering I came onto Project Imp late. Third and final I gained experience explaining the importance of and what is involved with this type of approach to producers and programmers.
For the remainder of this post I will try my best to explain the pipeline in context of Project Imp. If you want to see it from the source the GDC talk was GDC 2018 Visual Effects Bootcamp: Autonomy in Real-Time Effects: Artist Driven Tools and Techniques for Large Scale Production (Link but it is premium content on the GDC vault at the time of this post).
Let's say you have three characters. They look completely different and could even have different rigs but chances are their materials are made up of the same contents. It could include a base color, diffuse, roughness, etc. Chances are it was imported into Unreal as one material per character. Let's say all three of those characters have a disintegration effect and only one of those characters have a spawn effect that takes place in the material. Instead of making an obscene amount of materials for each character you could do all this with only two materials. This is accomplished by an approach to setting up materials in the project and how to use them with the systems in the game.
You have a single Parent Material that knows how to handle the texture sheets and effects for the three characters. It would be set up like the above (figure A) with the base stuff being the texture sheets that then blends into every other node. In Unreal these nodes would be material functions that input and output material attributes. The Parent Material is the material attributes of the Parent Material but compressed as a single pin in Unreal.
At this point all you need is a material instance of the Parent Material for each character. If some of the characters have extra effects it's easy to add. You would duplicate the Parent Material and splice in the extra effect between the base stuff and the disintegration effect nodes. After that you use the Copy Material Instance Parameters node in blueprints. This node will copy the parameters so you don't have to make another material instance for each of those two characters.
The above (figure B) is an abstract overview of whats happening in consideration to an arbitrary number of enemies. The Data for Enemy is the material instance which is being processed by the Parent Material. In the case of extra effects that aren't present in the Parent Material the Data for Enemy is copied and then processed by the Modified Parent Material.