Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/libgdx/gdx-controllers
A libGDX cross platform game controllers extension
https://github.com/libgdx/gdx-controllers
android gamecontroller-framework gamepad gamepad-library ios java libgdx linux macosx windows
Last synced: 3 days ago
JSON representation
A libGDX cross platform game controllers extension
- Host: GitHub
- URL: https://github.com/libgdx/gdx-controllers
- Owner: libgdx
- License: apache-2.0
- Created: 2020-09-07T15:10:39.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-13T10:11:53.000Z (about 1 year ago)
- Last Synced: 2025-01-09T12:16:29.937Z (10 days ago)
- Topics: android, gamecontroller-framework, gamepad, gamepad-library, ios, java, libgdx, linux, macosx, windows
- Language: Java
- Homepage:
- Size: 1.14 MB
- Stars: 73
- Watchers: 16
- Forks: 14
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-libgdx - gdx-controllers - Adds support to gamepads and joysticks. (Resources / Controllers)
README
# 🎮️ Game Controller Extension for libGDX, Version 2
Use game controllers with ease in your libGDX games.
[📖️ Documentation](https://github.com/libgdx/gdx-controllers/wiki) - [🎁️ Feature overview](https://github.com/libgdx/gdx-controllers/wiki/Features) - [Compatibility](https://github.com/libgdx/gdx-controllers/wiki/Compatibility)
[🚀️ Migration guide from v1](https://github.com/libgdx/gdx-controllers/wiki/Migrate-from-v1)
## 💾️ Installation
The recommended way to use gdx-controllers is via dependency management with Gradle or Maven. Artifacts are available in
[Snapshot Repository](https://oss.sonatype.org/content/repositories/snapshots/com/badlogicgames/gdx-controllers/) and Maven Central.[![Sonatype Nexus (Releases)](https://img.shields.io/nexus/r/com.badlogicgames.gdx-controllers/gdx-controllers-core?nexusVersion=2&server=https%3A%2F%2Foss.sonatype.org&label=release)](https://search.maven.org/artifact/com.badlogicgames.gdx-controllers/gdx-controllers-core)
[![Sonatype Nexus (Snapshots)](https://img.shields.io/nexus/s/com.badlogicgames.gdx-controllers/gdx-controllers-core?server=https%3A%2F%2Foss.sonatype.org&label=snapshot)](https://oss.sonatype.org/#nexus-search;gav~com.badlogicgames.gdx-controllers~gdx-controllers-core)*project-root/build.gradle:*
ext {
gdxControllersVersion = '2.0.1' // see badges above for latest versions
}Add the following dependencies:
#### core:
```
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-core:$gdxControllersVersion"
```
#### desktop:
```
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-desktop:$gdxControllersVersion"
```This will automatically fetch the [underlying SDL-based natives and Java wrappers](https://github.com/libgdx/Jamepad).
If you want to use a newer version, add the dependency yourself:implementation("com.badlogicgames.jamepad:jamepad:$jamepadVersion") {
exclude group: 'com.badlogicgames.gdx', module: 'gdx-jnigen-loader'
}Make sure to check the [compatibility doc](https://github.com/libgdx/gdx-controllers/wiki/Compatibility) when doing so.
#### android:
```
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-android:$gdxControllersVersion"
```
Proguard setting:
```
-keep class com.badlogic.gdx.controllers.android.AndroidControllers { *; }
```#### ios:
```
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-ios:$gdxControllersVersion"
```
`robovml.xml` needs the following lines added to `forceLinkClasses` and `frameworks`:
```
com.badlogic.gdx.controllers.IosControllerManager
....
GameController
```
If you forget to explicitly link the framework, no game controller will show up.#### html:
```
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-core:$gdxControllersVersion:sources"
implementation "com.badlogicgames.gdx-controllers:gdx-controllers-gwt:$gdxControllersVersion:sources"
```
You also need to add the following file to your GdxDefinition.gwt.xml in your html project:
``````
### Building from source
To build from source, clone or download this repository, then open it in Android Studio. Perform the following command to compile and upload the library in your local repository:gradlew clean uploadArchives -PLOCAL=true
See `build.gradle` file for current version to use in your dependencies.## 🤝️ News & Community
You can get help on the [libgdx discord](https://discord.gg/6pgDK9F).
## License
The project is licensed under the Apache 2 License, meaning you can use it free of charge, without strings attached in commercial and non-commercial projects. We love to get (non-mandatory) credit in case you release a game or app using this project!