Skip to content

TABmk/minecraft-blocks-render

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Help

Rate

Minecraft sprites to isometric cube render.

With only few steps you can render your own actual minecraft blocks icons.

⚠️ WIP ⚠️

Some features not yet implemented, but you can help by contributing!

⚠️ V3 is on way

Now with web UI. Check out here

[Important] HOW TO USE 🍳🐕

Install

npm i -g minecraft-blocks-render

or

yarn global add minecraft-blocks-render

Usage

To render blocks, you need to get sprites. So we can just grab it from any .jar file, that you can find on /minecraft/versions/YOUR_VERSION/x.xx.x.jar after installing it from launcher.

https://help.minecraft.net/hc/en-us/articles/360035131551-Where-are-Minecraft-files-stored-

OS path
OSX ~/Library/Application\ Support/minecraft/versions
Windows %AppData%/.minecraft/versions
Linux ~/.minecraft/versions

mbr grab

options

option description required
-f, --file Load a file
-d, --debug Shows debug info of extraction
Example: mbr grab -f 1.16.2.jar -d

Make any folder and put .jar file on it.

And run command mbr grab on it

cd my-folder
mbr grab

grab will copy folders block and item from /assets/minecraft/textures in .jar file to local folder called grab

mbr render

options

option description required default type
-r, --reducer Image bit depth reducer. Bigger number will do more color reduce. 1 Number
-s, --scale scale image without reducing quality. Warning! May cause edges bugs 1 Number
-t, --type base will generate JSON file where key - block name, value - base64 string. png will render png images for each block String
--name render specified item. Items and all options support String
--rs, --renderSides Add if want render blocks with side textures -
--rt, --renderTransparent Add if want render blocks with transparent textures -
--ns, --noShadow disable shadows on sides -
-d, --debug Shows debug info of extraction -
Example: mbr render -t base -r 32 -s 10 -d
Example 2: mbr render -t base --name acacia_boat -s 2

After grabbing sprites you can render your blocks with command mbr render

If you use type png all output images will be saved to grab/rendered

Type base will save your renders to JSON file grab/rendered.json. Where key — bukkit name, value — base64 string. Items (fron grab/items) are will be also converted to base64.

rendered.json example
{
  "name": "ACACIA_LOG",
  "icon": "",
  ...

You can test base64 images here https://base64.guru/converter/decode/image

TODO

We have few ideas for project improvement. You can help by sending PR 🤗

  • create npm package
  • renderSides option for render command (allow render even *_top/*_bottom/etc blocks)
  • renderTransparent option for render command (allow render block with transparent textures)
  • noShadow option for render command
  • name option for render command (allow render only one block by name)
  • items to base64 converter
  • cleaning up items from extra icons like clock_09 or bow_pulling_1
  • add more info to json like in-game item ID and old style ID
  • add tests
  • rewrite code to classes (?)
  • API (?)
  • some blocks (like glass pane) using 2D sprite for preview. Need list of items which must be saved as sprite
  • render blocks with transparent parts

Some researches

Without looking at the minecraft code, we created almost the same looking 3D preview of block as the inventory one.

Width

width

As we know, width of cube in isometric projection is 1/sqrt(3) by ISO 5456-3. But as we can read here, games often use 1/2 (0.5). Minecraft is no exception, so we used 1/2 width formula and +20% height of front sprites to make it similar with game;

Height

shadows

Shadow

We see 2 different shadows on the sides of the block.. By doing some math @Kurikaeshiru found regularity in RGB shifts. So we just shift each value of RGB with formula

color /= 1.25 * multiplier

Multiplier is used for the second shadow, which is darker

Releases

No releases published

Packages

No packages published