Jump to content

Brand new 1.4.7 with the download for forge 6.6.0.497 + no mods = blackscreen


kamyk2000

Recommended Posts

I backed up (moved elsewhere) my .minecraft (1.4.5 ) folder, so am installing minecraft 1.4.7.exe fresh with no .minecraft folder under %application data%.  It installs and runs without a hitch.  I open minecraft.jar in /bin and delete meta-inf then add the contents of forge 6.6.0.497.  I get the forge downloading stuff screen, the mojang screen then black screen hang.  I have tried a fresh minecraft install using magiclauncher instead, same result.  There are 0 mods other than forge involved.

 

I noted an oddity.  In the forge download file I got from here there is a file called _aux.class not aux.class, _aux.class.  Is that inccorrect as I see an aux.class file in my minecraft.jar but no _aux.class.  Also the log says that my forge is Forge Mod Loader version 4.7.4.520 for Minecraft 1.4.7.  I can assure you I downloaded the link for forge 6.6.0.497.  The log also says no mcmod.info and a previous log said something about a missing .class file that was one of the ones starting with H (can't recall which one) but it was present in the forge download zip.

 

Here is my last log file.

 

 

2013-02-05 05:34:38 [iNFO] [ForgeModLoader] Forge Mod Loader version 4.7.4.520 for Minecraft 1.4.7 loading

2013-02-05 05:34:38 [FINEST] [ForgeModLoader] All core mods are successfully located

2013-02-05 05:34:38 [FINEST] [ForgeModLoader] Discovering coremods

2013-02-05 05:34:38 [FINEST] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/argo-2.25.jar

2013-02-05 05:34:38 [iNFO] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/argo-2.25.jar

2013-02-05 05:34:39 [FINEST] [ForgeModLoader] Download complete

2013-02-05 05:34:39 [iNFO] [ForgeModLoader] Download complete

2013-02-05 05:34:39 [FINEST] [ForgeModLoader] Library file argo-2.25.jar was downloaded and verified successfully

2013-02-05 05:34:39 [FINEST] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/guava-12.0.1.jar

2013-02-05 05:34:39 [iNFO] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/guava-12.0.1.jar

2013-02-05 05:34:45 [FINEST] [ForgeModLoader] Download complete

2013-02-05 05:34:45 [iNFO] [ForgeModLoader] Download complete

2013-02-05 05:34:45 [FINEST] [ForgeModLoader] Library file guava-12.0.1.jar was downloaded and verified successfully

2013-02-05 05:34:45 [FINEST] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/asm-all-4.0.jar

2013-02-05 05:34:45 [iNFO] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/asm-all-4.0.jar

2013-02-05 05:34:46 [FINEST] [ForgeModLoader] Download complete

2013-02-05 05:34:46 [iNFO] [ForgeModLoader] Download complete

2013-02-05 05:34:46 [FINEST] [ForgeModLoader] Library file asm-all-4.0.jar was downloaded and verified successfully

2013-02-05 05:34:46 [FINEST] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/bcprov-jdk15on-147.jar

2013-02-05 05:34:46 [iNFO] [ForgeModLoader] Downloading file http://files.minecraftforge.net/fmllibs/bcprov-jdk15on-147.jar

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Download complete

2013-02-05 05:34:52 [iNFO] [ForgeModLoader] Download complete

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Library file bcprov-jdk15on-147.jar was downloaded and verified successfully

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Running coremod plugins

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Running coremod plugin FMLCorePlugin

2013-02-05 05:34:52 [iNFO] [ForgeModLoader] Found valid fingerprint for Minecraft Forge. Certificate fingerprint de4cf8a3f3bc15635810044c39240bf96804ea7d

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Coremod plugin FMLCorePlugin run successfully

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Running coremod plugin FMLForgePlugin

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Coremod plugin FMLForgePlugin run successfully

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Validating minecraft

2013-02-05 05:34:52 [FINEST] [ForgeModLoader] Minecraft validated, launching...

2013-02-05 05:34:54 [iNFO] [sTDOUT] 27 achievements

2013-02-05 05:34:54 [iNFO] [sTDOUT] 210 recipes

2013-02-05 05:34:54 [iNFO] [sTDOUT] Setting user: kamyk@yahoo.com, -822202420

2013-02-05 05:34:54 [iNFO] [sTDERR] Client asked for parameter: server

2013-02-05 05:34:54 [iNFO] [sTDOUT] LWJGL Version: 2.4.2

2013-02-05 05:34:54 [iNFO] [ForgeModLoader] Attempting early MinecraftForge initialization

2013-02-05 05:34:54 [iNFO] [sTDOUT] MinecraftForge v6.6.0.497 Initialized

2013-02-05 05:34:54 [iNFO] [ForgeModLoader] MinecraftForge v6.6.0.497 Initialized

2013-02-05 05:34:55 [iNFO] [sTDOUT] Replaced 84 ore recipies

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Completed early MinecraftForge initialization

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] No mod directory found, creating one: C:\Documents and Settings\Kamyk\Application Data\.minecraft\mods

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Mod directory created successfully

