User:User-12316399

This page serves as a list of major features I want to see in Java Edition in the future. See /Technical changes for a list of minor to moderate technical changes.

Technical split
While assumed to be underway, there hasn't been anything back regarding this since 2018, when Dinnerbone tweeted a screenshot regarding a technical split removing minecraft:water as a block from the game. One can only assume that progress is being made.

Further waterlogging
There still remain many blocks in Java Edition that cannot be waterlogged under any circumstances. Support for waterlogging should be extended to all non-full blocks, alongside select full blocks such as leaves and monster spawners which can be assumed to not actually block water, and excluding honey blocks, fire and snow layers.

The ability to place more blocks underwater could allow for more building possibilities than ever before - for example, placing normal land-based vegetation underwater could allow for the creation of scenes reminiscent of Grüner See in Austria. Also, this would also patch out several exploits used for underwater breathing, notably the door trick.

For cases like torches, this behaviour could be reasonably considered odd, as fire kind of doesn't exist underwater. This could serve as a perfect opportunity to implement burned-out torches - instead of them burning out over time, they would act more like campfires in that being waterlogged (as well as right-clicked, in analogy of using a shovel to smother lit campfires) would put the torch out, allowing them to be placed underwater like any other block while not actually functioning as a torch.

The waterlogged block state would be completely removed, except for a few blocks: beds where it would be used to determine whether Water Breathing/Conduit Power would be neccessary for sleeping, sea pickles to handle their activity and light emission if not replaced with another state, and sculk sensors to control whether they are silent.

Lavalogging


Why this wasn't implemented with the Nether Update is a mystery.

Lavalogging is the obvious lava analogue for waterlogging - lava would gain the ability to occupy the same space as a non-full block and overall behave just as one would suspect. Lava would probably be more destructive to many blocks than water, and certain cases such as waterlogged wooden fences would end up burning as if in air and next to lava, leaving a lava block behind as neccessary. Lava would probably also instantly destroy most vegetation such as flowers and grass, whereas water would be completely compatible with all of them. Lava would also instantly kill submerged corals, turning them into their dead versions.

While people perhaps don't build around lava to the same extent that they do water, this feature would fill in a major gap in gameplay mechanics and soften the look of lava-themed builds nonetheless, and potentially allow for brand new gameplay mechanics and possibilities on the side.

Flowing waterlogging


Perhaps a more controversial feature, but it'd be a welcome addition either way.

This mechanic was originally shown off during MINECON Earth 2017, but has yet to see a proper debut in-game. The concept is relatively simple: if a block reasonably has enough gaps for water to pass through, then water will pass through it. This would, among other things, make working around redstone for safer than it otherwise would be. However, this comes with a possibility to break several farms which utilise water to break blocks such as crops. In the interests of maintaining consistency, crops would allow water to flow through them without breaking, like any other block, unless the farmland block beneath them is treated with a special item as mentioned below. Crops grown on such a block would then have a special block state set causing water to force them to pop off as before.

Flowing lavalogging


An obvious lava analogue to flowing waterlogging. The mechanics would be as expected, with lava destroying all incompatible blocks it flows into and simply going through ones it is compatible with.

Bubble column-logging
Bubble columns would also allow for blocks to be placed inside of them and still allow bubbles to pass through where it would make sense for them to.

Preventing unwanted waterlogging
It may become undesirable for water to flow through certain blocks, with them being broken by the water or blocking it being the behaviour expected.

To mitigate this, it should be possible to "treat" blocks with a hydrophobic coating in order to stop water from flowing through them. This item could be honeycombs, or a material crafted from honeycombs and phantom membranes, giving a large amount of them as a result. When applied to a block that could be waterlogged, a new immobile fluid called "minecraft:waterproof" would be set on that block which would prevent water and lava from being able to pass through the block. Farmland treated with this item will also set the fluid for any crops grown on top of it, making them be destroyed by flowing water (flowing lava would destroy them regardless).

In order to remove this coating, an axe can be used to scrape it off, or the block can be broken. Both will drop the coating as an item, and the "waterproof" fluid would be removed from the block.

