Compare commits
	
		
			2 Commits
		
	
	
		
			79c268bc5b
			...
			c9fbf66fd5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c9fbf66fd5 | |||
| 9ab8c6495f | 
| @ -38,12 +38,12 @@ mod_name=Compressed TNT | |||||||
| # The license of the mod. Review your options at https://choosealicense.com/. All Rights Reserved is the default. | # The license of the mod. Review your options at https://choosealicense.com/. All Rights Reserved is the default. | ||||||
| mod_license=All Rights Reserved | mod_license=All Rights Reserved | ||||||
| # The mod version. See https://semver.org/ | # The mod version. See https://semver.org/ | ||||||
| mod_version=0.6.0 | mod_version=0.7.0 | ||||||
| # The group ID for the mod. It is only important when publishing as an artifact to a Maven repository. | # The group ID for the mod. It is only important when publishing as an artifact to a Maven repository. | ||||||
| # This should match the base package used for the mod sources. | # This should match the base package used for the mod sources. | ||||||
| # See https://maven.apache.org/guides/mini/guide-naming-conventions.html | # See https://maven.apache.org/guides/mini/guide-naming-conventions.html | ||||||
| mod_group_id=com.jenny | mod_group_id=com.jenny | ||||||
| # The authors of the mod. This is a simple text string that is used for display purposes in the mod list. | # The authors of the mod. This is a simple text string that is used for display purposes in the mod list. | ||||||
| mod_authors= | mod_authors=Jenny | ||||||
| # The description of the mod. This is a simple multiline text string that is used for display purposes in the mod list. | # The description of the mod. This is a simple multiline text string that is used for display purposes in the mod list. | ||||||
| mod_description= | mod_description=strong & throwable explosives | ||||||
|  | |||||||
| @ -51,6 +51,8 @@ public class blocks { | |||||||
|     public static final RegistryObject<Block> TNT_CLAYMORE =  BLOCKS.register("tnt_claymore", () -> new claymoreTNTBlock(BlockBehaviour.Properties.of().mapColor(MapColor.COLOR_RED), 2.0f, 20, 256)); |     public static final RegistryObject<Block> TNT_CLAYMORE =  BLOCKS.register("tnt_claymore", () -> new claymoreTNTBlock(BlockBehaviour.Properties.of().mapColor(MapColor.COLOR_RED), 2.0f, 20, 256)); | ||||||
|     public static final RegistryObject<Item> TNT_CLAYMORE_ITEM = ITEMS.register("tnt_claymore", () -> new BlockItemTooltip(TNT_CLAYMORE.get(), new Item.Properties())); |     public static final RegistryObject<Item> TNT_CLAYMORE_ITEM = ITEMS.register("tnt_claymore", () -> new BlockItemTooltip(TNT_CLAYMORE.get(), new Item.Properties())); | ||||||
| 
 | 
 | ||||||
|  |     public static final RegistryObject<Block> TNT_SELECTIVE = BLOCKS.register("tnt_selective", () -> new selectiveTNTBlock(BlockBehaviour.Properties.of().mapColor(MapColor.COLOR_RED), 32.0f, 80)); | ||||||
|  |     public static final RegistryObject<Item> TNT_SELECTIVE_ITEM = ITEMS.register("tnt_selective", () -> new BlockItemTooltip(TNT_SELECTIVE.get(), new Item.Properties())); | ||||||
| 
 | 
 | ||||||
|     public static void register(IEventBus bus) { |     public static void register(IEventBus bus) { | ||||||
|         BLOCKS.register(bus); |         BLOCKS.register(bus); | ||||||
|  | |||||||
| @ -0,0 +1,59 @@ | |||||||
|  | package com.jenny.compressedtnt.blocks; | ||||||
|  | 
 | ||||||
|  | import com.jenny.compressedtnt.entities.tnt.selectivePrimedTNT; | ||||||
|  | import com.jenny.compressedtnt.entities.tnt.StrongerPrimedTNT; | ||||||
|  | import net.minecraft.core.BlockPos; | ||||||
|  | import net.minecraft.core.Direction; | ||||||
|  | import net.minecraft.sounds.SoundEvents; | ||||||
|  | import net.minecraft.sounds.SoundSource; | ||||||
|  | import net.minecraft.world.entity.LivingEntity; | ||||||
|  | import net.minecraft.world.entity.player.Player; | ||||||
|  | import net.minecraft.world.level.Explosion; | ||||||
|  | import net.minecraft.world.level.Level; | ||||||
|  | import net.minecraft.world.level.block.TntBlock; | ||||||
|  | import net.minecraft.world.level.block.state.BlockState; | ||||||
|  | import net.minecraft.world.level.gameevent.GameEvent; | ||||||
|  | import org.jetbrains.annotations.NotNull; | ||||||
|  | 
 | ||||||
|  | import javax.annotation.Nullable; | ||||||
|  | 
 | ||||||
|  | public class selectiveTNTBlock extends TntBlock { | ||||||
|  |     public final float pRadius; | ||||||
|  |     public final int fuseTime; | ||||||
|  | 
 | ||||||
|  |     public selectiveTNTBlock(Properties p_57422_, float pRadius, int fuseTime) { | ||||||
|  |         super(p_57422_); | ||||||
|  |         this.pRadius = pRadius; | ||||||
|  |         this.fuseTime = fuseTime; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void onCaughtFire(@NotNull BlockState state, @NotNull Level world, @NotNull BlockPos pos, @Nullable Direction face, @Nullable LivingEntity igniter) { | ||||||
|  |         explode(world, pos, igniter, this.pRadius, this.fuseTime); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Deprecated | ||||||
|  |     public static void explode(Level p_57434_, BlockPos p_57435_, float pRadius, int fuseTime) { | ||||||
|  |         explode(p_57434_, p_57435_, (LivingEntity)null, pRadius, fuseTime); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Deprecated | ||||||
|  |     private static void explode(Level p_57437_, BlockPos p_57438_, @Nullable LivingEntity p_57439_, float pRadius, int fuseTime) { | ||||||
|  |         if (!p_57437_.isClientSide) { | ||||||
|  |             selectivePrimedTNT primedtnt = new selectivePrimedTNT(p_57437_, (double)p_57438_.getX() + (double)0.5F, (double)p_57438_.getY(), (double)p_57438_.getZ() + (double)0.5F, p_57439_, pRadius, fuseTime); | ||||||
|  |             p_57437_.addFreshEntity(primedtnt); | ||||||
|  |             p_57437_.playSound((Player)null, primedtnt.getX(), primedtnt.getY(), primedtnt.getZ(), SoundEvents.TNT_PRIMED, SoundSource.BLOCKS, 1.0F, 1.0F); | ||||||
|  |             p_57437_.gameEvent(p_57439_, GameEvent.PRIME_FUSE, p_57438_); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void wasExploded(Level level, @NotNull BlockPos blockPos, @NotNull Explosion pExplosion) { | ||||||
|  |         if (!level.isClientSide) { | ||||||
|  |             int ft = (short) (level.random.nextInt(fuseTime / 4) + fuseTime / 8); | ||||||
|  |             selectivePrimedTNT primedtnt = new selectivePrimedTNT(level, (double) blockPos.getX() + (double) 0.5F, (double) blockPos.getY(), (double) blockPos.getZ() + (double) 0.5F, pExplosion.getIndirectSourceEntity(), pRadius, ft); | ||||||
|  |             level.addFreshEntity(primedtnt); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -27,6 +27,7 @@ public class creativeTab { | |||||||
|         output.accept(blocks.TNT_HOMING.get()); |         output.accept(blocks.TNT_HOMING.get()); | ||||||
|         output.accept(blocks.TNT_BLACK_HOLE.get()); |         output.accept(blocks.TNT_BLACK_HOLE.get()); | ||||||
|         output.accept(blocks.TNT_CLAYMORE.get()); |         output.accept(blocks.TNT_CLAYMORE.get()); | ||||||
|  |         output.accept(blocks.TNT_SELECTIVE.get()); | ||||||
|         output.accept(items.TNT_ARROW.get()); |         output.accept(items.TNT_ARROW.get()); | ||||||
|         output.accept(items.CONCUSSIVE_ARROW.get()); |         output.accept(items.CONCUSSIVE_ARROW.get()); | ||||||
|         output.accept(items.CARPET_ARROW.get()); |         output.accept(items.CARPET_ARROW.get()); | ||||||
|  | |||||||
| @ -37,6 +37,10 @@ public class entities { | |||||||
|             ENTITY_TYPES.register("tnt_blackhole", () -> EntityType.Builder.<blackHolePrimedTNT>of(blackHolePrimedTNT::new, MobCategory.MISC) |             ENTITY_TYPES.register("tnt_blackhole", () -> EntityType.Builder.<blackHolePrimedTNT>of(blackHolePrimedTNT::new, MobCategory.MISC) | ||||||
|                     .sized(0.98F, 0.7F).fireImmune().clientTrackingRange(8).build("tnt_blackhole")); |                     .sized(0.98F, 0.7F).fireImmune().clientTrackingRange(8).build("tnt_blackhole")); | ||||||
| 
 | 
 | ||||||
|  |     public static final RegistryObject<EntityType<selectivePrimedTNT>> TNT_SELECTIVE = | ||||||
|  |             ENTITY_TYPES.register("tnt_selective", () -> EntityType.Builder.<selectivePrimedTNT>of(selectivePrimedTNT::new, MobCategory.MISC) | ||||||
|  |                     .sized(0.98F, 0.7F).fireImmune().clientTrackingRange(8).build("tnt_selective")); | ||||||
|  | 
 | ||||||
|     public static final RegistryObject<EntityType<claymorePrimedTNT>> TNT_CLAYMORE = |     public static final RegistryObject<EntityType<claymorePrimedTNT>> TNT_CLAYMORE = | ||||||
|             ENTITY_TYPES.register("tnt_claymore", () -> EntityType.Builder.<claymorePrimedTNT>of(claymorePrimedTNT::new, MobCategory.MISC) |             ENTITY_TYPES.register("tnt_claymore", () -> EntityType.Builder.<claymorePrimedTNT>of(claymorePrimedTNT::new, MobCategory.MISC) | ||||||
|                     .sized(0.98F, 0.7F).fireImmune().clientTrackingRange(8).build("tnt_claymore")); |                     .sized(0.98F, 0.7F).fireImmune().clientTrackingRange(8).build("tnt_claymore")); | ||||||
| @ -66,6 +70,7 @@ public class entities { | |||||||
|         EntityRenderers.register(TNT_HOMING.get(), BaseTNTRenderer::new); |         EntityRenderers.register(TNT_HOMING.get(), BaseTNTRenderer::new); | ||||||
|         EntityRenderers.register(TNT_BLACK_HOLE.get(), BaseTNTRenderer::new); |         EntityRenderers.register(TNT_BLACK_HOLE.get(), BaseTNTRenderer::new); | ||||||
|         EntityRenderers.register(TNT_CLAYMORE.get(), BaseTNTRenderer::new); |         EntityRenderers.register(TNT_CLAYMORE.get(), BaseTNTRenderer::new); | ||||||
|  |         EntityRenderers.register(TNT_SELECTIVE.get(), BaseTNTRenderer::new); | ||||||
|         EntityRenderers.register(TNT_CLUSTER.get(), clusterTNTRenderer::new); |         EntityRenderers.register(TNT_CLUSTER.get(), clusterTNTRenderer::new); | ||||||
| 
 | 
 | ||||||
|         EntityRenderers.register(ARROW_TNT.get(), TNTArrowRenderer::new); |         EntityRenderers.register(ARROW_TNT.get(), TNTArrowRenderer::new); | ||||||
|  | |||||||
| @ -0,0 +1,47 @@ | |||||||
|  | package com.jenny.compressedtnt.entities.tnt; | ||||||
|  | 
 | ||||||
|  | import com.jenny.compressedtnt.entities.entities; | ||||||
|  | import net.minecraft.core.BlockPos; | ||||||
|  | import net.minecraft.world.entity.EntityType; | ||||||
|  | import net.minecraft.world.entity.LivingEntity; | ||||||
|  | import net.minecraft.world.level.BlockGetter; | ||||||
|  | import net.minecraft.world.level.Explosion; | ||||||
|  | import net.minecraft.world.level.ExplosionDamageCalculator; | ||||||
|  | import net.minecraft.world.level.Level; | ||||||
|  | import net.minecraft.world.level.block.state.BlockState; | ||||||
|  | import net.minecraft.world.phys.Vec3; | ||||||
|  | import org.jetbrains.annotations.NotNull; | ||||||
|  | 
 | ||||||
|  | import javax.annotation.Nullable; | ||||||
|  | 
 | ||||||
|  | public class selectivePrimedTNT extends basePrimedTNT { | ||||||
|  |     static class SelectiveExplosionCalculator extends ExplosionDamageCalculator { | ||||||
|  |         private final String block; | ||||||
|  | 
 | ||||||
|  |         public SelectiveExplosionCalculator(String block) { | ||||||
|  |             this.block = block; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public boolean shouldBlockExplode(@NotNull Explosion pExplosion, @NotNull BlockGetter pReader, @NotNull BlockPos pPos, BlockState pState, float pPower) { | ||||||
|  |             return pState.getBlock().toString().equals(block); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public selectivePrimedTNT(Level pLevel, double pX, double pY, double pZ, @Nullable LivingEntity pOwner, float power, int fuse) { | ||||||
|  |         super(entities.TNT_SELECTIVE.get(), pLevel, pOwner, new Vec3(pX, pY, pZ), fuse, power, "tnt_selective"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public selectivePrimedTNT(EntityType<selectivePrimedTNT> entityType, Level level) { | ||||||
|  |         super(entityType, level, null); | ||||||
|  |         this.setRenderID("tnt_selective"); | ||||||
|  |     } | ||||||
|  |     @Override | ||||||
|  |     protected void explode() { | ||||||
|  |         SelectiveExplosionCalculator dmgCalc = new SelectiveExplosionCalculator(getBlock()); | ||||||
|  |         this.level().explode(this, null, dmgCalc, position(), getPower(), false, Level.ExplosionInteraction.TNT); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getBlock() { | ||||||
|  |         return level().getBlockState(new BlockPos((int) Math.round(getX()), (int) Math.round(getY() - 1), (int) Math.round(getZ()))).getBlock().toString(); | ||||||
|  |     } | ||||||
|  |  } | ||||||
| @ -5,6 +5,7 @@ | |||||||
| # Find more information on toml format here:  https://github.com/toml-lang/toml | # Find more information on toml format here:  https://github.com/toml-lang/toml | ||||||
| # The name of the mod loader type to load - for regular FML @Mod mods it should be javafml | # The name of the mod loader type to load - for regular FML @Mod mods it should be javafml | ||||||
| modLoader = "javafml" #mandatory | modLoader = "javafml" #mandatory | ||||||
|  | logoFile = "logo.png" | ||||||
| # A version range to match for said mod loader - for regular FML @Mod it will be the forge version | # A version range to match for said mod loader - for regular FML @Mod it will be the forge version | ||||||
| loaderVersion = "${loader_version_range}" #mandatory This is typically bumped every Minecraft version by Forge. See our download page for lists of versions. | loaderVersion = "${loader_version_range}" #mandatory This is typically bumped every Minecraft version by Forge. See our download page for lists of versions. | ||||||
| # The license for you mod. This is mandatory metadata and allows for easier comprehension of your redistributive properties. | # The license for you mod. This is mandatory metadata and allows for easier comprehension of your redistributive properties. | ||||||
|  | |||||||
| @ -10,6 +10,7 @@ | |||||||
|   "block.compressedtnt.tnt_homing": "Homing TNT", |   "block.compressedtnt.tnt_homing": "Homing TNT", | ||||||
|   "block.compressedtnt.tnt_black_hole": "Black Hole TNT", |   "block.compressedtnt.tnt_black_hole": "Black Hole TNT", | ||||||
|   "block.compressedtnt.tnt_claymore": "Claymore TNT", |   "block.compressedtnt.tnt_claymore": "Claymore TNT", | ||||||
|  |   "block.compressedtnt.tnt_selective": "Selective TNT", | ||||||
| 
 | 
 | ||||||
|   "item.compressedtnt.arrow_tnt": "TNT Arrow", |   "item.compressedtnt.arrow_tnt": "TNT Arrow", | ||||||
|   "item.compressedtnt.arrow_concussive": "Concussive Arrow", |   "item.compressedtnt.arrow_concussive": "Concussive Arrow", | ||||||
| @ -22,6 +23,7 @@ | |||||||
|   "tooltip.compressedtnt.tnt_homing": "follows the closest entity", |   "tooltip.compressedtnt.tnt_homing": "follows the closest entity", | ||||||
|   "tooltip.compressedtnt.tnt_black_hole": "pulls all entities towards itself", |   "tooltip.compressedtnt.tnt_black_hole": "pulls all entities towards itself", | ||||||
|   "tooltip.compressedtnt.tnt_claymore": "throws arrows into all direcctions upon explosion", |   "tooltip.compressedtnt.tnt_claymore": "throws arrows into all direcctions upon explosion", | ||||||
|  |   "tooltip.compressedtnt.tnt_selective": "only destroys the type of block it explodes on", | ||||||
| 
 | 
 | ||||||
|   "tooltip.compressedtnt.arrow_tnt": "explodes on impact", |   "tooltip.compressedtnt.arrow_tnt": "explodes on impact", | ||||||
|   "tooltip.compressedtnt.arrow_concussive": "explodes on impact without block damage", |   "tooltip.compressedtnt.arrow_concussive": "explodes on impact without block damage", | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								src/main/resources/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/main/resources/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 29 KiB | 
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user