Skip to content

Latest commit

 

History

History
53 lines (34 loc) · 3.05 KB

README.md

File metadata and controls

53 lines (34 loc) · 3.05 KB

Skill Manager Mod Template

Some of the steps needed to set up a project using the Skill Manager from Blaxxun have already been done for you. Please read this file carefully if you have any issues. Also, asking in the OdinPlus discord if you need further assistance.

Skill Manager

Can be used to easily add new skills to Valheim. Will automatically add config options to your mod and sync the configuration from a server, if the mod is installed on the server as well. Please note that you still have to implement the effect your skill has yourself.

How to add skills

Copy the skill icon (a 64x64 image) into an icons directory in your project and make sure to set it as an EmbeddedResource in the properties of the asset bundle.

Merging the DLLs into your mod

The below steps are already done for you to merge ServerSync.dll into your mod. If you wish to not use the class for SkillManager please either remove or comment out the class code. Then navigate to the ILRepack.targets file and uncomment out the line to add the SkillManager.dll to the merged dlls.

Including the DLLs is best done via ILRepack (https://github.com/ravibpatel/ILRepack.Lib.MSBuild.Task). You can load this package (ILRepack.Lib.MSBuild.Task) from NuGet.

The template should have installed ILRepack via NuGet, simply create/edit the file named ILRepack.targets in your project and copy the following content into the file. This file should already be a part of the template.

<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
    <Target Name="ILRepacker" AfterTargets="Build">
        <ItemGroup>
            <InputAssemblies Include="$(TargetPath)" />
            <InputAssemblies Include="$(OutputPath)\SkillManager.dll" />
            <InputAssemblies Include="$(OutputPath)\ServerSync.dll" />
        </ItemGroup>
        <ILRepack Parallel="true" DebugInfo="true" Internalize="true" InputAssemblies="@(InputAssemblies)" OutputFile="$(TargetPath)" TargetKind="SameAsPrimaryAssembly" LibraryPath="$(OutputPath)" />
    </Target>
</Project>

Make sure to set the SkillManager.dll and the ServerSync.dll in your project to "Copy to output directory" in the properties of the DLLs and to add a reference to it. If you are not using the SkillManager.dll and are instead, using the class, you do not need to set this value for that DLL. After that, simply add using SkillManager; to your mod and use the Skill class, to add your skills.

The SkillManager also adds two extension methods GetSkillFactor and RaiseSkill on Character and Skills classes to get and increase the skill in your code by skill name.

Example projects

https://github.com/blaxxun-boop/Tenacity

This adds a skill Tenacity, which reduces the damage taken slightly. The tenacity-icon.png file is in a directory called icons.

https://github.com/blaxxun-boop/Building

This adds a skill Building, which increases the health of pieces built by you.

https://github.com/blaxxun-boop/Evasion

This adds a skill Evasion, which reduces the stamina usage of dodging.