Bedrock Wiki
  • QQ
  • 原站
新手入门指南
  • Guide
    • 1. 简介
      指南
    • 2. 附加组件详解
    • 3. 软件与准备工作
    • 4. 项目设置
    • 5. 创建自定义物品
    • 6. 创建自定义实体
    • 7. Blockbench:建模、贴图与动画制作
    • 8. 添加战利品表、生成规则与合成配方
  • Extra
    • a. 理解JSON
    • b. 下载示例包
    • c. 故障排除
      帮助
    • d. 高级清单文件指南
    • e. 格式版本
    • f. Android 项目设置
JSON UI
  • General
    • JSON UI 入门指南
      指南
    • 最佳实践
      指南
  • Tutorials
    • Aseprite 动画
    • 保留标题文本
      中级
    • 修改服务器表单
      中级
    • 字符串与数字转换
      中级
    • 按钮与开关
      新手
    • 添加HUD界面元素
      新手
  • Documentation
    • JSON UI 文档
Meta
  • Style Guide
  • 使用JSON模式(Schemas)
  • 实用链接
  • 版本控制
  • 附加包性能优化
  • Q&A
    • GameTest 问答集 2021/08/06
    • 世界生成问答 2024/11/15
    • 延迟渲染技术预览问答 2024/02/23
    • 方块与物品问答 2024/08/30
    • 脚本与编辑器问答 2023/09/22
NBT
  • General
    • .mcstructure
  • Tutorials
    • 扩展结构限制
      简单
    • 教育版中的实验功能
      简单
  • NBT in Depth
    • NBT 库列表
      专家
    • NBT读取示例
      专家
    • 关于NBT(命名二进制标签)
      专家
世界生成
  • General
    • 世界生成入门
      指南
      实验性
    • 特性类型
      实验性
    • 生物群系
      指南
      实验性
  • Tutorials
    • 特征(Feature)的方块条件
      实验性
    • 生成地表区块
      实验性
    • 生成自定义矿石
      实验性
    • 生成自定义结构
      实验性
    • 高度图噪声地形
      实验性
  • Documentation
    • 生物群系标签
动画控制器
  • 动画控制器入门指南
    指南
  • 实体命令
    中级
  • AFK检测器
  • 将Molang变量转换为计分板数值
  • 死亡指令
  • 重生指令
命令
  • General
    • 命令方块入门指南
    • 函数
    • NBT 命令
    • 坐标系
    • 方块状态
    • 理解目标选择器
    • 记分板操作
  • Commands
    • Execute
      简单
    • Playanimation
    • 伤害
    • 播放音效
  • On Event Systems
    • 玩家首次加入时
    • On Player Join
    • 玩家离开时触发
    • 玩家死亡事件
    • 玩家重生事件系统
    • 首次加载世界时
  • Scoreboard Systems
    • 实体计数器
    • 计分板计时器
    • 比较与获取分数
  • Techniques
    • 执行逻辑门
    • MBE - Max的方块实体
    • FMBE - 创建显示实体的新方法
    • 视线检测
    • 移动状态检测
    • 轨道摄像机
  • Useful Creations
    • 多人位置重排系统
      函数
    • 自定义合成台
      简单
实体
  • General
    • Intro to Entities BP
      指南
      新手
    • 实体资源包入门
      指南
      新手
    • 实体问题排查指南
      帮助
    • NPC对话系统
      中级
    • 实体事件
      新手
    • 实体属性
    • 渲染控制器
      新手
    • 生成规则
  • Tutorials
    • 任意坐标系间的坐标转换(世界、实体、骨骼)
      中级
    • 创建船只
      中级
    • 实体手持物品
      中级
    • 实体攻击机制
      中级
    • 实体睡眠机制
      中级
    • 实体碰撞体
      中级
    • 实体移动
    • 实体计时器
      中级
    • 无敌实体
      新手
    • 村庄机制实现指南
    • 检测其他实体
      中级
    • 生成已驯服的实体
      脚本
      中级
    • 视线检测实体
      中级
    • 禁用队友伤害
      中级
    • 范围效果云入门指南
      中级
    • 虚拟实体
      新手
    • 飞行实体控制
      中级
  • Documentation
    • Vanilla Usage Spawn Rules
    • 原版使用组件
    • 抛射物
    • 虚拟组件
    • 运行时标识符
    • 非生物实体运行时标识符
战利品、配方与交易
  • General
    • 交易行为
  • Documentation
    • 战利品表
    • 交易表
    • 合成配方
    • 物品函数
  • Tutorials
    • 随机化结构战利品
      简单
