정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

Accelerometer.ReadingChanged | readingchanged Event

가속계가 새 센서 판독값을 보고할 때마다 발생합니다.

구문


function onReadingChanged(eventArgs) { /* 코드 */ }
 
// addEventListener syntax
accelerometer.addEventListener("readingchanged", onReadingChanged);
accelerometer.removeEventListener("readingchanged", onReadingChanged);
 
- or -

accelerometer.onreadingchanged = onReadingChanged;


이벤트 정보

대리자 TypedEventHandler<Accelerometer, AccelerometerReadingChangedEventArgs>

설명

응용 프로그램은 이 이벤트 처리기를 등록하여 센서 판독값을 얻을 수 있습니다. 응용 프로그램에서 원하는 ReportInterval을 설정해야 합니다. 이렇게 하면 응용 프로그램의 요구 사항을 충족시키기 위해 리소스를 할당해야 한다는 사실을 센서 드라이버에 알릴 수 있습니다.

다음 예제에서는 C# 및 XAML로 작성된 Windows 스토어 앱에서 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);
    });
}


다음 예제에서는 JavaScript로 작성된 Windows 스토어 앱에서 ReadingChanged 이벤트 처리기를 등록하는 방법을 보여 줍니다.


function enableReadingChangedScenario() {
    if (accelerometer) {
        // Set the reportInterval to enable the sensor events
        accelerometer.reportInterval = reportInterval;

        document.addEventListener("msvisibilitychange", msVisibilityChangeHandler, false);
        accelerometer.addEventListener("readingchanged", onDataChanged);
        document.getElementById("scenario1Open").disabled = true;
        document.getElementById("scenario1Revoke").disabled = false;
    } else {
        WinJS.log && WinJS.log("No accelerometer found", "sample", "error");
    }
}


다음 예제에서는 ReadingChanged 이벤트 처리기를 보여 줍니다.


function onDataChanged(e) {
    var reading = e.reading;

    document.getElementById("eventOutputX").innerHTML = reading.accelerationX.toFixed(2);
    document.getElementById("eventOutputY").innerHTML = reading.accelerationY.toFixed(2);
    document.getElementById("eventOutputZ").innerHTML = reading.accelerationZ.toFixed(2);
}


요구 사항

지원되는 최소 클라이언트

Windows 8

지원되는 최소 서버

지원되는 사항 없음

지원되는 최소 전화

Windows Phone 8

Namespace

Windows.Devices.Sensors
Windows::Devices::Sensors [C++]

Metadata

Windows.winmd

참고 항목

Accelerometer

 

 

표시: