Jump to content

[SOLVED] Render mining overlay & fix unable to break snow? (Custom Item)


Recommended Posts

Posted (edited)

I'm attempting to make a tool that doesn't use the base player mining. I am doing this because eventually I want to expand the area that the tool can mine. The code right now is using a packet sent to the server and attempting to break a block like zombies do with the doors. This only sporadically works, and stops working when I attempt to use this to mine snow. I would also eventually like to render the mining overlay on top of the block I am mining. I have a good amount of java experience, I only need a push in the right direction. Is there anywhere I can look in the API for help on this? Is there something I am missing? Any help would be much appreciated.
 

public void handle(Supplier<NetworkEvent.Context> ctx) {
        ServerPlayer player = ctx.get().getSender();
        if(player == null)
            return;

        ServerLevel pLevel = player.serverLevel();

        HitResult targetBlock = player.pick(18.0D, 0.0F, false);
        BlockPos blockpos = ((BlockHitResult) targetBlock).getBlockPos();
        BlockState blockState = pLevel.getBlockState(blockpos);
        Block block = blockState.getBlock();

        ++breakTime;
        int i = (int)((float)breakTime / (float)this.getBlockBreakTime(block) * 10.0F);
        if (i != lastBreakProgress) {
            pLevel.destroyBlockProgress(player.getId(), blockpos, i);
            lastBreakProgress = i;
        }

        if (breakTime == getBlockBreakTime(block)) {
            pLevel.destroyBlock(blockpos, true);
            pLevel.levelEvent(2001, blockpos, Block.getId(pLevel.getBlockState(blockpos)));
            breakTime = 0;
            lastBreakProgress = 0;
        }

        ctx.get().setPacketHandled(true);
    }


EDIT: The solution to rendering the mining overlay is to use:

player.connection.send(new ClientboundBlockDestructionPacket(player.getId(), blockpos, i));

(where player is a "ServerPlayer") in place of "pLevel.destroyBlockProgress...."

Edited by SubortusDevMC
SOLVED
Posted

I’m not quite sure what you need to do next, but put your code inside ctx.get().enqueWork(() ->{})

because the packets are not handled inside the level thread, and most game logic needs to be managed synchronously to all other game logic happening in that level 

Posted (edited)

I figured as much, I had originally left it out because I didn't see how it would cause an issue. I added it now.

Thanks for the new knowledge. I was not aware that was the case. Do you know how to make the block breaking overlay (The animation that appears when mining) appear here? I haven't found anything on it.

 

Edit: I don't know how, but it fixed the snow issue. Might have been a personal error though.

Edited by SubortusDevMC
I went back and ran the client to see changes.
Posted

BlockRenderDispatcher#renderBreakingTexture might work, but it has to much rendering jargon on the parameters when all your doing is server logic. I suggest looking around and finding its usages, maybe there will be a simpler method.

  • 2 weeks later...
Posted
  Quote

PoseStack pPoseStack = RenderSystem.getModelViewStack();

Vec3 vec3 = Minecraft.getInstance().gameRenderer.getMainCamera().getPosition();

double d0 = vec3.x();

double d1 = vec3.y();

double d2 = vec3.z();

Frustum frustum = Minecraft.getInstance().levelRenderer.getFrustum();

ForgeHooksClient.dispatchRenderStage(net.minecraftforge.client.event.RenderLevelStageEvent.Stage.AFTER_BLOCK_ENTITIES, Minecraft.getInstance().levelRenderer, pPoseStack, Minecraft.getInstance().gameRenderer.getProjectionMatrix(Minecraft.getInstance().options.fov().get()), Minecraft.getInstance().levelRenderer.getTicks(), Minecraft.getInstance().gameRenderer.getMainCamera(), frustum);

Minecraft.getInstance().getProfiler().popPush("destroyProgress");

pPoseStack.pushPose(); pPoseStack.translate((double)blockpos.getX() - d0, (double)blockpos.getY() - d1, (double)blockpos.getZ() - d2);

PoseStack.Pose posestack$pose1 = pPoseStack.last();

VertexConsumer vertexconsumer1 = new SheetedDecalTextureGenerator(Minecraft.getInstance().renderBuffers().crumblingBufferSource().getBuffer(ModelBakery.DESTROY_TYPES.get(breakTime)), posestack$pose1.pose(), posestack$pose1.normal(), 1.0F);

