Only rotate Android sensor values for sensors that need them rotated
This commit is contained in:
parent
1cbf3947d6
commit
6e38fc4b80
@ -727,45 +727,78 @@ public class Godot extends Fragment implements SensorEventListener, IDownloaderC
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public float[] getRotatedValues(float values[]) {
|
||||||
public void onSensorChanged(SensorEvent event) {
|
if (values == null || values.length != 3) {
|
||||||
|
return values;
|
||||||
|
}
|
||||||
|
|
||||||
Display display =
|
Display display =
|
||||||
((WindowManager)getActivity().getSystemService(WINDOW_SERVICE)).getDefaultDisplay();
|
((WindowManager)getActivity().getSystemService(WINDOW_SERVICE)).getDefaultDisplay();
|
||||||
int displayRotation = display.getRotation();
|
int displayRotation = display.getRotation();
|
||||||
|
|
||||||
float[] adjustedValues = new float[3];
|
float[] rotatedValues = new float[3];
|
||||||
final int[][] axisSwap = {
|
switch (displayRotation) {
|
||||||
{ 1, -1, 0, 1 }, // ROTATION_0
|
case Surface.ROTATION_0:
|
||||||
{ -1, -1, 1, 0 }, // ROTATION_90
|
rotatedValues[0] = values[0];
|
||||||
{ -1, 1, 0, 1 }, // ROTATION_180
|
rotatedValues[1] = values[1];
|
||||||
{ 1, 1, 1, 0 }
|
rotatedValues[2] = values[2];
|
||||||
}; // ROTATION_270
|
break;
|
||||||
|
case Surface.ROTATION_90:
|
||||||
|
rotatedValues[0] = -values[1];
|
||||||
|
rotatedValues[1] = values[0];
|
||||||
|
rotatedValues[2] = values[2];
|
||||||
|
break;
|
||||||
|
case Surface.ROTATION_180:
|
||||||
|
rotatedValues[0] = -values[0];
|
||||||
|
rotatedValues[1] = -values[1];
|
||||||
|
rotatedValues[2] = values[2];
|
||||||
|
break;
|
||||||
|
case Surface.ROTATION_270:
|
||||||
|
rotatedValues[0] = values[1];
|
||||||
|
rotatedValues[1] = -values[0];
|
||||||
|
rotatedValues[2] = values[2];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
final int[] as = axisSwap[displayRotation];
|
return rotatedValues;
|
||||||
adjustedValues[0] = (float)as[0] * event.values[as[2]];
|
}
|
||||||
adjustedValues[1] = (float)as[1] * event.values[as[3]];
|
|
||||||
adjustedValues[2] = event.values[2];
|
|
||||||
|
|
||||||
final float x = adjustedValues[0];
|
@Override
|
||||||
final float y = adjustedValues[1];
|
public void onSensorChanged(SensorEvent event) {
|
||||||
final float z = adjustedValues[2];
|
if (mRenderView == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
final int typeOfSensor = event.sensor.getType();
|
final int typeOfSensor = event.sensor.getType();
|
||||||
if (mRenderView != null) {
|
switch (typeOfSensor) {
|
||||||
|
case Sensor.TYPE_ACCELEROMETER: {
|
||||||
|
float[] rotatedValues = getRotatedValues(event.values);
|
||||||
mRenderView.queueOnRenderThread(() -> {
|
mRenderView.queueOnRenderThread(() -> {
|
||||||
if (typeOfSensor == Sensor.TYPE_ACCELEROMETER) {
|
GodotLib.accelerometer(-rotatedValues[0], -rotatedValues[1], -rotatedValues[2]);
|
||||||
GodotLib.accelerometer(-x, y, -z);
|
|
||||||
}
|
|
||||||
if (typeOfSensor == Sensor.TYPE_GRAVITY) {
|
|
||||||
GodotLib.gravity(-x, y, -z);
|
|
||||||
}
|
|
||||||
if (typeOfSensor == Sensor.TYPE_MAGNETIC_FIELD) {
|
|
||||||
GodotLib.magnetometer(-x, y, -z);
|
|
||||||
}
|
|
||||||
if (typeOfSensor == Sensor.TYPE_GYROSCOPE) {
|
|
||||||
GodotLib.gyroscope(x, -y, z);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Sensor.TYPE_GRAVITY: {
|
||||||
|
float[] rotatedValues = getRotatedValues(event.values);
|
||||||
|
mRenderView.queueOnRenderThread(() -> {
|
||||||
|
GodotLib.gravity(-rotatedValues[0], -rotatedValues[1], -rotatedValues[2]);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Sensor.TYPE_MAGNETIC_FIELD: {
|
||||||
|
float[] rotatedValues = getRotatedValues(event.values);
|
||||||
|
mRenderView.queueOnRenderThread(() -> {
|
||||||
|
GodotLib.magnetometer(-rotatedValues[0], -rotatedValues[1], -rotatedValues[2]);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case Sensor.TYPE_GYROSCOPE: {
|
||||||
|
float[] rotatedValues = getRotatedValues(event.values);
|
||||||
|
mRenderView.queueOnRenderThread(() -> {
|
||||||
|
GodotLib.gyroscope(rotatedValues[0], rotatedValues[1], rotatedValues[2]);
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user