From 44c43cd8d4c243f1c8b47360c9d9c02af8e9a95d Mon Sep 17 00:00:00 2001
From: Evorp <3vorpgaming@gmail.com>
Date: Tue, 7 Jan 2025 18:09:30 -0800
Subject: [PATCH] remove now-unused html anchors
---
package.json | 2 +-
pages/textures/cf32-texturing-guidelines.md | 76 ---------------------
pages/textures/f32-texturing-guidelines.md | 74 --------------------
pnpm-lock.yaml | 26 +++----
4 files changed, 14 insertions(+), 164 deletions(-)
diff --git a/package.json b/package.json
index 304631c..db38a9e 100644
--- a/package.json
+++ b/package.json
@@ -14,6 +14,6 @@
"vue": "^3.5.13"
},
"devDependencies": {
- "@types/node": "^22.10.2"
+ "@types/node": "^22.10.5"
}
}
\ No newline at end of file
diff --git a/pages/textures/cf32-texturing-guidelines.md b/pages/textures/cf32-texturing-guidelines.md
index 98357cb..9d68ff0 100644
--- a/pages/textures/cf32-texturing-guidelines.md
+++ b/pages/textures/cf32-texturing-guidelines.md
@@ -28,83 +28,59 @@ Many texturing and Faithful-specific terms are referred to throughout these guid
These requirements apply to all textures unless specified otherwise and must all be met for a texture to be considered viable for Classic Faithful.
-
-
1. **Textures need to follow vanilla Minecraft textures whenever possible.** This should go without saying, but textures have to keep the same proportions, general coloration, and representation as vanilla. A good rule of thumb is to check how the texture looks from far away compared with vanilla; the less difference, the better.
Right: A texture with vanilla color placement, proportions, and overall structure. Left: Its vanilla counterpart.
-
-
2. **When applicable, always reference [Vattic's art](https://web.archive.org/web/20170630235514/faithful32x32.com/dl/faithful32pack.zip/).** Another self explanatory one given the entire purpose of the pack. If the texture has a programmer art equivalent, or just generally fits into a similar material as one, always reference Vattic's original art when drawing textures. Not only does it make texturing much easier, but it also helps keep the stylistic cohesion of looking like Vattic's original Faithful 32x32.
Left: Vattic's bricks. Right: Its Jappa equivalent.
-
-
3. **With detailing, less is more.** Don’t overdo dithering or antialiasing, instead use the minimal amount of detail to keep textures from looking flat or ugly. Always ask yourself "could Jappa have done this in a 16x canvas" before adding additional detail; if large details are not present in vanilla there's probably a reason for it. If something genuinely could not fit in the vanilla texture and makes no sense to not add, such as gravel not containing actual rocks, then it can be acceptable to add. However, always get feedback before changing anything noticeable about any texture.
Left: A texture with just enough detail. Right: An overdetailed texture.
-
-
4. **Don't overly change the vanilla palette.** Adding in-between colors is encouraged to eliminate a "plasticky" flat look, but don't overdo it by making the texture completely nonvanilla or blurry. Generally, between one and three added colors should suffice, and oftentimes none are even necessary to begin with. As well as this, ensure that the darkest and lightest colors of the texture are untouched to avoid the overall contrast being significantly altered; any added colors should just be used to blend contrasty and/or flat areas rather than create nonvanilla contrast in the palette. Another thing to note is to never change any already existing colors in a texture, only add to them. There are certain specific exceptions to this rule which will be covered later on.
Left: Vanilla texture. Center: Unnecessary use of added colors. Right: Constructive use of added colors.
-
-
5. **When making item textures, thin out the borders to one pixel wide.** Pretty much exactly what it sounds like; two pixel wide outlines for items in 32x almost always look disproportionate and bloated. If the texture doesn't have a clear outline or the vanilla texture itself doesn't use a one pixel wide outline, then it can be acceptable to use more than one pixel, but nearly all of the time you should be thinning them out.
Left: Examples of textures with two pixel wide outlines. Right: Textures with one pixel wide outlines.
-
-
6. **If a vanilla texture references an outdated texture, use the outdated texture as a base in the Classic Faithful counterpart.** Examples of this include the observer top using an outdated furnace base, the end crystal using an outdated bedrock texture, and smooth stone using an outdated stone texture.
-
-
7. **If a texture uses another texture as a base, use the already existing Classic Faithful rendition of it, if available.** An example of this would be planks and the crafting table. Don't make planks from scratch just for the crafting table texture, as not only would this cause inconsistencies if the two are used in conjunction, but it would also waste a lot of effort.
A texture that directly references another. Note the identical plank background on the crafting table.
-
-
8. **Don't upscale useless textures.** If a texture would end up looking identical to vanilla when upscaled, is unused, or is already so high resolution that there's no real need to upscale it, then just don't do it. It just bloats the file size of the pack and wastes your effort, pretty self explanatory.
### **Tips**
These are less specific ways to improve your textures, and unlike rules can be subject to interpretation.
-
-
1. **Mob faces** can be difficult to interpret. If making eyes, try to blend the corner of the eye into the next color over using an added color. This can be seen on a number of mob textures, as Vattic employed this method a lot. Try to upscale other features unless you cannot make it work (or it creates your new sleep paralysis demon), in which case leaving it the same as default is fine (a "mixel" face).
Left and center: Examples of "demixelled" mob faces. Right: A hard to interpret face left as mixels.
-
-
2. **Smooth jagged lines whenever possible.** When upscaling lines and curves in a texture, you have to ensure jagged or lumpy edges (oftentimes referred to as "jaggies") do not form. Essentially, you want to ensure differing lengths of pixels within the curve don't alternate or repeat, rather curving it in a more natural way where the lengths of each section get longer or shorter consistently.
Left: Examples of jagged edges and curves. Right: Examples of smooth edges and curves.
-
-
3. **Don't overuse undetailed two pixel wide lines.** Not only does it look mixelly or incomplete which is undesired, but it also makes the texture look flat. The best way to upscale these types of textures would be to add a color or use an existing color to depth shade the block to eliminate these straight two pixel wide lines, or to simply reduce the width of the band if necessary.
Left: Improper interpretation of textures. Right: Utilizing the larger canvas size to remove unnecessarily thick lines.
-
-
4. **Cross reference other similar textures.** This is one of the most important tips to make textures look like they fit in the pack in the first place. You don't just have to reference Vattic's art, but other pre-existing Classic Faithful textures as well. More information about how to shade specific materials can be found below, but this tip in particular will not only help you improve at getting the general style of Classic Faithful down, but improve at pixel art in general over time.
::: tip And most importantly...
@@ -115,134 +91,96 @@ Always get feedback from others while drawing a texture! It will help you improv
This section goes into detail about how to shade materials that you shouldn't shade in the "normal" way. If a material is not on this list, refer to the first entry.
-
-
**Conventional/normal/painted upscaling** (used for basically everything not on this list) has no real special or unique way to shade these textures. Simply upscale them normally by smoothening out curves and shapes, taper off any lines and defined structures, add antialiasing and added colors to remove flat areas if and where needed, and keep stylistic cohesion present wherever possible by cross referencing existing textures as much as possible.
Examples of conventionally upscaled blocks.
-
-
**Gem and metal blocks** should be upscaled through a normal pass, and similar to the shading on large bricks if there are defined gaps and highlights, blend them. Added color usage is also encouraged to accurately portray a shiny material. For gaps, depth shade them by adding a lighter color(s) rather than a darker one, to give the texture an almost "glowy" look..
Examples of gem and metal blocks. Note the heavy usage of added colors and blended gaps.
-
-
**Contiguous stones** that are not broken up into defined shapes should not have any added colors, and should be upscaled in a highly "painted" style, meaning that blobs of color shouldn't have definition added to them where none exists, and it should be upscaled in a very literal sense of being closer to a simple "demixelling" pass. However, avoiding jagged edges and keeping stylistic cohesion present with the rest of the textures is still important.
Examples of contiguous stone textures. Note the lack of added detail and the plasticky look.
-
-
**Rocky materials with distinct stones** should first use added colors to define what is a rock and what is a gap before doing anything else. After this, upscale normally while ensuring that the gaps and the rocks are visibly separated and don't overly blend into each other using added colors. Always shape based on the rocks, and the gaps will follow based on the rocks and look natural as a result. Otherwise, the rocks won't look anything like rocks!
Examples of textures with distinct rocks. Note the visible separation of the rounded rocks and gaps through added colors, particularly in comparison to their vanilla counterparts.
-
-
**Small bricks and tiles** should thin out the gaps to one pixel wide in the direction that looks best, and be upscaled normally from there. If the bricks have highlights or shadows, thin those out as well to one pixel wide. If the texture ends up looking flat due to the larger brick size after thinning out the gaps and highlights, added colors and even dithering sometimes may be helpful depending on the texture.
Examples of small bricks and tiles. Note the one pixel wide gaps/highlights and slight usage of dithering.
-
-
**Large bricks (and polished stones in certain situations)** should leave the gaps, highlights, and shadows two pixels wide, and be upscaled normally from there. Depth shade the gaps and highlights, and for the gaps add a darker color as opposed to gems which add a lighter color. This helps give the gaps a 3d effect and makes the gaps a lot less flat and "AI upscaled" looking. If the bricks have a linear pattern, small amounts of linear dithering may also be helpful.
Examples of larger bricks and polished stones. Note the usage of two pixel wide blended gaps, small amounts of linear dithering, but the overall painted look.
-
-
**Polished stone/wood** are the same as large bricks, only with the interior of the texture being tiled and the obvious tiling repetitions removed. However, only do this if it looks good, otherwise refer to the entry of large bricks if it has a "noisy" or nonvanilla appearance which is undesirable.
Examples of polished stone and wood blocks. Note how the detail looks tiled and much more fine compared to vanilla, and the usage of two pixel wide blended gaps.
-
-
**Tree bark and mushroom stems** should have heavy amounts of antialiasing in the direction the texture goes added manually using added colors. This is primarily done to preserve the aesthetic of Vattic's original logs, which had an extremely glossy, almost motion blurred appearance and had no real reasoning for being so.
Examples of heavily motion blurred logs. Note the usage of added colors going in the direction of the texture's linearity.
-
-
**Planks and other refined wood** should be upscaled with a lot of linear dithering and small amounts of antialiasing, to accurately portray a wood grain material. A method of doing this which is useful for planks involves stretching the vanilla texture, tiling it downwards, and fixing any awkward areas. Alternatively, if this method does not work well, simply extend out the detail to portray a linear look. Do not add colors unless absolutely necessary, and preserve default's contrast where possible.
Examples of refined wood. Note the detailed and linear look.
-
-
**Leaves and larger plants** can use small amounts of dithering on the branches mixed in with a slightly increased usage of antialiasing and/or added colors. With thicker plants like cacti or bamboo, don't use any dithering and upscale conventionally.
Examples of larger plants. Note the lack of any blending method on stalks and stems.
-
-
**Flowers and other foliage** can use dithering more heavily than leaves or stalks. Similar to rocky stones, ensure that flowers have a defined shape and don't overly blend into the stems or leaves, and depending on the flower type either dither or antialias. For plant stems, antialias heavily and thin them out. Vines should be evenly conventionally dithered throughout the entire texture, and use heavy amounts of antialiasing in addition.
Examples of general foliage. Note the usage of dithering on the vines and on certain flowers, and how the flower stems were thinned out.
-
-
**Grassy textures and certain fungi** should use a "jumble" or "scramble" filter if your editing program has that, with a few edits to fix mixels and other visual issues. If it doesn't, manually dither it to give it a coarse texture. Keep the palette as close to vanilla as possible to preserve the contrast, sometimes you may want to use additional effects and index it back to the vanilla palette.
Examples of grassy textures. Note the usage of patchy dithering.
-
-
**Sand and other powdery materials** should tile the block in a 2x2 grid, then cut out random sections and rotate and/or flip them randomly to remove repetitions that stops the texture from looking just tiled on its own.
Examples of powdery materials. Note the fine detail and how it looks almost tiled but isn't.
-
-
**Sandstone** should have large amounts of dithering present, a jumble tool may also suffice if necessary. Thin out natural gaps a lot more than otherwise, to give a more slate-like appearance. For more refined textures such as cut or chiseled sandstone antialiasing can also be used to properly convey smoothness.
Examples of sandstone textures. Note the heavy usage of dithering, and heavy usage of antialiasing on polished blocks.
-
-
**Prismarine** should use added colors and antialiasing excessively to convey a smooth, shiny material. Thin out and curve highlights, and reduce gaps to one pixel wide.
Examples of prismarine textures. Note the heavy reliance on antialiasing to prevent flatness, and the one pixel wide gaps and highlights.
-
-
**Contrasty dirt and stone textures** should soften the colors by using a translucent layer of the midtone color or manually editing the contrasty colors, and tile vanilla 16x on top of the texture at a low opacity using another different layer. However, only do this if the texture is particularly contrasty and the vanilla palette doesn't look good in any way even with added colors, as this method can add a lot of unnecessary colors and should be used as a last resort.
Examples of contrasty dirt and stone textures. Note the noisy look.
-
-
**Icy and glassy textures** should use antialiasing excessively. For items in particular, added colors should be used to properly convey a smooth surface. For textures with an obvious diagonal shine, thin out the shine marks and use antialiasing in the direction of the the marks to convey a streaky look, almost like diagonal linear dithering.
Examples of glassy and icy blocks. Note the usage of antialiasing and added colors.
-
-
**Fur and fabric** should avoid false lines forming at all costs, which is very easy to happen given the spiky nature of these materials. Upscale it normally, and try to avoid having lines every two pixels from 16x by thickening and thinning out some of the spikes on the texture. Generally, the farther from the base color a spike gets, the thinner it should be. This creates a more natural effect and stops it from looking mindlessly upscaled.
Examples of fabric and fur textures. Note the heavy usage of tapering lines and spikes.
-
-
**Doors and trapdoors** should be upscaled like what they are made of. However, doors should always use one pixel wide borders, while trapdoors can use two pixel wide blended outlines for the outer border. This discrepancy is due to Vattic's original wooden door and trapdoor having this inconsistency present.
@@ -279,43 +217,31 @@ This is a very useful skill for anyone interested in programmer art to learn, an
Noise is usually present on textures because they are an original, programmer art texture, or are placeholder visuals for a snapshot texture. The reason for noise in textures is generally due to a programmer having no idea how to properly draw pixel art and hiding whatever they made behind a mess of darker and lighter pixels to make it harder to see.
-
-
1. **Tiling with edits** works very well if the texture is powdery or grainy, particularly when the texture is too chaotic and noisy to do it by hand. However, the most important part is to edit the texture after it's been tiled, or tiling repetitions will occur and it won't look good as a result.
Left: The default texture. Center: The default texture tiled in a 2x2 grid. Right: Tiling repetitions removed.
-
-
2. **Jumbling**, sometimes also called "scrambling", "diffuse", or just "randomize", is a method of automatically upscaling textures with a lot of noise, which you may recall is how you should be upscaling grassy textures. Essentially, it gets demixelled by shuffling the pixels around randomly near, meaning that color placement stays similar to default. However, this method has a very rough and almost patchy look and not all materials will support it.
Examples of texture upscaling via jumbling.
-
-
3. **Tiled detail**, which contrasty stone and dirt textures also use, however just without the contrast reduction. After doing a cursory upscale, likely using another method on this list such as bilinear or indexing, tile the same vanilla 16x texture you're upscaling on top of the texture at a low opacity using a different layer. This works best on dirty or very detailed textures however, as it has a very grainy appearance, similar to jumbling but even more detailed.
Left: An automatically upscaled base. Center: The vanilla texture tiled. Right: The two overlaid on top of each other.
-
-
4. **Softening** is effectively the opposite effect of tiled detail, in that rather than making it more contrasty and grainy, it makes it less so. Basically, rather than tiling default on top you put a heavily blurred version of the texture on top at a very low opacity, decreasing the contrast on the colors and softening the overall texture to look less sharp.
Left: A base upscale. Center: The base upscale blurred. Right: The two overlaid on top of each other.
-
-
5. **Indexing and re-adding noise** is a method where you index the palette down to a more reasonable size, upscale like normal or however the material should be shaded, then adding noise back and approximating the palette to something similar to what it originally was. On textures with defined gaps or other visible structures this is oftentimes the most viable option.
Top right: The default vanilla texture. Top left: Indexed down to essential colors. Bottom Left: An upscale of the indexed version. Bottom right: Added noise back in, finished version.
-
-
6. **Natively upscaling** is pretty much exactly what it sounds like, and by far the most difficult on this list. Simply upscale the texture as usual, while keeping the noise present and avoiding mixelly areas.
::: tip
@@ -326,8 +252,6 @@ Many of the techniques listed here can work in conjunction with each other. You
The majority of additional techniques for upscaling blurry textures are shared with noise.
-
-
1. **Automatic upscaling**, such as a bilinear or bicubic upscaling filter rather than nearest neighbor and doing it by hand can oftentimes do the trick. As it tends to add a lot of additional transition tones, it fits blurry textures very well.
diff --git a/pages/textures/f32-texturing-guidelines.md b/pages/textures/f32-texturing-guidelines.md
index 22ead1b..942b91c 100644
--- a/pages/textures/f32-texturing-guidelines.md
+++ b/pages/textures/f32-texturing-guidelines.md
@@ -30,64 +30,44 @@ Many texturing and Faithful-specific terms are referred to throughout these guid
These requirements apply to all textures unless specified otherwise and must all be met for a texture to be considered viable for Faithful.
-
-
1. **Textures need to mimic vanilla Minecraft textures, and should be heavily based upon them.** This probably goes without saying, but it’s good to have it specified nonetheless. While you are not required to make your texture by directly editing the vanilla one, it is heavily recommended and usually helps your texture look better and closer to the default texture.
-
-
2. **Outlines, dividing lines and the like that would end up being 2 pixels wide when upscaled to double the resolution should almost always be 1 pixel wide.** Pretty straightforward; most lines in Faithful should be 1 pixel wide (examples: glass, gold block, iron ingot, diamond). There are exceptions to this, especially if a line is not an outline/dividing line and/or is curvy, or would be off-centre if it was 1 pixel wide—in these cases it’s acceptable to make the line wider.
Top: Vanilla texture. Bottom left: Improper interpretation of lines present in the vanilla texture. Bottom right: Better interpretation.
-
-
3. **All textures are required to be shaded correctly according to their material and shape.** Before shading a texture, define its material correctly (rough/smooth, shiny/non-reflective), and then use adequate shading methods. These are further described in the Material and Shape Reference List.
Left: Incorrectly shaded item (see the Material and Shape Reference List). Right: Correctly shaded item.
-
-
4. **All elements of a texture need to have their meaning, and should look like actual things instead of just shapes.** Don’t just mindlessly upscale textures without paying attention to what they’re supposed to represent: When drawing an element of a texture, always think about what it’s supposed to represent in vanilla, and then draw the element according to this idea (while still keeping similarity to vanilla in mind, of course).
Top: Vanilla texture. Bottom left: Incorrect upscale. Bottom right: Correct interpretation (note the individual leaves, which are required in double the resolution but aren’t possible to be depicted in the vanilla resolution).
-
-
5. **Textures should stick to the vanilla colour palette.** Self-explanatory; try to only use the colours that the vanilla texture uses. If you’re trying to blend two colours together using anti-aliasing, you can usually re-use a colour from elsewhere in the texture. In difficult circumstances you can add colours to help you, but most of the time, one or two is enough. If the texture you’re upscaling already has many colours, you can use that to your advantage, but you should still keep the palette limited to more or less than 10 colours. Additionally, never change existing colours from the vanilla palette! If a vanilla texture uses 5 specific colours, make sure your texture uses these exact ones. \
This rule does not apply to animated textures that used to be generated procedurally in the past: e.g. water, lava, nether portal, fire and soul fire.
-
-
6. **Do not make up features/details that are not clearly present in the vanilla texture and don’t add them to your texture, unless not having them makes absolutely no sense in double the resolution.** While upscaling a texture, one might have the tendency to add significant elements that are not present in vanilla. This is discouraged, as it makes a texture look too distant from the vanilla look most of the time. This also applies to various details in a texture: If appropriate, a normal amount is encouraged, but don’t overdo it.
Top: Vanilla texture. Bottom left: A texture with too many added details. Bottom right: A texture with just enough details and features.
-
-
7. **When blending colour using anti-aliasing or dithering, make sure that darkest colours never directly border the lightest ones and vice versa.** Dirt is an example of this. Always have a transition colour in between the colours. In some cases this is desired, but not in many. If you’re a beginner Faithful contributor, always follow this rule.
Left: Improper colour borders. Note the very harsh-looking colour borders caused by the lack of a transition colour. Right: Correct colour transitions.
-
-
8. **Try to eliminate colour banding, if possible.** This can be done by cleverly reducing the width of each colour band to one or two pixels. Don’t brute force it though, since in some cases where the colour palette is especially limited this can harm the texture overall. It’s certainly possible to do in most cases though.
Left: An example of a texture with noticeable colour banding. Right: The same texture, with colour banding mostly eliminated.
-
-
9. **Unless it’s intentional and makes sense to have, there should never be large single-colour areas in your texture.** This applies especially to raw materials like stone or wood. You can always break these areas up by using dithering or other methods.
-
-
10. **Noise** that was clearly generated using a filter is only to be kept if removing it would alter the general look of the texture too significantly. If noise is upscaled, its palette should be reduced to a minimum.
@@ -96,19 +76,13 @@ This rule does not apply to animated textures that used to be generated procedur
The shulker box is an example of a texture where the noise is barely visible, and therefore should be removed.
-
-
11. **If a texture uses another texture as a base, use the already existing Faithful rendition of it, if available.** An example of this would be stone and ores. Don’t make stone from scratch just for the ore texture. Make your life simpler and re-use existing textures when you can.
An ore texture. Note how the already existing stone texture is used in the background.
-
-
12. **If a texture would end up looking identical to vanilla when upscaled (while following all the above rules), it shall not be included in Faithful.** Self-explanatory. Textures like these look exactly the same as vanilla when used in-game, and so they only bloat the pack and needlessly increase the file size.
-
-
13. **If a texture has issues noted on the Mojira website, Mojang's offical bug tracker, then changes should be made to fix them.** Some examples of bugs that are allowed to be fixed include: unused/misaligned pixels or textures, “Jappafication” errors, and parity issues. Fixing bugs allows for the pack to have issues in textures resolved before they are added into the base game, which saves us time.
::: danger NOTE
@@ -118,22 +92,16 @@ Special rules and/or exceptions can apply to specific textures if the Art Direct
**Tips**
-
-
1. **Mob faces** can be particularly hard to interpret in only double the resolution. If all attempts at upscaling the face end up looking bad, it is acceptable to use a “mixel-face”—just keeping the vanilla mob face, without any edits, on an upscaled background.
An acceptable mob face.
-
-
2. **Dithering** should not be overdone, unless you’re re-drawing a particularly noisy texture (e.g. sand). Also while dithering, try to avoid lone pixels, as in the ones that do not border other ones of the same colour.
A close-up of a colour transition with lone pixels, which should be avoided.
-
-
3. **Try to minimise the occurrence of stairing pixels**, an example of which is shown below.
@@ -151,127 +119,87 @@ This section goes into detail about how to draw and shade specific materials and
There exists a correlation between the roughness and shininess of a material and the colour blending method. Generally, the rougher a material is, the more dithering you should use. The same applies to high-contrast colours and minimal colour blending for shiny materials.
-
-
**Smooth metal** should only use anti-aliasing as a colour blending method, or no blending at all. The colour palette should be limited and contrasty. In some cases mild linear dithering is acceptable if it’s required to keep the texture from looking like plastic. Additionally, in item textures, faces of an object which are in the shade should have a lighter outline (as well as the item outline itself) to simulate light reflection.
Examples of various smooth metal textures.
-
-
**Rough metals** such as raw ore blocks, netherite, anvils and even iron golems should follow the same lighting logic as regular metals while being dithered. Regular dithering should be used as the preferred method.
Examples of rough metal textures.
-
-
**Diamonds and other gemstones** in Minecraft’s context should be shaded like reflective rocks more than anything—they usually don’t let much light pass through, unlike their real-life counterparts. Only anti-aliasing should be used here. For faces in the shade in item textures, the same shading logic as on smooth metal textures applies.
Examples of gemstone textures.
-
-
**Contiguous stones** that are not broken up into smaller rocks are very rough, so they should use dithering as much as possible. For textures with a linear pattern (stone, dripstone), it is recommended to use a mixture of linear and regular dithering to emphasise the material even more. Anti-aliasing can be used here, but only when the material is smoother than usual, like with dripstone.
Examples of contiguous raw stone textures.
-
-
**Polished stones** should use dithering (linear when applicable) a bit, but not nearly as much as raw stones. Instead, anti-aliasing should be used in heavier amounts to express the smoothness of the material.
Smooth stone is a special case however, as it directly reuses regular stone’s texture pattern (which you should do as well, as per rule 11).
Examples of polished stone textures.
-
-
**Rocky materials** such as cobblestone and netherrack should be dithered as much as raw stones, but unless the rocks are arranged in a clear linear pattern (like in the deepslate texture), linear dithering should never be used.
Examples of rocky material textures.
-
-
**Wood** should use a lot of linear dithering and very minimal amounts of regular dithering. To smooth colour transitions, anti-aliasing can be used if it looks good.
Examples of wood textures.
-
-
**Most flowers, foliage, and other plant matter** can use dithering (linear or regular) depending on the general roughness/smoothness of the surface. While flower petals can employ this shading method, genuine leaves should never use dithering.
Examples of plant textures.
-
-
**Corals** should mainly use anti-aliasing, but regular dithering is also acceptable.
Examples of coral textures.
-
-
**Sand and other powdery materials** should be heavily dithered: there should be no large contiguous area of a single colour. Even checkerboard dithering can be used in this case, in small amounts. Anti-aliasing is encouraged to a smaller degree. This also applies to gravel, where the individual rocks that make up the material are clearly visible.
Examples of powdery textures.
-
-
**Bee nests** are to be shaded the same way wood is.
-
-
**Honey and slime** should not feature any dithering at all, only using anti-aliasing to smooth the colours.
-
-
**Glazed terracotta** should only use minimal amounts of anti-aliasing when required, otherwise no colour blending should be present.
Examples of glazed terracotta textures.
-
-
**Glass** can use small amounts of dithering for the frame. This does not apply to items.
-
-
**Bones** (including skeletons) should ideally mainly use anti-aliasing, with a bit of occasional linear dithering sprinkled in, near colour transitions. This applies to tusks as well.
Examples of bone textures.
-
-
**Cloth and paper** should both be shaded approximately the same way, with the only difference being that cloth should have more linearity. Anti-aliasing should be the main colour blending method for these materials.
-
-
**Skin (in mob textures) and leather** should mainly use anti-aliasing. Not using many colour blending methods can lead to heavy colour banding and looking plasticky, so this is a reminder to try and eliminate that if possible. Depending on the roughness of a specific skin type, linear and regular dithering can also be used to communicate the feel of the material.
Examples of skin textures.
-
-
**Creepers** are quite mind boggling. The texture was originally made from the leaves texture used in Alpha, but since a lot of noise has been overlaid on top, the texture no longer looks anything close to leaves, not to mention Alpha leaves barely resemble leaves in the first place. Basically, nobody knows how to shade this chaos of a material properly, so we just indexed the texture and used a combination of all the techniques listed here to create a chaotic material that doesn't really represent anything. Worked surprisingly well.
-
-
**Fur and hair** should employ linear dithering, but in such a way that it creates visible strands of hair. Some regular dithering and anti-aliasing can also come in handy. This applies to wool on sheep as well.
Examples of fur/hair textures.
-
-
**Fish entities** should have clearly visible scales present where appropriate (don’t just draw a checkerboard!). Basically all colour blending methods can be used here.
@@ -281,8 +209,6 @@ Smooth stone is a special case however, as it directly reuses regular stone’s
### Shapes
-
-
**Cylindrical type objects** such as iron bars, individual dynamite sticks that make up TNT and metal railings should have visible shades along both sides and a highlight on the side near the centre like so:
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index f7e3933..1fc20ae 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -13,14 +13,14 @@ importers:
version: 4.0.3
vitepress:
specifier: ^1.5.0
- version: 1.5.0(@algolia/client-search@5.17.1)(@types/node@22.10.2)(postcss@8.4.49)(search-insights@2.13.0)
+ version: 1.5.0(@algolia/client-search@5.17.1)(@types/node@22.10.5)(postcss@8.4.49)(search-insights@2.13.0)
vue:
specifier: ^3.5.13
version: 3.5.13
devDependencies:
'@types/node':
- specifier: ^22.10.2
- version: 22.10.2
+ specifier: ^22.10.5
+ version: 22.10.5
packages:
@@ -414,8 +414,8 @@ packages:
'@types/mdurl@2.0.0':
resolution: {integrity: sha512-RGdgjQUZba5p6QEFAVx2OGb8rQDL/cPRG7GiedRzMcJ1tYnUANBncjbSB1NRGwbvjcPeikRABz2nshyPk1bhWg==}
- '@types/node@22.10.2':
- resolution: {integrity: sha512-Xxr6BBRCAOQixvonOye19wnzyDiUtTeqldOOmj3CkeblonbccA12PFwlufvRdrpjXxqnmUaeiU5EOA+7s5diUQ==}
+ '@types/node@22.10.5':
+ resolution: {integrity: sha512-F8Q+SeGimwOo86fiovQh8qiXfFEh2/ocYv7tU5pJ3EXMSSxk1Joj5wefpFK2fHTf/N6HKGSxIDBT9f3gCxXPkQ==}
'@types/unist@3.0.3':
resolution: {integrity: sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==}
@@ -1150,7 +1150,7 @@ snapshots:
'@types/mdurl@2.0.0': {}
- '@types/node@22.10.2':
+ '@types/node@22.10.5':
dependencies:
undici-types: 6.20.0
@@ -1160,9 +1160,9 @@ snapshots:
'@ungap/structured-clone@1.2.1': {}
- '@vitejs/plugin-vue@5.2.1(vite@5.4.11(@types/node@22.10.2))(vue@3.5.13)':
+ '@vitejs/plugin-vue@5.2.1(vite@5.4.11(@types/node@22.10.5))(vue@3.5.13)':
dependencies:
- vite: 5.4.11(@types/node@22.10.2)
+ vite: 5.4.11(@types/node@22.10.5)
vue: 3.5.13
'@vue/compiler-core@3.5.13':
@@ -1566,16 +1566,16 @@ snapshots:
'@types/unist': 3.0.3
vfile-message: 4.0.2
- vite@5.4.11(@types/node@22.10.2):
+ vite@5.4.11(@types/node@22.10.5):
dependencies:
esbuild: 0.21.5
postcss: 8.4.49
rollup: 4.28.1
optionalDependencies:
- '@types/node': 22.10.2
+ '@types/node': 22.10.5
fsevents: 2.3.3
- vitepress@1.5.0(@algolia/client-search@5.17.1)(@types/node@22.10.2)(postcss@8.4.49)(search-insights@2.13.0):
+ vitepress@1.5.0(@algolia/client-search@5.17.1)(@types/node@22.10.5)(postcss@8.4.49)(search-insights@2.13.0):
dependencies:
'@docsearch/css': 3.8.0
'@docsearch/js': 3.8.0(@algolia/client-search@5.17.1)(search-insights@2.13.0)
@@ -1584,7 +1584,7 @@ snapshots:
'@shikijs/transformers': 1.24.2
'@shikijs/types': 1.24.2
'@types/markdown-it': 14.1.2
- '@vitejs/plugin-vue': 5.2.1(vite@5.4.11(@types/node@22.10.2))(vue@3.5.13)
+ '@vitejs/plugin-vue': 5.2.1(vite@5.4.11(@types/node@22.10.5))(vue@3.5.13)
'@vue/devtools-api': 7.6.8
'@vue/shared': 3.5.13
'@vueuse/core': 11.3.0(vue@3.5.13)
@@ -1593,7 +1593,7 @@ snapshots:
mark.js: 8.11.1
minisearch: 7.1.1
shiki: 1.24.2
- vite: 5.4.11(@types/node@22.10.2)
+ vite: 5.4.11(@types/node@22.10.5)
vue: 3.5.13
optionalDependencies:
postcss: 8.4.49