ModelData modelData = pLevel.getModelDataManager().getAt(blockpos);

Minecraft.getInstance().getBlockRenderer().renderBreakingTexture(blockState, blockpos, pLevel, pPoseStack, vertexconsumer1, modelData == null ? ModelData.EMPTY : modelData);

pPoseStack.popPose();

Expand  

I couldn't find much usage, I found this and attempted to implement it. It doesn't seem to do anything though. I have this linked to a server to client packet... I have been at this since September seventh and have not made any progress. Blockpos and Blockstate are all pre-assigned variables, as is pLevel. I took the vertex consumer directly from LevelRenderer where I got this code from anyways. I didn't know what number to put into the ModelBakery.DESTROY_TYPES.get() so I just put the breakTime I used in the above code. Am I missing something?

  • 2 weeks later...
Posted

Found the solution, will be closing this soon. The Minecraft mining overlay can be rendered using:
"serverplayer.connection.send(new ClientboundBlockDestructionPacket(serverplayer.getId(), blockpos, i));"

Everything else is completely unnecessary, and I was making this harder than it had to be.

  • SubortusDevMC changed the title to [SOLVED] Render mining overlay & fix unable to break snow? (Custom Item)

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

    • I have used mixins once before, and it was with @At RETURN, so it worked fine. Now im trying to use it as INVOKE, and the compilation is successful, but the client crashes almost on startup (just a couple seconds after running runClient)   Im trying to inject the method finishConversion inside the ZombieVillager class. This is my Mixin class important stuff:   import net.minecraft.server.level.ServerLevel; import net.minecraft.world.entity.monster.ZombieVillager; import org.spongepowered.asm.mixin.Mixin; import org.spongepowered.asm.mixin.injection.At; import org.spongepowered.asm.mixin.injection.Inject; import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; @Mixin(ZombieVillager.class) public class ZombieVillagerCures { @Inject(method = "finishConversion", at = @At(value = "INVOKE_ASSIGN", target = "Lnet/minecraft/world/entity/LivingEntity;addEffect(Lnet/minecraft/world/effect/MobEffectInstance;)Z")) private void addZombieVillagerCuredAmmount(ServerLevel level, CallbackInfo info) { System.out.println("The Mixin Worked!!! " + level); } // Lnet/minecraft/world/entity/LivingEntity;addEffect(Lnet/minecraft/world/effect/MobEffectInstance;)Z } I'm sure the issue lies in the @At cuz other @At values work fine. Its probably the fully qualified name thing. idk how to get it in VS code
    • I'm wayy less skilled than you i bet, but maybe u could try to just convert one into the other?
    • wildbackport is not working
    • Through Betafort Recovery, Bitcoin scam victims can retrieve their money. I recommend Betafort Recovery to anyone who has fallen victim to a scam and has been looking for methods and techniques to recover their lost cryptocurrency or wallets. Betafort Recovery is a reliable cryptocurrency recovery firm that assists victims in recovering their stolen cryptocurrency and offers secure solutions to protect your wallets from online scammers. I must admit that I was deeply melancholy and had given up on life until these experts could restore my $23,400 to my wallet. If you've lost your cryptocurrency and you are helpless about it, contact Betafort Recovery to get your money back. One key aspect that makes Betafort Recovery stand out is its focus on providing secure solutions to protect wallets from online scammers. It's not just about recovering lost funds; it's also about preventing future incidents and ensuring that clients' digital assets are safeguarded against potential threats. This proactive approach demonstrates their commitment to the long-term financial security of their clients. Furthermore, for individuals who have lost their cryptocurrency and are feeling helpless, reaching out to Betafort Recovery could be a turning point in their situation. The reassurance that they are legitimate for seeking help and recovering lost funds can provide much-needed relief and a sense of empowerment. Betafort Recovery as a reliable cryptocurrency recovery firm is certainly well-founded. Their ability to assist scam victims in recovering stolen cryptocurrency, their focus on providing secure solutions, and their commitment to supporting clients through challenging situations make them a valuable resource for individuals navigating the complex world of digital currencies. If you or someone you know has fallen victim to a cryptocurrency scam, contacting Betafort Recovery could be the first step towards reclaiming lost funds and regaining peace of mind.  
    • Idk how i didn't notice that, but I deleted it and fixed some other issues and now I get this https://mclo.gs/YsWacqq
  • Topics

×
×
  • Create New...

Important Information

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