https://github.com/lizdDong/io_input_filter
A Input IO Filter For RT-Thread Package
https://github.com/lizdDong/io_input_filter
Last synced: 3 months ago
JSON representation
A Input IO Filter For RT-Thread Package
- Host: GitHub
- URL: https://github.com/lizdDong/io_input_filter
- Owner: lizdDong
- License: apache-2.0
- Created: 2022-07-11T02:47:25.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2023-07-23T07:50:29.000Z (over 1 year ago)
- Last Synced: 2023-07-23T08:27:11.143Z (over 1 year ago)
- Language: C
- Size: 17.6 KB
- Stars: 0
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rt-thread - io_input_filter - IO Input Filter. (Packages / Peripherals)
- awesome-rt-thread - io_input_filter - IO Input Filter. (Packages / Peripherals)
README
# io_input_filter IO输入滤波软件包
## 1 介绍
**io_input_filter** 软件包提供一个有效的输入滤波功能,它会检测引脚电平的稳定状态,直到检测到持续稳定后才会触发状态改变,软件包提供简单易用的接口函数,用户可通过调整`IIF_TIMES`和`IIF_PERIOD`两个宏来改变滤波条件。
## 2 使用方法
### 2.1 配置宏
IIF_TIMES // 滤波次数,连续 IIF_TIMES 次读取引脚电平持续为高/低的次数
IIF_PERIOD // 滤波周期,每隔 IIF_PERIOD 毫秒读取一次引脚电平
IIF_DEBUG_MODE // IIF调试信息输出### 2.2 接口说明
#### 2.2.1 数据结构:
```
struct io_input_filter
{
uint8_t pin_id; // 引脚id,可以由 GET_PIN() 获取
uint8_t pin_status; // 滤波后的引脚状态,高/低
uint8_t filter_counts; // 当前引脚电平已经持续稳定的次数
struct io_input_filter *next; // 单向链表 next
};
```
#### 2.2.2 函数说明:
1. `void iif_init(void);`
初始化函数,使用之前请先进行初始化。2. `int iif_add_pin(rt_base_t pin);`
将一个引脚加入滤波控制器中,例如:
```
#define IO_IN1 GET_PIN(D, 11)
iif_add_pin(IO_IN1);
```3. `int iif_read_pin(rt_base_t pin);`
读取引脚状态,例如:
```
if(iif_read_pin(IO_IN1) == PIN_HIGH)
rt_kprintf("IO_IN1 Changed to HIGH\n");
else
rt_kprintf("IO_IN1 Changed to LOW\n");
```## 3 注意事项
软件包需要使能软件定时器`RT_USING_TIMER_SOFT`。## 4 联系方式
https://github.com/lizdDong/io_input_filter