ボタンのクリックで Android の加速度計の値を保存するためのサンプル プロジェクトを試しています。機能しており、値を取得しています。ボタンのクリックから始まり、ボタンのリリースで終了する加速度計の読み取り値を保存したいのですが、OnTouchListenerを使用してみましたが、私は加速度計を制御できません. 以前にこれを試した人はいます.
layout.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
if(event.getAction() == MotionEvent.ACTION_DOWN) {
sensorMgr = (SensorManager) getSystemService(SENSOR_SERVICE);
mAccelerometer = sensorMgr.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
sensorMgr.registerListener((SensorEventListener) getApplicationContext(), mAccelerometer,SensorManager.SENSOR_DELAY_FASTEST);
} else if (event.getAction() == MotionEvent.ACTION_UP) {
sensorMgr.unregisterListener(this);
}
return true;
}
});
これは、加速度計を制御するために使用しているコードですが、私のアプリは強制終了し、logcat でエラーが発生します。
03-27 12:36:29.570: I/TextToSpeech.java(28968): initTts() successfully bound to service
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 1
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 2
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 3
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 4
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 5
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 6
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 7
03-27 12:36:29.578: D/SensorManager(28968): ====>>>>>Num Sensor: 0
03-27 12:36:30.570: W/dalvikvm(28968): threadid=1: thread exiting with uncaught exception (group=0x40015578)
03-27 12:36:30.578: E/AndroidRuntime(28968): FATAL EXCEPTION: main
03-27 12:36:30.578: E/AndroidRuntime(28968): java.lang.ClassCastException: android.app.Application
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.example.androidphonemotion.MainActivity$1.onTouch(MainActivity.java:59)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.View.dispatchTouchEvent(View.java:3934)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:903)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:869)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:869)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:869)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:869)
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1733)
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1151)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.app.Activity.dispatchTouchEvent(Activity.java:2096)
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1717)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewRoot.deliverPointerEvent(ViewRoot.java:2215)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.view.ViewRoot.handleMessage(ViewRoot.java:1886)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.os.Handler.dispatchMessage(Handler.java:99)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.os.Looper.loop(Looper.java:130)
03-27 12:36:30.578: E/AndroidRuntime(28968): at android.app.ActivityThread.main(ActivityThread.java:3689)
03-27 12:36:30.578: E/AndroidRuntime(28968): at java.lang.reflect.Method.invokeNative(Native Method)
03-27 12:36:30.578: E/AndroidRuntime(28968): at java.lang.reflect.Method.invoke(Method.java:507)
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:842)
03-27 12:36:30.578: E/AndroidRuntime(28968): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
03-27 12:36:30.578: E/AndroidRuntime(28968): at dalvik.system.NativeStart.main(Native Method)