手把手教你用XML为RimWorld Mod添加第一个新物品:从Defs文件到游戏内生效全流程

张开发
2026/4/11 11:32:21 15 分钟阅读

分享文章

手把手教你用XML为RimWorld Mod添加第一个新物品:从Defs文件到游戏内生效全流程
从零开始为RimWorld Mod添加自定义武器XML实战指南第一次打开RimWorld的Mod文件夹时那些密密麻麻的XML文件可能让人望而生畏。但别担心——每个资深Mod作者都经历过这个阶段。今天我们就用最直观的方式带你完成第一个可运行的物品Mod一把带有你个人印记的定制钢剑。这不是理论课而是一次手把手的实战演练你会亲眼看到代码如何转化为游戏中的实体物品。1. 准备工作搭建你的第一个Mod骨架在开始编写XML之前我们需要先建立一个标准的Mod文件夹结构。打开RimWorld的Mods目录通常位于Steam\steamapps\common\RimWorld\Mods新建一个文件夹命名为YourName_FirstSword——建议用你的昵称或缩写作为前缀这是Mod开发的良好习惯。在这个文件夹内创建以下结构YourName_FirstSword/ ├── About/ │ └── About.xml ├── Defs/ │ └── ThingDefs_Weapons.xml └── Textures/ └── YourName_Sword.png现在打开About.xml文件填入基础信息?xml version1.0 encodingutf-8? ModMetaData name你的第一把剑/name author你的名字/author packageIdYourName.FirstSword/packageId description我的第一个RimWorld Mod作品/description version1.0/version loadAfter liCore/li /loadAfter /ModMetaData提示packageId需要全局唯一建议采用作者名.Mod名的格式。这是Mod在系统中的唯一标识符。2. 定义你的第一件武器ThingDef详解打开ThingDefs_Weapons.xml我们将在这里定义新武器的所有属性。从最基础的框架开始?xml version1.0 encodingutf-8? Defs ThingDef ParentNameBaseWeapon defNameYourName_SteelSword/defName label旋风钢剑/label description一把轻盈但致命的武器剑身刻有独特的螺旋纹路。/description !-- 更多属性将在这里添加 -- /ThingDef /Defs让我们分解这个基础结构的关键元素defName武器的唯一标识符必须全部由字母、数字和下划线组成。建议采用作者前缀_物品名的格式label游戏中显示的名称支持中文和特殊字符description物品的详细描述会显示在物品信息面板ParentName继承自BaseWeapon这表示我们的剑将拥有所有基础武器的默认属性3. 完善武器属性从基础到进阶现在为我们的钢剑添加更多实用属性。在原有代码中继续扩展ThingDef ParentNameBaseWeapon !-- 基础信息 -- statBases MarketValue350/MarketValue Mass1.2/Mass WorkToMake4000/WorkToMake MeleeWeapon_DamageAmount14/MeleeWeapon_DamageAmount MeleeWeapon_Cooldown2.1/MeleeWeapon_Cooldown MeleeWeapon_DamageDefCut/MeleeWeapon_DamageDef /statBases graphicData texPathThings/Item/Weapon/YourName_Sword/texPath graphicClassGraphic_Single/graphicClass /graphicData weaponTags liMelee/li liSharp/li /weaponTags tools li label剑刃/label capacities liCut/li /capacities power14/power cooldownTime2.1/cooldownTime /li /tools /ThingDef关键参数说明参数说明示例值MarketValue基础市场价格350Mass重量(kg)1.2WorkToMake制作所需工时4000MeleeWeapon_DamageAmount基础伤害值14MeleeWeapon_Cooldown攻击间隔(秒)2.1注意texPath指向的是你的武器贴图路径。如果你暂时没有自定义贴图可以使用游戏原有的武器贴图如Things/Item/Weapon/LongSword4. 添加制作配方让武器可被制造为了让你的新武器能在游戏中被制作我们需要添加一个RecipeDef。在同一个XML文件中继续添加RecipeDef ParentNameMakeWeapon defNameMake_YourName_SteelSword/defName label打造旋风钢剑/label description锻造一把带有螺旋纹路的钢剑。/description jobString正在打造旋风钢剑。/jobString workSkillCrafting/workSkill workSkillLearnFactor0.25/workSkillLearnFactor workAmount4000/workAmount products YourName_SteelSword1/YourName_SteelSword /products ingredients li filter thingDefs liSteel/li /thingDefs /filter count40/count /li /ingredients /RecipeDef这个配方定义了需要40个钢铁资源需要4000 ticks的工作量约1.33游戏小时会提升 crafting 技能经验完成后获得1把旋风钢剑5. 测试与调试让Mod活起来现在你的第一个武器Mod已经具备了基本功能是时候在游戏中测试了启动RimWorld进入Mod配置界面确保你的Mod已被检测到并启用开始新游戏或加载已有存档测试要点检查表[ ] Mod是否出现在已启用列表[ ] 物品是否出现在制作菜单[ ] 能否正常收集材料并开始制作[ ] 制作完成后物品是否出现在库存[ ] 物品属性是否与定义一致[ ] 能否正常装备和使用如果遇到问题检查以下常见错误源XML格式错误缺少闭合标签等defName冲突贴图路径错误配方材料定义错误6. 进阶优化让你的武器独一无二基础功能实现后我们可以为武器添加更多特色!-- 在ThingDef中添加这些属性 -- costList Steel50/Steel /costList equippedStatOffsets WorkSpeedGlobal0.05/WorkSpeedGlobal /equippedStatOffsets descriptionHyperlinks ThingDefSteel/ThingDef /descriptionHyperlinks weaponTags liMelee/li liSharp/li liYourName_Special/li /weaponTags这些新增属性为武器带来了明确的制作成本显示装备时获得5%全局工作速度加成描述中可点击的钢铁超链接自定义武器标签可供其他Mod识别7. 从Mod到创作下一步的方向完成第一个可运行Mod后你可能会想探索更多可能性。以下是几个值得尝试的进阶方向视觉效果增强添加自定义贴图实现攻击时的特效创建不同材质变体游戏机制扩展添加特殊攻击效果制作升级系统设计配套护甲套装与其他Mod互动添加对Combat Extended的支持与RimWorld of Magic的魔法武器系统兼容为Dubs Bad Hygiene添加温度相关属性每次打开游戏看到自己创造的武器被小人使用时那种成就感是无可替代的。我的第一个Mod武器至今还保留在我的核心Mod列表中——尽管它的代码现在看来相当简陋。这就是Mod制作的魅力你的创意能真正成为游戏世界的一部分。

更多文章