Files
zh_inclinometer/include/zh_inclinometer.h
2026-01-02 12:06:32 +03:00

76 lines
2.0 KiB
C

/**
* @file zh_inclinometer.h
*/
#pragma once
#include "esp_log.h"
#include "driver/gpio.h"
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
/**
* @brief Inclinometer initial default values.
*/
#define ZH_INCLINOMETER_INIT_CONFIG_DEFAULT() \
{ \
.a_gpio_number = GPIO_NUM_MAX, \
.b_gpio_number = GPIO_NUM_MAX, \
.encoder_pulses = 0}
#ifdef __cplusplus
extern "C"
{
#endif
/**
* @brief Structure for initial initialization of inclinometer.
*/
typedef struct
{
uint8_t a_gpio_number; /*!< Encoder A GPIO number. */
uint8_t b_gpio_number; /*!< Encoder B GPIO number. */
uint16_t encoder_pulses; /*!< Number of pulses per one rotation. */
} zh_inclinometer_init_config_t;
/**
* @brief Initialize inclinometer.
*
* @param[in] config Pointer to inclinometer initialized configuration structure. Can point to a temporary variable.
*
* @note Before initialize the inclinometer recommend initialize zh_inclinometer_init_config_t structure with default values.
*
* @code zh_inclinometer_init_config_t config = ZH_INCLINOMETER_INIT_CONFIG_DEFAULT() @endcode
*
* @return ESP_OK if success or an error code otherwise.
*/
esp_err_t zh_inclinometer_init(const zh_inclinometer_init_config_t *config);
/**
* @brief Deinitialize inclinometer.
*
* @return ESP_OK if success or an error code otherwise.
*/
esp_err_t zh_inclinometer_deinit(void);
/**
* @brief Get inclinometer position.
*
* @param[out] position inclinometer position.
*
* @return ESP_OK if success or an error code otherwise.
*/
esp_err_t zh_inclinometer_get(double *position);
/**
* @brief Reset inclinometer position.
*
* @note The inclinometer will be set to 0 position.
*
* @return ESP_OK if success or an error code otherwise.
*/
esp_err_t zh_inclinometer_reset(void);
#ifdef __cplusplus
}
#endif