Merge "Adding AK8975 geo-sensor info in sensors.xml.in required by geo-plugin" into...
[platform/core/system/sensord.git] / src / gravity / gravity_sensor.h
1 /*
2  * sensord
3  *
4  * Copyright (c) 2014 Samsung Electronics Co., Ltd.
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *
18  */
19
20 #ifndef _GRAVITY_SENSOR_H_
21 #define _GRAVITY_SENSOR_H_
22
23 #include <sensor.h>
24 #include <virtual_sensor.h>
25 #include <string>
26
27 using std::string;
28
29 class gravity_sensor : public virtual_sensor
30 {
31 public:
32         gravity_sensor();
33         virtual ~gravity_sensor();
34
35         bool init();
36         sensor_type_t get_type(void);
37
38         static bool working(void *inst);
39
40         bool on_start(void);
41         bool on_stop(void);
42
43         void synthesize(const sensor_event_t &event, vector<sensor_event_t> &outs);
44
45         bool add_interval(int client_id, unsigned int interval);
46         bool delete_interval(int client_id);
47
48         int get_sensor_data(const unsigned int event_type, sensor_data_t &data);
49         bool get_properties(const unsigned int type, sensor_properties_t &properties);
50 private:
51         sensor_base *m_orientation_sensor;
52
53         float m_x;
54         float m_y;
55         float m_z;
56         unsigned long long m_timestamp;
57 };
58
59 #endif /*_GRAVITY_SENSOR_H_*/