Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
71883d93e9 | |||
fc33eea2e5 | |||
301d8b192a |
17
build.gradle
17
build.gradle
@ -14,7 +14,7 @@ base {
|
|||||||
}
|
}
|
||||||
|
|
||||||
java {
|
java {
|
||||||
toolchain.languageVersion = JavaLanguageVersion.of(17)
|
toolchain.languageVersion = JavaLanguageVersion.of(21)
|
||||||
}
|
}
|
||||||
|
|
||||||
minecraft {
|
minecraft {
|
||||||
@ -31,7 +31,7 @@ minecraft {
|
|||||||
//
|
//
|
||||||
// Use non-default mappings at your own risk. They may not always work.
|
// Use non-default mappings at your own risk. They may not always work.
|
||||||
// Simply re-run your setup task after changing the mappings to update your workspace.
|
// Simply re-run your setup task after changing the mappings to update your workspace.
|
||||||
mappings channel: 'parchment', version: '2023.09.03-1.20.1'
|
mappings channel: 'parchment', version: '2024.06.16-1.20.6'
|
||||||
|
|
||||||
// When true, this property will have all Eclipse/IntelliJ IDEA run configurations run the "prepareX" task for the given run configuration before launching the game.
|
// When true, this property will have all Eclipse/IntelliJ IDEA run configurations run the "prepareX" task for the given run configuration before launching the game.
|
||||||
// In most cases, it is not necessary to enable.
|
// In most cases, it is not necessary to enable.
|
||||||
@ -75,12 +75,6 @@ minecraft {
|
|||||||
// You can set various levels here.
|
// You can set various levels here.
|
||||||
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels
|
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels
|
||||||
property 'forge.logging.console.level', 'debug'
|
property 'forge.logging.console.level', 'debug'
|
||||||
|
|
||||||
mods {
|
|
||||||
"${mod_id}" {
|
|
||||||
source sourceSets.main
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
client {
|
client {
|
||||||
@ -146,6 +140,8 @@ dependencies {
|
|||||||
// For more info:
|
// For more info:
|
||||||
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
||||||
// http://www.gradle.org/docs/current/userguide/dependency_management.html
|
// http://www.gradle.org/docs/current/userguide/dependency_management.html
|
||||||
|
|
||||||
|
implementation('net.sf.jopt-simple:jopt-simple:5.0.4') { version { strictly '5.0.4' } }
|
||||||
}
|
}
|
||||||
|
|
||||||
// This block of code expands all declared replace properties in the specified resource targets.
|
// This block of code expands all declared replace properties in the specified resource targets.
|
||||||
@ -186,3 +182,8 @@ tasks.withType(JavaCompile).configureEach {
|
|||||||
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation
|
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sourceSets.each {
|
||||||
|
def dir = layout.buildDirectory.dir("sourcesSets/$it.name")
|
||||||
|
it.output.resourcesDir = dir
|
||||||
|
it.java.destinationDirectory = dir
|
||||||
|
}
|
@ -1,17 +1,17 @@
|
|||||||
org.gradle.jvmargs=-Xmx3G
|
org.gradle.jvmargs=-Xmx3G
|
||||||
org.gradle.daemon=false
|
org.gradle.daemon=false
|
||||||
# The Minecraft version must agree with the Forge version to get a valid artifact
|
# The Minecraft version must agree with the Forge version to get a valid artifact
|
||||||
minecraft_version=1.20.1
|
minecraft_version=1.20.6
|
||||||
# The Minecraft version range can use any release version of Minecraft as bounds.
|
# The Minecraft version range can use any release version of Minecraft as bounds.
|
||||||
# Snapshots, pre-releases, and release candidates are not guaranteed to sort properly
|
# Snapshots, pre-releases, and release candidates are not guaranteed to sort properly
|
||||||
# as they do not follow standard versioning conventions.
|
# as they do not follow standard versioning conventions.
|
||||||
minecraft_version_range=[1.20.1,1.20.2]
|
minecraft_version_range=[1.20.6]
|
||||||
# The Forge version must agree with the Minecraft version to get a valid artifact
|
# The Forge version must agree with the Minecraft version to get a valid artifact
|
||||||
forge_version=47.3.0
|
forge_version=50.1.0
|
||||||
# The Forge version range can use any version of Forge as bounds or match the loader version range
|
# The Forge version range can use any version of Forge as bounds or match the loader version range
|
||||||
forge_version_range=[47,)
|
forge_version_range=[50,)
|
||||||
# The loader version range can only use the major version of Forge/FML as bounds
|
# The loader version range can only use the major version of Forge/FML as bounds
|
||||||
loader_version_range=[47,)
|
loader_version_range=[50,)
|
||||||
# The mapping channel to use for mappings.
|
# The mapping channel to use for mappings.
|
||||||
# The default set of supported mapping channels are ["official", "snapshot", "snapshot_nodoc", "stable", "stable_nodoc"].
|
# The default set of supported mapping channels are ["official", "snapshot", "snapshot_nodoc", "stable", "stable_nodoc"].
|
||||||
# Additional mapping channels can be registered through the "channelProviders" extension in a Gradle plugin.
|
# Additional mapping channels can be registered through the "channelProviders" extension in a Gradle plugin.
|
||||||
@ -29,7 +29,7 @@ loader_version_range=[47,)
|
|||||||
mapping_channel=official
|
mapping_channel=official
|
||||||
# The mapping version to query from the mapping channel.
|
# The mapping version to query from the mapping channel.
|
||||||
# This must match the format required by the mapping channel.
|
# This must match the format required by the mapping channel.
|
||||||
mapping_version=1.20.1
|
mapping_version=1.20.6
|
||||||
# The unique mod identifier for the mod. Must be lowercase in English locale. Must fit the regex [a-z][a-z0-9_]{1,63}
|
# The unique mod identifier for the mod. Must be lowercase in English locale. Must fit the regex [a-z][a-z0-9_]{1,63}
|
||||||
# Must match the String constant located in the main mod class annotated with @Mod.
|
# Must match the String constant located in the main mod class annotated with @Mod.
|
||||||
mod_id=advancedarrows
|
mod_id=advancedarrows
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
package com.jenny.advancedarrows.datagen;
|
package com.jenny.advancedarrows.datagen;
|
||||||
|
|
||||||
import net.minecraft.core.HolderLookup;
|
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraft.data.PackOutput;
|
import net.minecraft.data.PackOutput;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.minecraftforge.common.data.ExistingFileHelper;
|
||||||
@ -9,8 +8,6 @@ import net.minecraftforge.eventbus.api.SubscribeEvent;
|
|||||||
import net.minecraftforge.fml.common.Mod;
|
import net.minecraftforge.fml.common.Mod;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
|
||||||
|
|
||||||
import static com.jenny.advancedarrows.advancedArrows.MODID;
|
import static com.jenny.advancedarrows.advancedArrows.MODID;
|
||||||
|
|
||||||
@Mod.EventBusSubscriber(modid = MODID, bus = Mod.EventBusSubscriber.Bus.MOD)
|
@Mod.EventBusSubscriber(modid = MODID, bus = Mod.EventBusSubscriber.Bus.MOD)
|
||||||
@ -20,8 +17,6 @@ public class DataGenerators {
|
|||||||
DataGenerator generator = event.getGenerator();
|
DataGenerator generator = event.getGenerator();
|
||||||
PackOutput packOutput = generator.getPackOutput();
|
PackOutput packOutput = generator.getPackOutput();
|
||||||
ExistingFileHelper existingFileHelper = event.getExistingFileHelper();
|
ExistingFileHelper existingFileHelper = event.getExistingFileHelper();
|
||||||
CompletableFuture<HolderLookup.Provider> lookupProvider = event.getLookupProvider();
|
|
||||||
|
|
||||||
generator.addProvider(event.includeClient(), new ModItemModelProvider(packOutput, existingFileHelper));
|
generator.addProvider(event.includeClient(), new ModItemModelProvider(packOutput, existingFileHelper));
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -8,6 +8,7 @@ import net.minecraftforge.client.model.generators.ItemModelBuilder;
|
|||||||
import net.minecraftforge.client.model.generators.ItemModelProvider;
|
import net.minecraftforge.client.model.generators.ItemModelProvider;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.minecraftforge.common.data.ExistingFileHelper;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
import net.minecraftforge.registries.RegistryObject;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import static com.jenny.advancedarrows.advancedArrows.MODID;
|
import static com.jenny.advancedarrows.advancedArrows.MODID;
|
||||||
|
|
||||||
@ -23,7 +24,7 @@ public class ModItemModelProvider extends ItemModelProvider {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private ItemModelBuilder simpleItem(RegistryObject<Item> item) {
|
private ItemModelBuilder simpleItem(@NotNull RegistryObject<Item> item) {
|
||||||
return withExistingParent(item.getId().getPath(),
|
return withExistingParent(item.getId().getPath(),
|
||||||
new ResourceLocation("item/generated")).texture("layer0",
|
new ResourceLocation("item/generated")).texture("layer0",
|
||||||
new ResourceLocation(MODID,"item/" + item.getId().getPath()));
|
new ResourceLocation(MODID,"item/" + item.getId().getPath()));
|
||||||
|
@ -1,230 +1,57 @@
|
|||||||
package com.jenny.advancedarrows.entities;
|
package com.jenny.advancedarrows.entities;
|
||||||
|
|
||||||
import com.google.common.collect.Sets;
|
|
||||||
import net.minecraft.core.particles.ParticleTypes;
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries;
|
|
||||||
import net.minecraft.nbt.CompoundTag;
|
|
||||||
import net.minecraft.nbt.ListTag;
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor;
|
|
||||||
import net.minecraft.network.syncher.EntityDataSerializers;
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData;
|
|
||||||
import net.minecraft.world.effect.MobEffectInstance;
|
|
||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.entity.projectile.AbstractArrow;
|
import net.minecraft.world.entity.projectile.AbstractArrow;
|
||||||
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
import net.minecraft.world.item.Items;
|
|
||||||
import net.minecraft.world.item.alchemy.Potion;
|
|
||||||
import net.minecraft.world.item.alchemy.PotionUtils;
|
|
||||||
import net.minecraft.world.item.alchemy.Potions;
|
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
public class baseArrow extends AbstractArrow {
|
public class baseArrow extends AbstractArrow {
|
||||||
private static final int EXPOSED_POTION_DECAY_TIME = 600;
|
private final Item itemPickup;
|
||||||
private static final int NO_EFFECT_COLOR = -1;
|
|
||||||
private static final EntityDataAccessor<Integer> ID_EFFECT_COLOR = SynchedEntityData.defineId(baseArrow.class, EntityDataSerializers.INT);
|
|
||||||
private static final byte EVENT_POTION_PUFF = 0;
|
|
||||||
private Potion potion = Potions.EMPTY;
|
|
||||||
private final Set<MobEffectInstance> effects = Sets.newHashSet();
|
|
||||||
private boolean fixedColor;
|
|
||||||
private int tick = 0;
|
private int tick = 0;
|
||||||
|
|
||||||
public baseArrow(EntityType<? extends baseArrow> pEntityType, Level pLevel) {
|
public baseArrow(EntityType<? extends baseArrow> pEntityType, Level pLevel, Item item) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item.getDefaultInstance());
|
||||||
|
this.itemPickup = item;
|
||||||
}
|
}
|
||||||
|
|
||||||
public baseArrow(Level pLevel, double pX, double pY, double pZ, EntityType<? extends baseArrow> pEntityType) {
|
public baseArrow(Level pLevel, LivingEntity pShooter, EntityType<? extends baseArrow> pEntityType, Item item) {
|
||||||
super(pEntityType, pX, pY, pZ, pLevel);
|
super(pEntityType, pShooter, pLevel, item.getDefaultInstance());
|
||||||
}
|
this.itemPickup = item;
|
||||||
|
|
||||||
public baseArrow(Level pLevel, LivingEntity pShooter, EntityType<? extends baseArrow> pEntityType) {
|
|
||||||
super(pEntityType, pShooter, pLevel);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setEffectsFromItem(ItemStack pStack) {
|
|
||||||
if (pStack.is(Items.TIPPED_ARROW)) {
|
|
||||||
this.potion = PotionUtils.getPotion(pStack);
|
|
||||||
Collection<MobEffectInstance> collection = PotionUtils.getCustomEffects(pStack);
|
|
||||||
if (!collection.isEmpty()) {
|
|
||||||
for(MobEffectInstance mobeffectinstance : collection) {
|
|
||||||
this.effects.add(new MobEffectInstance(mobeffectinstance));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int i = getCustomColor(pStack);
|
|
||||||
if (i == -1) {
|
|
||||||
this.updateColor();
|
|
||||||
} else {
|
|
||||||
this.setFixedColor(i);
|
|
||||||
}
|
|
||||||
} else if (pStack.is(Items.ARROW)) {
|
|
||||||
this.potion = Potions.EMPTY;
|
|
||||||
this.effects.clear();
|
|
||||||
this.entityData.set(ID_EFFECT_COLOR, -1);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int getCustomColor(ItemStack pStack) {
|
|
||||||
CompoundTag compoundtag = pStack.getTag();
|
|
||||||
return compoundtag != null && compoundtag.contains("CustomPotionColor", 99) ? compoundtag.getInt("CustomPotionColor") : -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateColor() {
|
|
||||||
this.fixedColor = false;
|
|
||||||
if (this.potion == Potions.EMPTY && this.effects.isEmpty()) {
|
|
||||||
this.entityData.set(ID_EFFECT_COLOR, -1);
|
|
||||||
} else {
|
|
||||||
this.entityData.set(ID_EFFECT_COLOR, PotionUtils.getColor(PotionUtils.getAllEffects(this.potion, this.effects)));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addEffect(MobEffectInstance pEffectInstance) {
|
|
||||||
this.effects.add(pEffectInstance);
|
|
||||||
this.getEntityData().set(ID_EFFECT_COLOR, PotionUtils.getColor(PotionUtils.getAllEffects(this.potion, this.effects)));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void defineSynchedData() {
|
|
||||||
super.defineSynchedData();
|
|
||||||
this.entityData.define(ID_EFFECT_COLOR, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void tick() {
|
public void tick() {
|
||||||
super.tick();
|
super.tick();
|
||||||
if (this.level().isClientSide) {
|
if (this.level().isClientSide) {
|
||||||
if (this.inGround) {
|
if (!this.inGround) {
|
||||||
if (this.inGroundTime % 5 == 0) {
|
|
||||||
this.makeParticle(1);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
spawnParticles();
|
spawnParticles();
|
||||||
}
|
}
|
||||||
this.tick++;
|
this.tick++;
|
||||||
} else if (this.inGround && this.inGroundTime != 0 && !this.effects.isEmpty() && this.inGroundTime >= 600) {
|
} else if (this.inGround && this.inGroundTime != 0 && this.inGroundTime >= 600) {
|
||||||
this.level().broadcastEntityEvent(this, (byte)0);
|
this.level().broadcastEntityEvent(this, (byte)0);
|
||||||
this.potion = Potions.EMPTY;
|
|
||||||
this.effects.clear();
|
|
||||||
this.entityData.set(ID_EFFECT_COLOR, -1);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void makeParticle(int pParticleAmount) {
|
|
||||||
int i = this.getColor();
|
|
||||||
if (i != -1 && pParticleAmount > 0) {
|
|
||||||
double d0 = (double)(i >> 16 & 255) / 255.0D;
|
|
||||||
double d1 = (double)(i >> 8 & 255) / 255.0D;
|
|
||||||
double d2 = (double)(i >> 0 & 255) / 255.0D;
|
|
||||||
|
|
||||||
for(int j = 0; j < pParticleAmount; ++j) {
|
|
||||||
this.level().addParticle(ParticleTypes.ENTITY_EFFECT, this.getRandomX(0.5D), this.getRandomY(), this.getRandomZ(0.5D), d0, d1, d2);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getColor() {
|
|
||||||
return this.entityData.get(ID_EFFECT_COLOR);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setFixedColor(int pFixedColor) {
|
|
||||||
this.fixedColor = true;
|
|
||||||
this.entityData.set(ID_EFFECT_COLOR, pFixedColor);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addAdditionalSaveData(@NotNull CompoundTag pCompound) {
|
|
||||||
super.addAdditionalSaveData(pCompound);
|
|
||||||
if (this.potion != Potions.EMPTY) {
|
|
||||||
pCompound.putString("Potion", BuiltInRegistries.POTION.getKey(this.potion).toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.fixedColor) {
|
|
||||||
pCompound.putInt("Color", this.getColor());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this.effects.isEmpty()) {
|
|
||||||
ListTag listtag = new ListTag();
|
|
||||||
|
|
||||||
for(MobEffectInstance mobeffectinstance : this.effects) {
|
|
||||||
listtag.add(mobeffectinstance.save(new CompoundTag()));
|
|
||||||
}
|
|
||||||
|
|
||||||
pCompound.put("CustomPotionEffects", listtag);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public void readAdditionalSaveData(@NotNull CompoundTag pCompound) {
|
|
||||||
super.readAdditionalSaveData(pCompound);
|
|
||||||
if (pCompound.contains("Potion", 8)) {
|
|
||||||
this.potion = PotionUtils.getPotion(pCompound);
|
|
||||||
}
|
|
||||||
|
|
||||||
for(MobEffectInstance mobeffectinstance : PotionUtils.getCustomEffects(pCompound)) {
|
|
||||||
this.addEffect(mobeffectinstance);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pCompound.contains("Color", 99)) {
|
|
||||||
this.setFixedColor(pCompound.getInt("Color"));
|
|
||||||
} else {
|
|
||||||
this.updateColor();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void doPostHurtEffects(@NotNull LivingEntity pLiving) {
|
|
||||||
super.doPostHurtEffects(pLiving);
|
|
||||||
Entity entity = this.getEffectSource();
|
|
||||||
|
|
||||||
for(MobEffectInstance mobeffectinstance : this.potion.getEffects()) {
|
|
||||||
pLiving.addEffect(new MobEffectInstance(mobeffectinstance.getEffect(), Math.max(mobeffectinstance.mapDuration((p_268168_) -> {
|
|
||||||
return p_268168_ / 8;
|
|
||||||
}), 1), mobeffectinstance.getAmplifier(), mobeffectinstance.isAmbient(), mobeffectinstance.isVisible()), entity);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this.effects.isEmpty()) {
|
|
||||||
for(MobEffectInstance mobeffectinstance1 : this.effects) {
|
|
||||||
pLiving.addEffect(mobeffectinstance1, entity);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
protected ItemStack getPickupItem() {
|
protected ItemStack getPickupItem() {
|
||||||
if (this.effects.isEmpty() && this.potion == Potions.EMPTY) {
|
return itemPickup.getDefaultInstance();
|
||||||
return new ItemStack(Items.ARROW);
|
}
|
||||||
} else {
|
|
||||||
ItemStack itemstack = new ItemStack(Items.TIPPED_ARROW);
|
|
||||||
PotionUtils.setPotion(itemstack, this.potion);
|
|
||||||
PotionUtils.setCustomEffects(itemstack, this.effects);
|
|
||||||
if (this.fixedColor) {
|
|
||||||
itemstack.getOrCreateTag().putInt("CustomPotionColor", this.getColor());
|
|
||||||
}
|
|
||||||
|
|
||||||
return itemstack;
|
@Override
|
||||||
|
protected @NotNull ItemStack getDefaultPickupItem() {
|
||||||
|
if (itemPickup == null) {
|
||||||
|
return ItemStack.EMPTY;
|
||||||
|
} else {
|
||||||
|
return new ItemStack(itemPickup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleEntityEvent(byte pId) {
|
public void handleEntityEvent(byte pId) {
|
||||||
if (pId == 0) {
|
if (pId != 0) {
|
||||||
int i = this.getColor();
|
|
||||||
if (i != -1) {
|
|
||||||
double d0 = (double)(i >> 16 & 255) / 255.0D;
|
|
||||||
double d1 = (double)(i >> 8 & 255) / 255.0D;
|
|
||||||
double d2 = (double)(i >> 0 & 255) / 255.0D;
|
|
||||||
|
|
||||||
for(int j = 0; j < 20; ++j) {
|
|
||||||
this.level().addParticle(ParticleTypes.ENTITY_EFFECT, this.getRandomX(0.5D), this.getRandomY(), this.getRandomZ(0.5D), d0, d1, d2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
super.handleEntityEvent(pId);
|
super.handleEntityEvent(pId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,7 +74,6 @@ public class baseArrow extends AbstractArrow {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void spawnParticles() {
|
public void spawnParticles() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getTick() {
|
public int getTick() {
|
||||||
|
@ -6,7 +6,7 @@ import com.jenny.advancedarrows.particles.particles;
|
|||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.AABB;
|
import net.minecraft.world.phys.AABB;
|
||||||
import net.minecraft.world.phys.EntityHitResult;
|
import net.minecraft.world.phys.EntityHitResult;
|
||||||
@ -19,13 +19,14 @@ import java.util.List;
|
|||||||
|
|
||||||
public class breachingArrow extends baseArrow{
|
public class breachingArrow extends baseArrow{
|
||||||
static final int range = 4;
|
static final int range = 4;
|
||||||
|
static final Item item = items.ARROW_BREACHING.get();
|
||||||
|
|
||||||
public breachingArrow(EntityType<breachingArrow> pEntityType, Level pLevel) {
|
public breachingArrow(EntityType<breachingArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public breachingArrow(Level pLevel, LivingEntity pShooter) {
|
public breachingArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_BREACHING.get());
|
super(pLevel, pShooter, entities.ARROW_BREACHING.get(), item);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -73,9 +74,4 @@ public class breachingArrow extends baseArrow{
|
|||||||
level().addParticle(particles.PARTICLE_BREACHING_ARROW.get(), pos.x, pos.y, pos.z, 0, 0, 0);
|
level().addParticle(particles.PARTICLE_BREACHING_ARROW.get(), pos.x, pos.y, pos.z, 0, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_BREACHING.get());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,37 +1,25 @@
|
|||||||
package com.jenny.advancedarrows.entities;
|
package com.jenny.advancedarrows.entities;
|
||||||
|
|
||||||
import com.jenny.advancedarrows.config.ConfigClient;
|
import com.jenny.advancedarrows.config.ConfigClient;
|
||||||
import com.jenny.advancedarrows.items.items;
|
|
||||||
import net.minecraft.core.particles.ParticleTypes;
|
import net.minecraft.core.particles.ParticleTypes;
|
||||||
import net.minecraft.world.entity.Entity;
|
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
|
import net.minecraft.world.item.Items;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.EntityHitResult;
|
|
||||||
import net.minecraft.world.phys.HitResult;
|
import net.minecraft.world.phys.HitResult;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class enderArrow extends baseArrow {
|
public class enderArrow extends baseArrow {
|
||||||
|
static final Item item = Items.AIR;
|
||||||
|
|
||||||
public enderArrow(EntityType<enderArrow> pEntityType, Level pLevel) {
|
public enderArrow(EntityType<enderArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public enderArrow(Level pLevel, LivingEntity pShooter) {
|
public enderArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_ENDER.get());
|
super(pLevel, pShooter, entities.ARROW_ENDER.get(), item);
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onHitEntity(@NotNull EntityHitResult pTarget) {
|
|
||||||
super.onHitEntity(pTarget);
|
|
||||||
Entity target = pTarget.getEntity();
|
|
||||||
target.addDeltaMovement(getDeltaMovement().multiply(1.5, 0.2, 1.5));
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_ENDER.get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -41,6 +29,7 @@ public class enderArrow extends baseArrow {
|
|||||||
Vec3 pos = pResult.getLocation();
|
Vec3 pos = pResult.getLocation();
|
||||||
level().getPlayerByUUID(getOwner().getUUID()).teleportTo(pos.x, pos.y, pos.z);
|
level().getPlayerByUUID(getOwner().getUUID()).teleportTo(pos.x, pos.y, pos.z);
|
||||||
}
|
}
|
||||||
|
discard();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -6,32 +6,27 @@ import com.jenny.advancedarrows.items.items;
|
|||||||
import net.minecraft.core.particles.ParticleTypes;
|
import net.minecraft.core.particles.ParticleTypes;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.AABB;
|
import net.minecraft.world.phys.AABB;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class homingArrow extends baseArrow {
|
public class homingArrow extends baseArrow {
|
||||||
LivingEntity target;
|
LivingEntity target;
|
||||||
|
static final Item item = items.ARROW_HOMING.get();
|
||||||
|
|
||||||
public homingArrow(EntityType<homingArrow> pEntityType, Level pLevel) {
|
public homingArrow(EntityType<homingArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public homingArrow(Level pLevel, LivingEntity pShooter) {
|
public homingArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_HOMING.get());
|
super(pLevel, pShooter, entities.ARROW_HOMING.get(), item);
|
||||||
setBaseDamage(1);
|
setBaseDamage(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_HOMING.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void tick() {
|
public void tick() {
|
||||||
if (!level().isClientSide) {
|
if (!level().isClientSide) {
|
||||||
|
@ -5,33 +5,26 @@ import com.jenny.advancedarrows.items.items;
|
|||||||
import net.minecraft.core.particles.ParticleTypes;
|
import net.minecraft.core.particles.ParticleTypes;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class incendiaryArrow extends baseArrow{
|
public class incendiaryArrow extends baseArrow{
|
||||||
|
static final Item item = items.ARROW_INCENDIARY.get();
|
||||||
|
|
||||||
public incendiaryArrow(EntityType<incendiaryArrow> pEntityType, Level pLevel) {
|
public incendiaryArrow(EntityType<incendiaryArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public incendiaryArrow(Level pLevel, LivingEntity pShooter) {
|
public incendiaryArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_INCENDIARY.get());
|
super(pLevel, pShooter, entities.ARROW_INCENDIARY.get(), item);
|
||||||
}
|
|
||||||
|
|
||||||
public incendiaryArrow(Level pLevel, double x, double y, double z) {
|
|
||||||
super(entities.ARROW_INCENDIARY.get(), pLevel);
|
|
||||||
setPos(x, y, z);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doPostHurtEffects(@NotNull LivingEntity pTarget) {
|
protected void doPostHurtEffects(@NotNull LivingEntity pTarget) {
|
||||||
pTarget.setSecondsOnFire(5);
|
pTarget.setSharedFlagOnFire(true);
|
||||||
}
|
pTarget.setRemainingFireTicks(100);
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_INCENDIARY.get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -6,19 +6,21 @@ import net.minecraft.core.particles.ParticleTypes;
|
|||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.EntityHitResult;
|
import net.minecraft.world.phys.EntityHitResult;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class kineticArrow extends baseArrow{
|
public class kineticArrow extends baseArrow{
|
||||||
|
static final Item item = items.ARROW_KINETIC.get();
|
||||||
|
|
||||||
public kineticArrow(EntityType<kineticArrow> pEntityType, Level pLevel) {
|
public kineticArrow(EntityType<kineticArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public kineticArrow(Level pLevel, LivingEntity pShooter) {
|
public kineticArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_KINETIC.get());
|
super(pLevel, pShooter, entities.ARROW_KINETIC.get(), item);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -28,11 +30,6 @@ public class kineticArrow extends baseArrow{
|
|||||||
target.addDeltaMovement(getDeltaMovement().multiply(1.5, 0.2, 1.5));
|
target.addDeltaMovement(getDeltaMovement().multiply(1.5, 0.2, 1.5));
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_KINETIC.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void spawnParticles() {
|
public void spawnParticles() {
|
||||||
for (int i = 1; i <= ConfigClient.calcPCount(5); i++) {
|
for (int i = 1; i <= ConfigClient.calcPCount(5); i++) {
|
||||||
|
@ -3,18 +3,19 @@ package com.jenny.advancedarrows.entities;
|
|||||||
import com.jenny.advancedarrows.items.items;
|
import com.jenny.advancedarrows.items.items;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
public class ricochetArrow extends baseArrow{
|
public class ricochetArrow extends baseArrow{
|
||||||
|
static final Item item = items.ARROW_RICOCHET.get();
|
||||||
|
|
||||||
public ricochetArrow(EntityType<ricochetArrow> pEntityType, Level pLevel) {
|
public ricochetArrow(EntityType<ricochetArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ricochetArrow(Level pLevel, LivingEntity pShooter) {
|
public ricochetArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_RICOCHET.get());
|
super(pLevel, pShooter, entities.ARROW_RICOCHET.get(), item);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -33,10 +34,4 @@ public class ricochetArrow extends baseArrow{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_RICOCHET.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -5,26 +5,22 @@ import com.jenny.advancedarrows.items.items;
|
|||||||
import net.minecraft.core.particles.ParticleTypes;
|
import net.minecraft.core.particles.ParticleTypes;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
public class sharpenedArrow extends baseArrow{
|
public class sharpenedArrow extends baseArrow{
|
||||||
|
static final Item item = items.ARROW_SHARPENED.get();
|
||||||
|
|
||||||
public sharpenedArrow(EntityType<sharpenedArrow> pEntityType, Level pLevel) {
|
public sharpenedArrow(EntityType<sharpenedArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public sharpenedArrow(Level pLevel, LivingEntity pShooter) {
|
public sharpenedArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_SHARPENED.get());
|
super(pLevel, pShooter, entities.ARROW_SHARPENED.get(), item);
|
||||||
setBaseDamage(3);
|
setBaseDamage(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_SHARPENED.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void spawnParticles() {
|
public void spawnParticles() {
|
||||||
for (int i = 1; i <= ConfigClient.calcPCount(5); i++) {
|
for (int i = 1; i <= ConfigClient.calcPCount(5); i++) {
|
||||||
|
@ -6,24 +6,21 @@ import net.minecraft.core.particles.ParticleTypes;
|
|||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.LivingEntity;
|
import net.minecraft.world.entity.LivingEntity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.phys.EntityHitResult;
|
import net.minecraft.world.phys.EntityHitResult;
|
||||||
import net.minecraft.world.phys.Vec3;
|
import net.minecraft.world.phys.Vec3;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class switchArrow extends baseArrow{
|
public class switchArrow extends baseArrow{
|
||||||
|
static final Item item = items.ARROW_SWITCH.get();
|
||||||
|
|
||||||
public switchArrow(EntityType<switchArrow> pEntityType, Level pLevel) {
|
public switchArrow(EntityType<switchArrow> pEntityType, Level pLevel) {
|
||||||
super(pEntityType, pLevel);
|
super(pEntityType, pLevel, item);
|
||||||
}
|
}
|
||||||
|
|
||||||
public switchArrow(Level pLevel, LivingEntity pShooter) {
|
public switchArrow(Level pLevel, LivingEntity pShooter) {
|
||||||
super(pLevel, pShooter, entities.ARROW_SWITCH.get());
|
super(pLevel, pShooter, entities.ARROW_SWITCH.get(), item);
|
||||||
}
|
|
||||||
|
|
||||||
public switchArrow(Level pLevel, double x, double y, double z) {
|
|
||||||
super(entities.ARROW_SWITCH.get(), pLevel);
|
|
||||||
setPos(x, y, z);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -37,11 +34,7 @@ public class switchArrow extends baseArrow{
|
|||||||
//owner.setPos(ownerPos) doesn't work somehow, idk why
|
//owner.setPos(ownerPos) doesn't work somehow, idk why
|
||||||
level().getPlayerByUUID(owner.getUUID()).teleportTo(ownerPos.x, ownerPos.y, ownerPos.z);
|
level().getPlayerByUUID(owner.getUUID()).teleportTo(ownerPos.x, ownerPos.y, ownerPos.z);
|
||||||
}
|
}
|
||||||
}
|
discard();
|
||||||
|
|
||||||
@NotNull
|
|
||||||
protected ItemStack getPickupItem() {
|
|
||||||
return new ItemStack(items.ARROW_SWITCH.get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -10,7 +10,6 @@ import net.minecraft.world.item.ItemStack;
|
|||||||
import net.minecraft.world.item.TooltipFlag;
|
import net.minecraft.world.item.TooltipFlag;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -22,12 +21,12 @@ public abstract class ArrowAbstract extends ArrowItem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void appendHoverText(@NotNull ItemStack pStack, @Nullable Level pLevel, @NotNull List<Component> pTooltipComponents, @NotNull TooltipFlag pIsAdvanced) {
|
public void appendHoverText(@NotNull ItemStack pStack, @NotNull TooltipContext pContext, @NotNull List<Component> pTooltipComponents, @NotNull TooltipFlag pTooltipFlag) {
|
||||||
String key = String.format("tooltip.%s.%s", MODID, this);
|
String key = String.format("tooltip.%s.%s", MODID, this);
|
||||||
MutableComponent toolTip = Component.translatable(key);
|
MutableComponent toolTip = Component.translatable(key);
|
||||||
if (!toolTip.getString().equals(key)) {
|
if (!toolTip.getString().equals(key)) {
|
||||||
pTooltipComponents.add(toolTip.withStyle(ChatFormatting.DARK_BLUE));
|
pTooltipComponents.add(toolTip.withStyle(ChatFormatting.DARK_BLUE));
|
||||||
super.appendHoverText(pStack, pLevel, pTooltipComponents, pIsAdvanced);
|
super.appendHoverText(pStack, pContext, pTooltipComponents, pTooltipFlag);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,15 +2,17 @@ package com.jenny.advancedarrows.items;
|
|||||||
|
|
||||||
import com.jenny.advancedarrows.entities.baseArrow;
|
import com.jenny.advancedarrows.entities.baseArrow;
|
||||||
import com.jenny.advancedarrows.entities.entities;
|
import com.jenny.advancedarrows.entities.entities;
|
||||||
|
import net.minecraft.core.Direction;
|
||||||
import net.minecraft.core.Position;
|
import net.minecraft.core.Position;
|
||||||
import net.minecraft.core.dispenser.AbstractProjectileDispenseBehavior;
|
import net.minecraft.core.dispenser.BlockSource;
|
||||||
|
import net.minecraft.core.dispenser.DefaultDispenseItemBehavior;
|
||||||
import net.minecraft.world.entity.EntityType;
|
import net.minecraft.world.entity.EntityType;
|
||||||
import net.minecraft.world.entity.projectile.AbstractArrow;
|
import net.minecraft.world.entity.projectile.AbstractArrow;
|
||||||
import net.minecraft.world.entity.projectile.Projectile;
|
|
||||||
import net.minecraft.world.item.Item;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.level.block.DispenserBlock;
|
import net.minecraft.world.level.block.DispenserBlock;
|
||||||
|
import net.minecraft.world.phys.Vec3;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.minecraftforge.eventbus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.minecraftforge.registries.DeferredRegister;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.minecraftforge.registries.ForgeRegistries;
|
||||||
@ -37,30 +39,46 @@ public class items {
|
|||||||
|
|
||||||
|
|
||||||
public static void registerDispenser() {
|
public static void registerDispenser() {
|
||||||
class ArrowDispenseBehaviour extends AbstractProjectileDispenseBehavior {
|
class ArrowDispenseBehaviour extends DefaultDispenseItemBehavior {
|
||||||
|
private final ArrowAbstract.DispenseConfig dispenseConfig;
|
||||||
private final EntityType<? extends baseArrow> arrowType;
|
private final EntityType<? extends baseArrow> arrowType;
|
||||||
|
|
||||||
public ArrowDispenseBehaviour(EntityType<? extends baseArrow> arrow) {
|
public ArrowDispenseBehaviour(@NotNull ArrowAbstract arrowItem, EntityType<? extends baseArrow> arrow) {
|
||||||
|
this.dispenseConfig = arrowItem.createDispenseConfig();
|
||||||
this.arrowType = arrow;
|
this.arrowType = arrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected @NotNull Projectile getProjectile(@NotNull Level pLevel, @NotNull Position pPosition, @NotNull ItemStack pStack) {
|
public @NotNull ItemStack execute(@NotNull BlockSource pBlockSource, @NotNull ItemStack pItem) {
|
||||||
baseArrow arrow = arrowType.create(pLevel);
|
Level level = pBlockSource.level();
|
||||||
assert arrow != null;
|
Direction dir = pBlockSource.state().getValue(DispenserBlock.FACING);
|
||||||
arrow.setPos(pPosition.x(), pPosition.y(), pPosition.z());
|
Position pos = this.dispenseConfig.positionFunction().getDispensePosition(pBlockSource, dir);
|
||||||
arrow.pickup = AbstractArrow.Pickup.ALLOWED;
|
|
||||||
return arrow;
|
AbstractArrow arrowEntity = arrowType.create(level);
|
||||||
|
assert arrowEntity != null;
|
||||||
|
arrowEntity.setPos(new Vec3(pos.x(), pos.y(), pos.z()));
|
||||||
|
arrowEntity.setDeltaMovement(dir.getStepX(), dir.getStepY(), dir.getStepZ());
|
||||||
|
level.addFreshEntity(arrowEntity);
|
||||||
|
pItem.shrink(1);
|
||||||
|
return pItem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DispenserBlock.registerBehavior(ARROW_INCENDIARY.get(), new ArrowDispenseBehaviour(entities.ARROW_INCENDIARY.get()));
|
DispenserBlock.registerBehavior(ARROW_INCENDIARY.get(), new ArrowDispenseBehaviour(
|
||||||
DispenserBlock.registerBehavior(ARROW_RICOCHET.get(), new ArrowDispenseBehaviour(entities.ARROW_RICOCHET.get()));
|
(ArrowAbstract) items.ARROW_INCENDIARY.get(), entities.ARROW_INCENDIARY.get()));
|
||||||
DispenserBlock.registerBehavior(ARROW_KINETIC.get(), new ArrowDispenseBehaviour(entities.ARROW_KINETIC.get()));
|
DispenserBlock.registerBehavior(ARROW_RICOCHET.get(), new ArrowDispenseBehaviour(
|
||||||
DispenserBlock.registerBehavior(ARROW_SHARPENED.get(), new ArrowDispenseBehaviour(entities.ARROW_SHARPENED.get()));
|
(ArrowAbstract) items.ARROW_RICOCHET.get(), entities.ARROW_RICOCHET.get()));
|
||||||
DispenserBlock.registerBehavior(ARROW_SWITCH.get(), new ArrowDispenseBehaviour(entities.ARROW_SWITCH.get()));
|
DispenserBlock.registerBehavior(ARROW_KINETIC.get(), new ArrowDispenseBehaviour(
|
||||||
DispenserBlock.registerBehavior(ARROW_BREACHING.get(), new ArrowDispenseBehaviour(entities.ARROW_BREACHING.get()));
|
(ArrowAbstract) items.ARROW_KINETIC.get(), entities.ARROW_KINETIC.get()));
|
||||||
DispenserBlock.registerBehavior(ARROW_HOMING.get(), new ArrowDispenseBehaviour(entities.ARROW_HOMING.get()));
|
DispenserBlock.registerBehavior(ARROW_SHARPENED.get(), new ArrowDispenseBehaviour(
|
||||||
DispenserBlock.registerBehavior(ARROW_ENDER.get(), new ArrowDispenseBehaviour(entities.ARROW_ENDER.get()));
|
(ArrowAbstract) items.ARROW_SHARPENED.get(), entities.ARROW_SHARPENED.get()));
|
||||||
|
DispenserBlock.registerBehavior(ARROW_SWITCH.get(), new ArrowDispenseBehaviour(
|
||||||
|
(ArrowAbstract) items.ARROW_SWITCH.get(), entities.ARROW_SWITCH.get()));
|
||||||
|
DispenserBlock.registerBehavior(ARROW_BREACHING.get(), new ArrowDispenseBehaviour(
|
||||||
|
(ArrowAbstract) items.ARROW_BREACHING.get(), entities.ARROW_BREACHING.get()));
|
||||||
|
DispenserBlock.registerBehavior(ARROW_HOMING.get(), new ArrowDispenseBehaviour(
|
||||||
|
(ArrowAbstract) items.ARROW_HOMING.get(), entities.ARROW_HOMING.get()));
|
||||||
|
DispenserBlock.registerBehavior(ARROW_ENDER.get(), new ArrowDispenseBehaviour(
|
||||||
|
(ArrowAbstract) items.ARROW_ENDER.get(), entities.ARROW_ENDER.get()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user