|
@@ -313,6 +313,7 @@ struct engine {
|
|
|
|
|
|
ASensorManager* sensorManager;
|
|
ASensorManager* sensorManager;
|
|
const ASensor* accelerometerSensor;
|
|
const ASensor* accelerometerSensor;
|
|
|
|
+ const ASensor* magnetometerSensor;
|
|
ASensorEventQueue* sensorEventQueue;
|
|
ASensorEventQueue* sensorEventQueue;
|
|
|
|
|
|
bool display_active;
|
|
bool display_active;
|
|
@@ -735,16 +736,29 @@ static void engine_handle_cmd(struct android_app* app, int32_t cmd) {
|
|
ASensorEventQueue_setEventRate(engine->sensorEventQueue,
|
|
ASensorEventQueue_setEventRate(engine->sensorEventQueue,
|
|
engine->accelerometerSensor, (1000L/60)*1000);
|
|
engine->accelerometerSensor, (1000L/60)*1000);
|
|
|
|
|
|
|
|
+ }
|
|
|
|
+ // Also start monitoring the magnetometer.
|
|
|
|
+ if (engine->magnetometerSensor != NULL) {
|
|
|
|
+ ASensorEventQueue_enableSensor(engine->sensorEventQueue,
|
|
|
|
+ engine->magnetometerSensor);
|
|
|
|
+ // We'd like to get 60 events per second (in us).
|
|
|
|
+ ASensorEventQueue_setEventRate(engine->sensorEventQueue,
|
|
|
|
+ engine->magnetometerSensor, (1000L/60)*1000);
|
|
|
|
+
|
|
}
|
|
}
|
|
engine->animating = 1;
|
|
engine->animating = 1;
|
|
break;
|
|
break;
|
|
case APP_CMD_LOST_FOCUS:
|
|
case APP_CMD_LOST_FOCUS:
|
|
- // When our app loses focus, we stop monitoring the accelerometer.
|
|
|
|
|
|
+ // When our app loses focus, we stop monitoring the sensors.
|
|
// This is to avoid consuming battery while not being used.
|
|
// This is to avoid consuming battery while not being used.
|
|
if (engine->accelerometerSensor != NULL) {
|
|
if (engine->accelerometerSensor != NULL) {
|
|
ASensorEventQueue_disableSensor(engine->sensorEventQueue,
|
|
ASensorEventQueue_disableSensor(engine->sensorEventQueue,
|
|
engine->accelerometerSensor);
|
|
engine->accelerometerSensor);
|
|
}
|
|
}
|
|
|
|
+ if (engine->magnetometerSensor != NULL) {
|
|
|
|
+ ASensorEventQueue_disableSensor(engine->sensorEventQueue,
|
|
|
|
+ engine->magnetometerSensor);
|
|
|
|
+ }
|
|
// Also stop animating.
|
|
// Also stop animating.
|
|
engine->animating = 0;
|
|
engine->animating = 0;
|
|
engine_draw_frame(engine);
|
|
engine_draw_frame(engine);
|
|
@@ -768,10 +782,12 @@ void android_main(struct android_app* state) {
|
|
|
|
|
|
FileAccessAndroid::asset_manager=state->activity->assetManager;
|
|
FileAccessAndroid::asset_manager=state->activity->assetManager;
|
|
|
|
|
|
- // Prepare to monitor accelerometer
|
|
|
|
|
|
+ // Prepare to monitor sensors
|
|
engine.sensorManager = ASensorManager_getInstance();
|
|
engine.sensorManager = ASensorManager_getInstance();
|
|
engine.accelerometerSensor = ASensorManager_getDefaultSensor(engine.sensorManager,
|
|
engine.accelerometerSensor = ASensorManager_getDefaultSensor(engine.sensorManager,
|
|
- ASENSOR_TYPE_ACCELEROMETER);
|
|
|
|
|
|
+ ASENSOR_TYPE_ACCELEROMETER);
|
|
|
|
+ engine.magnetometerSensor = ASensorManager_getDefaultSensor(engine.sensorManager,
|
|
|
|
+ ASENSOR_TYPE_MAGNETIC_FIELD);
|
|
engine.sensorEventQueue = ASensorManager_createEventQueue(engine.sensorManager,
|
|
engine.sensorEventQueue = ASensorManager_createEventQueue(engine.sensorManager,
|
|
state->looper, LOOPER_ID_USER, NULL, NULL);
|
|
state->looper, LOOPER_ID_USER, NULL, NULL);
|
|
|
|
|
|
@@ -812,16 +828,21 @@ void android_main(struct android_app* state) {
|
|
// If a sensor has data, process it now.
|
|
// If a sensor has data, process it now.
|
|
// LOGI("events\n");
|
|
// LOGI("events\n");
|
|
if (ident == LOOPER_ID_USER) {
|
|
if (ident == LOOPER_ID_USER) {
|
|
- if (engine.accelerometerSensor != NULL) {
|
|
|
|
|
|
+ if (engine.accelerometerSensor != NULL || engine.magnetometerSensor != NULL) {
|
|
ASensorEvent event;
|
|
ASensorEvent event;
|
|
while (ASensorEventQueue_getEvents(engine.sensorEventQueue,
|
|
while (ASensorEventQueue_getEvents(engine.sensorEventQueue,
|
|
&event, 1) > 0) {
|
|
&event, 1) > 0) {
|
|
|
|
|
|
|
|
|
|
if (engine.os) {
|
|
if (engine.os) {
|
|
|
|
+ if (event.acceleration != NULL) {
|
|
engine.os->process_accelerometer(Vector3(event.acceleration.x, event.acceleration.y,
|
|
engine.os->process_accelerometer(Vector3(event.acceleration.x, event.acceleration.y,
|
|
event.acceleration.z));
|
|
event.acceleration.z));
|
|
-
|
|
|
|
|
|
+ }
|
|
|
|
+ if (event.magnetic != NULL) {
|
|
|
|
+ engine.os->process_magnetometer(Vector3(event.magnetic.x, event.magnetic.y,
|
|
|
|
+ event.magnetic.z));
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
}
|