User Tools

Site Tools


zh_cn:tutorial:extendedscreenhandler

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
zh_cn:tutorial:extendedscreenhandler [2022/02/10 13:19] – [使用扩展的 ScreenHandler 同步数据] timothy_starmanzh_cn:tutorial:extendedscreenhandler [2022/02/10 13:32] (current) – Result timothy_starman
Line 7: Line 7:
 由于 Block 类根本不需要更改,我们将其留在这里。 由于 Block 类根本不需要更改,我们将其留在这里。
  
-我们的方块实体现在实现了 "ExtendedScreenHandlerFactory",这个接口为我们提供了 "writeScreenOpeningData方法,当它请求客户端(client)打开一个 "ScreenHandler时,将在服务器(server)上调用该方法。 您写入 "PacketByteBuf的数据将通过网络传输到客户端(client)。+我们的方块实体现在实现了 ''ExtendedScreenHandlerFactory'',这个接口为我们提供了 ''writeScreenOpeningData'' 方法,当它请求客户端(client)打开一个 ''ScreenHandler'' 时,将在服务器(server)上调用该方法。 您写入 ''PacketByteBuf'' 的数据将通过网络传输到客户端(client)。
  
 <code java [enable_line_numbers="true"] BoxBlockEntity.java> <code java [enable_line_numbers="true"] BoxBlockEntity.java>
Line 106: Line 106:
 } }
 </code> </code>
 +
 +====== 在 Screen 中使用 ExtendedScreenHandler 信息 ======
 +
 +<code java [enable_line_numbers="true"] BoxScreen.java>
 +
 +public class BoxScreen extends HandledScreen<ScreenHandler> {
 +    private static final Identifier TEXTURE = new Identifier("minecraft", "textures/gui/container/dispenser.png");
 +
 +    public BoxScreen(ScreenHandler handler, PlayerInventory inventory, Text title) {
 +        super(handler, inventory, getPositionText(handler).orElse(title));
 +        //我们尝试获取方块位置以将其用作我们的标题,如果由于某种原因失败,我们将使用默认标题
 +    }
 +
 +    //此方法将尝试从 ScreenHandler 获取位置,因为 ScreenRendering 仅发生在客户端上,
 +    //我们在此处获取具有正确 BlockPos 的 ScreenHandler 实例!
 +    private static Optional<Text> getPositionText(ScreenHandler handler) {
 +        if (handler instanceof BoxScreenHandler) {
 +            BlockPos pos = ((BoxScreenHandler) handler).getPos();
 +            return pos != null ? Optional.of(new LiteralText("(" + pos.toShortString() + ")")) : Optional.empty();
 +        } else {
 +            return Optional.empty();
 +        }
 +    }
 +
 +
 +    @Override
 +    protected void drawBackground(MatrixStack matrices, float delta, int mouseX, int mouseY) { [...] }
 +
 +    @Override
 +    public void render(MatrixStack matrices, int mouseX, int mouseY, float delta) { [...] }
 +
 +    @Override
 +    protected void init() { [...] }
 +}
 +
 +</code>
 +
 +====== 注册我们的 ScreenHandler ======
 +
 +<code java [enable_line_numbers="true"] ExampleMod.java>
 +public class ExampleMod implements ModInitializer {
 +
 +    [...]
 +    public static final ScreenHandlerType<BoxScreenHandler> BOX_SCREEN_HANDLER;
 +
 +    static {
 +        [...]
 +       
 +        //我们现在使用 registerExtended 作为我们的 screenHandler 现在在其构造函数中接受一个 packetByteBuf
 +        BOX_SCREEN_HANDLER = ScreenHandlerRegistry.registerExtended(BOX, BoxScreenHandler::new);
 +    }
 +
 +    @Override
 +    public void onInitialize() {
 +
 +    }
 +}
 +</code>
 +
 +====== 结果 ======
 +您现在已经了解了如何在 ScreenHandler 打开时传输数据。 在图像中您可以看到结果:方块的标题现在是它的位置。
 +请注意,这只是一个演示,还有更简单的方法可以将位置设置为标题。
 +
 +您可能想知道://即使在屏幕打开后,我可以再次传输这些数据吗?//
 +这可以通过在屏幕打开后发送自定义数据包来实现。 (see: [[tutorial:networking|Networking Tutorial]]) \\
 +您可能还想看看''BlockEntityClientSerializable'', 来自Fabric API 的界面.
 +
 +如果您只想同步整数值,您可以使用''PropertyDelegate'': [[tutorial:propertydelegates]].
 +
 +{{:tutorial:bildschirmfoto_vom_2020-08-14_18-37-51.png?nolink&400|}}
 +
  
zh_cn/tutorial/extendedscreenhandler.1644499180.txt.gz · Last modified: 2022/02/10 13:19 by timothy_starman