mirror of
https://github.com/maddievision/Celestial.git
synced 2024-08-14 23:55:37 +00:00
Add README
This commit is contained in:
parent
fa50319b66
commit
b7a8924535
5 changed files with 34 additions and 1 deletions
35
README.md
35
README.md
|
@ -1 +1,34 @@
|
|||
Celeste Reverse Engineering tools in Ruby
|
||||
# Celeste Reverse Engineering tools in Ruby
|
||||
|
||||
In the interest of sharing (which I wish I had done more of in my early ROM hacking days), I'm putting up my code/findings here in case anyone may find it useful. I might clean it up later, make things easier to use, more tools, documentation, but I don't have any real goals here.
|
||||
|
||||
There is already a whole Celeste modding community out there who have already done a lot and have formal tools. I just love the challenge of seeing what I can do from scratch!
|
||||
|
||||
**Disclaimer**: This was done very quickly (most of a Saturday) and without reference resources so it is very, very rough.
|
||||
|
||||
## Map/level viewer demo
|
||||
|
||||
Learning through visualizations is fun. Lately, I've been playing around with [p5.js](https://p5js.org/) as a quick and dirty web drawing tool. It made sense to try putting these two things together so I made a quick level viewer. [You can see it in action here](https://codepen.io/deltabouche/pen/WJPbaQ).
|
||||
|
||||
I only included the first two maps in the interest of not giving away the entire game's map data away. However, if the devs would rather I not put those two maps up I will happily take down the Codepen demo until I add a way to load .bin files locally. The viewer code is in this repository as well.
|
||||
|
||||
Each map starts off with the Overview (like what you see in debug mode), which shows all the levels stitched together. Arrow keys move around the map, Q/A control zoom.
|
||||
|
||||
![Screenshot of Old Site Map overview](screenshot/overview1.png)
|
||||
|
||||
![Screenshot of zoomed out Mirror Temple overview](screenshot/overview2.png)
|
||||
|
||||
If you right click on a level it takes you to the level view, where you will also see the various entities in that level. It's neat to put a name on the various things in the game! Arrow keys also move around in this view. You can right click adjoining areas to enter them. Esc will take you back to the overview.
|
||||
|
||||
![Screenshot of Level view for one of the Badeline chase levels in Old Site](screenshot/levelview1.png)
|
||||
|
||||
![Screenshot of Level view for one of the Celestial Resort B-side levels](screenshot/levelview2.png)
|
||||
|
||||
For this, I took the levels and used `map2xml.rb` to convert them into JSON for easier JS manipulation and wrote a viewer in p5.js. Here's an [example](http://deltabouche.com/celeste/json/0-Intro.json) of what one of these looks like, which again might get taken down if requested.
|
||||
|
||||
# Tools used
|
||||
|
||||
* Turning on debug mode on Celeste and poking around. (Done by editing your save file and enabling the flag)
|
||||
* [010 Hex Editor](https://www.sweetscape.com/010editor/) for poking in the .bin
|
||||
* [ILSpy .NET Decompiler Visual Code extension](https://marketplace.visualstudio.com/items?itemName=icsharpcode.ilspy-vscode) - when I realized this was a kind of tree structure I started digging into code. This was most useful for looking at `BinaryPacker` for the map files, and in general getting a feel for how things are structured. `AreaData` is a good birds eye view of all map data.
|
||||
* [Codepen](https://codepen.io/) for quick JS sketches.
|
||||
|
|
BIN
screenshot/levelview1.png
Normal file
BIN
screenshot/levelview1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 280 KiB |
BIN
screenshot/levelview2.png
Normal file
BIN
screenshot/levelview2.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 360 KiB |
BIN
screenshot/overview1.png
Normal file
BIN
screenshot/overview1.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 223 KiB |
BIN
screenshot/overview2.png
Normal file
BIN
screenshot/overview2.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 273 KiB |
Loading…
Reference in a new issue