Merge pull request #55183 from madmiraal/fix-41421

Only rotate Android sensor values for sensors that need them rotated
This commit is contained in:
Rémi Verschelde 2021-12-15 20:25:59 +01:00 committed by GitHub
commit e311389580
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -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;
}
} }
} }