Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tabmk/minecraft-blocks-render

2D sprite to isometric icon
https://github.com/tabmk/minecraft-blocks-render

hacktoberfest isometric minecraft render

Last synced: 3 months ago
JSON representation

2D sprite to isometric icon

Awesome Lists containing this project

README

        

[](https://www.npmjs.com/package/minecraft-blocks-render) [](https://github.com/TABmk/minecraft-blocks-render/blob/master/LICENSE) [](https://www.npmjs.com/package/minecraft-blocks-render)

__Help__ [](https://github.com/TABmk/minecraft-blocks-render/issues?q=is%3Aopen+is%3Aissue) [](https://github.com/TABmk/minecraft-blocks-render/pulls?q=is%3Aopen+is%3Apr)

__Rate__ [](https://github.com/TABmk/minecraft-blocks-render)



#### 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](https://github.com/TABmk/minecraft-blocks-render/tree/v3)



# [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 🤗

- [x] create npm package
- [x] `renderSides` option for render command (allow render even `*_top`/`*_bottom`/etc blocks)
- [x] `renderTransparent` option for render command (allow render block with transparent textures)
- [x] `noShadow` option for render command
- [x] `name` option for render command (allow render only one block by name)
- [x] `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](https://www.compuphase.com/images/axometr2.gif)

As we know, width of cube in isometric projection is 1/sqrt(3) by ISO 5456-3. But as we can read [here](https://www.compuphase.com/axometr.htm), 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](img/cubeheight.jpg)

#### shadows

![Shadow](img/shadowcorner.jpg)

We see 2 different shadows on the sides of the block.. By doing some math [@Kurikaeshiru](https://github.com/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