2 * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
19 namespace Tizen.Sensor
22 /// WalkingActivityDetector Class. Used for registering callbacks for walking activity detector and getting the walking state
24 public sealed class WalkingActivityDetector : ActivityDetector
26 private static string ActivityDetectorKey = "http://tizen.org/feature/sensor.activity_recognition";
29 /// Gets the state of walking activity detector
31 public DetectorState Walking { get; private set; } = DetectorState.Unknown;
34 /// Returns true or false based on whether walking activity detector is supported by device.
36 public static bool IsSupported
40 Log.Info(Globals.LogTag, "Checking if the walking activity detector is supported");
41 return CheckIfSupported(SensorType.WalkingActivityDetector, ActivityDetectorKey);
46 /// Returns the number of walking activity detector available on the device.
48 public static int Count
52 Log.Info(Globals.LogTag, "Getting the count of walking activity detectors");
58 /// Initializes a new instance of the <see cref="Tizen.Sensor.walkingActivityDetector"/> class.
60 /// <exception cref="ArgumentException">Thrown when an invalid argument is used</exception>
61 /// <exception cref="NotSupportedException">Thrown when the sensor is not supported</exception>
62 /// <exception cref="InvalidOperationException">Thrown when the operation is invalid for the current state</exception>
63 /// <param name='index'>
64 /// Index. Default value for this is 0. Index refers to a particular walking activity detector in case of multiple sensors.
66 public WalkingActivityDetector(uint index = 0) : base(index)
68 SetAttribute((SensorAttribute)ActivityAttribute, (int)ActivityType.Walking);
69 Log.Info(Globals.LogTag, "Creating walking activity gesture detector object");
72 private static int GetCount()
76 int error = Interop.SensorManager.GetSensorList(SensorType.WalkingActivityDetector, out list, out count);
77 if (error != (int)SensorError.None)
79 Log.Error(Globals.LogTag, "Error getting sensor list for walking activity detector");
83 Interop.Libc.Free(list);
88 /// Event Handler for storing the callback functions for event corresponding to change in walking activity gesture detector data.
90 public event EventHandler<WalkingActivityDetectorDataUpdatedEventArgs> DataUpdated;
92 internal override void SensorEventCallback(IntPtr sensorHandle, IntPtr sensorPtr, IntPtr data)
94 Interop.SensorEventStruct sensorData = Interop.IntPtrToEventStruct(sensorPtr);
95 TimeSpan = new TimeSpan((Int64)sensorData.timestamp);
96 Walking = (DetectorState)sensorData.values[0];
97 ActivityAccuracy = (SensorDataAccuracy) sensorData.accuracy;
99 DataUpdated?.Invoke(this, new WalkingActivityDetectorDataUpdatedEventArgs(sensorData.values[0]));
102 internal override SensorType GetSensorType()
104 return SensorType.WalkingActivityDetector;