mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-27 07:11:45 +03:00
ffa3996a5e
* clang-format: AllowShortEnumsOnASingleLine: false * clang-format: InsertNewlineAtEOF: true * clang-format: Standard: c++20 * clang-format: AlignConsecutiveBitFields * clang-format: AlignConsecutiveMacros * clang-format: RemoveParentheses: ReturnStatement * clang-format: RemoveSemicolon: true * Restored RemoveParentheses: Leave, retained general changes for it * formatting: fixed logging TAGs * Formatting update for dev Co-authored-by: あく <alleteam@gmail.com>
58 lines
1.5 KiB
C
58 lines
1.5 KiB
C
/**
|
|
* @file input.h
|
|
* Input: main API
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <furi_hal_resources.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define RECORD_INPUT_EVENTS "input_events"
|
|
#define INPUT_SEQUENCE_SOURCE_HARDWARE (0u)
|
|
#define INPUT_SEQUENCE_SOURCE_SOFTWARE (1u)
|
|
|
|
/** Input Types
|
|
* Some of them are physical events and some logical
|
|
*/
|
|
typedef enum {
|
|
InputTypePress, /**< Press event, emitted after debounce */
|
|
InputTypeRelease, /**< Release event, emitted after debounce */
|
|
InputTypeShort, /**< Short event, emitted after InputTypeRelease done within INPUT_LONG_PRESS interval */
|
|
InputTypeLong, /**< Long event, emitted after INPUT_LONG_PRESS_COUNTS interval, asynchronous to InputTypeRelease */
|
|
InputTypeRepeat, /**< Repeat event, emitted with INPUT_LONG_PRESS_COUNTS period after InputTypeLong event */
|
|
InputTypeMAX, /**< Special value for exceptional */
|
|
} InputType;
|
|
|
|
/** Input Event, dispatches with FuriPubSub */
|
|
typedef struct {
|
|
union {
|
|
uint32_t sequence;
|
|
struct {
|
|
uint8_t sequence_source : 2;
|
|
uint32_t sequence_counter : 30;
|
|
};
|
|
};
|
|
InputKey key;
|
|
InputType type;
|
|
} InputEvent;
|
|
|
|
/** Get human readable input key name
|
|
* @param key - InputKey
|
|
* @return string
|
|
*/
|
|
const char* input_get_key_name(InputKey key);
|
|
|
|
/** Get human readable input type name
|
|
* @param type - InputType
|
|
* @return string
|
|
*/
|
|
const char* input_get_type_name(InputType type);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|