Modding:Block Entity: Difference between revisions
(→The BlockEntity: Fixed typo (FromTreeAtributes -> FromTreeAttributes) and added missing parameter) |
|||
Line 100: | Line 100: | ||
} | } | ||
public override void | public override void FromTreeAttributes(ITreeAttribute tree, IWorldAccessor worldForResolving) | ||
{ | { | ||
base. | base.FromTreeAttributes(tree, worldForResolving); | ||
timer = tree.GetInt("timer"); | timer = tree.GetInt("timer"); | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Revision as of 18:01, 17 January 2021
This page was last verified for Vintage Story version 1.9.
Introduction
A block entity is a construct that you can tack onto an existing block to give it additional functionality. Whenever a block should do something on a regular interval or store extra information, such as the contents of a chest block, you need a block entity. It's highly recommend to have read the tutorial about Basic Blocks and Block Class in order to understand this tutorial properly.
The Texture Flipper
Let's create a block which switches its texture every 3 seconds. It should have two variants "on"
and "off"
. Additionally we need to define the blockentity class like so:
entityClass: "tickingcounter",
You can download the assets here and place it in your mods directory.
The BlockEntity
Now we need to register our blockentity class and therefore we need to create a new *.cs file in our project. Let's name it Ticking.cs
.
First of all you need to create the blockentity class itself. Therefore you need to extend BlockEntity
:
public class TickingBlockEntity : BlockEntity
{
}
This class needs to have a timer, once the timer reaches 3 seconds it should replace the current block with the different state.
In order to create a timer we need to register a tick listener. Therefore we need to override Initialize(ICoreAPI)
:
public override void Initialize(ICoreAPI api)
{
base.Initialize(api);
}
add a counter (which should increase per tick) ...
public int timer;
... and the actual ticking method ...
public void OnTick(float par)
{
}
To register the ticking method we can use RegisterGameTickListener
in Inizialize
public override void Initialize(ICoreAPI api)
{
base.Initialize(api);
RegisterGameTickListener(OnTick, 20);
}
The timer itself should increase per tick. It ticks 20 times per seconds, meaning 3 seconds have passed after the timer has reached 60. So if it's greater than 60 it should replace the block:
public void OnTick(float par)
{
timer++;
if(timer > 60)
{
Block block = Api.World.BlockAccessor.GetBlock(Pos);
if (block.Code.Path.EndsWith("-on"))
{
block = Api.World.GetBlock(block.CodeWithParts("off"));
}
else
{
block = Api.World.GetBlock(block.CodeWithParts("on"));
}
Api.World.BlockAccessor.SetBlock(block.BlockId, Pos);
}
}
Furthermore we need to save the current time:
public override void ToTreeAttributes(ITreeAttribute tree)
{
base.ToTreeAttributes(tree);
tree.SetInt("timer", timer);
}
public override void FromTreeAttributes(ITreeAttribute tree, IWorldAccessor worldForResolving)
{
base.FromTreeAttributes(tree, worldForResolving);
timer = tree.GetInt("timer");
}
Registering the Block Entity
Registering the blockentity class is rather simple (rather similar to registering a block class). You need a mod class and override Start(ICoreAPI)
:
public class Ticking : ModSystem
{
public override void Start(ICoreAPI api)
{
base.Start(api);
api.RegisterBlockEntityClass("tickingcounter", typeof(TickingBlockEntity));
}
}
Testing
Now everything is ready to run the first test:
Distribution
In order to finish everything, open the modtools and type in pack <your mod id>
. Now you can take the zip file and share it with other people. It will work in the same way as ordinary mods, you can install it by copying it into the mods folder.
Mod Download
- for VS 1.12 (Source only): GitHub
- for VS 1.9: Ticking_v1.0.0.zip
- for VS 1.6: Ticking.zip
Wondering where some links have gone?
The modding navbox is going through some changes! Check out Navigation Box Updates for more info and help finding specific pages.
Modding | |
---|---|
Modding Introduction | Getting Started • Theme Pack |
Content Modding | Content Mods • Developing a Content Mod • Basic Tutorials • Intermediate Tutorials • Advanced Tutorials • Content Mod Concepts |
Code Modding | Code Mods • Setting up your Development Environment |
Property Overview | Item • Entity • Entity Behaviors • Block • Block Behaviors • Block Classes • Block Entities • Block Entity Behaviors • Collectible Behaviors • World properties |
Workflows & Infrastructure | Modding Efficiency Tips • Mod-engine compatibility • Mod Extensibility • VS Engine |
Additional Resources | Community Resources • Modding API Updates • Programming Languages • List of server commands • List of client commands • Client startup parameters • Server startup parameters Example Mods • API Docs • GitHub Repository |