Credits
The demonstration screenshots above were taken with the Towelette mod. This mod allows for the waterlogging of several more blocks, as well as lavalogging, and, if enabled via config, flowing waterlogging and flowing lavalogging. The mod uses a system of block states to accomplish this, however, as opposed to an actual complete splitting of fluids from blocks, and an intense amount of RAM is required for starting up the game with flowing fluidlogging enabled.


 * Download Towelette (Fabric): https://www.curseforge.com/minecraft/mc-mods/towelette

Overview
As of 1.16.5, Java Edition's chunk format strictly defines positions as having only one block able to be assigned to it. While this makes sense for many situations, this implementation is rather limiting in the long run - blocks which from a visual and functional standpoint should clearly be able to occupy the exact same space are by definition forbidden from coexistence as a result. For cases where "multiple blocks" are allowed to exist in the same space, these are usually very specialised cases and seldom involve distinct blocks.

While also a highly nontrivial rewrite, redoing the world format such that one space can be occupied by multiple distinct blocks would allow for more than a handful of new possibilities, make other elements of the game functionally much cleaner, and bring parity between the Java and Bedrock editions of the game.

Deprecation of certain block states
As was previously stated, certain cases of multiple blocks existing in one block space do exist, but these have mildly hacky implementations through the use (and debatable abuse) of block states.

For example, vines can be placed on the four orthogonal sides of a block, as well as their undersides. As vines can also combine in the same block space, this allows for up to five of them to exist in said block space - one for each orthogonal direction as well as one for the very top. While visually and to an extent functionally this implementation does work, further examination reveals significant functional flaws:


 * Despite each vine being implied to be a distinct unit, it is completely impossible to directly break individual vines within a block space. Directly breaking such an instance will break every single present vine, requiring all others to be replaced in said region if the breaking of only one was desired. Individual vines can only be broken via indirect means, namely removing one of their supporting blocks, and even this demonstrates a flaw in that, for cases where one or more vines would still remain, said breaking action produces no particles nor breaking sound as is typical of almost all other block breaking actions.
 * A further flaw of this can be found in its loot implementation; breaking vines will always drop a single vine item, regardless of how many vines were in that space when it was broken.
 * A final issue manifests as a bug which affects other non-multipart blocks, but could nonetheless be avoided were vines to be considered individual units - particles are always generated at the outer bounds of the block's cubical bounding box, disregarding any concavities, which can be seen on several vine combinations when in the process of being broken.

Were the vines' current block state implementation of having a boolean for each of the five applicable faces it can be attached to to be deprecated, with it instead having a single facing direction state with each of the five directions being a permitted value instead, these vine issues would more than likely be completely eliminated as a result, as they all stem from multiple vines per space being considered a single unit.

In a less extreme but far more widespread example, slabs utilise a three-state value determining whether they occupy the bottom half of the block, top half of the block or are composed of two slabs. Were double slabs to be considered two individual slab blocks of differing half instead, not only could the aforementioned three-state value be changed to two-state, but they could be acted upon differently: pistons could gain the ability to combine two slabs or pull them together, and the player would gain the ability to mine constituent slabs separately, resulting in both functional parity with the case of two vertically connected slabs spanning two different block spaces and the removal of the loot table entry required for double slabs to drop two slabs. Importantly, the slabs would no longer necessarily have to be of the same type (see dedicated section below).

Item frame parity
A well-known functional difference between Java Edition and Bedrock Edition is the fact that item frames, while an entity in Java Edition, are instead blocks in Bedrock Edition. The block implementation of the latter brings with it a notable, often-pointed-out disadvantage in contrast to its Java Edition counterpart: only one item frame can occupy a given block space in Bedrock Edition, and an item frame cannot exist within the same block space as a block such as a pressure plate or torch.

This disadvantage, as can be rather clearly seen, arises solely due to the fact that blocks cannot occupy the same space as other blocks. As the general suggestion here is to jettison this paradigm in favor of a newer format allowing of said cases, which would result in Java Edition item frames being allowed to be converted over to blocks while still allowing for the multiple-in-one-space functionality demonstrated by its current entity form (although cases where the item frame outright physically intersects another block would likely end up being removed as a result).

This conversion also comes with its own set of benefits:
 * Item frames are already defined via block models and block states, with their texture and model files being outright placed in block asset directories. When converted to a proper block, this could allow for item frames to take further advantages of model features such as cullface.
 * Converting item frames to blocks would likely result in them being given breaking particles like other blocks.
 * They would also likely be given proper outlines like other blocks, also causing them to be more consistent.
 * It may allow smooth lighting to properly affect them.