文档
  • Shared Constructs
  • Molang 查询详解
  • Vanilla Materials
    专家
  • 声音定义
  • 文件类型
  • 材质配置文件说明
    专家
  • 菜单分类
  • 资源包文件夹结构
  • 雾效ID
  • 高级Molang指南
方块
  • General
    • 方块入门指南
      指南
      新手
    • 方块组件
    • Block Tags
    • 方块状态
    • Block Traits
    • 方块排列组合
    • 方块事件
      脚本
    • 方块事件迁移指南
      帮助
    • 方块物品化
      中级
    • 方块问题排查指南
      帮助
  • Visuals
    • 方块剔除
      中级
    • 方块模型
      指南
      新手
      简单
    • 方块着色
      简单
    • 方块纹理动画
      中级
    • 方块纹理变体
      中级
  • Tutorials
    • Precise Interaction
      专家
      脚本
    • Precise Rotation
      专家
      脚本
    • 伪方块
      中级
    • 可旋转方块
    • 应用持续效果
      简单
      脚本
    • 矿石战利品表
      简单
      脚本
    • 规避状态值限制
      专家
  • Vanilla Re-Creations
    • 自定义作物
      中级
      脚本
    • 自定义活板门
      中级
      脚本
    • 自定义玻璃
      新手
      简单
      已弃用
    • 自定义釉面陶瓦
      简单
  • Documentation
    • 原版方块模型
      新手
    • 方块形状
    • 方块格式历史
    • 方块音效
服务器
  • Software
    • Bedrock Server Software
  • Protocols
    • Bedrock Protocol
    • NetherNet 协议
    • RakNet 协议
概念
  • contents.json
  • Molang
    中级
  • Rawtext
  • textures_list.json
  • 命名空间
  • 子包
  • 文本与本地化
  • 着色器
  • 纹理图集
    中级
  • 表情符号与特殊字符
  • 覆盖资源
    中级
  • 音效
    中级
物品
  • General
    • 物品入门指南
      指南
      新手
    • 物品组件
    • 物品标签
    • 物品事件
      脚本
    • Item Event Migration
      帮助
    • 物品问题排查指南
      帮助
  • Tutorials
    • Custom Pottery Sherds
    • 可投掷物品
      中级
    • 生成物品
      中级
    • 自定义武器
      简单
    • 自定义盔甲
    • 自定义食物
      简单
      脚本
    • 通过装备物品执行命令
      实验性
      中级
    • 高分辨率物品
  • Documentation
    • 附魔
    • Numerical Item IDs
    • Vanilla Usage Components
    • 原版物品标识符
      已弃用
    • 可附着物
      新手
    • 物品格式历史记录
视觉效果
  • General
    • 实体视觉效果简介
      指南
    • 基岩版建模指南
    • 动画中的特效
    • 基于数学的动画
      中级
    • 材质
      专家
    • 材质创作
      专家
    • 皮肤包制作指南
    • 自定义死亡动画
      中级
  • Tutorials
    • Glowing Entity Texture
    • 受伤动画
      中级
    • 实体纹理动画
      中级
    • 栓绳位置调整
      简单
    • 玩家几何模型
      新手
    • 移除实体阴影
      中级
    • 重绘生成蛋纹理
      新手
  • Ideas
    • 结构展示技巧
粒子效果
  • General
    • 粒子效果入门
      指南
  • Tutorials
    • 禁用粒子效果
      新手
  • Documentation
    • 原版粒子效果
脚本编写
  • General
    • 脚本编程入门
    • 什么是Script API?
    • API 模块
  • Tutorials
    • GameTests
      实验性
    • 简易聊天命令
      实验性
    • 脚本核心功能
    • 脚本表单
      实验性
    • 脚本请求API
      实验性
    • 阻止方块放置
  • Documentation
    • JavaScript 问题排查指南
    • Script Resources
    • Script Watchdog
      实验性
    • TypeScript
    • 引擎环境
虚拟现实
  • General
    • 启用VR模式
      指南
    • 配置资源包
      专家
  • Tutorials
    • 编辑你的第一个模型
      专家

实体资源包入门

guide
beginner
实体资源包入门
  • 文件结构概览
  • 材质系统
  • 纹理系统
  • 几何体
  • 渲染控制器
  • 动画系统
  • 脚本系统
    • 初始化脚本
    • 动画前处理
    • 动画控制器
    • 缩放控制
  • 音效系统
  • 粒子系统
  • 刷怪蛋配置
  • 附加设置

