mcpe/README.md

102 lines
5.2 KiB
Markdown
Raw Normal View History

# ReMinecraftPE
This project aims to create a custom Minecraft experience based on Minecraft: Pocket Edition as of 2011. It's based on the mcpe01_canada.apk build of the game.
2023-08-18 21:47:28 +03:00
**Its goals are:**
* To add Quality-of-Life features to Minecraft: Pocket Edition, such as a brighter color gamut, an in-game options menu, etc.
* To add features that were in Minecraft Alpha and the early Betas in 2011. (before and during Minecraft PE's development - this excludes hunger, for example, as it was added in Beta 1.8)
* To keep the source code layout similar to the original Minecraft PE (reconstructed from clues hidden within certain versions of the game, such as the 0.1.0 touch prototype/debug build)
* To port the game to more platforms, such as Windows (including older versions), Linux, WebGL, Android, and macOS. Currently we have ports for:
* Windows 10/8/7
* Windows XP/Vista
* Linux
* WebGL
* macOS (port by [BrentDaMage](https://github.com/BrentDaMage))
* Xbox 360 (incomplete; port by [BrentDaMage](https://github.com/BrentDaMage))
**We will not do the following:**
* Add features added in or after Java Edition Beta 1.8
* Backport features from versions newer than 0.9.0
* Add The Nether or The End (probably)
* Add Herobrine
2023-08-18 21:47:28 +03:00
* Add support for Minecraft Java or Minecraft Bedrock servers. (although LAN play with original MCPE clients will be supported for as long as possible)
* Modify the project structure
Note: The original mcpe01_canada.apk does not work on newer Android devices. A port of this likely will.
2023-07-30 22:22:02 +03:00
2023-08-03 11:58:32 +03:00
### This is the main modded version. For the original decompilation, see [ReMinecraftPE/mcped](https://github.com/ReMinecraftPE/mcped)
## License information
This project is licensed under the [BSD 1 clause license](LICENSE.md). However, it contains third party software with different but compatible licenses:
- [RakNet](https://github.com/facebookarchive/RakNet): [Licensed under the BSD 2 clause license](thirdparty/raknet/LICENSE)
- [zlib](https://github.com/madler/zlib): [View license](thirdparty/zlib/LICENSE)
2023-07-30 22:22:02 +03:00
## WANT TO HELP?
Want to help this project? [Here's a list of things left to do.](TODO.md)
2023-08-02 22:39:54 +03:00
## DISCLAIMER
This project **requires** you to have a copy of the `mcpe01_canada.apk` (sha256: `74b1d3b51a174c4dcaaa58d2bbdf7a4f4c9cfe5f2aeec4844427c2b8f1124343`), before you can build.
2023-07-30 22:22:02 +03:00
## Setup
2023-08-06 15:25:55 +03:00
Before trying to build, load the sound assets into the `sound_data/` folder in the root of the project
2023-07-31 13:53:17 +03:00
by **running the following command**:
2023-07-30 22:22:02 +03:00
* `tools/grabsounds.py /path/to/the/mcpe01_canada/lib/armeabi-v7a/libminecraftpe.so`.
2023-08-06 15:25:55 +03:00
After that, **prepare the assets folder** from mcpe01_canada.apk. You will need it for the platform specific build.
2023-08-18 21:47:28 +03:00
## Building
### Windows (VS 2022)
2023-08-06 15:25:55 +03:00
This is simple enough - just open the project and compile.
After building, place the `assets` folder you have prepared in the working directory of the output executable.
(if running from VS, it's in `game/`, otherwise, where your executable is)
2023-08-06 15:25:55 +03:00
### Windows (VS 2010)
This target is only around to target Windows XP (or potentially earlier) versions.
To compile, you will **need the Microsoft Platform SDK and the DirectX (June 2010) SDK**. After that, follow the same steps as
the VS2022 build. (open the minecraftcpp_vs2010.sln project instead of the minecraftcpp.sln project).
2023-08-18 21:47:28 +03:00
**Note!** If you are running from within VirtualBox, disable mouse integration (absolute mouse), or the camera won't work properly.
2023-08-06 15:25:55 +03:00
### WebAssembly
2023-08-18 21:47:28 +03:00
The game will use the assets from within the `game/` directory. So put your assets there if you want to build for wasm.
2023-08-06 15:25:55 +03:00
Then run the `build-wasm` script corresponding to your platform (`-.sh` on linux/WSL, `-.bat` on windows).
The output files will be in `./wasm/dist`, but you need to upload them to a web host (localhost works too) to use. (problem with Emscripten)
**NOTE:** If you are using nginx, make sure the `*.wasm` file is served as `application/wasm`, and not `application/octet-stream`. This can be done by
opening `/etc/nginx/mime.types` as root and adding `application/wasm wasm;` to the types block.
2023-07-31 13:53:17 +03:00
2023-07-30 22:22:02 +03:00
## Have seams when playing?
2023-08-18 21:47:28 +03:00
I've had texture seams when playing Minecraft Classic, ClassiCube and this recreation of Minecraft PE, on a fresh new laptop. If seams bother you, and you
are using an NVIDIA graphics card, go to the NVIDIA Control Panel, then in "Manage 3D Settings", change "Antialiasing - Mode" to "Application Controlled".
2023-07-30 22:22:02 +03:00
## Notes on assets
2023-08-18 21:47:28 +03:00
2023-07-30 22:22:02 +03:00
The terrain.png and related textures appear to have stayed the same between the E3 demo and the final release for Xperia PLAY. It appears to have been fetched before
Java Edition Beta 1.4's release. This can be seen because the cookie's texture is missing. (it was added in Java Edition Beta 1.4)
2023-08-18 21:47:28 +03:00
## Screenshots (from the decomp)
2023-07-30 22:22:02 +03:00
![Title screen](screenshots/title_screen.png)
![Generating world](screenshots/loading.png)
![In-game](screenshots/ingame.png)
![Inventory](screenshots/inventory.png)
![Pause menu](screenshots/pause_screen.png)
## Enhancements
2023-08-18 21:47:28 +03:00
All enhancements (and more) that are available in the decomp version are turned on by default, but only some of them can be disabled, and the GameMods.hpp file used
to control them is deprecated and will be removed. Check the decomp version's repository for a partial list of enhancements that were added to the game.