Flutter 获取手机传感器数据

前言

在Flutter中可以使用sensors_plus插件来访问加速度计、陀螺仪、磁力计以及气压传感器

sensors_plue的平台支持

平台 是否支持
Android
iOS
MacOS
Web
Linux
Windows

sensors_plue的要求

  • Flutter >=3.19.0
  • Dart >=3.3.0 <4.0.0
  • iOS >=12.0
  • MacOS >=10.14
  • Android compileSDK 34
  • Java 17
  • Android Gradle Plugin >=8.3.0
  • Gradle wrapper >=8.4

sensors_plue的常用方法

常用方法 描述 监听返回类型
accelerometerEventStream({samplingPeriod}).listen() 监听设备的加速度(包括重力影响) AccelerometerEvent
userAccelerometerEventStream({samplingPeriod}).listen() 监听设备的加速度(不包括重力影响) UserAccelerometerEvent
gyroscopeEventStream({samplingPeriod}).listen() 监听设备的陀螺仪数据 GyroscopeEvent
magnetometerEventStream({samplingPeriod}).listen() 监听设备的环境磁场 MagnetometerEvent
barometerEventStream({samplingPeriod}).listen() 监听设备周围的大气压力 BarometerEvent
AccelerometerEvent

加速计的离散读数。加速计测量设备的速度。请注意,这些读数包括重力的影响。简单地说,您可以使用加速计读数来判断设备是否在特定方向上移动。

属性 描述 类型
timestamp 事件的时间戳,单位为微秒 DateTime
x 沿x轴的加速力(包括重力),单位为m/s^2 double
y 沿y轴的加速力(包括重力),单位为m/s^2 double
z 沿z轴的加速力(包括重力),单位为m/s^2 double
UserAccelerometerEvent

与[AccelerometerEvent]一样,这是加速计的离散读数,用于测量设备的速度。然而,与[AccelerometerEvent]不同,该事件不包括重力的影响。

属性 描述 类型
x 沿x轴的加速力(不包括重力),单位为m/s^2 double
y 沿y轴的加速力(不包括重力),单位为m/s^2 double
z 沿z轴的加速力(不包括重力),单位为m/s^2 double
timestamp 事件的时间戳,单位为微秒 DateTime
GyroscopeEvent

陀螺仪的离散读数。陀螺仪测量设备在3D空间中的速率或旋转。

属性 描述 类型
x 绕x轴的旋转速率,单位为rad/s double
y 绕y轴的旋转速率,单位为rad/s double
z 绕z轴的旋转速率,单位为rad/s double
timestamp 事件的时间戳,单位为微秒 DateTime
MagnetometerEvent

磁力计测量传感器周围的环境磁场,返回每个三维轴的微特斯拉(μT)值。

考虑到这些样本可能受到地球磁场的影响以及设备本身的金属或附近磁铁等局部因素的影响,尽管大多数设备都会补偿这些因素。指南针是磁力计数据通用工具的一个例子。

属性 描述 类型
x 传感器x轴上的环境磁场,单位为μT double
y 传感器y轴上的环境磁场,单位为μT double
z 传感器z轴上的环境磁场,单位为μT double
timestamp 事件的时间戳,单位为微秒 DateTime
BarometerEvent

气压计测量传感器周围的大气压力,返回百帕(hPa)的值。

考虑到这些样本可能受到海拔和天气条件的影响,可用于预测短期天气变化或确定海拔高度。请注意,由于操作设备引起的压力变化,防水手机或类似的密封设备在握持或使用时可能会出现压力波动。高度计是气压计数据通用工具的一个例子。

属性 描述 类型
pressure 传感器周围的大气压力,单位为百帕(hPa)。 double
timestamp 事件的时间戳,单位为微秒 DateTime

用法

如果要获取气压计数据,iOS需要访问运动数据。因此必须在应用文件中包含一个名为的键Info.plist。此键提供一条消息,告知用户应用为何请求访问设备的运动数据

info.plist 条目示例:

复制代码
<key>NSMotionUsageDescription</key>
<string>This app requires access to the barometer to provide altitude information.</string>

示例内容

