-
-
Notifications
You must be signed in to change notification settings - Fork 53
API documentation zh CN
目录:
将 CPM api 添加到你的 gradle 构建脚本(build.gradle
):
Note
本章可能已过时。 查看本页的英文版本:跳转
从 Releases 下载 api 并将其放入您的模组项目文件夹中。 将其添加到你的 gradle 文件中
dependencies {
implementation files("CustomPlayerModels-API-0.4.0.jar");
}
repositories {
maven {
name = "tom5454 maven"
url = "https://raw.githubusercontent.com/tom5454/maven/main"
}
}
Note
本章可能已过时。 查看本页的英文版本:跳转
API 版本:
Minecraft 版本 | 运行版本(Forge) | 运行版本(NeoForge) | 运行版本(Fabric) | 运行版本(Quilt) |
---|---|---|---|---|
1.20.5 | - | |||
1.20.4 | ||||
1.20.2 | Use the Fabric version | |||
1.20 | Use the Forge version | |||
1.19.4 | - | Use the Fabric version | ||
1.19.3 | - | Use the Fabric version | ||
1.19 | - | Use the Fabric version | ||
1.18 | - | Use the Fabric version | ||
1.17 | - | - | ||
1.16 | - | - | ||
1.15 | - | - | ||
1.14 | - | - | ||
1.12.2 | - | - | - | |
1.10.2 | - | - | - | |
1.8 | - | - | - | |
1.7.10 | - | - | - | |
1.6.4 | - | - | - | |
1.5.2 | - | - | - | |
1.4.7 | - | - | - | |
1.2.5 | - | - | - | |
b1.7.3 | - | - | - | |
BTA | - | - | - |
# CPM 版本
cpm_api_version=<api 版本>
cpm_mc_version=<Minecraft 版本>
cpm_runtime_version=<运行版本>
dependencies {
compile "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
deobfProvided "com.tom5454.cpm:CustomPlayerModels-${project.cpm_mc_version}:${project.cpm_runtime_version}"
}
dependencies {
/* Minecraft 依赖在这里 */
compileOnly "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
runtimeOnly fg.deobf("com.tom5454.cpm:CustomPlayerModels-${project.cpm_mc_version}:${project.cpm_runtime_version}")
}
dependencies {
/* Minecraft 依赖在这里 */
compileOnly "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
runtimeOnly "com.tom5454.cpm:CustomPlayerModels-${project.cpm_mc_version}:${project.cpm_runtime_version}"
}
dependencies {
/* Minecraft 依赖在这里 */
compileOnly "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
modRuntimeOnly "com.tom5454.cpm:CustomPlayerModels-Fabric-${project.cpm_mc_version}:${project.cpm_runtime_version}"
}
dependencies {
/* Minecraft 依赖在这里 */
compileOnly "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
//1.4.7, 1.5.2
coremodImplementation ("com.tom5454.cpm:CustomPlayerModels-${project.cpm_mc_version}:${project.cpm_runtime_version}") {
copyToFolder("coremods")
}
//1.6.4
modRuntimeOnly "com.tom5454.cpm:CustomPlayerModels-${project.cpm_mc_version}:${project.cpm_runtime_version}"
}
On 1.2.5:
volde {
runs {
client {
programArg "Dev"
vmArg "-Dcpmcore.deobf=true"
vmArg "-Dcpmcore.env.client=true"
vmArg "-javaagent:\"" + file("CustomPlayerModels-${project.cpm_runtime_version}.jar").absolutePath + "\""
}
}
}
dependencies {
/* Minecraft 依赖在这里 */
compileOnly "com.tom5454.cpm:CustomPlayerModels-API:${project.cpm_api_version}"
}
您必须将当前模组版本从 Modrinth 放置到项目根文件夹中,否则 Java 代理将无法加载。
创建一个实现 ICPMPlugin
的类。
public class CPMCompat implements ICPMPlugin {
public void initClient(IClientAPI api) {
//初始化客户端
}
public void initCommon(ICommonAPI api) {
//通用的初始化
}
public String getOwnerModId() {
return "example_mod";
}
}
插件加载器未实现。
发送包含您的插件类位置的 IMC 消息。
FMLInterModComms.sendMessage("customplayermodels", "api", "com.example.mod.CPMCompat");
发送 IMC 消息。
public MyMod() {
...
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::enqueueIMC);
...
}
private void enqueueIMC(final InterModEnqueueEvent event) {
InterModComms.sendTo("cpm", "api", () -> (Supplier<?>) () -> new CPMCompat());
...
}
在 fabric.mod.json 文件中的entrypoints
字段添加cpmapi
字段,如下所示:
"entrypoints": {
"cpmapi": [ "com.example.mod.CPMCompat" ]
}
使用服务管理器注册您的插件,您的插件的initCommon
方法将使用ICommonAPI
实例调用。
RegisteredServiceProvider<CPMPluginRegistry> rsp = getServer().getServicesManager().getRegistration(CPMPluginRegistry.class);
if (rsp != null)
rsp.getProvider().register(new CPMCompat());
else
log.info("Customizable Player Models plugin not installed, compat disabled");
注册语音级别支持。
IClientAPI:registerVoice(Player.class, player -> voiceLevel);
Player.class
注册语音级别支持。(UUID变体)(0.6.0+)
IClientAPI:registerVoice(playerUUID -> voiceLevel);
注册语音静音支持。(0.6.0+)
IClientAPI:registerVoiceMute(Player.class, player -> voiceMuted);
Player.class
注册语音静音支持。(UUID变体)(0.6.0+)
IClientAPI:registerVoiceMute(playerUUID -> voiceMuted);
创建一个玩家渲染器以在任何玩家实体上渲染 CPM 模型。
PlayerRenderer<Model, ResourceLocation, RenderType, MultiBufferSource, GameProfile> renderer = IClientAPI.createPlayerRenderer(Model.class, ResourceLocation.class, RenderType.class, MultiBufferSource.class, GameProfile.class)
对于 1.12 及更低版本需要使用:
RetroPlayerRenderer<Model, GameProfile> renderer = IClientAPI.createPlayerRenderer(Model.class, GameProfile.class);
Model.class
ResourceLocation.class
RenderType.class
MultiBufferSource.class
GameProfile.class
- 在渲染之前使用渲染器设置 GameProfile 或 LocalModel。
setGameProfile(gameProfile)
:渲染玩家模型setLocalModel(localModel)
:渲染本地模型,加载本地模型 - 设置基础模型,必须是人形或双足模型:
setRenderModel(model)
- 在 1.16+ 上设置默认 RenderType 工厂:例如:半透明实体:
setRenderType(RenderType::entityTranslucent)
。 - 设置模型姿势,使用
getAnimationState()
、setActivePose(pose)
、setActiveGesture(gesture)
将动画应用到模型。 - 调用
preRender(buffers, mode)
(或 1.12 版中的preRender(mode)
) - 正常渲染您的模型。CPM 已将其渲染器注入您的模型。(使用
getDefaultRenderType()
获取模型的 RenderType(1.16+))。- 要渲染其他模型(鞘翅、披风、盔甲),请调用:
prepareSubModel(model, type,texture)
(或 1.12- 上的prepareSubModel(model, type)
) - 可选在 1.16+ 版本中更改模型的默认 RenderType:例如:
setRenderType(RenderType::armorCutoutNoCull)
- 渲染你的模型(使用
getRenderTypeForSubModel(subModel)
获取模型的 RenderType(1.16+))。
- 要渲染其他模型(鞘翅、披风、盔甲),请调用:
- 调用
postRender()
完成渲染。
示例(1.18 Forge):
import java.io.IOException;
import java.io.InputStream;
import net.minecraft.client.Minecraft;
import net.minecraft.client.model.Model;
import net.minecraft.client.model.PlayerModel;
import net.minecraft.client.model.geom.ModelLayers;
import net.minecraft.client.renderer.MultiBufferSource;
import net.minecraft.client.renderer.RenderType;
import net.minecraft.client.renderer.entity.EntityRendererProvider.Context;
import net.minecraft.client.renderer.entity.LivingEntityRenderer;
import net.minecraft.resources.ResourceLocation;
import com.mojang.authlib.GameProfile;
import com.mojang.blaze3d.vertex.PoseStack;
import com.tom.cpm.api.IClientAPI;
import com.tom.cpm.api.IClientAPI.PlayerRenderer;
import com.tom.cpm.shared.animation.AnimationEngine.AnimationMode;
public class ExampleRenderer extends LivingEntityRenderer<ExampleEntity, PlayerModel<ExampleEntity>> {
private static PlayerRenderer<Model, ResourceLocation, RenderType, MultiBufferSource, GameProfile> renderer;
public static void init(IClientAPI api) {
renderer = api.createPlayerRenderer(Model.class, ResourceLocation.class, RenderType.class, MultiBufferSource.class, GameProfile.class);
// TODO: 替换为资源重载监听器以支持资源包。
try (InputStream is = Minecraft.getInstance().getResourceManager().open(new ResourceLocation("example_mod", "models/example_entity_model.cpmmodel"))){
renderer.setLocalModel(api.loadModel("example_entity_model", is));
} catch (IOException e) {
e.printStackTrace();
}
}
public ExampleRenderer(Context pContext, float pShadowRadius) {
super(pContext, new PlayerModel<>(pContext.bakeLayer(ModelLayers.PLAYER), false), pShadowRadius);
}
@Override
public void render(ExampleEntity pEntity, float pEntityYaw, float pPartialTicks, PoseStack pMatrixStack,
MultiBufferSource pBuffer, int pPackedLight) {
renderer.setRenderModel(model);
renderer.setRenderType(RenderType::entityTranslucent);
// 使用 renderer.getAnimationState()、setActivePose(name) 或 setActiveGesture(name) 设置模型姿势
renderer.preRender(pBuffer, AnimationMode.PLAYER);
if(renderer.getDefaultTexture() != null) {
super.render(pEntity, pEntityYaw, pPartialTicks, pMatrixStack, pBuffer, pPackedLight);
} else {
renderNameTag(pEntity, pEntity.getDisplayName(), pMatrixStack, pBuffer, pPackedLight);
}
renderer.postRender();
}
@Override
public ResourceLocation getTextureLocation(ExampleEntity pEntity) {
return renderer.getDefaultTexture();
}
}
当模型在后台加载时,renderer.getDefaultTexture()
将返回 null!
从“.cpmmodel”文件加载模型。
IClientAPI.loadModel(name, inputstream)
使用加载的模型进行渲染实体
为编辑器注册一个模型生成器。生成器位于“编辑/工具”下。
IClientAPI.registerEditorGenerator("button.example_mod.example_generator", "tooltip.example_mod.example_generator", ExampleGenerator::apply);
public class ExampleGenerator {
public static void apply(EditorGui gui) {
//TODO: 应用生成器
// 使用 gui.getEditor() 访问编辑器
// 使用 Editor.action 和 ActionBuilder 进行可撤消的更改。
// 注意:编辑器的部分内容可能会发生变化。
}
}
本地化(i18n):
将 button.example_mod.example_generator
、tooltip.example_mod.example_generator
添加到您的语言文件中。在工具提示中使用 \
字符作为换行符。
为玩家播放指定的命令动画(客户端)。
name:动画名称
IClientAPI.playAnimation(name);
或
value:0:重置姿势/手势,1:播放姿势/手势,对于图层值:0-255,切换:0-1 或 -1 切换状态
IClientAPI.playAnimation(name, value);
返回:如果找到动画并开始播放,则返回 true
检测玩家是否正在播放动画
int value = IClientAPI.getAnimationPlaying(name);
返回:动画值(值层:0-255,其他动画:0-1),如果动画不存在则返回 -1
注册NBT消息发送到服务器,或广播给其他客户端。
MessageSender sender = IClientAPI.registerPluginMessage(Player.class, message_id, (player, message) -> {/*Handle message*/}, broadcastToTracking);
Player.class
或 UUID 版本:
MessageSender sender = IClientAPI.registerPluginMessage(message_id, (player_uuid, message) -> {/*Handle message*/}, broadcastToTracking);
使用MessageSender
发送消息。
boolean success = sender.sendMessage(message_tag);
使用com.tom.cpl.nbt.*
包的独立于平台的 NBT 实现。
broadcastToTracking:false:将消息发送到服务器/true:向附近的玩家广播消息(通过服务器)。
服务器端需要 CPM 0.6.1+ 才能实现网络功能。
当使用broadcastToTracking或状态消息时,服务器上不需要您的模组/插件即可使数据包转发正常工作,您无需注册任何内容。 要接收非广播消息,请使用 ICommonAPI.registerPluginMessage
最后的状态消息存储在服务器上,并发送给进入跟踪范围(渲染距离)的每个客户端。
MessageSender sender = IClientAPI.registerPluginStateMessage(Player.class, message_id, (player, message) -> {/*Handle message*/});
Player.class
或 UUID 版本:
MessageSender sender = IClientAPI.registerPluginMessage(message_id, (player_uuid, message) -> {/*Handle message*/});
类取决于您的 Minecraft 版本和模组加载器。
Minecraft Forge 1.12 及更低版本:EntityPlayer.class
Minecraft Forge 1.16 和 Fabric:PlayerEntity.class
Minecraft Forge 1.17 及更高版本:来自 net.minecraft.*
的 Player.class
Minecraft Forge 1.16+ 和 Fabric:来自 net.minecraft.client.*
的 Model.class
Minecraft Forge 1.12 及更低版本:ModelBase.class
Minecraft Forge: ResourceLocation.class
Fabric: Identifier.class
Minecraft Forge: RenderType.class
Fabric: RenderLayer.class
Minecraft Forge 1.16: IRenderTypeBuffer.class
Minecraft Forge (1.17+): MultiBufferSource.class
Fabric: VertexConsumerProvider.class
来自 AuthLib 的 GameProfile:com.mojang.authlib.GameProfile
设置玩家模型
ICommonAPI.setPlayerModel(Player.class, playerObj, base64Model, forced, persistent);
或
ICommonAPI.setPlayerModel(Player.class, playerObj, modelFile, forced);
使用 ModelFile.load(file);
或 ModelFile.load(inputstream);
创建 ModelFile
或
ICommonAPI.resetPlayerModel(Player.class, playerObj);
清除服务器设置模型
Player.class
为玩家播放跳跃动画。
ICommonAPI.playerJumped(Player.class, playerObj);
Player.class
为玩家播放指定的命令动画(服务器端)。
name:动画名称
ICommonAPI.playAnimation(Player.class, playerObj, name);
or
ICommonAPI.playAnimation(Player.class, playerObj, name, value);
Value:0:重置姿势/手势,1:播放姿势/手势,图层值:0-255,切换:0-1 或 -1 切换状态
Player.class
注册NBT消息,用于接收非广播消息/向客户端发送消息。
MessageSender<Player> sender = ICommonAPI.registerPluginMessage(Player.class, message_id, (player, message) -> {/*Handle message*/});
Player.class
使用MessageSender
发送消息。
boolean success = sender.sendMessageTo(player, message_tag);
或广播给附近的玩家:
sender.sendMessageToTracking(player, message_tag, sendToSelf);
使用来自“com.tom.cpl.nbt.*”包的独立于平台的 NBT 实现。
sendToSelf:向参数 1 中选定的玩家发送消息
检测玩家是否正在播放动画
int value = ICommonAPI.getAnimationPlaying(Player.class, playerObj, name);
返回:动画值(值层:0-255,其他动画:0-1),如果动画不存在则返回 -1
Player.class
类别取决于你的 Minecraft 版本和模组加载器。
Minecraft Forge 1.12 及更低版本:EntityPlayer.class
Minecraft Forge 1.16 和 Fabric:PlayerEntity.class
Minecraft Forge 1.17 及更高版本:来自 net.minecraft.*
的 Player.class
Bukkit: 来自“org.bukkit.entity”的“Player.class”。