2019-10-15 23:22:58 -03:00
# GDBrowser
2019-12-15 21:11:35 -03:00
Uh... so I've never actually used GitHub before this. But I'll try to explain everything going on here.
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
Sorry for my messy code. It's why I was skeptical about making this open source, but you know what, the code runs fine in the end.
2019-12-22 00:16:18 -03:00
## Using this for a GDPS?
I mean, sure. Why not.
Just make sure to give credit, obviously. Via the bottom of the homepage, the credits button, or maybe even both if you're feeling extra nice.
2021-01-04 12:21:58 -03:00
Obviously, GDBrowser isn't perfect when it comes to GD private servers, since both requests and responses might be a bit different. Or a LOT, as I learned. (seriously what's with that?)
2019-12-22 00:16:18 -03:00
2020-11-07 21:20:44 -03:00
You can also check out `settings.js` to tweak some additional settings (mainly GDPS related) such as whether to cache things or if timestamps should end with "ago"
2019-12-22 00:16:18 -03:00
# Folders
GDBrowser has a lot of folders. I like to keep things neat.
Most folders contain exactly what you'd expect, but here's some in-depth info in case you're in the dark.
## API
2019-10-16 00:29:47 -03:00
This is where all the backend stuff happens! Yipee!
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
They're all fairly similar. Fetch something from boomlings.com, parse the response, and serve it in a crisp and non-intimidating JSON. This is probably what you came for.
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
The odd one out is icon.js, which is for generating GD icons. The code here is horrendous, so apologies in advance. Improvements to it (especially UFO and robot generation) would be greatly appreciated! (and i will love you forever)
## Assets
Assets! Assets everywhere!
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
All the GD stuff was ripped straight from the GD spritesheets via [Absolute's texture splitter hack ](https://youtu.be/pYQgIyNhow8 ). If you want a nice categorized version, [I've done all the dirty work for you. ](https://www.mediafire.com/file/4d99bw1zhwcl507/textures.zip/file )
2019-10-16 00:36:11 -03:00
2021-01-04 12:21:58 -03:00
I'd explain what's in all the subfolders but it's pretty obvious. I tried my best to organize everything nicely.
2019-10-16 00:29:47 -03:00
2019-12-15 21:11:35 -03:00
## Classes
2021-01-04 12:21:58 -03:00
What's a class you ask? Good question.
2019-12-15 21:11:35 -03:00
I guess the best way to put it is uh... super fancy functions???
Level.js parses the server's disgusting response and sends back a nice object with all the level info
2021-01-04 12:21:58 -03:00
XOR.js encrypts/decrypts stuff like GD passwords
2019-12-15 21:11:35 -03:00
2019-10-16 00:29:47 -03:00
## HTML
The HTML files! Nothing too fancy, since it can all be seen directly from gdbrowser. Note that profile.html and level.html have [[VARIABLES]] (name, id, etc) replaced by the server when they're sent.
2019-12-15 21:11:35 -03:00
comingsoon.html was used while the site was still in development, I just left it in there as a nice little throwback
2019-10-16 00:29:47 -03:00
## Icons
It's GJ_Gamesheet02 but split into a much more intimidating cluster of a million files. These icons are put together and colored in the monstrosity that is icon.js
2019-10-16 00:36:11 -03:00
2019-12-15 21:11:35 -03:00
parsePlist.js reads GJ_GameSheet02-uhd.plist and magically transforms it into gameSheet.json. Props to 101arrowz for making this
2019-10-16 00:36:11 -03:00
2019-12-15 21:11:35 -03:00
forms.json is a list of the different icon forms, their ingame filenames, and their index in responses from the GD servers
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
## Misc
Inevitable misc folder
**For level analysis**
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
blocks.json - The object IDs in the different 'families' of blocks
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
colorProperties.json - Color channel cheatsheet
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
initialProperties.json - Level settings cheatsheet
2019-10-16 00:36:11 -03:00
2021-01-04 12:21:58 -03:00
objectProperties.json - Object property cheatsheet. Low budget version of [AlFas' one ](https://github.com/AlFasGD/GDAPI/blob/master/GDAPI/GDAPI/Enumerations/GeometryDash/ObjectProperty.cs )
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
objects.json - IDs for portals, orbs, triggers, and misc stuff
**Not for level analysis**
2019-10-16 00:36:11 -03:00
2021-01-04 12:21:58 -03:00
colors.json - List of icon colors in RGB format
2019-12-15 21:11:35 -03:00
credits.json - Credits! (shown on the homepage)
2021-01-04 12:21:58 -03:00
dragscroll.js - Used on several pages for drag scrolling
2019-10-16 00:29:47 -03:00
level.json - An array of the official GD tracks, and also difficulty face stuff for level searching
2019-10-16 00:36:11 -03:00
2021-01-04 12:21:58 -03:00
sampleIcons.json - A pool of icons, one of which will randomly appear when visiting the icon kit. Syntax is [Name, ID, Col1, Col2, Glow],
2019-12-15 21:11:35 -03:00
secretStuff.json - GJP goes here, needed for level leaderboards. Not included in the repo for obvious reasons
2019-10-16 00:36:11 -03:00
2020-11-07 21:20:44 -03:00
settings.js - Tweak small settings here, mainly for local use or GDPS'es
2021-01-04 12:21:58 -03:00
sizecheck.js - Excecuted on most pages. Used for the 'page isn't wide enough' message, back button, and a few other things
2019-10-16 00:36:11 -03:00
2019-10-16 00:29:47 -03:00
---
2021-01-04 12:21:58 -03:00
happy gdbrowsing and god bless.