Android传感器_悦动凸轮轴位置传感器故障

Android传感器_悦动凸轮轴位置传感器故障效果图:连接真机Milestone,编译并运行程序,显示结果如下: 结合程序我们做一些解释。      1)Android所有的传感器都归传感器管理器SensorManager管理,获取传感器管理器的方法很简单:      Stringservice_name=Context.SENSOR_SERVICE;      SensorM

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

效果图:

连接真机Milestone,编译并运行程序,显示结果如下:

Android手机传感器列表

  结合程序我们做一些解释。

       1)Android所有的传感器都归传感器管理器 SensorManager 管理,获取传感器管理器的方法很简单:

       String service_name = Context.SENSOR_SERVICE;

       SensorManager sensorManager = (SensorManager)getSystemService(service_name);

       2)现阶段Android常支持的传感器有8种,它们分别是:

传感器类型常量
内部整数值
中文名称
Sensor.TYPE_ACCELEROMETER
1
加速度传感器
Sensor.TYPE_MAGNETIC_FIELD
2
磁力传感器
Sensor.TYPE_ORIENTATION
3
方向传感器
Sensor.TYPE_GYROSCOPE
4
陀螺仪传感器
Sensor.TYPE_LIGHT
5
环境光照传感器
Sensor.TYPE_PRESSURE
6
压力传感器
Sensor.TYPE_TEMPERATURE
7
温度传感器
Sensor.TYPE_PROXIMITY
8 距离传感器

       3)从传感器管理器中获取其中某个或者某些传感器的方法有如下三种:

       第一种:获取某种传感器的默认传感器

       Sensor defaultGyroscope = sensorManager.getDefaultSensor(Sensor.TYPE_GYROSCOPE);

       第二种:获取某种传感器的列表

       List<Sensor> pressureSensors = sensorManager.getSensorList(Sensor.TYPE_PRESSURE);

       第三种:获取所有传感器的列表,我们这个例子就用的第三种

       List<Sensor> allSensors = sensorManager.getSensorList(Sensor.TYPE_ALL);

       4)对于某一个传感器,它的一些具体信息的获取方法可以见下表:

方法
描述
getMaximumRange()
最大取值范围
getName()
设备名称
getPower()
功率
getResolution()
精度
getType()
传感器类型
getVentor()
设备供应商
getVersion()
设备版本号


程序代码:

public class MainActivity extends ActionBarActivity {

	private TextView tx1;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		//准备显示信息的UI组建   
        tx1 = (TextView) findViewById(R.id.text);
        //从系统服务中获得传感器管理器   
        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_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_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_TEMPERATURE:   
	                        tx1.setText(tx1.getText().toString() + s.getType() + " 温度传感器temperature" + tempString);   
	                        break;   
	                default:   
	                        tx1.setText(tx1.getText().toString() + s.getType() + " 未知传感器" + tempString);   
	                        break;   
                }   
        }  
	}

}


布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.example.sensordemo.MainActivity" >

    <TextView
        android:id="@+id/text" 
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="传感器"
        />

</LinearLayout>


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/188314.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • PyTorch安装最全流程

    PyTorch安装最全流程本文介绍基于Anaconda环境以及PyCharm软件结合,安装PyTorch深度学习框架。1.Anaconda安装下载链接:https://www.anaconda.com/1.1点击Next1.2点击同意1.3点击Next1.4选择目标文件夹,点击下一步1.5将Anaconda加入到系统变量安装成功后,在CMD中检查Anaconda时候加入到环境变量中。1.6单击启动AnacondaPrompt创建虚拟“房间”通过conda创建一个名为:pytorch.

  • docker启动mysql失败(闪退)原因

    docker启动mysql失败(闪退)原因创建好mysql之后容器之后可以连接后来修改了配置发现mysql启动不了dockerps-a查看发现mysql的状态一直是EXISTdockerstartmysql能成功启动(docker返回mysql)但是再查看dockerps发现还是没有启动起来大概可以知道就是docker启动之后又迅速关闭想起Docker容器后台运行,就必须有一个前台进程。否则就会自动关闭,大概推测是docker里的mysql没又起起来。想起刚刚修改了配置,可能是配置错了导致的。一看发现粘贴配置的时候格

  • BZOJ4872:[SHOI2017]分手是祝愿——题解

    BZOJ4872:[SHOI2017]分手是祝愿——题解

  • HttpClient与CloseableHttpClient

    前言起因是最近做的一个历史遗留项目,需要加些新需求,在本机进行压测时,发现在并发600的状态下跑一段时间后,就会开始偶现500的错误。可能是老项目用的人少(B2B的项目),实际部署后以前也没有人反馈过这个问题,大致跟踪了下日志,发现是系统在调用第三方服务出现异常,这种情况原因很多,需要仔细看异常堆栈打出来的Exception信息,将问题范围缩小并求证,这次抛出的是java.net.Socket…

  • stat 函数详解

    stat 函数详解stat函数作用:获取文件信息头文件:include<sys/types.h>#include<sys/stat.h>#include<unistd.h>​函数原型:intstat(constchar*path,structstat*buf)​返回值:成功返回0,失败返回-1;​参数:文件路径(名),structstat…

    2022年10月24日
  • 电商网站的商品详情页系统架构

    电商网站的商品详情页系统架构电商网站的商品详情页系统架构1小型电商架构:小型电商网站的页面展示采用页面全量静态化的思想。数据库中存放了所有的商品信息,页面静态化系统,将数据填充进静态模板中,形成静态化页面推入Nginx服务器。用户浏览网站页面时,取用一个已经静态化好的html页面,例如freemarker,thymeleaf等,直接返回回去,不涉及任何的业务逻辑处理。例如下面一个简单的魔板…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号