mirror of
https://github.com/Jacobwasbeast/LegacyWeaveLoader.git
synced 2026-05-22 21:54:30 +00:00
Mod Atlas (ModAtlas.cpp/h): - Build merged terrain.png and items.png from mod assets (blocks/*.png, items/*.png) - Scan vanilla atlas for empty (fully transparent) cells; place mod textures only there - Install merged atlases over game files before Minecraft::init; restore originals after - Hook loadUVs to create SimpleIcon objects for mod textures - Hook registerIcon to return mod icons when requested by name - FixupModIcons: copy field_0x48 (source-image ptr) from vanilla icons after init Mod Strings (ModStrings.cpp/h): - Store mod display names by description ID - Hook GetString to serve mod names for blocks/items API changes: - BlockProperties/ItemProperties: .Name(displayName), namespaced .Icon() - NativeInterop: displayName params, native_allocate_description_id, native_register_string - Registry.Assets for string registration - Output: mods/LegacyForge.API/, mods/ExampleMod/ (per-mod folders) Mod discovery: - Scan mods/*/ for mod folders; load DLLs from each - LegacyForge.API as mod in mods/LegacyForge.API/ ExampleMod: - Ruby ore block and ruby item with custom textures and names - Assets: blocks/ruby_ore.png, items/ruby.png, lang files - Furnace recipe: ruby_ore -> ruby Runtime: loadUVs, registerIcon, getResourceAsStream, GetString hooks; stb_image for PNG
59 lines
2.0 KiB
C#
59 lines
2.0 KiB
C#
namespace LegacyForge.API.Block;
|
|
|
|
/// <summary>
|
|
/// Represents a block that has been registered with the game engine.
|
|
/// </summary>
|
|
public class RegisteredBlock
|
|
{
|
|
/// <summary>The namespaced string ID (e.g. "mymod:ruby_ore").</summary>
|
|
public Identifier StringId { get; }
|
|
|
|
/// <summary>The numeric ID allocated by the engine.</summary>
|
|
public int NumericId { get; }
|
|
|
|
internal RegisteredBlock(Identifier id, int numericId)
|
|
{
|
|
StringId = id;
|
|
NumericId = numericId;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Block registration via the LegacyForge registry.
|
|
/// Accessed through <see cref="Registry.Block"/>.
|
|
/// </summary>
|
|
public static class BlockRegistry
|
|
{
|
|
/// <summary>
|
|
/// Register a new block with the game engine.
|
|
/// </summary>
|
|
/// <param name="id">Namespaced identifier (e.g. "mymod:ruby_ore").</param>
|
|
/// <param name="properties">Block properties built with <see cref="BlockProperties"/>.</param>
|
|
/// <returns>A handle to the registered block.</returns>
|
|
public static RegisteredBlock Register(Identifier id, BlockProperties properties)
|
|
{
|
|
int numericId = NativeInterop.native_register_block(
|
|
id.ToString(),
|
|
(int)properties.MaterialValue,
|
|
properties.HardnessValue,
|
|
properties.ResistanceValue,
|
|
(int)properties.SoundValue,
|
|
properties.IconValue,
|
|
properties.LightEmissionValue,
|
|
properties.LightBlockValue,
|
|
properties.NameValue ?? "");
|
|
|
|
if (numericId < 0)
|
|
throw new InvalidOperationException($"Failed to register block '{id}'. No free IDs or invalid parameters.");
|
|
|
|
if (properties.CreativeTabValue != CreativeTab.None)
|
|
{
|
|
NativeInterop.native_add_to_creative(numericId, 1, 0, (int)properties.CreativeTabValue);
|
|
Logger.Debug($"Block '{id}' added to creative tab {properties.CreativeTabValue}");
|
|
}
|
|
|
|
Logger.Debug($"Registered block '{id}' -> numeric ID {numericId}");
|
|
return new RegisteredBlock(id, numericId);
|
|
}
|
|
}
|