谈谈Android平台上的11个感应器

本文来自:安卓航班网(Android开发社区)

在Android 2.3中新增了3个感应器,对于Android平台的开发我们通过感应器可以发挥想象设计出一些很实用的软件。下面就一起看下目前API Level为9时一共11个感应器分辨是什么吧.

  1. ACCELEROMETER 加速,描述加速度的。
  2.GRAVITY 重力,这个在大家都知道。
  3.GYROSCOPE 陀螺仪,对于物体跌落检测更强大些,开发游戏少了它会有点遗憾的,API Level 9新增的类型。

  4. LIGHT 光线感应器,很多Android手机的屏幕亮度是根据这个感应器的数组自动调节的。
  5. LINEAR_ACCELERATION 线性加速器,API Level 9新增的。
  6. MAGNETIC_FIELD 磁极感应器。
  7. ORIENTATION 方向感应器。

  8. PRESSURE 压力感应器。  
  9. PROXIMITY 距离感应器,对于通话后关闭屏幕背光很有用。
  10. ROTATION_VECTOR 旋转向量,Android 2.3新增的,如果我们过去处理图像会发现这个还是很有用的,不过这里还是对游戏开发起到辅助。
  11. TEMPERATURE 温度感应器,可以获取手机的内部温度,不过和周边的有些差距,毕竟手机内部一般温度比较高。

   对于以上感应器Android123提醒开发者,除了特别描述API Level为9或2.3之外的,SDK在1.5即Level 3时就已经支持了,不过最终使用还要看手机硬件的支持,很多山寨机或小品牌的设备可能会在这些上面偷工减料,同时Android开发网提醒大家,感应器的 数据刷新比较快一般,考虑到电池功耗一般长时间使用CPU的占用率可能会提升,影响系统性能。

  列举手机上已经有的感应器,可以通过SensorManager类的List<Sensor>  getSensorList(int type)  获取,返回一个感应器类型的数组。这里在列举时type参数应该写TYPE_ALL.

一下代码有两个作用 一个是现实手机上的所有传感器

一个是在title上显示重力传感器的变化


Java代码

    package com.HelloSensor;   

import java.util.List;

import android.app.Activity;
import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.widget.TextView;

public class HelloSensor extends Activity {
Sensor sensor ;
private float x, y, z;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

//准备显示信息的UI组建
final TextView tx1 = (TextView) findViewById(R.id.TextView01);

//从系统服务中获得传感器管理器
SensorManager sm = (SensorManager) getSystemService(Context.SENSOR_SERVICE);

//从传感器管理器中获得全部的传感器列表
List<Sensor> allSensors = sm.getSensorList(Sensor.TYPE_ALL);

//显示有多少个传感器
tx1.setText("经检测该手机有" + allSensors.size() + "个传感器,他们分别是:\n");

//显示每个传感器的具体信息
for (Sensor s : allSensors) {

String tempString
= "\n" + " 设备名称:" + s.getName() + "\n" + " 设备版本:" + s.getVersion() + "\n" + " 供应商:"
+ s.getVendor() + "\n";

switch (s.getType()) {
case Sensor.TYPE_ACCELEROMETER:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 加速度传感器accelerometer" + tempString);
break;
case Sensor.TYPE_GRAVITY:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 重力传感器gravity API 9" + tempString);
break;
case Sensor.TYPE_GYROSCOPE:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 陀螺仪传感器gyroscope" + tempString);
break;
case Sensor.TYPE_LIGHT:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 环境光线传感器light" + tempString);
break;
case Sensor.TYPE_LINEAR_ACCELERATION:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 线性加速器LINEAR_ACCELERATION API 9" + tempString);
break;
case Sensor.TYPE_MAGNETIC_FIELD:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 电磁场传感器magnetic field" + tempString);
break;
case Sensor.TYPE_ORIENTATION:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 方向传感器orientation" + tempString);
break;
case Sensor.TYPE_PRESSURE:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 压力传感器pressure" + tempString);
break;
case Sensor.TYPE_PROXIMITY:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 距离传感器proximity" + tempString);
break;
case Sensor.TYPE_ROTATION_VECTOR:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 旋转向量ROTATION" + tempString);
break;
case Sensor.TYPE_TEMPERATURE:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 温度传感器temperature" + tempString);
break;
default:
tx1.setText(tx1.getText().toString()
+ s.getType() + " 未知传感器" + tempString);
break;
}
}

//在title上显示重力传感器的变化
sensor = sm.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
SensorEventListener lsn
= new SensorEventListener() {
public void onSensorChanged(SensorEvent e) {
x
= e.values[SensorManager.DATA_X];
y
= e.values[SensorManager.DATA_Y];
z
= e.values[SensorManager.DATA_Z];
setTitle(
"x=" + (int) x + "," + "y=" + (int) y + "," + "z="+ (int) z);
}

public void onAccuracyChanged(Sensor s, int accuracy) {
}
};
// 注册listener,第三个参数是检测的精确度
sm.registerListener(lsn, sensor, SensorManager.SENSOR_DELAY_GAME);

}
}

转载于:https://www.cnblogs.com/androidghost/archive/2011/08/01/apkway111.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值