2013-02-05 05:34:55 [FINE] [ForgeModLoader] No config directory found, creating one: C:\Documents and Settings\Kamyk\Application Data\.minecraft\config

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Config directory created successfully

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Building injected Mod Containers [cpw.mods.fml.common.FMLDummyContainer, net.minecraftforge.common.ForgeDummyContainer]

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Attempting to load mods contained in the minecraft jar file and associated classes

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Found a minecraft related file at C:\Documents and Settings\Kamyk\Desktop\Minecraft\New Minecraft Mods\minecraftforge-universal-1.4.7-6.6.0.497.zip, examining for mod candidates

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Found a minecraft related file at C:\Documents and Settings\Kamyk\Application Data\.minecraft\bin\minecraft.jar, examining for mod candidates

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\bin\jinput.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\bin\lwjgl.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\bin\lwjgl_util.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\lib\argo-2.25.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\lib\guava-12.0.1.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\lib\asm-all-4.0.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Skipping known library file C:\Documents and Settings\Kamyk\Application Data\.minecraft\lib\bcprov-jdk15on-147.jar

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Minecraft jar mods loaded successfully

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Searching C:\Documents and Settings\Kamyk\Application Data\.minecraft\mods for mods

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Examining file minecraftforge-universal-1.4.7-6.6.0.497.zip for potential mods

2013-02-05 05:34:55 [FINE] [ForgeModLoader] The mod container minecraftforge-universal-1.4.7-6.6.0.497.zip appears to be missing an mcmod.info file

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Examining file minecraft.jar for potential mods

2013-02-05 05:34:55 [FINE] [ForgeModLoader] The mod container minecraft.jar appears to be missing an mcmod.info file

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Forge Mod Loader has identified 3 mods to load

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Received a system property request ''

2013-02-05 05:34:55 [FINE] [ForgeModLoader] System property request managing the state of 0 mods

2013-02-05 05:34:55 [FINE] [ForgeModLoader] After merging, found state information for 0 mods

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Activating mod mcp

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Activating mod FML

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Activating mod Forge

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Verifying mod requirements are satisfied

2013-02-05 05:34:55 [FINE] [ForgeModLoader] All mod requirements are satisfied

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Sorting mods into an ordered list

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Mod sorting completed successfully

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Mod sorting data:

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLConstructionEvent to mod mcp

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLConstructionEvent to mod mcp

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLConstructionEvent to mod FML

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLConstructionEvent to mod FML

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLConstructionEvent to mod Forge

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLConstructionEvent to mod Forge

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Mod signature data:

2013-02-05 05:34:55 [FINE] [ForgeModLoader] mcp(Minecraft Coder Pack:7.26): minecraft.jar (NO VALID CERTIFICATE FOUND)

2013-02-05 05:34:55 [FINE] [ForgeModLoader] FML(Forge Mod Loader:4.7.4.520): coremods (de4cf8a3f3bc15635810044c39240bf96804ea7d)

2013-02-05 05:34:55 [FINE] [ForgeModLoader] Forge(Minecraft Forge:6.6.0.497): coremods (NO VALID CERTIFICATE FOUND)

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLPreInitializationEvent to mod mcp

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLPreInitializationEvent to mod mcp

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLPreInitializationEvent to mod FML

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLPreInitializationEvent to mod FML

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sending event FMLPreInitializationEvent to mod Forge

2013-02-05 05:34:55 [iNFO] [ForgeModLoader] Configured a dormant chunk cache size of 0

2013-02-05 05:34:55 [FINER] [ForgeModLoader] Sent event FMLPreInitializationEvent to mod Forge

2013-02-05 05:34:55 [iNFO] [sTDERR] Exception in thread "Minecraft main thread" java.lang.NoSuchMethodError: jg.a(Lji;)Ljg;

