Home | History | Annotate | Download | only in android
      1 /*
      2  * Copyright (C) 2010 The Android Open Source Project
      3  *
      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
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     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.
     15  */
     16 
     17 /**
     18  * @addtogroup Sensor
     19  * @{
     20  */
     21 
     22 /**
     23  * @file sensor.h
     24  */
     25 
     26 #ifndef ANDROID_SENSOR_H
     27 #define ANDROID_SENSOR_H
     28 
     29 /******************************************************************
     30  *
     31  * IMPORTANT NOTICE:
     32  *
     33  *   This file is part of Android's set of stable system headers
     34  *   exposed by the Android NDK (Native Development Kit).
     35  *
     36  *   Third-party source AND binary code relies on the definitions
     37  *   here to be FROZEN ON ALL UPCOMING PLATFORM RELEASES.
     38  *
     39  *   - DO NOT MODIFY ENUMS (EXCEPT IF YOU ADD NEW 32-BIT VALUES)
     40  *   - DO NOT MODIFY CONSTANTS OR FUNCTIONAL MACROS
     41  *   - DO NOT CHANGE THE SIGNATURE OF FUNCTIONS IN ANY WAY
     42  *   - DO NOT CHANGE THE LAYOUT OR SIZE OF STRUCTURES
     43  */
     44 
     45 /**
     46  * Structures and functions to receive and process sensor events in
     47  * native code.
     48  *
     49  */
     50 
     51 #include <android/looper.h>
     52 
     53 #include <stdbool.h>
     54 #include <sys/types.h>
     55 #include <math.h>
     56 #include <stdint.h>
     57 
     58 #ifdef __cplusplus
     59 extern "C" {
     60 #endif
     61 
     62 typedef struct AHardwareBuffer AHardwareBuffer;
     63 
     64 #define ASENSOR_RESOLUTION_INVALID     (nanf(""))
     65 #define ASENSOR_FIFO_COUNT_INVALID     (-1)
     66 #define ASENSOR_DELAY_INVALID          INT32_MIN
     67 #define ASENSOR_INVALID                (-1)
     68 
     69 /* (Keep in sync with hardware/sensors-base.h and Sensor.java.) */
     70 
     71 /**
     72  * Sensor types.
     73  *
     74  * See
     75  * [android.hardware.SensorEvent#values](https://developer.android.com/reference/android/hardware/SensorEvent.html#values)
     76  * for detailed explanations of the data returned for each of these types.
     77  */
     78 enum {
     79     /**
     80      * Invalid sensor type. Returned by {@link ASensor_getType} as error value.
     81      */
     82     ASENSOR_TYPE_INVALID = -1,
     83     /**
     84      * {@link ASENSOR_TYPE_ACCELEROMETER}
     85      * reporting-mode: continuous
     86      *
     87      *  All values are in SI units (m/s^2) and measure the acceleration of the
     88      *  device minus the force of gravity.
     89      */
     90     ASENSOR_TYPE_ACCELEROMETER       = 1,
     91     /**
     92      * {@link ASENSOR_TYPE_MAGNETIC_FIELD}
     93      * reporting-mode: continuous
     94      *
     95      *  All values are in micro-Tesla (uT) and measure the geomagnetic
     96      *  field in the X, Y and Z axis.
     97      */
     98     ASENSOR_TYPE_MAGNETIC_FIELD      = 2,
     99     /**
    100      * {@link ASENSOR_TYPE_GYROSCOPE}
    101      * reporting-mode: continuous
    102      *
    103      *  All values are in radians/second and measure the rate of rotation
    104      *  around the X, Y and Z axis.
    105      */
    106     ASENSOR_TYPE_GYROSCOPE           = 4,
    107     /**
    108      * {@link ASENSOR_TYPE_LIGHT}
    109      * reporting-mode: on-change
    110      *
    111      * The light sensor value is returned in SI lux units.
    112      */
    113     ASENSOR_TYPE_LIGHT               = 5,
    114     /**
    115      * {@link ASENSOR_TYPE_PRESSURE}
    116      *
    117      * The pressure sensor value is returned in hPa (millibar).
    118      */
    119     ASENSOR_TYPE_PRESSURE            = 6,
    120     /**
    121      * {@link ASENSOR_TYPE_PROXIMITY}
    122      * reporting-mode: on-change
    123      *
    124      * The proximity sensor which turns the screen off and back on during calls is the
    125      * wake-up proximity sensor. Implement wake-up proximity sensor before implementing
    126      * a non wake-up proximity sensor. For the wake-up proximity sensor set the flag
    127      * SENSOR_FLAG_WAKE_UP.
    128      * The value corresponds to the distance to the nearest object in centimeters.
    129      */
    130     ASENSOR_TYPE_PROXIMITY           = 8,
    131     /**
    132      * {@link ASENSOR_TYPE_GRAVITY}
    133      *
    134      * All values are in SI units (m/s^2) and measure the direction and
    135      * magnitude of gravity. When the device is at rest, the output of
    136      * the gravity sensor should be identical to that of the accelerometer.
    137      */
    138     ASENSOR_TYPE_GRAVITY             = 9,
    139     /**
    140      * {@link ASENSOR_TYPE_LINEAR_ACCELERATION}
    141      * reporting-mode: continuous
    142      *
    143      *  All values are in SI units (m/s^2) and measure the acceleration of the
    144      *  device not including the force of gravity.
    145      */
    146     ASENSOR_TYPE_LINEAR_ACCELERATION = 10,
    147     /**
    148      * {@link ASENSOR_TYPE_ROTATION_VECTOR}
    149      */
    150     ASENSOR_TYPE_ROTATION_VECTOR     = 11,
    151     /**
    152      * {@link ASENSOR_TYPE_RELATIVE_HUMIDITY}
    153      *
    154      * The relative humidity sensor value is returned in percent.
    155      */
    156     ASENSOR_TYPE_RELATIVE_HUMIDITY   = 12,
    157     /**
    158      * {@link ASENSOR_TYPE_AMBIENT_TEMPERATURE}
    159      *
    160      * The ambient temperature sensor value is returned in Celcius.
    161      */
    162     ASENSOR_TYPE_AMBIENT_TEMPERATURE = 13,
    163     /**
    164      * {@link ASENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED}
    165      */
    166     ASENSOR_TYPE_MAGNETIC_FIELD_UNCALIBRATED = 14,
    167     /**
    168      * {@link ASENSOR_TYPE_GAME_ROTATION_VECTOR}
    169      */
    170     ASENSOR_TYPE_GAME_ROTATION_VECTOR = 15,
    171     /**
    172      * {@link ASENSOR_TYPE_GYROSCOPE_UNCALIBRATED}
    173      */
    174     ASENSOR_TYPE_GYROSCOPE_UNCALIBRATED = 16,
    175     /**
    176      * {@link ASENSOR_TYPE_SIGNIFICANT_MOTION}
    177      */
    178     ASENSOR_TYPE_SIGNIFICANT_MOTION = 17,
    179     /**
    180      * {@link ASENSOR_TYPE_STEP_DETECTOR}
    181      */
    182     ASENSOR_TYPE_STEP_DETECTOR = 18,
    183     /**
    184      * {@link ASENSOR_TYPE_STEP_COUNTER}
    185      */
    186     ASENSOR_TYPE_STEP_COUNTER = 19,
    187     /**
    188      * {@link ASENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR}
    189      */
    190     ASENSOR_TYPE_GEOMAGNETIC_ROTATION_VECTOR = 20,
    191     /**
    192      * {@link ASENSOR_TYPE_HEART_RATE}
    193      */
    194     ASENSOR_TYPE_HEART_RATE = 21,
    195     /**
    196      * {@link ASENSOR_TYPE_POSE_6DOF}
    197      */
    198     ASENSOR_TYPE_POSE_6DOF = 28,
    199     /**
    200      * {@link ASENSOR_TYPE_STATIONARY_DETECT}
    201      */
    202     ASENSOR_TYPE_STATIONARY_DETECT = 29,
    203     /**
    204      * {@link ASENSOR_TYPE_MOTION_DETECT}
    205      */
    206     ASENSOR_TYPE_MOTION_DETECT = 30,
    207     /**
    208      * {@link ASENSOR_TYPE_HEART_BEAT}
    209      */
    210     ASENSOR_TYPE_HEART_BEAT = 31,
    211     /**
    212      * This sensor type is for delivering additional sensor information aside
    213      * from sensor event data.
    214      *
    215      * Additional information may include:
    216      *     - {@link ASENSOR_ADDITIONAL_INFO_INTERNAL_TEMPERATURE}
    217      *     - {@link ASENSOR_ADDITIONAL_INFO_SAMPLING}
    218      *     - {@link ASENSOR_ADDITIONAL_INFO_SENSOR_PLACEMENT}
    219      *     - {@link ASENSOR_ADDITIONAL_INFO_UNTRACKED_DELAY}
    220      *     - {@link ASENSOR_ADDITIONAL_INFO_VEC3_CALIBRATION}
    221      *
    222      * This type will never bind to a sensor. In other words, no sensor in the
    223      * sensor list can have the type {@link ASENSOR_TYPE_ADDITIONAL_INFO}.
    224      *
    225      * If a device supports the sensor additional information feature, it will
    226      * report additional information events via {@link ASensorEvent} and will
    227      * have {@link ASensorEvent#type} set to
    228      * {@link ASENSOR_TYPE_ADDITIONAL_INFO} and {@link ASensorEvent#sensor} set
    229      * to the handle of the reporting sensor.
    230      *
    231      * Additional information reports consist of multiple frames ordered by
    232      * {@link ASensorEvent#timestamp}. The first frame in the report will have
    233      * a {@link AAdditionalInfoEvent#type} of
    234      * {@link ASENSOR_ADDITIONAL_INFO_BEGIN}, and the last frame in the report
    235      * will have a {@link AAdditionalInfoEvent#type} of
    236      * {@link ASENSOR_ADDITIONAL_INFO_END}.
    237      *
    238      */
    239     ASENSOR_TYPE_ADDITIONAL_INFO = 33,
    240     /**
    241      * {@link ASENSOR_TYPE_LOW_LATENCY_OFFBODY_DETECT}
    242      */
    243     ASENSOR_TYPE_LOW_LATENCY_OFFBODY_DETECT = 34,
    244     /**
    245      * {@link ASENSOR_TYPE_ACCELEROMETER_UNCALIBRATED}
    246      */
    247     ASENSOR_TYPE_ACCELEROMETER_UNCALIBRATED = 35,
    248 };
    249 
    250 /**
    251  * Sensor accuracy measure.
    252  */
    253 enum {
    254     /** no contact */
    255     ASENSOR_STATUS_NO_CONTACT       = -1,
    256     /** unreliable */
    257     ASENSOR_STATUS_UNRELIABLE       = 0,
    258     /** low accuracy */
    259     ASENSOR_STATUS_ACCURACY_LOW     = 1,
    260     /** medium accuracy */
    261     ASENSOR_STATUS_ACCURACY_MEDIUM  = 2,
    262     /** high accuracy */
    263     ASENSOR_STATUS_ACCURACY_HIGH    = 3
    264 };
    265 
    266 /**
    267  * Sensor Reporting Modes.
    268  */
    269 enum {
    270     /** invalid reporting mode */
    271     AREPORTING_MODE_INVALID = -1,
    272     /** continuous reporting */
    273     AREPORTING_MODE_CONTINUOUS = 0,
    274     /** reporting on change */
    275     AREPORTING_MODE_ON_CHANGE = 1,
    276     /** on shot reporting */
    277     AREPORTING_MODE_ONE_SHOT = 2,
    278     /** special trigger reporting */
    279     AREPORTING_MODE_SPECIAL_TRIGGER = 3
    280 };
    281 
    282 /**
    283  * Sensor Direct Report Rates.
    284  */
    285 enum {
    286     /** stopped */
    287     ASENSOR_DIRECT_RATE_STOP = 0,
    288     /** nominal 50Hz */
    289     ASENSOR_DIRECT_RATE_NORMAL = 1,
    290     /** nominal 200Hz */
    291     ASENSOR_DIRECT_RATE_FAST = 2,
    292     /** nominal 800Hz */
    293     ASENSOR_DIRECT_RATE_VERY_FAST = 3
    294 };
    295 
    296 /**
    297  * Sensor Direct Channel Type.
    298  */
    299 enum {
    300     /** shared memory created by ASharedMemory_create */
    301     ASENSOR_DIRECT_CHANNEL_TYPE_SHARED_MEMORY = 1,
    302     /** AHardwareBuffer */
    303     ASENSOR_DIRECT_CHANNEL_TYPE_HARDWARE_BUFFER = 2
    304 };
    305 
    306 /**
    307  * Sensor Additional Info Types.
    308  *
    309  * Used to populate {@link AAdditionalInfoEvent#type}.
    310  */
    311 enum {
    312     /** Marks the beginning of additional information frames */
    313     ASENSOR_ADDITIONAL_INFO_BEGIN = 0,
    314 
    315     /** Marks the end of additional information frames */
    316     ASENSOR_ADDITIONAL_INFO_END = 1,
    317 
    318     /**
    319      * Estimation of the delay that is not tracked by sensor timestamps. This
    320      * includes delay introduced by sensor front-end filtering, data transport,
    321      * etc.
    322      * float[2]: delay in seconds, standard deviation of estimated value
    323      */
    324     ASENSOR_ADDITIONAL_INFO_UNTRACKED_DELAY = 0x10000,
    325 
    326     /** float: Celsius temperature */
    327     ASENSOR_ADDITIONAL_INFO_INTERNAL_TEMPERATURE,
    328 
    329     /**
    330      * First three rows of a homogeneous matrix, which represents calibration to
    331      * a three-element vector raw sensor reading.
    332      * float[12]: 3x4 matrix in row major order
    333      */
    334     ASENSOR_ADDITIONAL_INFO_VEC3_CALIBRATION,
    335 
    336     /**
    337      * Location and orientation of sensor element in the device frame: origin is
    338      * the geometric center of the mobile device screen surface; the axis
    339      * definition corresponds to Android sensor definitions.
    340      * float[12]: 3x4 matrix in row major order
    341      */
    342     ASENSOR_ADDITIONAL_INFO_SENSOR_PLACEMENT,
    343 
    344     /**
    345      * float[2]: raw sample period in seconds,
    346      *           standard deviation of sampling period
    347      */
    348     ASENSOR_ADDITIONAL_INFO_SAMPLING,
    349 };
    350 
    351 /*
    352  * A few useful constants
    353  */
    354 
    355 /** Earth's gravity in m/s^2 */
    356 #define ASENSOR_STANDARD_GRAVITY            (9.80665f)
    357 /** Maximum magnetic field on Earth's surface in uT */
    358 #define ASENSOR_MAGNETIC_FIELD_EARTH_MAX    (60.0f)
    359 /** Minimum magnetic field on Earth's surface in uT*/
    360 #define ASENSOR_MAGNETIC_FIELD_EARTH_MIN    (30.0f)
    361 
    362 /**
    363  * A sensor event.
    364  */
    365 
    366 /* NOTE: changes to these structs have to be backward compatible */
    367 typedef struct ASensorVector {
    368     union {
    369         float v[3];
    370         struct {
    371             float x;
    372             float y;
    373             float z;
    374         };
    375         struct {
    376             float azimuth;
    377             float pitch;
    378             float roll;
    379         };
    380     };
    381     int8_t status;
    382     uint8_t reserved[3];
    383 } ASensorVector;
    384 
    385 typedef struct AMetaDataEvent {
    386     int32_t what;
    387     int32_t sensor;
    388 } AMetaDataEvent;
    389 
    390 typedef struct AUncalibratedEvent {
    391     union {
    392         float uncalib[3];
    393         struct {
    394             float x_uncalib;
    395             float y_uncalib;
    396             float z_uncalib;
    397         };
    398     };
    399     union {
    400         float bias[3];
    401         struct {
    402             float x_bias;
    403             float y_bias;
    404             float z_bias;
    405         };
    406     };
    407 } AUncalibratedEvent;
    408 
    409 typedef struct AHeartRateEvent {
    410     float bpm;
    411     int8_t status;
    412 } AHeartRateEvent;
    413 
    414 typedef struct ADynamicSensorEvent {
    415     int32_t  connected;
    416     int32_t  handle;
    417 } ADynamicSensorEvent;
    418 
    419 typedef struct AAdditionalInfoEvent {
    420     int32_t type;
    421     int32_t serial;
    422     union {
    423         int32_t data_int32[14];
    424         float   data_float[14];
    425     };
    426 } AAdditionalInfoEvent;
    427 
    428 /* NOTE: changes to this struct has to be backward compatible */
    429 typedef struct ASensorEvent {
    430     int32_t version; /* sizeof(struct ASensorEvent) */
    431     int32_t sensor;
    432     int32_t type;
    433     int32_t reserved0;
    434     int64_t timestamp;
    435     union {
    436         union {
    437             float           data[16];
    438             ASensorVector   vector;
    439             ASensorVector   acceleration;
    440             ASensorVector   magnetic;
    441             float           temperature;
    442             float           distance;
    443             float           light;
    444             float           pressure;
    445             float           relative_humidity;
    446             AUncalibratedEvent uncalibrated_gyro;
    447             AUncalibratedEvent uncalibrated_magnetic;
    448             AMetaDataEvent meta_data;
    449             AHeartRateEvent heart_rate;
    450             ADynamicSensorEvent dynamic_sensor_meta;
    451             AAdditionalInfoEvent additional_info;
    452         };
    453         union {
    454             uint64_t        data[8];
    455             uint64_t        step_counter;
    456         } u64;
    457     };
    458 
    459     uint32_t flags;
    460     int32_t reserved1[3];
    461 } ASensorEvent;
    462 
    463 struct ASensorManager;
    464 /**
    465  * {@link ASensorManager} is an opaque type to manage sensors and
    466  * events queues.
    467  *
    468  * {@link ASensorManager} is a singleton that can be obtained using
    469  * ASensorManager_getInstance().
    470  *
    471  * This file provides a set of functions that uses {@link
    472  * ASensorManager} to access and list hardware sensors, and
    473  * create and destroy event queues:
    474  * - ASensorManager_getSensorList()
    475  * - ASensorManager_getDefaultSensor()
    476  * - ASensorManager_getDefaultSensorEx()
    477  * - ASensorManager_createEventQueue()
    478  * - ASensorManager_destroyEventQueue()
    479  */
    480 typedef struct ASensorManager ASensorManager;
    481 
    482 
    483 struct ASensorEventQueue;
    484 /**
    485  * {@link ASensorEventQueue} is an opaque type that provides access to
    486  * {@link ASensorEvent} from hardware sensors.
    487  *
    488  * A new {@link ASensorEventQueue} can be obtained using ASensorManager_createEventQueue().
    489  *
    490  * This file provides a set of functions to enable and disable
    491  * sensors, check and get events, and set event rates on a {@link
    492  * ASensorEventQueue}.
    493  * - ASensorEventQueue_enableSensor()
    494  * - ASensorEventQueue_disableSensor()
    495  * - ASensorEventQueue_hasEvents()
    496  * - ASensorEventQueue_getEvents()
    497  * - ASensorEventQueue_setEventRate()
    498  * - ASensorEventQueue_requestAdditionalInfoEvents()
    499  */
    500 typedef struct ASensorEventQueue ASensorEventQueue;
    501 
    502 struct ASensor;
    503 /**
    504  * {@link ASensor} is an opaque type that provides information about
    505  * an hardware sensors.
    506  *
    507  * A {@link ASensor} pointer can be obtained using
    508  * ASensorManager_getDefaultSensor(),
    509  * ASensorManager_getDefaultSensorEx() or from a {@link ASensorList}.
    510  *
    511  * This file provides a set of functions to access properties of a
    512  * {@link ASensor}:
    513  * - ASensor_getName()
    514  * - ASensor_getVendor()
    515  * - ASensor_getType()
    516  * - ASensor_getResolution()
    517  * - ASensor_getMinDelay()
    518  * - ASensor_getFifoMaxEventCount()
    519  * - ASensor_getFifoReservedEventCount()
    520  * - ASensor_getStringType()
    521  * - ASensor_getReportingMode()
    522  * - ASensor_isWakeUpSensor()
    523  * - ASensor_getHandle()
    524  */
    525 typedef struct ASensor ASensor;
    526 /**
    527  * {@link ASensorRef} is a type for constant pointers to {@link ASensor}.
    528  *
    529  * This is used to define entry in {@link ASensorList} arrays.
    530  */
    531 typedef ASensor const* ASensorRef;
    532 /**
    533  * {@link ASensorList} is an array of reference to {@link ASensor}.
    534  *
    535  * A {@link ASensorList} can be initialized using ASensorManager_getSensorList().
    536  */
    537 typedef ASensorRef const* ASensorList;
    538 
    539 /*****************************************************************************/
    540 
    541 /**
    542  * Get a reference to the sensor manager. ASensorManager is a singleton
    543  * per package as different packages may have access to different sensors.
    544  *
    545  * Deprecated: Use ASensorManager_getInstanceForPackage(const char*) instead.
    546  *
    547  * Example:
    548  *
    549  *     ASensorManager* sensorManager = ASensorManager_getInstance();
    550  *
    551  */
    552 #if __ANDROID_API__ >= 26
    553 __attribute__ ((deprecated)) ASensorManager* ASensorManager_getInstance();
    554 #else
    555 ASensorManager* ASensorManager_getInstance();
    556 #endif
    557 
    558 #if __ANDROID_API__ >= 26
    559 /**
    560  * Get a reference to the sensor manager. ASensorManager is a singleton
    561  * per package as different packages may have access to different sensors.
    562  *
    563  * Example:
    564  *
    565  *     ASensorManager* sensorManager = ASensorManager_getInstanceForPackage("foo.bar.baz");
    566  *
    567  */
    568 ASensorManager* ASensorManager_getInstanceForPackage(const char* packageName) __INTRODUCED_IN(26);
    569 #endif
    570 
    571 /**
    572  * Returns the list of available sensors.
    573  */
    574 int ASensorManager_getSensorList(ASensorManager* manager, ASensorList* list);
    575 
    576 /**
    577  * Returns the default sensor for the given type, or NULL if no sensor
    578  * of that type exists.
    579  */
    580 ASensor const* ASensorManager_getDefaultSensor(ASensorManager* manager, int type);
    581 
    582 #if __ANDROID_API__ >= 21
    583 /**
    584  * Returns the default sensor with the given type and wakeUp properties or NULL if no sensor
    585  * of this type and wakeUp properties exists.
    586  */
    587 ASensor const* ASensorManager_getDefaultSensorEx(ASensorManager* manager, int type, bool wakeUp) __INTRODUCED_IN(21);
    588 #endif
    589 
    590 /**
    591  * Creates a new sensor event queue and associate it with a looper.
    592  *
    593  * "ident" is a identifier for the events that will be returned when
    594  * calling ALooper_pollOnce(). The identifier must be >= 0, or
    595  * ALOOPER_POLL_CALLBACK if providing a non-NULL callback.
    596  */
    597 ASensorEventQueue* ASensorManager_createEventQueue(ASensorManager* manager,
    598         ALooper* looper, int ident, ALooper_callbackFunc callback, void* data);
    599 
    600 /**
    601  * Destroys the event queue and free all resources associated to it.
    602  */
    603 int ASensorManager_destroyEventQueue(ASensorManager* manager, ASensorEventQueue* queue);
    604 
    605 #if __ANDROID_API__ >= 26
    606 /**
    607  * Create direct channel based on shared memory
    608  *
    609  * Create a direct channel of {@link ASENSOR_DIRECT_CHANNEL_TYPE_SHARED_MEMORY} to be used
    610  * for configuring sensor direct report.
    611  *
    612  * \param manager the {@link ASensorManager} instance obtained from
    613  *                {@link ASensorManager_getInstanceForPackage}.
    614  * \param fd      file descriptor representing a shared memory created by
    615  *                {@link ASharedMemory_create}
    616  * \param size    size to be used, must be less or equal to size of shared memory.
    617  *
    618  * \return a positive integer as a channel id to be used in
    619  *         {@link ASensorManager_destroyDirectChannel} and
    620  *         {@link ASensorManager_configureDirectReport}, or value less or equal to 0 for failures.
    621  */
    622 int ASensorManager_createSharedMemoryDirectChannel(ASensorManager* manager, int fd, size_t size) __INTRODUCED_IN(26);
    623 
    624 /**
    625  * Create direct channel based on AHardwareBuffer
    626  *
    627  * Create a direct channel of {@link ASENSOR_DIRECT_CHANNEL_TYPE_HARDWARE_BUFFER} type to be used
    628  * for configuring sensor direct report.
    629  *
    630  * \param manager the {@link ASensorManager} instance obtained from
    631  *                {@link ASensorManager_getInstanceForPackage}.
    632  * \param buffer  {@link AHardwareBuffer} instance created by {@link AHardwareBuffer_allocate}.
    633  * \param size    the intended size to be used, must be less or equal to size of buffer.
    634  *
    635  * \return a positive integer as a channel id to be used in
    636  *         {@link ASensorManager_destroyDirectChannel} and
    637  *         {@link ASensorManager_configureDirectReport}, or value less or equal to 0 for failures.
    638  */
    639 int ASensorManager_createHardwareBufferDirectChannel(
    640         ASensorManager* manager, AHardwareBuffer const * buffer, size_t size) __INTRODUCED_IN(26);
    641 
    642 /**
    643  * Destroy a direct channel
    644  *
    645  * Destroy a direct channel previously created using {@link ASensorManager_createDirectChannel}.
    646  * The buffer used for creating direct channel does not get destroyed with
    647  * {@link ASensorManager_destroy} and has to be close or released separately.
    648  *
    649  * \param manager the {@link ASensorManager} instance obtained from
    650  *                {@link ASensorManager_getInstanceForPackage}.
    651  * \param channelId channel id (a positive integer) returned from
    652  *                  {@link ASensorManager_createSharedMemoryDirectChannel} or
    653  *                  {@link ASensorManager_createHardwareBufferDirectChannel}.
    654  */
    655 void ASensorManager_destroyDirectChannel(ASensorManager* manager, int channelId) __INTRODUCED_IN(26);
    656 
    657 /**
    658  * Configure direct report on channel
    659  *
    660  * Configure sensor direct report on a direct channel: set rate to value other than
    661  * {@link ASENSOR_DIRECT_RATE_STOP} so that sensor event can be directly
    662  * written into the shared memory region used for creating the buffer. It returns a positive token
    663  * which can be used for identify sensor events from different sensors on success. Calling with rate
    664  * {@link ASENSOR_DIRECT_RATE_STOP} will stop direct report of the sensor specified in the channel.
    665  *
    666  * To stop all active sensor direct report configured to a channel, set sensor to NULL and rate to
    667  * {@link ASENSOR_DIRECT_RATE_STOP}.
    668  *
    669  * In order to successfully configure a direct report, the sensor has to support the specified rate
    670  * and the channel type, which can be checked by {@link ASensor_getHighestDirectReportRateLevel} and
    671  * {@link ASensor_isDirectChannelTypeSupported}, respectively.
    672  *
    673  * Example:
    674  *
    675  *     ASensorManager *manager = ...;
    676  *     ASensor *sensor = ...;
    677  *     int channelId = ...;
    678  *
    679  *     ASensorManager_configureDirectReport(manager, sensor, channel_id, ASENSOR_DIRECT_RATE_FAST);
    680  *
    681  * \param manager   the {@link ASensorManager} instance obtained from
    682  *                  {@link ASensorManager_getInstanceForPackage}.
    683  * \param sensor    a {@link ASensor} to denote which sensor to be operate. It can be NULL if rate
    684  *                  is {@link ASENSOR_DIRECT_RATE_STOP}, denoting stopping of all active sensor
    685  *                  direct report.
    686  * \param channelId channel id (a positive integer) returned from
    687  *                  {@link ASensorManager_createSharedMemoryDirectChannel} or
    688  *                  {@link ASensorManager_createHardwareBufferDirectChannel}.
    689  *
    690  * \return positive token for success or negative error code.
    691  */
    692 int ASensorManager_configureDirectReport(ASensorManager* manager,
    693         ASensor const* sensor, int channelId, int rate) __INTRODUCED_IN(26);
    694 #endif /* __ANDROID_API__ >= 26 */
    695 
    696 /*****************************************************************************/
    697 
    698 /**
    699  * Enable the selected sensor with sampling and report parameters
    700  *
    701  * Enable the selected sensor at a specified sampling period and max batch report latency.
    702  * To disable  sensor, use {@link ASensorEventQueue_disableSensor}.
    703  *
    704  * \param queue {@link ASensorEventQueue} for sensor event to be report to.
    705  * \param sensor {@link ASensor} to be enabled.
    706  * \param samplingPeriodUs sampling period of sensor in microseconds.
    707  * \param maxBatchReportLatencyus maximum time interval between two batch of sensor events are
    708  *                                delievered in microseconds. For sensor streaming, set to 0.
    709  * \return 0 on success or a negative error code on failure.
    710  */
    711 int ASensorEventQueue_registerSensor(ASensorEventQueue* queue, ASensor const* sensor,
    712         int32_t samplingPeriodUs, int64_t maxBatchReportLatencyUs);
    713 
    714 /**
    715  * Enable the selected sensor at default sampling rate.
    716  *
    717  * Start event reports of a sensor to specified sensor event queue at a default rate.
    718  *
    719  * \param queue {@link ASensorEventQueue} for sensor event to be report to.
    720  * \param sensor {@link ASensor} to be enabled.
    721  *
    722  * \return 0 on success or a negative error code on failure.
    723  */
    724 int ASensorEventQueue_enableSensor(ASensorEventQueue* queue, ASensor const* sensor);
    725 
    726 /**
    727  * Disable the selected sensor.
    728  *
    729  * Stop event reports from the sensor to specified sensor event queue.
    730  *
    731  * \param queue {@link ASensorEventQueue} to be changed
    732  * \param sensor {@link ASensor} to be disabled
    733  * \return 0 on success or a negative error code on failure.
    734  */
    735 int ASensorEventQueue_disableSensor(ASensorEventQueue* queue, ASensor const* sensor);
    736 
    737 /**
    738  * Sets the delivery rate of events in microseconds for the given sensor.
    739  *
    740  * This function has to be called after {@link ASensorEventQueue_enableSensor}.
    741  * Note that this is a hint only, generally event will arrive at a higher
    742  * rate. It is an error to set a rate inferior to the value returned by
    743  * ASensor_getMinDelay().
    744  *
    745  * \param queue {@link ASensorEventQueue} to which sensor event is delivered.
    746  * \param sensor {@link ASensor} of which sampling rate to be updated.
    747  * \param usec sensor sampling period (1/sampling rate) in microseconds
    748  * \return 0 on sucess or a negative error code on failure.
    749  */
    750 int ASensorEventQueue_setEventRate(ASensorEventQueue* queue, ASensor const* sensor, int32_t usec);
    751 
    752 /**
    753  * Determine if a sensor event queue has pending event to be processed.
    754  *
    755  * \param queue {@link ASensorEventQueue} to be queried
    756  * \return 1 if the queue has events; 0 if it does not have events;
    757  *         or a negative value if there is an error.
    758  */
    759 int ASensorEventQueue_hasEvents(ASensorEventQueue* queue);
    760 
    761 /**
    762  * Retrieve pending events in sensor event queue
    763  *
    764  * Retrieve next available events from the queue to a specified event array.
    765  *
    766  * \param queue {@link ASensorEventQueue} to get events from
    767  * \param events pointer to an array of {@link ASensorEvents}.
    768  * \param count max number of event that can be filled into array event.
    769  * \return number of events returned on success; negative error code when
    770  *         no events are pending or an error has occurred.
    771  *
    772  * Examples:
    773  *
    774  *     ASensorEvent event;
    775  *     ssize_t numEvent = ASensorEventQueue_getEvents(queue, &event, 1);
    776  *
    777  *     ASensorEvent eventBuffer[8];
    778  *     ssize_t numEvent = ASensorEventQueue_getEvents(queue, eventBuffer, 8);
    779  *
    780  */
    781 ssize_t ASensorEventQueue_getEvents(ASensorEventQueue* queue, ASensorEvent* events, size_t count);
    782 
    783 #if __ANDROID_API__ >= __ANDROID_API_Q__
    784 /**
    785  * Request that {@link ASENSOR_TYPE_ADDITIONAL_INFO} events to be delivered on
    786  * the given {@link ASensorEventQueue}.
    787  *
    788  * Sensor data events are always delivered to the {@ASensorEventQueue}.
    789  *
    790  * The {@link ASENSOR_TYPE_ADDITIONAL_INFO} events will be returned through
    791  * {@link ASensorEventQueue_getEvents}. The client is responsible for checking
    792  * {@link ASensorEvent#type} to determine the event type prior to handling of
    793  * the event.
    794  *
    795  * The client must be tolerant of any value for
    796  * {@link AAdditionalInfoEvent#type}, as new values may be defined in the future
    797  * and may delivered to the client.
    798  *
    799  * \param queue {@link ASensorEventQueue} to configure
    800  * \param enable true to request {@link ASENSOR_TYPE_ADDITIONAL_INFO} events,
    801  *        false to stop receiving events
    802  * \return 0 on success or a negative error code on failure
    803  */
    804 int ASensorEventQueue_requestAdditionalInfoEvents(ASensorEventQueue* queue, bool enable);
    805 #endif /* __ANDROID_API__ >= __ANDRDOID_API_Q__ */
    806 
    807 /*****************************************************************************/
    808 
    809 /**
    810  * Returns this sensor's name (non localized)
    811  */
    812 const char* ASensor_getName(ASensor const* sensor);
    813 
    814 /**
    815  * Returns this sensor's vendor's name (non localized)
    816  */
    817 const char* ASensor_getVendor(ASensor const* sensor);
    818 
    819 /**
    820  * Return this sensor's type
    821  */
    822 int ASensor_getType(ASensor const* sensor);
    823 
    824 /**
    825  * Returns this sensors's resolution
    826  */
    827 float ASensor_getResolution(ASensor const* sensor);
    828 
    829 /**
    830  * Returns the minimum delay allowed between events in microseconds.
    831  * A value of zero means that this sensor doesn't report events at a
    832  * constant rate, but rather only when a new data is available.
    833  */
    834 int ASensor_getMinDelay(ASensor const* sensor);
    835 
    836 #if __ANDROID_API__ >= 21
    837 /**
    838  * Returns the maximum size of batches for this sensor. Batches will often be
    839  * smaller, as the hardware fifo might be used for other sensors.
    840  */
    841 int ASensor_getFifoMaxEventCount(ASensor const* sensor) __INTRODUCED_IN(21);
    842 
    843 /**
    844  * Returns the hardware batch fifo size reserved to this sensor.
    845  */
    846 int ASensor_getFifoReservedEventCount(ASensor const* sensor) __INTRODUCED_IN(21);
    847 
    848 /**
    849  * Returns this sensor's string type.
    850  */
    851 const char* ASensor_getStringType(ASensor const* sensor) __INTRODUCED_IN(21);
    852 
    853 /**
    854  * Returns the reporting mode for this sensor. One of AREPORTING_MODE_* constants.
    855  */
    856 int ASensor_getReportingMode(ASensor const* sensor) __INTRODUCED_IN(21);
    857 
    858 /**
    859  * Returns true if this is a wake up sensor, false otherwise.
    860  */
    861 bool ASensor_isWakeUpSensor(ASensor const* sensor) __INTRODUCED_IN(21);
    862 #endif /* __ANDROID_API__ >= 21 */
    863 
    864 #if __ANDROID_API__ >= 26
    865 /**
    866  * Test if sensor supports a certain type of direct channel.
    867  *
    868  * \param sensor  a {@link ASensor} to denote the sensor to be checked.
    869  * \param channelType  Channel type constant, either
    870  *                     {@ASENSOR_DIRECT_CHANNEL_TYPE_SHARED_MEMORY}
    871  *                     or {@link ASENSOR_DIRECT_CHANNEL_TYPE_HARDWARE_BUFFER}.
    872  * \returns true if sensor supports the specified direct channel type.
    873  */
    874 bool ASensor_isDirectChannelTypeSupported(ASensor const* sensor, int channelType) __INTRODUCED_IN(26);
    875 
    876 /**
    877  * Get the highest direct rate level that a sensor support.
    878  *
    879  * \param sensor  a {@link ASensor} to denote the sensor to be checked.
    880  *
    881  * \return a ASENSOR_DIRECT_RATE_... enum denoting the highest rate level supported by the sensor.
    882  *         If return value is {@link ASENSOR_DIRECT_RATE_STOP}, it means the sensor
    883  *         does not support direct report.
    884  */
    885 int ASensor_getHighestDirectReportRateLevel(ASensor const* sensor) __INTRODUCED_IN(26);
    886 #endif /* __ANDROID_API__ >= 26 */
    887 
    888 #if __ANDROID_API__ >= __ANDROID_API_Q__
    889 /**
    890  * Returns the sensor's handle.
    891  *
    892  * The handle identifies the sensor within the system and is included in the
    893  * {@link ASensorEvent#sensor} field of sensor events, including those sent with type
    894  * {@link ASENSOR_TYPE_ADDITIONAL_INFO}.
    895  *
    896  * A sensor's handle is able to be used to map {@link ASENSOR_TYPE_ADDITIONAL_INFO} events to the
    897  * sensor that generated the event.
    898  *
    899  * It is important to note that the value returned by {@link ASensor_getHandle} is not the same as
    900  * the value returned by the Java API {@link android.hardware.Sensor#getId} and no mapping exists
    901  * between the values.
    902  */
    903 int ASensor_getHandle(ASensor const* sensor) __INTRODUCED_IN(__ANDROID_API_Q__);
    904 #endif /* __ANDROID_API__ >= ANDROID_API_Q__ */
    905 
    906 #ifdef __cplusplus
    907 };
    908 #endif
    909 
    910 #endif // ANDROID_SENSOR_H
    911 
    912 /** @} */
    913