Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Alex1304/jdash
Geometry Dash API for Java developers
https://github.com/Alex1304/jdash
Last synced: 3 months ago
JSON representation
Geometry Dash API for Java developers
- Host: GitHub
- URL: https://github.com/Alex1304/jdash
- Owner: Alex1304
- License: mit
- Created: 2018-04-05T19:30:24.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-04-23T22:59:44.000Z (9 months ago)
- Last Synced: 2024-04-24T12:07:38.633Z (9 months ago)
- Language: Java
- Size: 22.4 MB
- Stars: 19
- Watchers: 3
- Forks: 2
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-geometry-dash - jdash - GD API for Java developers (Libraries)
README
# JDash
![GitHub release (latest SemVer)](https://img.shields.io/github/v/release/Alex1304/jdash?sort=semver)
[![Maven Central](https://img.shields.io/maven-central/v/com.alex1304.jdash/jdash.svg?label=Maven%20Central)](https://central.sonatype.com/namespace/com.alex1304.jdash)
![License](https://img.shields.io/github/license/Alex1304/jdash)
[![javadoc](https://javadoc.io/badge2/com.alex1304.jdash/jdash-client/javadoc.svg)](https://javadoc.io/doc/com.alex1304.jdash/jdash-client)A reactive Geometry Dash API wrapper for Java.
## Overview
JDash is a multi-module library **requiring [JDK 17](https://adoptium.net) or above since version 5.0**. There are currently 4 modules.
### JDash Client module
Provides a high-level client to request data from Geometry Dash servers. It is powered by [Project Reactor](https://projectreactor.io) which allows to make requests in an efficient and non-blocking manner with backpressure handling (requests are queued internally and processed when resources are available, allowing requests to fail-fast in case the queue is full).
```java
GDClient client = GDClient.create();// Block until request completes
GDLevel level = client.findLevelById(10565740).block();
System.out.println(level);// But we can also choose to make it asychronous and non-blocking
client.getUserProfile(98006).subscribe(System.out::println); // will not block
```Maven dependency:
```xml
com.alex1304.jdash
jdash-client
${version}```
### JDash Events module
Provides an event loop that can be subscribed to in order to periodically send requests with a `GDClient` and emit events when changes are detected on the server. It comes with default implementations that can detect when new levels or lists get rated, and when the Daily level or Weekly demon changes. You may also implement your own events with the `GDEventProducer` interface.
```java
GDClient client = GDClient.create();
GDEventLoop eventLoop = GDEventLoop.startWithDefaults(client);eventLoop.on(AwardedLevelAdd.class)
.subscribe(event -> System.out.println("New level rated: "
+ event.addedLevel().name()));eventLoop.on(DailyLevelChange.class)
.subscribe(event -> System.out.println("New Daily level: "
+ event.after().name()));
```Maven dependency:
```xml
com.alex1304.jdash
jdash-events
${version}```
### JDash Graphics module
Allows to generate player icons and level difficulty icons from game assets.
#### Example 1: Generate an arbitrary player icon
```java
IconRenderer renderer = IconRenderer.load(IconType.SPIDER, 15);
ColorSelection color = new ColorSelection(12, 9, OptionalInt.of(9));
BufferedImage output = renderer.render(color);
```![icon](website/docs/assets/spider-15.png)
#### Example 2: Generate the full icon set of a `GDUserProfile`
```java
GDClient client = GDClient.create();
GDUserProfile user = client.getUserProfile(98006).block();
IconSetFactory factory = IconSetFactory.forUser(user);
BufferedImage output = factory.createIconSet();
```![icon](website/docs/assets/iconSet.png)
#### Example 3: Generate an arbitrary difficulty icon
```java
BufferedImage image = DifficultyRenderer.create(DemonDifficulty.EASY)
.withMoons(10)
.withQualityRating(QualityRating.LEGENDARY)
.render();
```![icon](website/docs/assets/demon-easy-10-stars-legendary.png)
#### Example 4: Generate the difficulty icon of a `GDLevel`
```java
GDClient client = GDClient.create();
GDLevel level = client.findLevelById(10565740).block();
BufferedImage image = DifficultyRenderer.forLevel(level).render();
```
![icon](website/docs/assets/level.png)Maven dependency:
```xml
com.alex1304.jdash
jdash-graphics
${version}```
### JDash Common module
Contains utility classes and data types to encode the different entities of Geometry Dash (levels, users...) required by all other modules.
**If you are already using one of the other modules, you don't need to add this dependency as other modules transitively require it.**
```xml
com.alex1304.jdash
jdash-common
${version}```
## Documentation
The full documentation is available at: https://jdash.alex1304.com
Javadoc:
* For the common module: https://javadoc.io/doc/com.alex1304.jdash/jdash-common
* For the client module: https://javadoc.io/doc/com.alex1304.jdash/jdash-client
* For the events module: https://javadoc.io/doc/com.alex1304.jdash/jdash-events
* For the graphics module: https://javadoc.io/doc/com.alex1304.jdash/jdash-graphics## License
This project is licensed under the MIT licence.
## Contribute
Have a feature to suggest or a bug to report ? Issues and pull requests are more than welcome! Make sure to follow the template and share your ideas.
## Contact
E-mail: [email protected]
Discord: Alex1304#9704
Twitter: @gd_alex1304