「シェイク」イベントでいくつかの機能を接続しようとしています。ここでチュートリアルを使用しました:
http://www.vogella.com/articles/AndroidSensor/article.html
http://developer.android.com/resources/samples/ApiDemos/src/com/example/android/apis/os/Sensors.html
OpenIntents のSensorSimulatorでテストしています。エミュレーターを SensorSimulator に接続できました。シミュレーターでデバイスを動かすと、エミュレーターの加速度計の読み取り値がシミュレーターの読み取り値と正確に一致します。
私のコードでは、次のようなログ ステートメントを追加しました。
public class ShakeEventListener implements SensorEventListener {
private void getAccelerometer(SensorEvent event) {
float[] values = event.values;
// Movement
float x = values[0];
float y = values[1];
float z = values[2];
float accelationSquareRoot = (x * x + y * y + z * z)
/ (SensorManager.GRAVITY_EARTH * SensorManager.GRAVITY_EARTH);
long actualTime = System.currentTimeMillis();
Log.i("onSensorChanged", "accelationSquareRoot: " + accelationSquareRoot);
if (accelationSquareRoot >= 2) //
{
if (actualTime - lastUpdate < 200) {
return;
}
lastUpdate = actualTime;
// Shake Detected
Log.i("onSensorChanged", "Shakie Shakie!");
}
}
public void onSensorChanged(SensorEvent se) {
Log.d("onSensorChanged", "X: " + se.values[SensorManager.DATA_X] +
" Y: " + se.values[SensorManager.DATA_Y] +
" Z: " + se.values[SensorManager.DATA_Z]);
if (se.sensor.getType() == Sensor.TYPE_ACCELEROMETER)
{
getAccelerometer(se);
}
}
}
シミュレーターでデバイスを移動しても、log cat の出力は変わらないようです。常にこれらの測定値が表示されます (読み取り値は毎分何度も更新され続けますが、常に同じです):
05-22 15:09:07.717: I/onSensorChanged(686): accelationSquareRoot: 1.0006835
05-22 15:09:08.518: D/onSensorChanged(686): X: 0.0 Y: 9.77622 Z: 0.813417
05-22 15:09:08.518: I/onSensorChanged(686): accelationSquareRoot: 1.0006835
APIDemos
サンプルを試してみましたsensors.java
が、同じ動作が登録されています。何が欠けている可能性がありますか?