Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/tabmk/minecraft-blocks-render
- Owner: TABmk
- License: mit
- Created: 2020-08-26T10:51:01.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-07-20T04:59:50.000Z (over 1 year ago)
- Last Synced: 2024-10-10T21:33:25.695Z (3 months ago)
- Topics: hacktoberfest, isometric, minecraft, render
- Language: JavaScript
- Homepage:
- Size: 1.04 MB
- Stars: 53
- Watchers: 3
- Forks: 7
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
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-renderor
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