资源包中的实体文件定义了构成实体视觉效果的各种资源引用,同时还包含这些视觉效果如何及何时被渲染的信息。

本文将逐项解析实体文件的各个组成部分。如需了解如何创建自定义实体的完整教程,请参阅我们的新手指南。

文件结构概览 ​

RP/entity/example.json
json
{
    "format_version": "1.10.0",
    "minecraft:client_entity": {
        "description": {
            "identifier": "wiki:example",
            "materials": {...},
            "textures": {...},
            "geometry": {...},
            "render_controllers": [...],

            "animations": {...},
            "scripts": {...},

            "sound_effects": {...},
            "particle_effects": {...},

            "spawn_egg": {...},
            "enable_attachables": false,
            "hide_armor": false
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22

虽然看起来复杂,但其中许多部分只是_短名定义_。短名定义是指我们将纹理路径或几何体标识符等资源分配给一个简短名称,后续可以通过这个短名进行引用。这样做的好处是:如果后期需要修改资源路径,只需在一处进行更改;同时也能让代码更加简洁,避免重复书写冗长的路径或标识符。

材质系统 ​

材质决定了纹理的渲染方式。例如骷髅使用透明材质,末影人则使用让眼睛发光的材质。游戏内置了许多现成材质可供直接使用。

RP/entity/spider.entity.json#minecraft:client_entity/description
json
"materials": {
    "default": "spider",
    "invisible": "spider_invisible"
}
1
2
3
4

这里定义了两种材质:spider和spider_invisible,对应的短名分别是default和invisible。注意这个键仅定义了短名与材质的对应关系,实体尚不知道何时使用哪种材质。

如需查看预设材质列表,请访问材质文档。若要学习创建自定义材质,可参考材质制作指南,但需注意这属于进阶内容。

纹理系统 ​

纹理是映射到几何体上的图像。每个实体都有专属纹理。与材质类似,这个键也是短名定义,但此处引用的是纹理文件的路径。

RP/entity/bee.entity.json#minecraft:client_entity/description
json
"textures": {
    "default": "textures/entity/bee/bee",
    "angry": "textures/entity/bee/bee_angry",
    "nectar": "textures/entity/bee/bee_nectar",
    "angry_nectar": "textures/entity/bee/bee_angry_nectar"
}
1
2
3
4
5
6

我们可以定义多个纹理变体,如上例中的蜜蜂就有四种状态纹理。通过分层纹理技术(如村民的生物群系基底与职业图层的组合)能实现更复杂效果。详情可参阅渲染控制器章节。

几何体 ​

几何体文件通过骨骼系统定义实体外形。使用Blockbench等工具可以便捷创建模型,具体教程参见Blockbench指南。

RP/entity/creeper.entity.json#minecraft:client_entity/description
json
"geometry": {
    "default": "geometry.creeper",
    "charged": "geometry.creeper.charged"
}
1
2
3
4

短名对应的是几何体标识符:

RP/entity/creeper.entity.json#minecraft:client_entity/description
json
{
	"format_version" : "1.12.0",
	"minecraft:geometry" : [
		{
			"description" : {
				"identifier" : "geometry.creeper",
                ...
            }
        }
}
1
2
3
4
5
6
7
8
9
10

如同高压爬行者有两种形态,实体也可以配置多套几何体。

TIP

当视觉效果异常时,请优先检查实体短名是否存在拼写错误。

渲染控制器 ​

渲染控制器负责统筹材质、纹理和几何体的渲染逻辑,通过短名引用这些元素并定义渲染条件。

RP/render_controllers/example.rc.json
json
{
    "format_version": "1.10.0",
    "render_controllers": {
        "controller.render.example": {
            "geometry": "geometry.default",
            "materials": [
                {
                    "*": "material.default"
                }
            ],
            "textures": ["texture.default"]
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14

这个基础控制器始终使用默认材质组合。实际开发中可以实现动态切换纹理或隐藏骨骼等复杂功能,详见渲染控制器专题。

实体文件中通过标识符指定使用的控制器:

RP/entity/example.json#minecraft:client_entity/description
json
"render_controllers": [
    "controller.render.example"
]
1
2
3

一个可正常渲染的实体至少需要配置上述四个核心模块。

动画系统 ​

动画控制实体的运动表现,包括行走、攻击或注视玩家等行为。动画通过代码描述骨骼运动轨迹,或使用数学公式驱动。注意动画必须绑定几何体才能生效。

RP/animations/example.a.json
json
{
	"format_version" : "1.8.0",
	"animations" : {
		"animation.example.walk" : {...},
        "animation.example.attack" : {...}
	}
}
1
2
3
4
5
6
7

每个动画都有独立标识符。实体文件中的动画键则是这些动画的短名映射:

RP/entity/example.json#minecraft:client_entity/description
json
"animations": {
    "walk": "animation.example.walk",
    "attack": "animation.example.attack",
    "attack_controller": "controller.animation.example"
}
1
2
3
4
5

其中attack_controller是动画控制器,用于管理动画过渡逻辑。建议通过[专题指南]了解控制器的结构设计。

重要提示

此键仅定义动画短名,并不会自动播放动画。若要使动画生效,必须通过脚本系统激活。

脚本系统 ​

脚本系统用于在特定时机执行指令,包括运行动画、设置变量甚至控制实体尺寸。其中Molang是一种特殊的数学表达式语言,详见Molang专题。

RP/entity/example.json#minecraft:client_entity/description
json
"scripts": {
    "initialize": [...],
    "pre_animation": [...],
    "animate": [...],

    "scale": "1",
}
1
2
3
4
5
6
7

Molang的核心要素包括:

  • 查询语句(如query.time_of_day获取游戏时间)
  • 自定义变量(如variable.my_number存储数值)
  • 条件运算(如q.time_of_day > v.my_number)

初始化脚本 ​

当实体首次生成或重新加载时执行,适合设置变量初始值。

动画前处理 ​

在每帧动画计算前运行,用于预处理动画所需变量。

动画控制器 ​

在预处理后执行,是运行动画的核心区块:

RP/entity/example.json#minecraft:client_entity/description
json
"scripts": {
    "animate": [
        "attack_controller",
        {
            "walk": "q.modified_move_speed"
        }
    ],
}
1
2
3
4
5
6
7
8

这里attack_controller会逐帧更新动画状态,而walk动画的速度则与实体移动速度(q.modified_move_speed查询值)同步。若设为固定值如"walk":2,则动画会以双速播放。更复杂的控制逻辑可参考数学动画专题。

缩放控制 ​

不同于行为包中的minecraft:scale组件(同时影响模型和碰撞箱),此处的缩放仅作用于视觉模型,且支持Molang表达式和分轴缩放:

RP/entity/example.json#minecraft:client_entity/description
json
"scripts": {
    "scale": "q.variant",
    "scaleX": 2,
    "scaleY": 0.5
}
1
2
3
4
5

通过随机函数可以实现环境实体的动态尺寸:

RP/entity/example.json#minecraft:client_entity/description
json
"scripts": {
    "initialize": [
        "v.scale = math.random_integer(1, 5);"
    ],
    "scale": "v.scale"
}
1
2
3
4
5
6

音效系统 ​

音效短名定义后可用于动画事件触发,实现攻击连招等动态效果:

RP/entity/example.json#minecraft:client_entity/description
json
"sound_effects": {
    "attack_1": "mob.entity.attack_1",
    "attack_2": "mob.entity.attack_2",
    "attack_3": "mob.entity.attack_3"
}
1
2
3
4
5

注意动画中需使用短名,而命令中需使用sound_definitions.json定义的完整音效ID。

粒子系统 ​

粒子效果通过短名定义后,可在动画中触发类似幻影翅膀特效等视觉效果:

RP/entity/example.json#minecraft:client_entity/description
json
"particle_effects": {
    "smoke": "wiki:smoke_particle"
}
1
2
3

粒子制作教程参见粒子专题,动画集成方法参考动画特效。

刷怪蛋配置 ​

通过此配置可生成对应实体的刷怪蛋,并自动加入创造模式物品栏。提供两种样式选择:

颜色模式:

RP/entity/example.json#minecraft:client_entity/description
json
"spawn_egg": {
    "base_color": "#db7500",
    "overlay_color": "#242222"
}
1
2
3
4

贴图模式:

RP/entity/example.json#minecraft:client_entity/description
json
"spawn_egg": {
    "texture": "wiki:example",
}
1
2
3

若未配置此键,则不会生成刷怪蛋。

附加设置 ​

  • enable_attachables:控制实体是否能装备武器等附件
  • hide_armor:允许穿戴盔甲但不显示视觉效果

贡献者

编辑 实体资源包入门

Bedrock Wiki by Bedrock OSS ,Translate by 8aka-Team

"Minecraft"是Mojang AB的注册商标。

Bedrock OSS、Bedrock Wiki以及 bedrock.dev 与Microsoft及Mojang AB不存在任何隶属关系。

  • 隐私政策
  • 加入QQ社区
  • 参与贡献指南
  • 访问代码仓库