Jump Space

Details

Last Updated
5 days ago
First Uploaded
5 days ago
Downloads
85
Likes
0
Size
25KB
Dependency string
CocoPopEater-ModelSwapLib-2.1.0
Dependants

Categories

Model Swap Lib

Model Swap Lib is an abstraction originally based on this Asset Swap Template for the game Jump Space.

This library is intended for use by mod developers and will have no effect if installed alone.

Usage Steps:

  1. Add ModelSwapLib.dll as a project reference
  2. Include [assembly: MelonAdditionalDependencies("ModelSwapLib")] in your core file
  3. Instantiate a swapper using one of the options below
  4. Register your swapper with ObjectActionManager.GetInstance().RegisterSwapper(swapper); - This will return a populated Guid if this succeeded, or a Guid.Empty if ModelSwapLib was unable to validate the Swapper structure

There are 2 ways to create a swapper:

Option 1 - Builder Pattern:

Swapper swapper = new SwapperBuilder("Optional ModName")
    .SetModName("YourModName")
    .SetSwapperName("Any Name You Want")
    .SetBundleName("YourBundle.bundle")
    .AddObjectName("ObjectName")
    .AddAssetModule(new MeshModule("Path/To/Your/Model.fbx"))
    .AddAssetModule(new Texture2DModule("Path/To/Your/Texture.png"))
    .AddTransformModule(new MoveMeshModule(0f, 0f, 0f))
    .AddTransformModule(new RotateMeshModule(0f, 0f, 0f))
    .AddTransformModule(new ScaleMeshModule(0f, 0f, 0f))
    .AddDeactivation("ObjectYouWantDeactivated")
    .Build();

new Swapper() - The string parameter for ModName is optional here but is required at some point

SetModName(string) - ModName is a required parameter for a Swapper

SetSwapperName(string) - SwapperName is not required and will default to "Unnamed Swapper", this is mainly for logging

SetBundleName(string) - BundleName is only required if you use an IAssetModule

AddObjectName(string) - Swapper must contain at least 1 object name, otherwise it will not apply to anything and will be rejected

AddAssetModule(IAssetModule) - List of modules that use an asset from a provided AssetBundle

AddTransformModule(ITransformModule) - List of modules that manipulate the transform of a mesh

AddDeactivation(string) - List of object names to be deactivated

Additional methods include:

  • AddObjectNames(List<string>)
  • AddAssetModules(List<IAssetModule>)
  • AddTransformModules(List<ITransformModule>)
  • AddDeactivations(List<string>)

Build() - Returns the swapper object, or null if the configuration is not valid

Option 2 - Manual creation:

Swapper swapper = new Swapper
{
    ModName = "YourModName",
    SwapperName = "Any Name You Want",
    ObjectNames = new List<string>([
                    "ObjectName1",
                    "ObjectName2"
        ]),
    BundleName = "YourBundle.bundle",
    AssetModules = new List<IAssetModule>
    {
        new MeshModule("Path/To/Your/Model.fbx"),
        new Texture2DModule("Path/To/Your/Texture.png")
    },
    TransformModules = new List<ITransformModule>
    {
        new MoveMeshModule(0f, 0f, 0f),
        new RotateMeshModule(0f, 0f, 0f),
        new ScaleMeshModule(0f, 0f, 0f)
    },
    Deactivations = new List<string>
    {
        "ObjectYouWantDeactivated"
    }
};

Full Implementation Template

[assembly: MelonAdditionalDependencies("ModelSwapLib")]

namespace YourMod
{
    public class Core : MelonMod
    {
        public override void OnInitializeMelon()
        {
            Swapper swapper = new SwapperBuilder()
                .SetModName("YourModName")
                .SetSwapperName("Any Name You Want")
                .AddObjectNames(["ObjectName1", "ObjectName2"])
                .SetBundleName("YourBundle.bundle")
                .AddAssetModule(new MeshModule("Path/To/Your/Model.fbx"))
                .AddAssetModule(new Texture2DModule("Path/To/Your/Texture.png"))
                .AddTransformModule(new MoveMeshModule(0f, 0f, 0f))
                .AddTransformModule(new RotateMeshModule(0f, 0f, 0f))
                .AddTransformModule(new ScaleMeshModule(0f, 0f, 0f))
                .AddDeactivation("ObjectYouWantDeactivated")
                .Build();
            
            if(swapper == null)
            {
                Melon<Core>.Logger.Warning($"Invalid swapper");
            }else{
                Guid guid = ObjectActionManager.GetInstance().RegisterSwapper(swapper);
            
                if(guid == Guid.Empty) // If you receive a Guid.Empty then the Swapper.Validate() failed
                {
                    Melon<Core>.Logger.Warning($"Failed to register swapper: {swapper.SwapperName}");
                } else
                {
                    Melon<Core>.Logger.Msg($"Successfully registered swapper: {swapper.SwapperName} with guid: {swapper.SwapperGuid}");
                }
            }
            
            Melon<Core>.Logger.Msg($"YourMod Initialized");
        }
    }
}

Required Parameters:

ModName
At least 1 ObjectName
At least 1 IAssetModule, ITransformModule OR Deactivation
BundleName if you use an IAssetModule

Many thanks to GraciousCub5622 @graciouscub5622 on discord for his Asset Swap Template, upon which this entire project is based.
Many thanks to ScribbleTAS for MeshUtils and also for his help in debugging and brainstorming.

Thunderstore development is made possible with ads. Please consider making an exception to your adblock.
Thunderstore development is made possible with ads. Please consider making an exception to your adblock.
Thunderstore development is made possible with ads. Please consider making an exception to your adblock.