Credits are cool

This commit is contained in:
StormyBytes
2021-06-06 15:21:14 +07:00
parent 6f4b663196
commit e850a5a66b
3 changed files with 75 additions and 2 deletions

View File

@@ -0,0 +1,73 @@
package cloudburst.rejects.mixin;
import minegame159.meteorclient.systems.config.Config;
import minegame159.meteorclient.utils.render.color.Color;
import net.minecraft.client.gui.screen.Screen;
import net.minecraft.client.gui.screen.TitleScreen;
import net.minecraft.client.util.math.MatrixStack;
import net.minecraft.text.Text;
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(value = TitleScreen.class, priority = 500)
public class TitleScreenMixin extends Screen {
// Meteor should've used @Unique here
// And because of that I have to rename the variables to avoid collision.
// With @Unique, the variable names can stay the same without collision.
private final int rejectsTextColor = Color.fromRGBA(255, 255, 255, 255);
private final int rejectsCreditColor = Color.fromRGBA(175, 175, 175, 255);
private String rejectsText1;
private String rejectsText2;
// private String rejectsText3;
// private String rejectsText4;
private int rejectsLength1;
private int rejectsLength2;
// private int rejectsLength3;
// private int rejectsLength4;
private int rejectsFullLength;
private int rejectsPrevWidth;
protected TitleScreenMixin(Text title) {
super(title);
}
@Inject(method = "init", at = @At("TAIL"))
private void onInit(CallbackInfo info) {
rejectsText1 = "Meteor Rejects Addon by ";
rejectsText2 = "Cloudburst";
// rejectsText3 = "& ";
// rejectsText4 = "StormyBytes";
// I commented out my credit in case cloudburst didn't want it
rejectsLength1 = textRenderer.getWidth(rejectsText1);
rejectsLength2 = textRenderer.getWidth(rejectsText2);
// rejectsLength3 = textRenderer.getWidth(rejectsText3);
// rejectsLength4 = textRenderer.getWidth(rejectsText4);
// fullLength = rejectsLength1 + rejectsLength2 + rejectsLength3 + rejectsLength4;
rejectsFullLength = rejectsLength1 + rejectsLength2;
rejectsPrevWidth = 0;
}
@Inject(method = "render", at = @At("TAIL"))
private void onRender(MatrixStack matrices, int mouseX, int mouseY, float delta, CallbackInfo info) {
if (!Config.get().titleScreenCredits) return;
rejectsPrevWidth = 0;
textRenderer.drawWithShadow(matrices, rejectsText1, width - rejectsFullLength - 3, 20, rejectsTextColor);
rejectsPrevWidth += rejectsLength1;
textRenderer.drawWithShadow(matrices, rejectsText2, width - rejectsFullLength + rejectsPrevWidth - 3, 20, rejectsCreditColor);
// rejectsPrevWidth += rejectsLength2;
// textRenderer.drawWithShadow(matrices, rejectsText3, width - rejectsFullLength + rejectsPrevWidth - 3, 5, rejectsTextColor);
// prevWidth += rejectsLength3;
// textRenderer.drawWithShadow(matrices, rejectsText4, width - rejectsFullLength + rejectsPrevWidth - 3, 5, rejectsCreditColor);
}
}

View File

@@ -104,7 +104,6 @@ public class Painter extends Module {
// Find spots
for (BlockPos blockPos : WorldUtils.getSphere(mc.player.getBlockPos(), range.get(), range.get())) {
if (shouldPlace(blockPos, block.get())) positions.add(blockPos);
}
// Place
@@ -117,7 +116,7 @@ public class Painter extends Module {
}
private int findSlot(Block block) {
return InvUtils.findItemInHotbar(itemStack -> this.block.get() == block);
return InvUtils.findItemInHotbar(itemStack -> block == Block.getBlockFromItem(itemStack.getItem()));
}
private boolean shouldPlace(BlockPos blockPos, Block useBlock) {

View File

@@ -9,6 +9,7 @@
"ClientPlayerInteractionManagerMixin",
"Deadmau5FeatureRendererMixin",
"StructureVoidBlockMixin",
"TitleScreenMixin",
"LivingEntityRendererMixin",
"GameRendererMixin",
"ToastManagerMixin"