-
Notifications
You must be signed in to change notification settings - Fork 0
Accelerometer
An accelerometer measures the acceleration of a device on three axes (at least on Android). From this acceleration one can derive the tilt or orientation of the device.
Acceleration is measured in meters per second per second (m/s²). If an axis is pointing straight towards the center of the earth, it's acceleration will be roughly -10 m/s². If it is pointing in the opposite direction, the acceleration will be 10 m/s².
The axes in an Android device are setup as follows:
Sadly, this configuration is different for tablets. Android devices have a notion called default orientation. For phones, portrait mode (as in the image above) is the default orientation. For tablets, landscape mode is the default orientation. A default landscape orientation device has it's axes rotated, so that the y-axis points up the smaller side of the device and the x-axis points to the right of the wider side.
Libgdx takes care of this and presents the accelerometer readings as shown in the image above, no matter the default orientation of the device (positive z-axis comes out of the screen, positive x-axis points to the right along the smaller side of the device, positive y-axis points upwards along the wider side of the device).
Different Android devices have different hardware configurations. Checking whether the device has an accelerometer can be done as follows:
boolean available = Gdx.input.isPeripheralAvailable(Peripheral.Accelerometer);
If your game needs to know the current orientation of the device, the following method can be used:
int orientation = Gdx.input.getOrientation();
This will return a value of 0, 90, 180 or 270, giving you the angular difference between the current orientation and the native orientation.
The native orientation is either portrait mode (as in the image above) or landscape mode (mostly for tablets). It can be queried as follows:
Orientation nativeOrientation = Gdx.input.getNativeOrientation();
This returns either Orientation.Landscape or Orientation.Portrait.
Accelerometer readings can only be accessed via polling in libgdx:
float accelX = Gdx.input.getAccelerometerX();
float accelY = Gdx.input.getAccelerometerY();
float accelZ = Gdx.input.getAccelerometerZ();
Platforms or devices that don't have accelerometer support will return zero.
See the Super Jumper demo game for a demonstration on the usage of the accelerometer.
If you want to use the orientation of your device for rendering, it might be beneficial to work with the rotation matrix. See [this link](http://developer.android.com/reference/android/hardware/SensorManager.html#getRotationMatrix(float[], float[], float[], float[])) for an explanation. You can plug the resulting matrix directly into your OpenGL rendering:
Matrix4 matrix = new Matrix4();
Gdx.input.getRotationMatrix(matrix.val);
// use the matrix, Luke
-
Developer's Guide
- Introduction
- Goals & Features
- Community & Support
- Contributing
- Games Built with Libgdx
- Prerequisites
- Gradle Project Setup, Running, Debugging and Packaging
- Project Setup, Running & Debugging
- Third Party Services
- Working from Source
- Using libgdx with other JVM languages
- The Application Framework
- A Simple Game
- File Handling
- Networking
- Preferences
- Input Handling
- Memory Management
- Audio
-
Graphics
- Configuration & Querying Graphics ??
- Fullscreen & VSync
- Continuous & Non-Continuous Rendering
- Clearing the Screen
- Take a Screenshot
- OpenGL ES Support * Configuration & Querying OpenGL ?? * Direct Access ?? * Utility Classes * Rendering Shapes * Textures & TextureRegions * Meshes * Shaders * Frame Buffer Objects
- 2D Graphics * SpriteBatch, TextureRegions, and Sprite * 2D Animation * Clipping, with the use of ScissorStack * Orthographic camera * Mapping Touch Coordinates ?? * Viewports * NinePatches * Bitmap Fonts * Distance field fonts * Using TextureAtlases * Pixmaps * Packing Atlases Offline * Packing Atlases at Runtime * 2D Particle Effects * Tile Maps * scene2d * scene2d.ui * Skin
- 3D Graphics * Quick Start * Models * Material and environment * 3D animations and skinning * Importing Blender models in LibGDX * Perspective Camera ?? * Picking ??
- Managing Your Assets
- Utilities
-
Math Utilities
- Interpolation
- Vectors, Matrices, Quaternions
- Circles, Planes, Rays, etc.
- Path interface & Splines
- Bounding Volumes ??
- Intersection & Overlap Testing ??
- Physics
- Tools
- Extensions
- Deploying your Application
- Building Libgdx ??
- Known Issues
- Articles
- Deprecated (May be outdated)