1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
|
package de.hysky.skyblocker.skyblock.dwarven;
import com.google.gson.JsonObject;
import com.mojang.brigadier.context.CommandContext;
import com.mojang.serialization.Codec;
import com.mojang.serialization.JsonOps;
import com.mojang.serialization.codecs.RecordCodecBuilder;
import de.hysky.skyblocker.config.SkyblockerConfig;
import de.hysky.skyblocker.config.SkyblockerConfigManager;
import de.hysky.skyblocker.utils.render.RenderHelper;
import de.hysky.skyblocker.utils.waypoint.Waypoint;
import net.fabricmc.fabric.api.client.rendering.v1.WorldRenderContext;
import net.minecraft.client.MinecraftClient;
import net.minecraft.command.argument.EnumArgumentType;
import net.minecraft.entity.Entity;
import net.minecraft.text.Text;
import net.minecraft.text.TextCodecs;
import net.minecraft.util.Formatting;
import net.minecraft.util.StringIdentifiable;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Vec3d;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.awt.*;
import java.util.List;
import java.util.Map;
import java.util.function.Predicate;
import java.util.function.Supplier;
import java.util.function.ToDoubleFunction;
public class CrystalsWaypoint extends Waypoint {
private static final Logger LOGGER = LoggerFactory.getLogger(CrystalsWaypoint.class);
public static final Codec<CrystalsWaypoint> CODEC = RecordCodecBuilder.create(instance -> instance.group(
Category.CODEC.fieldOf("category").forGetter(crystalsWaypoint -> crystalsWaypoint.category),
TextCodecs.CODEC.fieldOf("name").forGetter(crystalsWaypoint -> crystalsWaypoint.name),
BlockPos.CODEC.fieldOf("pos").forGetter(crystalsWaypoint -> crystalsWaypoint.pos)
).apply(instance, CrystalsWaypoint::new));
private static final Supplier<SkyblockerConfig.CrystalsWaypoints> CONFIG = () -> SkyblockerConfigManager.get().locations.dwarvenMines.crystalsWaypoints;
static final Supplier<Type> TYPE_SUPPLIER = () -> CONFIG.get().waypointType;
final Category category;
final Text name;
private final Vec3d centerPos;
CrystalsWaypoint( JsonObject waypoint, String name, BlockPos pos) {
this(Category.get(waypoint), name, pos);
}
CrystalsWaypoint(Category category, String name, BlockPos pos) {
this( category, Text.of(name), pos);
}
CrystalsWaypoint( Category category, Text name, BlockPos pos) {
super(pos, TYPE_SUPPLIER, category.colorComponents);
this.category = category;
this.name = name;
this.centerPos = pos.toCenterPos();
}
static ToDoubleFunction<CrystalsWaypoint> getSquaredDistanceToFunction(Entity entity) {
return crystalsWaypoint -> entity.squaredDistanceTo(crystalsWaypoint.centerPos);
}
static Predicate<CrystalsWaypoint> getRangePredicate(Entity entity) {
return crystalsWaypoint -> entity.squaredDistanceTo(crystalsWaypoint.centerPos) <= 36D;
}
@Override
public boolean shouldRender() {
return super.shouldRender() ;
}
@Override
public boolean equals(Object obj) {
return super.equals(obj) || obj instanceof CrystalsWaypoint other && category == other.category && name.equals(other.name) && pos.equals(other.pos);
}
/**
* Renders the secret waypoint, including a waypoint through {@link Waypoint#render(WorldRenderContext)}, the name, and the distance from the player.
*/
@Override
public void render(WorldRenderContext context) {
super.render(context);
Vec3d posUp = centerPos.add(0, 1, 0);
RenderHelper.renderText(context, name, posUp, true);
double distance = context.camera().getPos().distanceTo(centerPos);
RenderHelper.renderText(context, Text.literal(Math.round(distance) + "m").formatted(Formatting.YELLOW), posUp, 1, MinecraftClient.getInstance().textRenderer.fontHeight + 1, true);
}
enum Category implements StringIdentifiable {
JUNGLETEMPLE("Jungle Temple",Color.GREEN),
MINESOFDIVAN("Mines Of Divan",Color.CYAN),
GOBLINQUEENSDEN("Goblin Queen's Den",Color.ORANGE),
LOSTPRECURSORCITY("Lost Precursor City",Color.BLUE),
KHAZADUM("Khazad-dûm",Color.RED),
FAIRYGROTTO("Fairy Grotto",Color.PINK),
DRAGONSLAIR("Dragon's Lair",Color.BLACK),
DEFAULT("Default",Color.BLACK);
public final Color color;
private static final Codec<Category> CODEC = StringIdentifiable.createCodec(Category::values);
private final String name;
private final float[] colorComponents;
Category(String name,Color color) {
this.name = name;
this.color = color;
colorComponents = color.getColorComponents(null);
}
static Category get(JsonObject waypointJson) {
return CODEC.parse(JsonOps.INSTANCE, waypointJson.get("category")).resultOrPartial(LOGGER::error).orElse(Category.DEFAULT);
}
@Override
public String toString() {
return name;
}
@Override
public String asString() {
return name;
}
static class CategoryArgumentType extends EnumArgumentType<Category> {
CategoryArgumentType() {
super(Category.CODEC, Category::values);
}
static CategoryArgumentType category() {
return new CategoryArgumentType();
}
static <S> Category getCategory(CommandContext<S> context, String name) {
return context.getArgument(name, Category.class);
}
}
}
}
|