custom-mob-spawn-egg
について
このスキルは、Minecraft MODにカスタムモブスポーンエッグを追加する実装ガイダンスを提供します。Fabric版とNeoForge版の両方に対応し、アイテム登録、エンティティ設定、リソースファイル設定を網羅した包括的なチェックリストを含みます。スポーンエッグ作成時に発生しやすい、黒い四角やグレースケールテクスチャといった視覚的な不具合を防ぐためにご利用ください。
クイックインストール
Claude Code
推奨/plugin add https://github.com/majiayu000/claude-skill-registrygit clone https://github.com/majiayu000/claude-skill-registry.git ~/.claude/skills/custom-mob-spawn-eggこのコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします
ドキュメント
Custom Mob Spawn Egg Implementation Guide
Purpose: Ensure all required steps are completed when adding a spawn egg for a custom mob. Spawn eggs require multiple registration points across Fabric, NeoForge, and multi-version resource files. Missing any step causes visual bugs (grayscale, invisible texture).
Spawn Egg Implementation Checklist
When adding a spawn egg for a new custom mob, all of the following steps must be completed:
1. Item Registration (ModItems.java)
Register the spawn egg item in ModItems.java for each version.
1.21.2 (requires .setId()):
public static final RegistrySupplier<Item> MOB_NAME_SPAWN_EGG = ITEMS.register(
"mob_name_spawn_egg",
() -> new com.chronodawn.items.DeferredSpawnEggItem(
ModEntities.MOB_NAME,
0xAABBCC, // Background color
0xDDEEFF, // Spots color
new Item.Properties()
.setId(ResourceKey.create(Registries.ITEM,
ResourceLocation.fromNamespaceAndPath(ChronoDawn.MOD_ID, "mob_name_spawn_egg")))
)
);
1.21.1 / 1.20.1 (simpler, no .setId()):
public static final RegistrySupplier<Item> MOB_NAME_SPAWN_EGG = ITEMS.register(
"mob_name_spawn_egg",
() -> new com.chronodawn.items.DeferredSpawnEggItem(
ModEntities.MOB_NAME,
0xAABBCC, // Background color
0xDDEEFF, // Spots color
new Item.Properties()
)
);
2. Initialize Spawn Egg (ModItems.java)
Add the initializeSpawnEgg() call inside the initializeSpawnEggs() method:
if (MOB_NAME_SPAWN_EGG.get() instanceof com.chronodawn.items.DeferredSpawnEggItem) {
((com.chronodawn.items.DeferredSpawnEggItem) MOB_NAME_SPAWN_EGG.get()).initializeSpawnEgg();
}
3. Creative Tab Entry (ModItems.java)
Add to the populateCreativeTab() method:
if (MOB_NAME_SPAWN_EGG.isPresent()) {
output.accept(MOB_NAME_SPAWN_EGG.get());
}
4. Item Model File (CRITICAL)
Without this file, the spawn egg will be completely invisible in the inventory.
Create models/item/mob_name_spawn_egg.json in all version resource directories:
common-1.20.1/src/main/resources/assets/chronodawn/models/item/common-1.21.1/src/main/resources/assets/chronodawn/models/item/common-1.21.2/src/main/resources/assets/chronodawn/models/item/
Content (identical for all versions):
{
"parent": "item/template_spawn_egg"
}
No custom texture file is needed - Minecraft generates the spawn egg texture procedurally from the two color values.
5. NeoForge Color Handler Registration (CRITICAL)
Without this, the spawn egg will appear grayscale on NeoForge. Fabric handles this automatically via vanilla mechanisms, but NeoForge requires explicit registration.
File: neoforge-base/src/main/java/com/chronodawn/neoforge/client/ChronoDawnClientNeoForge.java
Add ModItems.MOB_NAME_SPAWN_EGG.get() to the item list in the onRegisterItemColors method:
@SubscribeEvent
public static void onRegisterItemColors(RegisterColorHandlersEvent.Item event) {
event.register(
(stack, tintIndex) -> {
if (stack.getItem() instanceof com.chronodawn.items.DeferredSpawnEggItem egg) {
int color = egg.getColor(tintIndex);
return 0xFF000000 | color;
}
return 0xFFFFFFFF;
},
// ... existing spawn eggs ...
ModItems.MOB_NAME_SPAWN_EGG.get() // <-- Add here
);
}
6. Language Files
Add entries to both en_us.json and ja_jp.json for all 3 versions:
"item.chronodawn.mob_name_spawn_egg": "Mob Name Spawn Egg"
Common Issues
| Symptom | Cause | Fix |
|---|---|---|
| Spawn egg invisible, or black square (dark purple on hover) | Missing item model JSON | Add models/item/xxx_spawn_egg.json with "parent": "item/template_spawn_egg" |
| Grayscale on NeoForge only | Missing NeoForge color handler | Add to onRegisterItemColors in ChronoDawnClientNeoForge.java |
| Correct on NeoForge, broken on Fabric | Missing initializeSpawnEgg() call | Add to initializeSpawnEggs() |
| No name displayed | Missing lang entry | Add to en_us.json / ja_jp.json |
| Not in creative tab | Missing creative tab entry | Add to populateCreativeTab() |
Why NeoForge Needs Explicit Color Registration
Minecraft spawn eggs use tintIndex (0 = background, 1 = spots) to colorize the template texture at runtime. Fabric integrates with vanilla's ColorProviderRegistry automatically through DeferredSpawnEggItem, but NeoForge uses its own event system (RegisterColorHandlersEvent.Item) which requires manual registration. The alpha channel (0xFF000000 |) must also be added explicitly on NeoForge.
GitHub リポジトリ
関連スキル
content-collections
メタThis skill provides a production-tested setup for Content Collections, a TypeScript-first tool that transforms Markdown/MDX files into type-safe data collections with Zod validation. Use it when building blogs, documentation sites, or content-heavy Vite + React applications to ensure type safety and automatic content validation. It covers everything from Vite plugin configuration and MDX compilation to deployment optimization and schema validation.
creating-opencode-plugins
メタThis skill provides the structure and API specifications for creating OpenCode plugins that hook into 25+ event types like commands, files, and LSP operations. It offers implementation patterns for JavaScript/TypeScript modules that intercept and extend the AI assistant's lifecycle. Use it when you need to build event-driven plugins for monitoring, custom handling, or extending OpenCode's capabilities.
polymarket
メタThis skill enables developers to build applications with the Polymarket prediction markets platform, including API integration for trading and market data. It also provides real-time data streaming via WebSocket to monitor live trades and market activity. Use it for implementing trading strategies or creating tools that process live market updates.
langchain
メタLangChain is a framework for building LLM applications using agents, chains, and RAG pipelines. It supports multiple LLM providers, offers 500+ integrations, and includes features like tool calling and memory management. Use it for rapid prototyping and deploying production systems like chatbots, autonomous agents, and question-answering services.