As paintings are similarly entities which are nonetheless programmed to be eternally stationary, it may even be feasible to convert these to blocks and reap the benefits of block mechanics here as well.

32-bit


The maximum Minecraft: Java Edition world size, from Beta 1.8 Pre-release through to release version 1.17.1, is 30 million blocks from the center to an edge, a 2 million decrease from the playable solid area from March 13th Infdev through Beta 1.7.3 of 32 million blocks from the center to an edge. With some very simple modification, though, it is possible to see that the game is completely capable of handling blocks, entities and basically all other game mechanics all the way out to the 32-bit signed integer limit of 2,147,483,647 blocks.

The 32 million limit was likely put in place in order to stop the player from encountering a vast array of precision-loss bugs which would manifest with increasing distance from the center of the world. However, as of 1.17.1, no such significant bugs exist in the game anymore (a full list of all historical effects can be seen here). The only bugs which would impact gameplay to a detrimental degree is light no longer functioning beyond 33,554,432 blocks (due to a lighting rewrite which happened in 1.14), and the player getting stuck in the sides of blocks beyond 1,073,741,824 blocks. (Neither of these bugs appeared in 1.12.2.) While the latter may be a simple fix, the former may end up being far from trivial and may require significant changes to allow for light to work out to the 2 billion limit (although two bits could be borrowed from the y-axis and dedicated to the x and z axes, allowing for light to work fine out to 67,108,864 blocks).

These aside, extending the world limit outwards to make new terrain accessible would be an extremely easy task, and would come with no more major issues. The world border could be extended out to a few thousand blocks before 2,147,483,648 blocks (or, if round numbers are preferred, exactly 2 billion), allowing for far more world area to be playable in than previously. Alternatively, the world could be allowed to generate out to exactly 2,147,483,647 blocks, and any attempt to go past this point would wrap them to -2,147,483,648, and vice versa, allowing for a truly unbounded (but still technically finite) world to exist.

64-bit


While an expansion of the current standard world size to the 32-bit limit of 2 billion is considerably large, this is only the beginning of the story.

If we want to take things to the extremes, it's worth noting that Java Edition at its core is a 64-bit game designed for 64-bit platforms. While labour-intensive, it is entirely possible to convert several 32-bit values pertaining to blocks, chunks and rendering to 64-bit, to more than square the radius of the current playable game.

As of 2021, there are effectively no 32-bit desktop computers remain in common use in 2021, with Windows 11 planned to only come in a 64-bit version. Making all positions 64-bit instead of 32-bit would make the game inaccessible to effectively nobody compared to its current playerbase.

The playable area (as opposed to the absolute area) opened up by making the game 64-bit is truly vast. Even at a trillion blocks out, the precision of a double is comparable to the precision of a float at 1024 blocks out, meaning that any precision loss here is effectively unnoticeable without ridiculously precise testing, and harmful effects such as falling out of the world are virtually nonexistent (especially considering reaching 1 trillion blocks is a bit more tricky than reaching 1024). Placing the world boundary at such a round number, much larger than the current mere 30 million, would still give a massive playable range for survival while avoiding all harmful double precision loss bugs.

Vertical expansion


The current world height, as of 1.18 Experimental Snapshot 1, is exactly 384 blocks (from -64 to 319), a 1.5-fold increase from the prior standard set in 12w07a onwards of 256 blocks (from 0 to 255), which is in turn a doubling of the previous world height of 128 (from 0 to 127). Two thirds of this space is reserved for surface terrain generation, leaving only 128 blocks worth of height for underground and ocean generation - which for a game called Minecraft does not lend itself as best it can to underground features.

Increasing the height of the world while keeping the game in a playable state would be a considerably more difficult task than just expanding it on the x and z axes. The world format would need a complete rewrite for this world, as to allow for chunks to fully unload vertically as they currently do horizontally. The size of chunks is currently 16x256x16 blocks - this could be changed to 16x16x16, 32x32x32 or 64x64x64 for a perfectly cubic chunk, whichever size is desired. This would have some further implications for other game mechanics - notably sky lighting - although solutions for this are proposed below. For weather, a good way to deal with infinite height would to make it only exist where the clouds are and below.

