Accelerometer 类

定义

表示加速计传感器。

此传感器返回相对于 x、y 和 z 轴的 G 力值。

有关实现的示例,请参阅加速计示例

public ref class Accelerometer sealed
/// [Windows.Foundation.Metadata.ContractVersion(Windows.Foundation.UniversalApiContract, 65536)]
/// [Windows.Foundation.Metadata.MarshalingBehavior(Windows.Foundation.Metadata.MarshalingType.Agile)]
/// [Windows.Foundation.Metadata.Threading(Windows.Foundation.Metadata.ThreadingModel.Both)]
class Accelerometer final
[Windows.Foundation.Metadata.ContractVersion(typeof(Windows.Foundation.UniversalApiContract), 65536)]
[Windows.Foundation.Metadata.MarshalingBehavior(Windows.Foundation.Metadata.MarshalingType.Agile)]
[Windows.Foundation.Metadata.Threading(Windows.Foundation.Metadata.ThreadingModel.Both)]
public sealed class Accelerometer
Public NotInheritable Class Accelerometer
继承
Object Platform::Object IInspectable Accelerometer
属性

Windows 要求

设备系列
Windows 10 (在 10.0.10240.0 中引入)
API contract
Windows.Foundation.UniversalApiContract (在 v1.0 中引入)

注解

应用程序使用此类中的方法来确定传感器读数是否已更改或设备已摇动。

应用程序使用此类中的属性来检索和调整传感器报告间隔。

传感器数据相对于设备的固定传感器坐标系提供,并且与显示方向无关。 对于依赖传感器数据进行输入控制或操作屏幕上元素的应用程序,开发人员必须考虑当前显示方向并相应地补偿数据。 有关传感器坐标系的详细信息,请参阅 传感器数据和显示方向

以下示例演示了使用 XAML 和 C# 生成的 UWP 应用如何使用 GetDefault 方法与加速计建立连接。 如果未找到集成加速计,该方法将返回 null 值。

_accelerometer = Accelerometer.GetDefault();

以下示例演示使用 XAML 生成的 UWP 应用如何注册 ReadingChanged 事件处理程序。

private void ScenarioEnable(object sender, RoutedEventArgs e)
{
    if (_accelerometer != null)
    {
        // Establish the report interval
        _accelerometer.ReportInterval = _desiredReportInterval;

        Window.Current.VisibilityChanged += new WindowVisibilityChangedEventHandler(VisibilityChanged);
        _accelerometer.ReadingChanged += new TypedEventHandler<Accelerometer, AccelerometerReadingChangedEventArgs>(ReadingChanged);

        ScenarioEnableButton.IsEnabled = false;
        ScenarioDisableButton.IsEnabled = true;
    }
    else
    {
        rootPage.NotifyUser("No accelerometer found", NotifyType.StatusMessage);
    }
}

以下示例演示 ReadingChanged 事件处理程序。

async private void ReadingChanged(object sender, AccelerometerReadingChangedEventArgs e)
{
    await Dispatcher.RunAsync(CoreDispatcherPriority.Normal, () =>
    {
        AccelerometerReading reading = e.Reading;
        ScenarioOutput_X.Text = String.Format("{0,5:0.00}", reading.AccelerationX);
        ScenarioOutput_Y.Text = String.Format("{0,5:0.00}", reading.AccelerationY);
        ScenarioOutput_Z.Text = String.Format("{0,5:0.00}", reading.AccelerationZ);
    });
}

版本历史记录

Windows 版本 SDK 版本 已添加值
1607 14393 GetDefault (AccelerometerReadingType)
1607 14393 ReadingType
1709 16299 FromIdAsync
1709 16299 GetDeviceSelector
2004 19041 ReportThreshold

属性

DeviceId

获取设备标识符。

MaxBatchSize

获取传感器可以批处理的最大事件数。

MinimumReportInterval

获取加速计支持的最小报告间隔。

ReadingTransform

获取或设置需要应用于传感器数据的转换。 要应用的转换与用于对齐传感器数据的显示方向相关联。

ReadingType

获取由此 对象表示的加速计传感器的类型。

ReportInterval

获取或设置加速计的当前报告间隔。

ReportLatency

获取或设置传感器信息批次之间的延迟。

ReportThreshold

获取 加速计传感器的 AccelerometerDataThreshold

方法

FromIdAsync(String)

从传感器标识符异步获取传感器。

GetCurrentReading()

获取当前加速计读数。

GetDefault()

返回默认加速计。

GetDefault(AccelerometerReadingType)

返回特定类型的传感器的默认加速计。 可能的加速计传感器由 AccelerometerReadingType 定义。

GetDeviceSelector(AccelerometerReadingType)

获取设备选择器。

事件

ReadingChanged

每次加速计报告新的传感器读数时发生。

Shaken

当加速计检测到电脑已摇动时发生。

适用于

另请参阅