当前位置:网站首页>STM32 key state machine 2 - state simplification and long press function addition
STM32 key state machine 2 - state simplification and long press function addition
2022-07-06 17:58:00 【Code farmer loves learning】
Last article , With the key anti shake function , The basic principle and application method of state machine are introduced .
The state diagram of the previous article is as follows :
Because only press and release are detected , And it has the function of key shaking elimination , Therefore, the above 4 Status , Press jitter and release jitter are two independent States , And these two jittery States , It can also run continuously in multiple cycles , The cycle period of this state machine is set to 10ms, When a certain level is continuously detected in the jitter state 5 Next time , That is, it is considered that the chattering elimination is completed , Go to the next steady state .
For the same function , State diagrams are not static , For key debounce , The two jitter states can also be represented by sharing a jitter state .
1 De chattering state simplification
1.1 State diagram
Press jitter and release jitter share a jitter state to represent , At the same time, the cycle period of the state machine needs to be set to 50ms, such , The jitter state only needs to pass once , Whether it is really key jitter can be determined by the level . The simplified state diagram is as follows :
In order to be able to , Distinguish whether the previous state is released or pressed , Then we can judge whether this time it is the jitter or the real action of the key , You need to add a status to record the previous status
KEY_STATUS g_keyStatus = KS_RELEASE; // The end of the current cycle ( State machine ) state
KEY_STATUS g_nowKeyStatus = KS_RELEASE; // current state ( After each cycle with g_keyStatus bring into correspondence with )
KEY_STATUS g_lastKeyStatus = KS_RELEASE; // Last state ( Used to record the previous state to distinguish the source of the state )
Be careful : Here g_lastKeyStatus Used to record the previous status , There is also this variable in the last article , But the effect is different , The function of this variable in the previous article is the same as that here g_nowKeyStatus The same effect .
1.2 Code
Compare with the simplified state diagram , Write the corresponding state machine logic code :
void key_status_check()
{
switch(g_keyStatus)
{
// Key release ( The initial state )
case KS_RELEASE:
{
// Low level detected , First, eliminate the chattering
if (KEY0 == 0)
{
g_keyStatus = KS_SHAKE;
}
}
break;
// shake
case KS_SHAKE:
{
if (KEY0 == 1)
{
g_keyStatus = KS_RELEASE;
if (KS_PRESS == g_lastKeyStatus)
{
printf("=====> key release\r\n");
}
}
else
{
g_keyStatus = KS_PRESS;
if (KS_RELEASE == g_lastKeyStatus)
{
printf("=====> key press\r\n");
}
}
}
break;
// Press steadily and briefly
case KS_PRESS:
{
// High level detected , First, eliminate the chattering
if (KEY0 == 1)
{
g_keyStatus = KS_SHAKE;
}
}
break;
default:break;
}
if (g_keyStatus != g_nowKeyStatus)
{
g_lastKeyStatus = g_nowKeyStatus;
g_nowKeyStatus = g_keyStatus;
printf("new key status:%d(%s)\r\n", g_keyStatus, key_status_name[g_keyStatus]);
}
}
Be careful g_lastKeyStatus Role of variables .
1.3 test
2 Add long press function
On the basis of detecting press and release , Add long press function , You need to add a long press state in the state diagram . then , Modify the code according to the state diagram .
Again , According to whether it is necessary to distinguish the two jitter States and the difference of the cycle cycle cycle of the state machine , There are two kinds of state diagrams .
2.1 Not simplified state diagram
Let's first look at the cycle 10ms, Distinguish between press jitter and release jitter. Add the state diagram after long press function :
After clarifying the logic of the state diagram , According to the state diagram , Modify the corresponding code , No more code here , The complete code can be checked in my code warehouse
2.2 Simplified state diagram
Next, let's take a look at the state machine diagram of the specific long press function to simplify the dithering state :
The comparison shows that , Simplified state diagram , The status can be one less , But the shaking state , There will be more inputs and outputs , Because at present, every state has passed through this state .
If the requirements for jitter detection are not high , You can also keep only the logic of press jitter , Loosen the shaking branch and remove , Jump directly to the released state , State logic can be simplified again .
2.3 Code
According to the state diagram , Write the corresponding state machine logic code , as follows :
void key_status_check()
{
switch(g_keyStatus)
{
// Key release ( The initial state )
case KS_RELEASE:
{
// Low level detected , First, eliminate the chattering
if (KEY0 == 0)
{
g_keyStatus = KS_SHAKE;
}
}
break;
// shake
case KS_SHAKE:
{
if (KEY0 == 1)
{
g_keyStatus = KS_RELEASE;
if (KS_SHORT_PRESS == g_lastKeyStatus || KS_LONG_PRESS == g_lastKeyStatus)
{
printf("=====> key release\r\n");
}
}
else
{
if (KS_RELEASE == g_lastKeyStatus)
{
g_PressTimeCnt = 0;
g_keyStatus = KS_SHORT_PRESS;
printf("=====> key short press\r\n");
}
else if (KS_SHORT_PRESS == g_lastKeyStatus)
{
g_keyStatus = KS_SHORT_PRESS;
}
else
{
}
}
}
break;
// Press steadily and briefly
case KS_SHORT_PRESS:
{
// High level detected , First, eliminate the chattering
if (KEY0 == 1)
{
g_keyStatus = KS_SHAKE;
}
g_PressTimeCnt++;
if (g_PressTimeCnt == 20) //1000ms
{
g_keyStatus = KS_LONG_PRESS;
printf("=====> key long press\r\n");
}
}
break;
// Steady long press
case KS_LONG_PRESS:
{
// High level detected , First, eliminate the chattering
if (KEY0 == 1)
{
g_keyStatus = KS_SHAKE;
}
g_PressTimeCnt++;
if (g_PressTimeCnt % 20 == 0) // every other 1000ms Print once
{
printf("=====> key long press:%d\r\n", g_PressTimeCnt/20);
}
}
break;
default:break;
}
if (g_keyStatus != g_nowKeyStatus)
{
g_lastKeyStatus = g_nowKeyStatus;
g_nowKeyStatus = g_keyStatus;
printf("new key status:%d(%s)\r\n", g_keyStatus, key_status_name[g_keyStatus]);
}
}
Be careful , In the jitter state , When the detection is high ( Release the button ), Whether the previous state is short press or long press , The next state is the released state .
2.4 test
3 summary
This article continues to introduce the use of state machines , On the basis of the first part , By simplifying the button to shake the logic , And add the function of pressing and holding keys , Further introduce the modification of state diagram and the implementation of state machine code , And passed the actual test , Demonstrate the running effect of the state machine .
边栏推荐
- It doesn't make sense without a distributed gateway
- 10 advanced concepts that must be understood in learning SQL
- Kivy tutorial: support Chinese in Kivy to build cross platform applications (tutorial includes source code)
- 基于STM32+华为云IOT设计的智能路灯
- 带你穿越古罗马,元宇宙巴士来啦 #Invisible Cities
- Spark accumulator and broadcast variables and beginners of sparksql
- C语言通过指针交换两个数
- PyTorch 提取中间层特征?
- FlutterWeb瀏覽器刷新後無法回退的解决方案
- Mysqlimport imports data files into the database
猜你喜欢
There is a gap in traditional home decoration. VR panoramic home decoration allows you to experience the completion effect of your new house
How to use scroll bars to dynamically adjust parameters in opencv
偷窃他人漏洞报告变卖成副业,漏洞赏金平台出“内鬼”
[introduction to MySQL] third, common data types in MySQL
10 advanced concepts that must be understood in learning SQL
Solution qui ne peut pas être retournée après la mise à jour du navigateur Web flutter
node の SQLite
【MySQL入门】第一话 · 初入“数据库”大陆
Optimization of middle alignment of loading style of device player in easycvr electronic map
EasyCVR授权到期页面无法登录,该如何解决?
随机推荐
1700C - Helping the Nature
Kernel link script parsing
adb常用命令
IP, subnet mask, gateway, default gateway
Compile and build, from the bottom to the top
EasyCVR电子地图中设备播放器loading样式的居中对齐优化
Binary search strategy
Pytest learning ----- detailed explanation of the request for interface automation test
Solution qui ne peut pas être retournée après la mise à jour du navigateur Web flutter
Selected technical experts from China Mobile, ant, SF, and Xingsheng will show you the guarantee of architecture stability
Single responsibility principle
【Android】Kotlin代码编写规范化文档
TCP packet sticking problem
分布式不来点网关都说不过去
scratch疫情隔离和核酸检测模拟 电子学会图形化编程scratch等级考试三级真题和答案解析2022年6月
Pyspark operator processing spatial data full parsing (5): how to use spatial operation interface in pyspark
[translation] principle analysis of X Window Manager (I)
Growth of operation and maintenance Xiaobai - week 7
李書福為何要親自掛帥造手機?
[ASM] introduction and use of bytecode operation classwriter class