复制代码
import 'package:sensors_plus/sensors_plus.dart';
// 监听设备的加速度(包括重力影响)
accelerometerEventStream().listen(
  (AccelerometerEvent event) {
    print(event);
  },
  onError: (error) {},
  cancelOnError: true,
); // [AccelerometerEvent (x: 0.0, y: 9.8, z: 0.0)]
 
// 监听设备的加速度(不包括重力影响)
userAccelerometerEventStream().listen(
  (UserAccelerometerEvent event) {
    print(event);
  },
  onError: (error) {},
  cancelOnError: true,
); // [UserAccelerometerEvent (x: 0.0, y: 0.0, z: 0.0)]
 
// 监听设备的陀螺仪数据
gyroscopeEventStream().listen(
  (GyroscopeEvent event) {
    print(event);
  },
  onError: (error) {},
  cancelOnError: true,
);// [GyroscopeEvent (x: 0.0, y: 0.0, z: 0.0)]
 
//监听设备的环境磁场
magnetometerEventStream().listen(
  (MagnetometerEvent event) {
    print(event);
  },
  onError: (error) {},
  cancelOnError: true,
);// [MagnetometerEvent (x: -23.6, y: 6.2, z: -34.9)]
 
//监听设备周围的大气压力
barometerEventStream().listen(
  (BarometerEvent event) {
    print(event);
  },
  onError: (error) {},
  cancelOnError: true,
);// [BarometerEvent (pressure: 1000.0)]
相关推荐
亚历克斯神4 小时前
Flutter for OpenHarmony: Flutter 三方库 mutex 为鸿蒙异步任务提供可靠的临界资源互斥锁(并发安全基石)
android·数据库·安全·flutter·华为·harmonyos
钛态4 小时前
Flutter 三方库 smartstruct 鸿蒙化字段映射适配指南:介入静态预编译引擎扫除视图及数据模型双向强转类型错乱隐患,筑稳如磐石的企业级模型治理防线-适配鸿蒙 HarmonyOS ohos
flutter·华为·harmonyos
键盘鼓手苏苏4 小时前
Flutter 组件 csv2json 适配鸿蒙 HarmonyOS 实战:高性能异构数据转换,构建 CSV 流式解析与全栈式数据映射架构
flutter·harmonyos·鸿蒙·openharmony
左手厨刀右手茼蒿4 小时前
Flutter 组件 http_requests 适配鸿蒙 HarmonyOS 实战:极简网络请求,构建边缘端轻量级 RESTful 通讯架构
网络·flutter·http
雷帝木木4 小时前
Flutter 三方库 hrk_logging 的鸿蒙化适配指南 - 实现标准化分层日志记录、支持多目的地输出与日志分级过滤
flutter·harmonyos·鸿蒙·openharmony·hrk_logging
左手厨刀右手茼蒿4 小时前
Flutter 三方库 dio_compatibility_layer 的鸿蒙化适配指南 - 实现 Dio 跨主版本的平滑迁移、支持遗留拦截器兼容与网络请求架构稳定升级
flutter·harmonyos·鸿蒙·openharmony·dio_compatibility_layer
雷帝木木4 小时前
Flutter 三方库 hashids2 基于鸿蒙安全内核的深度隐匿映射适配:数字指纹泄露防御层、生成短小精悍唯一不可逆加盐哈希,护航全链路请求 URL 隐私-适配鸿蒙 HarmonyOS ohos
安全·flutter·harmonyos
王码码20357 小时前
Flutter 组件 inappwebview_cookie_manager 适配 鸿蒙Harmony 实战 - 驾驭核心大 Web 容器缓存隧道、构建金融级政企应用绝对防串号跨域大隔离基座
flutter·harmonyos·鸿蒙·openharmony·inappwebview_cookie_manager
左手厨刀右手茼蒿7 小时前
Flutter 组件 ews 的适配 鸿蒙Harmony 实战 - 驾驭企业级 Exchange Web Services 协议、实现鸿蒙端政企办公同步与高安通讯隔离方案
flutter·harmonyos·鸿蒙·openharmony
钛态7 小时前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js