Jump to content

Recommended Posts

Posted

I have programmed an entity that can load chunks independently of the player and is therefore always active. Since the entity is very large (volume of about 66800 blocks), I implemented that the entity is rendered from a distance of several thousand blocks, even outside of the player's actual render distance. Since I logically want to render the entity with the correct distance to the camera, rotation, motion, tickCount, etc., I use the server-side entity, which stores all this information. I get the server-side entity via an event and use the synchronized method to prevent an exception. In single player this also works perfectly, the entity has the correct position, rotation, etc. and I have the correct server-side entity. The same applies to a local LAN world. However, when I'm playing on an actual multiplayer server, whether alone or with other players, my code strangely always gives me the client-side entity, which is why the entity stops at the position where you leave its range of view, and the entity rendered from a long distance is no longer updated, which is obviously a problem. The problem is definitely not due to my long distant render logic, since the client-side entity, except for the problem that it is client-side, is rendered correctly, and the render logic otherwise only contains things like distance interpolations and a fog logic that definitely does not cause the problem. The server-side entity in the single player is actually rendered perfectly. So the problem must somehow be with the way I'm trying to get the entity. Here's the code that works perfectly in single player: 

    private final Object renderLock = new Object();

    WitherStormEntity witherStorm = null;

    @SubscribeEvent
    public void onServerTickLivingEntity(LivingEvent.LivingTickEvent event) {
        if (event.getEntity() instanceof WitherStormEntity witherStormEntity) {
            synchronized(this.renderLock) {
                if (!witherStormEntity.getLevel().isClientSide()) {
                    this.witherStorm = witherStormEntity;
                }
            }
        }

    }

    @SubscribeEvent
    @OnlyIn(Dist.CLIENT)
    public void renderTickDistantRenderer(RenderLevelStageEvent event) {
        synchronized(this.renderLock) {
            if (this.witherStorm != null && event.getStage().equals(RenderLevelStageEvent.Stage.AFTER_PARTICLES) && WitherStormModClientConfigs.DISTANT_RENDERER.get()) {
                render(event.getPoseStack(), event.getPartialTick(), this.witherStorm);
            }

        }
    }

Unfortunately, as I said, I get the client-side entity in multiplayer mode, or at least not the correct server-side entity. I've also tried things like an iterator over all entities in the server level, but unfortunately it didn't help. I desperately need help with this issue, and would really appreciate some help and an answer on how to fix this! 😀

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Different problem now. https://paste.ee/p/iDo8lS35
    • I would like to have a BoP sapling drop from my block if it is also installed. I think I have done everything and I cannot pinpoint the problem, which is the error in the logs that appears when joining a world:   [Worker-Main-11/ERROR] [ne.mi.co.ForgeHooks/]: Couldn't parse element loot_tables:grasses:blocks/leaves_block com.google.gson.JsonSyntaxException: Expected name to be an item, was unknown string 'biomesoplenty:magic_sapling' My code:   LootItemConditions.CONDITIONS.register(modEventBus); public class LootItemConditions { public static final DeferredRegister<LootItemConditionType> CONDITIONS = DeferredRegister.create(Registries.LOOT_CONDITION_TYPE, Grasses.MOD_ID); public static final RegistryObject<LootItemConditionType> IS_MOD_LOADED = CONDITIONS.register("is_mod_loaded", () -> new LootItemConditionType(new IsModLoaded.ConditionSerializer())); } public class IsModLoaded implements LootItemCondition { private final boolean exists; private final String modID; public IsModLoaded(String modID) { this.exists = ModList.get().isLoaded(modID); this.modID = modID; } @Override public LootItemConditionType getType() { return LootItemConditions.IS_MOD_LOADED.get(); } @Override public boolean test(LootContext context) { return this.exists; } public static LootItemCondition.Builder builder(String modid) { return () -> new IsModLoaded(modid); } public static class ConditionSerializer implements Serializer<IsModLoaded> { @Override public void serialize(JsonObject json, IsModLoaded instance, JsonSerializationContext ctx) { json.addProperty("modid", instance.modID); } @Override public IsModLoaded deserialize(JsonObject json, JsonDeserializationContext ctx) { return new IsModLoaded(GsonHelper.getAsString(json, "modid")); } } } protected LootTable.Builder createLeavesDropsWithModIDCheck(Block selfBlock, Item sapling, Property<?>[] properties, String modIDToCheck, float... chances) { CopyBlockState.Builder blockStateCopyBuilder = CopyBlockState.copyState(selfBlock); for(Property<?> property : properties) { blockStateCopyBuilder.copy(property); } return LootTable.lootTable() .withPool(LootPool.lootPool().setRolls(ConstantValue.exactly(1.0F)) .add(LootItem.lootTableItem(selfBlock) .when(HAS_SHEARS_OR_SILK_TOUCH) .apply(blockStateCopyBuilder))) .withPool(LootPool.lootPool().setRolls(ConstantValue.exactly(1.0F)) .add(this.applyExplosionCondition(selfBlock, LootItem.lootTableItem(sapling)) .when(IsModLoaded.builder(modIDToCheck))) .when(BonusLevelTableCondition.bonusLevelFlatChance(Enchantments.BLOCK_FORTUNE, chances)) .when(HAS_NO_SHEARS_OR_SILK_TOUCH)) .withPool(LootPool.lootPool().name("sticks").setRolls(ConstantValue.exactly(1.0F)) .add(this.applyExplosionDecay(selfBlock, LootItem.lootTableItem(Items.STICK). apply(SetItemCountFunction.setCount(UniformGenerator.between(1.0F, 2.0F)))) .when(BonusLevelTableCondition.bonusLevelFlatChance(Enchantments.BLOCK_FORTUNE, NORMAL_LEAVES_STICK_CHANCES)) .when(HAS_NO_SHEARS_OR_SILK_TOUCH))); } I don't know. Am I making a mistake somewhere? Am I forgetting something? Should there be something else?
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.