次の方法で共有


Accelerometer.Shaken イベント

定義

PC が振られたことを加速度計が検出したときに発生します。

// Register
event_token Shaken(TypedEventHandler<Accelerometer, AccelerometerShakenEventArgs const&> const& handler) const;

// Revoke with event_token
void Shaken(event_token const* cookie) const;

// Revoke with event_revoker
Accelerometer::Shaken_revoker Shaken(auto_revoke_t, TypedEventHandler<Accelerometer, AccelerometerShakenEventArgs const&> const& handler) const;
public event TypedEventHandler<Accelerometer,AccelerometerShakenEventArgs> Shaken;
function onShaken(eventArgs) { /* Your code */ }
accelerometer.addEventListener("shaken", onShaken);
accelerometer.removeEventListener("shaken", onShaken);
- or -
accelerometer.onshaken = onShaken;
Public Custom Event Shaken As TypedEventHandler(Of Accelerometer, AccelerometerShakenEventArgs) 

イベントの種類

次の例では、C# と XAML を使用して構築された UWP アプリが Shaken イベント ハンドラーを登録する方法を示します。

private void ScenarioEnable(object sender, RoutedEventArgs e)
{
    if (_accelerometer != null)
    {
        Window.Current.VisibilityChanged += new WindowVisibilityChangedEventHandler(VisibilityChanged);
        _accelerometer.Shaken += new TypedEventHandler<Accelerometer, AccelerometerShakenEventArgs>(Shaken);
        ScenarioEnableButton.IsEnabled = false;
        ScenarioDisableButton.IsEnabled = true;
    }
    else
    {
        rootPage.NotifyUser("No accelerometer found", NotifyType.StatusMessage);
    }
}

次の例は、Shaken イベント ハンドラーを示しています。

async private void Shaken(object sender, AccelerometerShakenEventArgs e)
{
    await Dispatcher.RunAsync(CoreDispatcherPriority.Normal, () =>
    {
        _shakeCount++;
        ScenarioOutputText.Text = _shakeCount.ToString();
    });
}

注釈

このイベントを使用して、加速度計を含むデバイスがシェイクされたことを示す通知を受け取ります。 アプリは、Shaken イベントに登録する前にレポート間隔を設定する必要はありません。

Shaken イベントのサポートは、ハードウェアとドライバーのサポートによって異なります。 実際には、シェイクイベントをサポートする加速度計はほとんどありません。 加速度計が Shaken イベントをサポートせず、Shaken イベントのイベント ハンドラーを追加した場合、エラーは発生しませんが、イベント ハンドラー内のコードは実行されません。

適用対象