Elite: Dangerous Star Map Android Client
A client library for the Elite: Dangerous Star Map APIs.
I've found several Mac, Windows, and iOS tools leveraging the EDSM APIs, but nothing geared specifically to our Android developer friends, myself included.
My hope is that this easy to use library will help innovate more tools available on our Android devices.
You can check out the other Elite: Dangerous tools I've created for Android at my github
Installation
- Library is available through
jcenter
andjitpack.io
.
For gradle projects using jcenter
repositories include the following in your build script:
dependencies {
implementation 'com.github.stpatrck:edsm:+'
}
For gradle projects using jitpack.io
repositories include the following in your build script:
dependencies {
implementation 'com.github.StPatrck:edsm-android:+'
}
Usage
- First, initialize the client class
EdsmClient.java
with your application context. It is highly recommended to do this when theApplication.onCreate()
method is invoked.
public class MyApplication extends Application {
public void onCreate() {
super.onCreate();
EdsmClient.init(MyApp.getInstance());
}
}
- If you are running in debug mode the
Server
should be set toTest
to avoid overloading the EDSM servers during development and testing. SinceEdsmClient
is a singleton, useEdsmClient.getInstance()
to get the current instance of the client in order to set the server.
public class MyApplication extends Application {
public void onCreate() {
super.onCreate();
EdsmClient.init(MyApp.getInstance());
// EdsmClient defaults to ServerTest, so explicitly set it to
// production when not running debug builds.
if (!BuildConfig.DEBUG)
EdsmClient.getInstance().setServer(Server.Production);
}
}
- Now is also a good time to configure logging...
public class MyApplication extends Application {
public void onCreate() {
super.onCreate();
EdsmClient.init(MyApp.getInstance());
// EdsmClient defaults to ServerTest, so explicitly set it to
// production when not running debug builds.
if (!BuildConfig.DEBUG)
EdsmClient.getInstance().setServer(Server.Production);
else
EdsmClient.getInstance().setLoggingEnabled(true);
}
}
- And that's all! You can now call any of the
EdsmClient
APIs.
Notes
A few notes on usage:
- Most importantly, I am not in any way affiliated with Frontier Games or any of the Elite: Dangerous developers. This is a pet project of an avid fan of the games.
- The client is still under heavy development so some features may contain bugs (like any other software) and have room for improvement. Please create issues and/or pull requests and I will address them as time permits.
Special Thanks
I would like to give a very special thank you to developers and contributors of the EDSM site. Without them this library and the vast wealth of data about the cosmos would not be available.