From 2cd000458b280331e30551d3f26617ca193bc0cd Mon Sep 17 00:00:00 2001 From: GridExpert <126912375+TheGridExpert@users.noreply.github.com> Date: Fri, 16 Aug 2024 19:15:49 +0300 Subject: [PATCH 1/3] Make blood food properties be displayed correctly depending on the race --- README.md | 2 +- .../java/de/teamlapen/vampirism/core/ModItems.java | 4 ++-- .../vampirism/items/VampirismItemBloodFoodItem.java | 13 +++++++++++-- src/main/resources/META-INF/neoforge.mods.toml | 2 +- 4 files changed, 15 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 336c5b565..7461f04e5 100755 --- a/README.md +++ b/README.md @@ -66,7 +66,7 @@ The following labeling scheme is used: - BugraaK _Textures/Models_ - MrVityaTrash _Textures_ - FrostedOver _Textures_ -- Grid _Textures_ +- Grid _Models/Textures/Structures_ - T_Corvus _Textures_ ## API diff --git a/src/main/java/de/teamlapen/vampirism/core/ModItems.java b/src/main/java/de/teamlapen/vampirism/core/ModItems.java index 40aa9e4d0..5193abed0 100755 --- a/src/main/java/de/teamlapen/vampirism/core/ModItems.java +++ b/src/main/java/de/teamlapen/vampirism/core/ModItems.java @@ -146,7 +146,7 @@ public boolean isFoil(ItemStack stack) { public static final DeferredItem HUNTER_INTEL_8 = register("hunter_intel_8", () -> new HunterIntelItem(8)); public static final DeferredItem HUNTER_INTEL_9 = register("hunter_intel_9", () -> new HunterIntelItem(9)); - public static final DeferredItem HUMAN_HEART = register("human_heart", () -> new VampirismItemBloodFoodItem((new FoodProperties.Builder()).nutrition(20).saturationModifier(1.5F).build(), new FoodProperties.Builder().nutrition(5).saturationModifier(1f).build())); + public static final DeferredItem HUMAN_HEART = register("human_heart", () -> new VampirismItemBloodFoodItem(new Item.Properties().food(new FoodProperties.Builder().nutrition(5).saturationModifier(1f).build()), new FoodProperties.Builder().nutrition(20).saturationModifier(1.5F).build())); public static final DeferredItem INJECTION_EMPTY = register("injection_empty", () -> new InjectionItem(InjectionItem.TYPE.EMPTY)); public static final DeferredItem INJECTION_GARLIC = register("injection_garlic", () -> new InjectionItem(InjectionItem.TYPE.GARLIC)); @@ -191,7 +191,7 @@ public void appendHoverText(@NotNull ItemStack stack, @Nullable TooltipContext c public static final DeferredItem VAMPIRE_BLOOD_BOTTLE = register("vampire_blood_bottle", VampireBloodBottleItem::new); public static final DeferredItem VAMPIRE_BOOK = register("vampire_book", VampireBookItem::new); public static final DeferredItem VAMPIRE_FANG = register("vampire_fang", VampireFangItem::new); - public static final DeferredItem WEAK_HUMAN_HEART = register("weak_human_heart", () -> new VampirismItemBloodFoodItem((new FoodProperties.Builder()).nutrition(10).saturationModifier(0.9F).build(), new FoodProperties.Builder().nutrition(3).saturationModifier(1f).build())); + public static final DeferredItem WEAK_HUMAN_HEART = register("weak_human_heart", () -> new VampirismItemBloodFoodItem(new Item.Properties().food(new FoodProperties.Builder().nutrition(3).saturationModifier(1f).build()), new FoodProperties.Builder().nutrition(10).saturationModifier(0.9F).build())); public static final DeferredItem VAMPIRE_SPAWN_EGG = register("vampire_spawn_egg", CreativeModeTabs.SPAWN_EGGS, () -> new DeferredSpawnEggItem(ModEntities.VAMPIRE, 0x8B15A3, 0xa735e3, new Item.Properties())); public static final DeferredItem VAMPIRE_HUNTER_SPAWN_EGG = register("vampire_hunter_spawn_egg", CreativeModeTabs.SPAWN_EGGS, () -> new DeferredSpawnEggItem(ModEntities.HUNTER, 0x2d05f2, 0x2600e0, new Item.Properties())); diff --git a/src/main/java/de/teamlapen/vampirism/items/VampirismItemBloodFoodItem.java b/src/main/java/de/teamlapen/vampirism/items/VampirismItemBloodFoodItem.java index a07e58835..1fd5b02cf 100755 --- a/src/main/java/de/teamlapen/vampirism/items/VampirismItemBloodFoodItem.java +++ b/src/main/java/de/teamlapen/vampirism/items/VampirismItemBloodFoodItem.java @@ -1,5 +1,6 @@ package de.teamlapen.vampirism.items; +import de.teamlapen.vampirism.VampirismMod; import de.teamlapen.vampirism.api.entity.vampire.IVampire; import de.teamlapen.vampirism.entity.player.vampire.VampirePlayer; import de.teamlapen.vampirism.entity.vampire.DrinkBloodContext; @@ -15,13 +16,14 @@ import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; import org.jetbrains.annotations.NotNull; +import org.jetbrains.annotations.Nullable; public class VampirismItemBloodFoodItem extends Item { private final FoodProperties vampireFood; - public VampirismItemBloodFoodItem(FoodProperties vampireFood, @NotNull FoodProperties humanFood) { - super(new Properties().food(humanFood)); + public VampirismItemBloodFoodItem(Properties properties, FoodProperties vampireFood) { + super(properties); this.vampireFood = vampireFood; } @@ -45,5 +47,12 @@ public ItemStack finishUsingItem(@NotNull ItemStack stack, @NotNull Level worldI return stack; } + @Override + public @Nullable FoodProperties getFoodProperties(@NotNull ItemStack stack, @Nullable LivingEntity entity) { + if (entity == null) { + entity = VampirismMod.proxy.getClientPlayer(); + } + return Helper.isVampire(entity) ? vampireFood : super.getFoodProperties(stack, entity); + } } diff --git a/src/main/resources/META-INF/neoforge.mods.toml b/src/main/resources/META-INF/neoforge.mods.toml index 57f47bee7..2076e8239 100755 --- a/src/main/resources/META-INF/neoforge.mods.toml +++ b/src/main/resources/META-INF/neoforge.mods.toml @@ -35,7 +35,7 @@ config = "vampirism.mixins.json" - BugraaK (textures/models) - MrVityaTrash (textures) - FrostedOver (textures) - - Grid (textures) + - Grid (textures/models/structures) - T_Corvus (textures) - freesound.org (sounds) - freeSFX.co.uk (sounds)''' From e3fca3b9fe020a76ecf2a74d0835410c283f1fd3 Mon Sep 17 00:00:00 2001 From: GridExpert <126912375+TheGridExpert@users.noreply.github.com> Date: Fri, 16 Aug 2024 19:46:43 +0300 Subject: [PATCH 2/3] Add VampireFogEvent --- .../vampirism/api/event/VampireFogEvent.java | 37 +++++++++++++++++++ .../client/renderer/RenderHandler.java | 7 +++- .../vampirism/util/VampirismEventFactory.java | 14 +++++-- 3 files changed, 53 insertions(+), 5 deletions(-) create mode 100644 src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java diff --git a/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java b/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java new file mode 100644 index 000000000..f80cd5c86 --- /dev/null +++ b/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java @@ -0,0 +1,37 @@ +package de.teamlapen.vampirism.api.event; + +import net.minecraft.client.player.LocalPlayer; +import net.neoforged.bus.api.Event; +import org.jetbrains.annotations.NotNull; + +@SuppressWarnings("unused") +public class VampireFogEvent extends Event { + private final LocalPlayer player; + private float fogDistanceMultiplier; + + public VampireFogEvent(@NotNull LocalPlayer player, float fogDistanceMultiplier) { + this.player = player; + this.fogDistanceMultiplier = fogDistanceMultiplier; + } + + /** + * @return The Player that is seeing the fog. + */ + @NotNull + public LocalPlayer getPlayer() { + return player; + } + /** + * @return The fog distance multiplier of vampire fog. + */ + public float getFogDistanceMultiplier() { + return fogDistanceMultiplier; + } + + /** + * @param fogDistanceMultiplier The fog distance multiplier of vampire fog + */ + public void setFogDistanceMultiplier(float fogDistanceMultiplier) { + this.fogDistanceMultiplier = fogDistanceMultiplier; + } +} diff --git a/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java b/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java index 26ef11106..397fc283b 100644 --- a/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java +++ b/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java @@ -2,9 +2,9 @@ import com.mojang.blaze3d.pipeline.RenderTarget; import de.teamlapen.lib.util.OptifineHandler; -import de.teamlapen.vampirism.REFERENCE; import de.teamlapen.vampirism.api.entity.IExtendedCreatureVampirism; import de.teamlapen.vampirism.api.entity.hunter.IHunterMob; +import de.teamlapen.vampirism.api.event.VampireFogEvent; import de.teamlapen.vampirism.api.items.IItemWithTier; import de.teamlapen.vampirism.api.util.VResourceLocation; import de.teamlapen.vampirism.blocks.CoffinBlock; @@ -19,6 +19,7 @@ import de.teamlapen.vampirism.mixin.client.accessor.CameraAccessor; import de.teamlapen.vampirism.util.Helper; import de.teamlapen.vampirism.util.MixinHooks; +import de.teamlapen.vampirism.util.VampirismEventFactory; import net.minecraft.client.Minecraft; import net.minecraft.client.model.HumanoidModel; import net.minecraft.client.model.PlayerModel; @@ -52,6 +53,7 @@ /** * Handle most general rendering related stuff */ +@SuppressWarnings("unused") public class RenderHandler implements ResourceManagerReloadListener { private static final int ENTITY_NEAR_SQ_DISTANCE = 100; @NotNull @@ -160,6 +162,9 @@ public void onClientTick(ClientTickEvent.Pre event) { vampireBiomeTicks--; } } + + VampireFogEvent vampireFogEvent = VampirismEventFactory.fireVampireFogEvent(mc.player, vampireBiomeFogDistanceMultiplier); + vampireBiomeFogDistanceMultiplier = vampireFogEvent.getFogDistanceMultiplier(); } @SubscribeEvent diff --git a/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java b/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java index aa8739bb8..70ba75080 100644 --- a/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java +++ b/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java @@ -8,11 +8,9 @@ import de.teamlapen.vampirism.api.entity.player.vampire.IDrinkBloodContext; import de.teamlapen.vampirism.api.entity.player.vampire.IVampirePlayer; import de.teamlapen.vampirism.api.entity.vampire.IVampire; -import de.teamlapen.vampirism.api.event.ActionEvent; -import de.teamlapen.vampirism.api.event.BloodDrinkEvent; -import de.teamlapen.vampirism.api.event.PlayerFactionEvent; -import de.teamlapen.vampirism.api.event.VampirismVillageEvent; +import de.teamlapen.vampirism.api.event.*; import de.teamlapen.vampirism.api.world.ITotem; +import net.minecraft.client.player.LocalPlayer; import net.minecraft.world.entity.Mob; import net.minecraft.world.entity.npc.Villager; import net.neoforged.neoforge.common.NeoForge; @@ -80,11 +78,13 @@ public static boolean fireMakeAggressive(@NotNull ITotem totem, @NotNull Village NeoForge.EVENT_BUS.post(event); return event; } + public static @NotNull ActionEvent.ActionActivatedEvent fireActionActivatedEvent(@NotNull IFactionPlayer factionPlayer, @NotNull IAction action, int cooldown, int duration) { ActionEvent.ActionActivatedEvent event = new ActionEvent.ActionActivatedEvent(factionPlayer, action, cooldown, duration); NeoForge.EVENT_BUS.post(event); return event; } + public static int fireActionDeactivatedEvent(@NotNull IFactionPlayer factionPlayer, @NotNull IAction action, int remainingDuration, int cooldown) { ActionEvent.ActionDeactivatedEvent event = new ActionEvent.ActionDeactivatedEvent(factionPlayer, action, remainingDuration, cooldown); NeoForge.EVENT_BUS.post(event); @@ -97,4 +97,10 @@ public static ActionEvent.ActionUpdateEvent fireActionUpdateEvent(@NotNull IFact return event; } + public static VampireFogEvent fireVampireFogEvent(@NotNull LocalPlayer player, float fogDistanceMultiplier) { + VampireFogEvent event = new VampireFogEvent(player, fogDistanceMultiplier); + NeoForge.EVENT_BUS.post(event); + return event; + } + } \ No newline at end of file From e2fa9269bfcb99ce66100fdfaf1863336c053511 Mon Sep 17 00:00:00 2001 From: GridExpert <126912375+TheGridExpert@users.noreply.github.com> Date: Thu, 22 Aug 2024 21:37:18 +0300 Subject: [PATCH 3/3] Make requested changes --- .../vampirism/api/event/VampireFogEvent.java | 13 +------------ .../vampirism/client/renderer/RenderHandler.java | 5 ++--- .../vampirism/util/VampirismEventFactory.java | 6 +++--- 3 files changed, 6 insertions(+), 18 deletions(-) diff --git a/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java b/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java index f80cd5c86..8d9c952ca 100644 --- a/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java +++ b/src/api/java/de/teamlapen/vampirism/api/event/VampireFogEvent.java @@ -1,26 +1,15 @@ package de.teamlapen.vampirism.api.event; -import net.minecraft.client.player.LocalPlayer; import net.neoforged.bus.api.Event; -import org.jetbrains.annotations.NotNull; @SuppressWarnings("unused") public class VampireFogEvent extends Event { - private final LocalPlayer player; private float fogDistanceMultiplier; - public VampireFogEvent(@NotNull LocalPlayer player, float fogDistanceMultiplier) { - this.player = player; + public VampireFogEvent(float fogDistanceMultiplier) { this.fogDistanceMultiplier = fogDistanceMultiplier; } - /** - * @return The Player that is seeing the fog. - */ - @NotNull - public LocalPlayer getPlayer() { - return player; - } /** * @return The fog distance multiplier of vampire fog. */ diff --git a/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java b/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java index 397fc283b..0800c7254 100644 --- a/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java +++ b/src/main/java/de/teamlapen/vampirism/client/renderer/RenderHandler.java @@ -149,6 +149,8 @@ public void onClientTick(ClientTickEvent.Pre event) { vampireBiomeFogDistanceMultiplier = vampire.getLevel() > 0 ? 2 : 1; vampireBiomeFogDistanceMultiplier += vampire.getSkillHandler().isRefinementEquipped(ModRefinements.VISTA.get()) ? VampirismConfig.BALANCE.vrVistaMod.get().floatValue() : 0; + vampireBiomeFogDistanceMultiplier = VampirismEventFactory.fireVampireFogEvent(vampireBiomeFogDistanceMultiplier); + } else { insideFog = false; } @@ -162,9 +164,6 @@ public void onClientTick(ClientTickEvent.Pre event) { vampireBiomeTicks--; } } - - VampireFogEvent vampireFogEvent = VampirismEventFactory.fireVampireFogEvent(mc.player, vampireBiomeFogDistanceMultiplier); - vampireBiomeFogDistanceMultiplier = vampireFogEvent.getFogDistanceMultiplier(); } @SubscribeEvent diff --git a/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java b/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java index 70ba75080..f0a0dc287 100644 --- a/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java +++ b/src/main/java/de/teamlapen/vampirism/util/VampirismEventFactory.java @@ -97,10 +97,10 @@ public static ActionEvent.ActionUpdateEvent fireActionUpdateEvent(@NotNull IFact return event; } - public static VampireFogEvent fireVampireFogEvent(@NotNull LocalPlayer player, float fogDistanceMultiplier) { - VampireFogEvent event = new VampireFogEvent(player, fogDistanceMultiplier); + public static float fireVampireFogEvent(float fogDistanceMultiplier) { + VampireFogEvent event = new VampireFogEvent(fogDistanceMultiplier); NeoForge.EVENT_BUS.post(event); - return event; + return event.getFogDistanceMultiplier(); } } \ No newline at end of file