2013-02-05 05:34:55 [iNFO] [sTDERR] at net.minecraft.client.Minecraft.a(Minecraft.java:425)

2013-02-05 05:34:55 [iNFO] [sTDERR] at asq.a(SourceFile:56)

2013-02-05 05:34:55 [iNFO] [sTDERR] at net.minecraft.client.Minecraft.run(Minecraft.java:744)

2013-02-05 05:34:55 [iNFO] [sTDERR] at java.lang.Thread.run(Unknown Source)

2013-02-05 05:37:34 [iNFO] [sTDERR] Someone is closing me!

 

 

Link to comment
Share on other sites

Aside from that, the error is saying that you've not installed all of Forge's files properly or something during installation has corrupted the jg class.

I'd suggest trying a different archive tool, such as 7zip or a launcher like MagicLuancher/MultiMC.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

Link to comment
Share on other sites

That is exactly what I use is 7zip and magiclauncher.  My error log was immediately after trying with magiclauncher. 

 

It is irrelevant for me now though as I got version 6.6.0.5.1.8 working.  :)

 

Edit: I would like to point out however that in the releases section both the latest forge version thread and the minecraft 1.4.7 thread directly below it point to 6.6.0.497 as the latest recommended version.  So finding a later version wasn't obvious.

Link to comment
Share on other sites

thats because it is the recomended version we havent bumped it because there are dev features in the newer versions.