What exists for world boundaries horizontally could also be made to exist vertically as a result, to bring closer parity between the three axes. Firstly, the damage applied by falling more than 64 blocks below the bottom of the world would be removed, as there would be no way to reasonably access the new bottom of the world in survival. Instead, the world border itself would be reworked: it would exist at the absolute top and bottom of the world, just like it does at the four horizontal edges. Moreover, instead of being strictly a square (excluding world boundary restrictions which allow for limited rectangles), it could be set to be any cuboid shape: the diameter on the X, Y and Z axes could all be changed independently.

Adjusting world generation to account for infinite height
With a world height increase, it would be wise to make changes to world generation such that it generates terrain to take advantage of said space. This section only lists changes that could be made while still retaining an experience similar to current vanilla. Such changes to world height could pave for exciting new updates which add wealths of content based on terrain found at great depths and heights - one need only look at Terraria to see the potential that comes with greater world height.

For starters, generation of the Overworld and the Nether would be adjusted such that the sea level of each biome exists at y=0, rather than y=64. Old worlds converted to the new format would be shifted downwards accordingly. The generation of the End could also be similarly moved downwards to have the exit fountain at y=0.

For the Overworld, changes would be relatively minimal at the surface, although underground generation would obviously be able to continue downwards practically indefinitely. It would also be a wise decision to remove the "lava layer" from caves, such that they can be reasonably explored as deep down as desired. Alternatively this layer could vary from cave to cave (with most not having one at all), such that bubble column underwater ravines would still be a feature that could be encountered in oceans. Some underwater caves would still only generate with water down to the bottom of the world. Oceans themselves could also be made considerably deeper.

For the Nether, changes would be more significant. Caves would now also be able to extend upwards as far as possible, and lava oceans could be just as deep.

For the End, the outer island layout around the central island could be changed to be more spherical. A cheap, but effective, way to do this would be to make outer islands spawn in layers, separated by perhaps 512 blocks on the Y axis. The central layer would be the same as the current End in vanilla, with all other sheets being continuous islands even near x/z 0. This would also solve the problem of void damage in this dimension - eventually a player will have to die of fall damage after falling off an island. Falling off will therefore no longer be a death sentence for the player's resources, with a careful expedition to the lower layers of islands allowing for a full recovery. Clever players may also be able to save doomed mobs by exploiting unloaded chunks.

For the true bottom of the End, maybe a few thousand blocks above the world border, the terrain could be made to generate in a more traditional, Overworld-like terrain shape, rather than as islands, as to prevent any potential softlocks from surviving a fall onto the bottom world border and being unable to place blocks on it.

Credits
The 32-bit horizontal world expansion is achievable through simple modding, some of which are linked below. The vertical world expansion was made possible by the Cubic Chunks mod, which can also be found linked below.

The 64-bit horizontal expansion mod for 1.2.5 was created by Daniel "314rft" Ryan, which also fixes all 32-bit float precision bugs (excluding end portal rendering, which vanilla fixes in 1.11 already, and the sounds from sheep eating grass).


 * Download FarLands (Fabric): https://www.curseforge.com/minecraft/mc-mods/farlands
 * Download FarLandsMod (Forge, 1.12.2): https://github.com/ThisTestUser/FarLandsMod/releases/
 * Download FarLandsModV2 (Forge, 1.14+): https://github.com/ThisTestUser/FarLandsModV2/releases/
 * Download OpenCubicChunks (Forge): https://www.curseforge.com/minecraft/mc-mods/opencubicchunks

A video has also been created by AntVenom highlighting all that would need to be done in order to have the game be playable at extreme 32-bit horizontal distances.

Make smooth lighting... actually smooth?
Smooth lighting in the current version (Java Edition 1.17) is frankly an absolute joke, and finding sharp discontinuities and other ugly effects takes little to no effort. Here is a showcase of several examples of smooth lighting doing anything but what it says on the tin:

Changes to lighting with infinite world height
As mentioned before, an increase in world height (especially making it infinite) would have major implications for lighting, and these would need to be taken into serious consideration were such a change to be implemented.

