Android Accelerometer Sensor

package zhangphil.sensor;

import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

public class MainActivity extends AppCompatActivity {
    private SensorManager mSensorManager;
    private MySensorEventListener mSensorEventListener;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        startSensor();
    }

    /**
     * 启动传感器,监测设备的运动位移。
     */
    private void startSensor() {
        mSensorManager = (SensorManager) this.getSystemService(Context.SENSOR_SERVICE);
        if (mSensorManager == null) {
            throw new UnsupportedOperationException();
        }

        Sensor mSensor = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        if (mSensor == null) {
            throw new UnsupportedOperationException("设备不支持");
        }

        //加速度传感器
        mSensorEventListener = new MySensorEventListener();

        boolean isRegister = mSensorManager.registerListener(mSensorEventListener, mSensor, SensorManager.SENSOR_DELAY_NORMAL);
        if (!isRegister) {
            throw new UnsupportedOperationException("设备不支持");
        }
    }

    private class MySensorEventListener implements SensorEventListener {
        private float x_old = 0, y_old = 0, z_old = 0;
        private float x_new = 0, y_new = 0, z_new = 0;
        private float delta_x = 0, delta_y = 0, delta_z = 0;
        private double delta = 0;

        @Override
        public void onSensorChanged(SensorEvent sensorEvent) {
            x_new = sensorEvent.values[0];    //x坐标轴
            y_new = sensorEvent.values[1];    //y坐标轴
            z_new = sensorEvent.values[2];    //z坐标轴

            delta_x = x_new - x_old;
            delta_y = y_new - y_old;
            delta_z = z_new - z_old;

            //此处建立不严格的数学模型,计算运动量,从而得出位移的值。
            delta = Math.sqrt(delta_x * delta_x + delta_y * delta_y + delta_z * delta_z);
            Log.d("设备运动位移", delta + "");

            x_old = x_new;
            y_old = y_new;
            z_old = z_new;
        }

        @Override
        public void onAccuracyChanged(Sensor sensor, int i) {

        }
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        mSensorManager.unregisterListener(mSensorEventListener);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值