Thats why was have 'Lastest' and 'Recomended', two different things.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • My modded minecraft world don't go past 100% on the loading screen. My backup still work, but i've made a lot of progress from the point i was that save. i have already checked online and did some suggestions i found, but nothing worked. Here is my latest log + i don´t have crash reports: https://github.com/GmsantosPT/Minecraft-mod-problems/tree/main   Pls Help, Santos
    • Please share a link to your crash report, as explained in the FAQ
    • I have a block already registered in my mod, which I have used in some worlds. The problem arises when in code, I add a property called CURRENT_AGE, when running Minecraft it freezes. In the console it doesn't appear any excpetion except that it stays in this phase: [Render thread/DEBUG] [ne.mi.co.ca.CapabilityManager/CAPABILITIES]: Attempting to automatically register: Lnet/minecraftforge/items/IItemHandler; Does anyone have an idea what it could be? I show the block and its registration public class SoulLichenBlock extends MultifaceBlock implements SimpleWaterloggedBlock, EntityBlock { public static final BooleanProperty WATERLOGGED = BlockStateProperties.WATERLOGGED; public static final IntegerProperty SKILL_LEVEL = IntegerProperty.create("soullichen_level", 0, 30); public static final DirectionProperty FACE = DirectionProperty.create("soullichen_face"); public static final DirectionProperty DIRECTION = DirectionProperty.create("soullichen_direction"); public static final IntegerProperty CURRENT_AGE = BlockStateProperties.AGE_25; private final MultifaceSpreader spreader = new MultifaceSpreader(this); private final MultifaceSpreader.DefaultSpreaderConfig config = new MultifaceSpreader.DefaultSpreaderConfig(this); private LivingEntity owner; //private static final Integer MAX_AGE = 25; public SoulLichenBlock(Properties properties) { super(properties); this.registerDefaultState(this .defaultBlockState() .setValue(WATERLOGGED, Boolean.FALSE) .setValue(SKILL_LEVEL, 0) .setValue(FACE, Direction.DOWN) .setValue(DIRECTION, Direction.DOWN) .trySetValue(CURRENT_AGE, 0) ); } public static ToIntFunction<BlockState> emission(int p_181223_) { return (p_181221_) -> MultifaceBlock.hasAnyFace(p_181221_) ? p_181223_ : 0; } public static boolean hasFace(BlockState p_153901_, @NotNull Direction p_153902_) { BooleanProperty booleanproperty = getFaceProperty(p_153902_); return p_153901_.hasProperty(booleanproperty) && p_153901_.getValue(booleanproperty); } protected void createBlockStateDefinition(StateDefinition.@NotNull Builder<Block, BlockState> stateDefinition) { stateDefinition.add(WATERLOGGED).add(SKILL_LEVEL).add(FACE).add(DIRECTION).add(CURRENT_AGE); super.createBlockStateDefinition(stateDefinition); } public @NotNull BlockState updateShape(BlockState p_153302_, @NotNull Direction p_153303_, @NotNull BlockState p_153304_, @NotNull LevelAccessor p_153305_, @NotNull BlockPos p_153306_, @NotNull BlockPos p_153307_) { if (p_153302_.getValue(WATERLOGGED)) { p_153305_.scheduleTick(p_153306_, Fluids.WATER, Fluids.WATER.getTickDelay(p_153305_)); } return super.updateShape(p_153302_, p_153303_, p_153304_, p_153305_, p_153306_, p_153307_); } @SuppressWarnings("deprecation") public @NotNull FluidState getFluidState(BlockState fluidState) { return fluidState.getValue(WATERLOGGED) ? Fluids.WATER.getSource(false) : super.getFluidState(fluidState); } public boolean propagatesSkylightDown(BlockState p_181225_, @NotNull BlockGetter blockGetter, @NotNull BlockPos blockPos) { return p_181225_.getFluidState().isEmpty(); } public @NotNull MultifaceSpreader getSpreader() { return this.spreader; } public Optional<MultifaceSpreader.SpreadPos> spreadFromRandomFaceTowardRandomDirection( BlockState p_221620_, LevelAccessor p_221621_, BlockPos p_221622_, RandomSource p_221623_, int skillPoints, int age) { return Direction.allShuffled(p_221623_).stream().filter((p_221680_) -> { return this.config.canSpreadFrom(p_221620_, p_221680_); }).map((p_221629_) -> { return this.spreadFromFaceTowardRandomDirection(p_221620_, p_221621_, p_221622_, p_221629_, p_221623_, false, skillPoints, age); }).filter(Optional::isPresent).findFirst().orElse(Optional.empty()); } public Optional<MultifaceSpreader.SpreadPos> spreadFromFaceTowardRandomDirection( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, RandomSource randomSource, boolean aBoolean, int skillPoints, int age) { return Direction.allShuffled(randomSource).stream().map((direction) -> spreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, direction, aBoolean, skillPoints, age)) .filter(Optional::isPresent) .findFirst() .orElse(Optional.empty()); } public Optional<MultifaceSpreader.SpreadPos> spreadFromFaceTowardDirection( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, Direction direction, boolean aBoolean, int skillPoints, int age) { //DevilRpg.LOGGER.debug("BEGIN ==================================== spreadFromFaceTowardDirection skillPoints {}", skillPoints); return skillPoints < 0 ? Optional.empty() : getSpreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, direction, this::canSpreadInto) .flatMap((spreadPos) -> { //DevilRpg.LOGGER.debug("END ================================ spreadFromFaceTowardDirection spreadPos {}", spreadPos); return this.spreadToFace(levelAccessor, spreadPos, aBoolean, skillPoints, direction, age); }); } public boolean canSpreadInto(BlockGetter p_221685_, BlockPos p_221686_, MultifaceSpreader.SpreadPos p_221687_) { BlockState blockstate = p_221685_.getBlockState(p_221687_.pos()); return this.stateCanBeReplaced(p_221685_, p_221686_, p_221687_.pos(), p_221687_.face(), blockstate) && isValidStateForPlacement(p_221685_, blockstate, p_221687_.pos(), p_221687_.face()); } protected boolean stateCanBeReplaced(BlockGetter p_221688_, BlockPos p_221689_, BlockPos p_221690_, Direction p_221691_, BlockState p_221692_) { return p_221692_.isAir() || p_221692_.is(this) || p_221692_.is(Blocks.WATER) && p_221692_.getFluidState().isSource(); } public Optional<MultifaceSpreader.SpreadPos> getSpreadFromFaceTowardDirection(BlockState blockState, BlockGetter blockGetter, BlockPos blockPos, Direction face, Direction direction, MultifaceSpreader.SpreadPredicate spreadPredicate) { //DevilRpg.LOGGER.debug("--- getSpreadFromFaceTowardDirection direction.getAxis() == face.getAxis(): {}", direction.getAxis() == face.getAxis()); ArrayList<Direction> directions = new ArrayList<>(); directions.add(direction); if (direction.getAxis() == face.getAxis()) { if (direction.getAxis().isHorizontal()) { directions = Arrays.stream(Direction.values()).filter(dir -> dir.getAxis().isVertical()).collect(Collectors.toCollection(ArrayList::new)); } if (direction.getAxis().isVertical()) { directions = Arrays.stream(Direction.values()).filter(dir -> dir.getAxis().isHorizontal()).collect(Collectors.toCollection(ArrayList::new)); } } for (Direction directionElement : directions) { /*DevilRpg.LOGGER.debug("--->> getSpreadFromFaceTowardDirection config.isOtherBlockValidAsSource(blockState) {} || " + "hasFace(blockState, face) {} && " + "!hasFace(blockState, direction) {}", config.isOtherBlockValidAsSource(blockState), hasFace(blockState, face), !hasFace(blockState, directionElement));*/ if (config.isOtherBlockValidAsSource(blockState) || hasFace(blockState, face) && !hasFace(blockState, directionElement)) { for (MultifaceSpreader.SpreadType multifacespreader$spreadtype : config.getSpreadTypes()) { MultifaceSpreader.SpreadPos multifacespreader$spreadpos = multifacespreader$spreadtype.getSpreadPos(blockPos, directionElement, face); //DevilRpg.LOGGER.debug("--- test SpreadPos: {} direction {} face {} ", multifacespreader$spreadpos, directionElement, face); if (spreadPredicate.test(blockGetter, blockPos, multifacespreader$spreadpos)) { //DevilRpg.LOGGER.debug("--- spreadPredicate success:"); return Optional.of(multifacespreader$spreadpos); } } } } return Optional.empty(); } public boolean isValidStateForPlacement(@NotNull BlockGetter blockGetter, @NotNull BlockState blockState, @NotNull BlockPos blockPos, @NotNull Direction face) { //DevilRpg.LOGGER.debug("------ isValidStateForPlacement 1st condition: {} && ({} || {})", this.isFaceSupported(face), !blockState.is(this), !hasFace(blockState, face)); if (this.isFaceSupported(face) && (!blockState.is(this) || !hasFace(blockState, face))) { BlockPos blockpos = blockPos.relative(face); //DevilRpg.LOGGER.debug("------ isValidStateForPlacement 2nd condition: canAttachTo {} ", secondCondition); return canAttachTo(blockGetter, face, blockpos, blockGetter.getBlockState(blockpos)); } else { return false; } } @Nullable public BlockState getStateForPlacement(@NotNull BlockState blockState, @NotNull BlockGetter blockGetter, @NotNull BlockPos blockPos, @NotNull Direction face, int skillPoints, Direction direction, int age) { //DevilRpg.LOGGER.debug("--- getStateForPlacement"); boolean isNotValidStateForPlacement = !this.isValidStateForPlacement(blockGetter, blockState, blockPos, face); //DevilRpg.LOGGER.debug("------- isNotValidStateForPlacement: {}", isNotValidStateForPlacement); if (isNotValidStateForPlacement) { return null; } else { BlockState blockstate; if (blockState.is(this)) { blockstate = blockState; } else if (this.isWaterloggable() && blockState.getFluidState().isSourceOfType(Fluids.WATER)) { blockstate = this.defaultBlockState().setValue(BlockStateProperties.WATERLOGGED, Boolean.TRUE); } else { blockstate = this.defaultBlockState(); } //DevilRpg.LOGGER.debug("------- getStateForPlacement -> blockStateResult "); return blockstate .setValue(getFaceProperty(face), Boolean.TRUE) .setValue(SKILL_LEVEL, skillPoints).setValue(FACE, face) .setValue(DIRECTION, direction) .setValue(CURRENT_AGE,age) ; } } public Optional<MultifaceSpreader.SpreadPos> spreadToFace(LevelAccessor levelAccessor, MultifaceSpreader.SpreadPos spreadPos, boolean p_221596_, int skillPoints, Direction direction, int age) { BlockState blockstate = levelAccessor.getBlockState(spreadPos.pos()); //DevilRpg.LOGGER.debug("---> spreadToFace blockstate{} direction: {}", blockstate, direction); return this.placeBlock(levelAccessor, spreadPos, blockstate, p_221596_, skillPoints, direction, age) ? Optional.of(spreadPos) : Optional.empty(); } public boolean placeBlock(LevelAccessor p_221702_, MultifaceSpreader.SpreadPos p_221703_, BlockState p_221704_, boolean p_221705_, int skillPoints, Direction direction, int age) { //DevilRpg.LOGGER.debug("---> placeBlock {} direction {} ", p_221703_, direction); BlockState blockstate = this.getStateForPlacement(p_221704_, p_221702_, p_221703_.pos(), p_221703_.face(), skillPoints, direction, age); if (blockstate != null) { if (p_221705_) { p_221702_.getChunk(p_221703_.pos()).markPosForPostprocessing(p_221703_.pos()); } //DevilRpg.LOGGER.debug("------> setBlock"); return p_221702_.setBlock(p_221703_.pos(), blockstate, 2); } else { return false; } } public long spreadFromFaceTowardAllDirections( BlockState blockState, LevelAccessor levelAccessor, BlockPos blockPos, Direction face, boolean aBoolean, int skillPoints, int age) { return Direction.stream().map((p_221656_) -> spreadFromFaceTowardDirection(blockState, levelAccessor, blockPos, face, p_221656_, aBoolean, skillPoints, age)) .filter(Optional::isPresent).count(); } private boolean isWaterloggable() { return this.stateDefinition.getProperties().contains(BlockStateProperties.WATERLOGGED); } @Override public void setPlacedBy(@NotNull Level level, @NotNull BlockPos blockPos, @NotNull BlockState blockState, @Nullable LivingEntity livingEntity, @NotNull ItemStack itemStack) { super.setPlacedBy(level, blockPos, blockState, livingEntity, itemStack); this.setOwner(livingEntity); } public LivingEntity getOwner() { return this.owner; } private void setOwner(LivingEntity livingEntity) { this.owner = livingEntity; } @Deprecated @Override public void entityInside(@NotNull BlockState blockState, @NotNull Level level, @NotNull BlockPos blockPos, @NotNull Entity entity) { if (entity instanceof LivingEntity /*&& entity.getType() != EntityType.BEE*/ && entity.getType() != ModEntities.LICHEN_SEEDBALL.get()) { entity.makeStuckInBlock(blockState, new Vec3(0.8D, 0.75D, 0.8D)); if (!level.isClientSide /*&& (entity.xOld != entity.getX() || entity.zOld != entity.getZ())*/) { // double d0 = Math.abs(entity.getX() - entity.xOld); // double d1 = Math.abs(entity.getZ() - entity.zOld); // if (d0 >= (double) 0.003F || d1 >= (double) 0.003F) { entity.hurt(level.damageSources().playerAttack((Player) owner), 1.0F); // Aplicar aceleración al movimiento double speedBoost = -0.4; // Ajusta este valor según lo rápido que quieras que sea el impulso double motionX = entity.getX() - entity.xOld; double motionZ = entity.getZ() - entity.zOld; double speed = Math.sqrt(motionX * motionX + motionZ * motionZ); //if (speed > 0.0) { entity.setDeltaMovement(entity.getDeltaMovement().multiply( (motionX / speed) * speedBoost, 0.0, (motionZ / speed) * speedBoost )); // } //} } } } @Nullable @Override public BlockEntity newBlockEntity(@NotNull BlockPos pos, @NotNull BlockState state) { return ModEntityBlocks.SOUL_LICHEN_ENTITY_BLOCK.get().create(pos, state); } @Nullable @Override public <T extends BlockEntity> BlockEntityTicker<T> getTicker(Level level, @NotNull BlockState blockState, @NotNull BlockEntityType<T> type) { return level.isClientSide ? null : (alevel, pos, aBlockstate, blockEntity) -> { if (blockEntity instanceof SoulLichenBlockEntity soulLichenBlockEntity && alevel.getGameTime() % 5 == 0) { soulLichenBlockEntity.tick(blockState, (ServerLevel) alevel, pos, alevel.getRandom()); //DevilRpg.LOGGER.info("-------->tick. this: {}", this.getClass().getSimpleName()); } }; } }   This is the registration:   public final class ModBlocks { public static final DeferredRegister<Block> BLOCKS = DeferredRegister.create(ForgeRegistries.BLOCKS, DevilRpg.MODID); ... public static final RegistryObject<SoulLichenBlock> SOUL_LICHEN_BLOCK = BLOCKS.register("soullichen", () -> new SoulLichenBlock( Block.Properties.copy(Blocks.GLOW_LICHEN).lightLevel(SoulLichenBlock.emission(7)).randomTicks() )); }  
    • If you are using AMD/ATI, check for driver updates on their website - do not update via system
    • Hi, Create a new class that extends "Block" class and you need json for it in resources/assets/modid/blockstates directory and resources/assets/modid/models. You can generate json for it using a tool like misodes model generator. Here, atleast, are blocks explained at forge docs.  Don't forge to look at vanilla code, like Magma Block is a good reference if you're trying a "green fire block".  Modid should be replaced with your actual forge mod namespace!
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.