A cheap, but nasty, solution would be to assume that all blocks receive full sky light until it can be confirmed that an opaque block exists above it at some point. This would obviously work, but would cause problems in structures such as massive naturally-generated caves whose heights are greater than the chunk loading distance. Also, if structures or terrain existed in the sky, for example if a layer of floating islands were added to the Overworld a few thousand blocks above the regular terrain, generating these would cause massive and ugly shadows on the surface of the world, which would also provide ample opportunity for hostile mob spawning.

A solution for this latter problem could be to make sky lighting spread laterally somewhat as it travels downwards; an implementation of this could make one-block columns of transparent blocks with sky light values between 1 and 14 inclusive increase by one every vertical chunk border crossed, and columns with light level zero change to one if adjacent to at least one column with a light level greater than one.

Coloured lighting
This would be an amazing change, and allow for not only diverse presentations for builds but exciting new mechanics for generated structures to take advantage of.

The implementation of such light could vary, although most methods would likely come with a major performance and memory impact.

One way would be to use sixteen bits for lighting, by having separate channels for invisible (used for ice and snow, plant growth and mob spawning and burning), red, green and blue lighting, which themselves use four bits each as to range from 0 to 15. A more expensive approach, which would stop certain mixed light colors from looking weird as they fade, could be to have eight different colors and 32-bit lighting: a channel each for infrared (used for handling the formation and melting of ice and snow, and plant growth), red, green, blue, cyan, magenta, yellow and ultraviolet (for handling mob spawning and burning), which would all still have 4 bits each.

Different blocks would outright forbid the passage of some colors of light, while allowing for others to pass through. For example, if we were to use the 16-bit implementation, blue stained glass allows blue light through, blocking all other channels. Cyan stained glass would allow both blue and green light through, blocking only red and "invisible" light. These could be generalised to the 32-bit case with some experimentation. Light gray and gray stained glass would significantly decrease all light passing through, but not completely block it. Black stained glass would block all light from passing, allowing for the observation of a dark room from a well-lit one without any fear of interfering with it. Assuming the 32-bit implementation, normal glass as well as white stained glass, in order to reflect reality somewhat, could allow all visible and ultraviolet light to pass, but block the passage of infrared. As such, an area where the player intends to build with snow and ice, or farm it, could be lit up for visibility and spawn-proofing without fear of hampering their generation, simply by making sure all light emitted passes through said glass blocks.

Many vanilla blocks could themselves be changed to emit colored light. For example, the light fire, lava, torches, lanterns and jack o' lanterns emit could be slightly reddish, nether portals could emit purple light, soul fire, soul torches and soul lanterns could emit blue light, and redstone ore and redstone torches emit deeper red light.

Structures could be added to the game which utilise colored light in their design - the original stained glass suggestion from 2012 features some potential structures such as glowing crystal formations.

It seems an official implementation of colored lighting by Ryan Holtz was extremely close to fruition, but ultimately never made it.

Directional light emission
In snapshot 12w39a furnaces were tweaked as to only emit light from their front face, rather than nonsensically emitting it from all faces. This change was reverted in the following week, and has not returned.

Fixing this would involve making furnaces, blast furnaces, smokers and jack o'lanterns emit light exclusively from the direction they're facing, rather than from everywhere on the block. With the support added for directional block emission in snapshot 18w46a this shouldn't be particularly difficult.

Directional opacity should also be extended to carpets, shulker boxes, composters, cauldrons and hoppers.

Dynamic lighting
This would involve light not being handled on a per-block basis, and allow entities to emit real light. This could allow for held torches and dropped torch items, or indeed any held or dropped light emitting block, to emit light. Further applications could for example be to add a "Minecart with Glowstone" which can be added to minecart trains to illuminate dark tunnels on the fly. Implementing real dynamic lighting would itself require a ridiculous overhaul of lighting.

Credits
The fixes for smooth lighting were taken with the Sodium mod, which among other things makes smooth lighting considerably better than it currently is in vanilla.

The colored lighting example was taken with the Colored Light mod for 1.7.10. While the fact that this mod is only available up to 1.7.10 may be disappointing for some, the only truly disappointing thing is that it needs to be a mod in the first place, rather than a vanilla feature.


 * Download Sodium (Fabric): https://www.curseforge.com/minecraft/mc-mods/sodium
 * Download Colored Light Core (Forge): https://www.curseforge.com/minecraft/mc-mods/colored-light-core