/* * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved * * Licensed under the Apache License, Version 2.0 (the License); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an AS IS BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; namespace Tizen.Sensor { /// /// LinearAccelerationSensor Class. Used for registering callbacks for linear acceleration sensor and getting linear acceleration data /// public sealed class LinearAccelerationSensor : Sensor { private const string LinearAccelerationSensorKey = "http://tizen.org/feature/sensor.linear_acceleration"; private event EventHandler _accuracyChanged; /// /// Gets the X component of the linear acceleration. /// /// 3 /// X public float X { get; private set; } = float.MinValue; /// /// Gets the Y component of the linear acceleration. /// /// 3 /// Y public float Y { get; private set; } = float.MinValue; /// /// Gets the Z component of the linear acceleration. /// /// 3 /// Z public float Z { get; private set; } = float.MinValue; /// /// Returns true or false based on whether linear acceleration sensor is supported by device. /// /// 3 /// true if supported; otherwise, false. public static bool IsSupported { get { Log.Info(Globals.LogTag, "Checking if the LinearAccelerationSensor is supported"); return CheckIfSupported(SensorType.LinearAccelerationSensor, LinearAccelerationSensorKey); } } /// /// Returns the number of linear acceleration sensors available on the device. /// /// 3 /// The count of linear acceleration sensors public static int Count { get { Log.Info(Globals.LogTag, "Getting the count of linear acceleration sensors"); return GetCount(); } } /// /// Initializes a new instance of the class. /// /// 3 /// http://tizen.org/feature/sensor.linear_acceleration /// Thrown when an invalid argument is used /// Thrown when the sensor is not supported /// Thrown when the operation is invalid for the current state /// /// Index. Default value for this is 0. Index refers to a particular linear acceleration sensor in case of multiple sensors /// public LinearAccelerationSensor(uint index = 0) : base(index) { Log.Info(Globals.LogTag, "Creating LinearAccelerationSensor object"); } internal override SensorType GetSensorType() { return SensorType.LinearAccelerationSensor; } /// /// Event Handler for storing the callback functions for event corresponding to change in linear acceleration sensor data. /// /// 3 public event EventHandler DataUpdated; /// /// Event handler for accuracy changed events. /// /// 3 public event EventHandler AccuracyChanged { add { if (_accuracyChanged == null) { AccuracyListenStart(); } _accuracyChanged += value; } remove { _accuracyChanged -= value; if (_accuracyChanged == null) { AccuracyListenStop(); } } } private static int GetCount() { IntPtr list; int count; int error = Interop.SensorManager.GetSensorList(SensorType.LinearAccelerationSensor, out list, out count); if (error != (int)SensorError.None) { Log.Error(Globals.LogTag, "Error getting sensor list for linear acceleration sensor"); count = 0; } else Interop.Libc.Free(list); return count; } private static Interop.SensorListener.SensorEventCallback _callback; internal override void EventListenStart() { _callback = (IntPtr sensorHandle, IntPtr eventPtr, IntPtr data) => { Interop.SensorEventStruct sensorData = Interop.IntPtrToEventStruct(eventPtr); TimeSpan = new TimeSpan((Int64)sensorData.timestamp); X = sensorData.values[0]; Y = sensorData.values[1]; Z = sensorData.values[2]; DataUpdated?.Invoke(this, new LinearAccelerationSensorDataUpdatedEventArgs(sensorData.values)); }; int error = Interop.SensorListener.SetEventCallback(ListenerHandle, Interval, _callback, IntPtr.Zero); if (error != (int)SensorError.None) { Log.Error(Globals.LogTag, "Error setting event callback for linear acceleration sensor"); throw SensorErrorFactory.CheckAndThrowException(error, "Unable to set event callback for linear acceleration sensor"); } } internal override void EventListenStop() { int error = Interop.SensorListener.UnsetEventCallback(ListenerHandle); if (error != (int)SensorError.None) { Log.Error(Globals.LogTag, "Error unsetting event callback for linear acceleration sensor"); throw SensorErrorFactory.CheckAndThrowException(error, "Unable to unset event callback for linear acceleration"); } } private static Interop.SensorListener.SensorAccuracyCallback _accuracyCallback; private void AccuracyListenStart() { _accuracyCallback = (IntPtr sensorHandle, UInt64 timestamp, SensorDataAccuracy accuracy, IntPtr data) => { TimeSpan = new TimeSpan((Int64)timestamp); _accuracyChanged?.Invoke(this, new SensorAccuracyChangedEventArgs(new TimeSpan((Int64)timestamp), accuracy)); }; int error = Interop.SensorListener.SetAccuracyCallback(ListenerHandle, _accuracyCallback, IntPtr.Zero); if (error != (int)SensorError.None) { Log.Error(Globals.LogTag, "Error setting accuracy event callback for linear acceleration sensor"); throw SensorErrorFactory.CheckAndThrowException(error, "Unable to set accuracy event callback for linear acceleration sensor"); } } private void AccuracyListenStop() { int error = Interop.SensorListener.UnsetAccuracyCallback(ListenerHandle); if (error != (int)SensorError.None) { Log.Error(Globals.LogTag, "Error unsetting accuracy event callback for linear acceleration sensor"); throw SensorErrorFactory.CheckAndThrowException(error, "Unable to unset accuracy event callback for linear acceleration sensor"); } } } }