Keil uVision5:4 按键(K1-K4)精准控制声光模式切换,附详尽源码!
以下是一个使用 Keil uVision5 编写的满足您需求的 C 语言代码示例: ```c #include <reg52.h> // 包含 51 单片机寄存器定义的头文件 // 定义 LED 连接的端口 sbit LED1 = P0^0; sbit LED2 = P0^1; sbit LED3 = P0^2; sbit LED4 = P0^3; sbit LED5 = P0^4; sbit LED6 = P0^5; sbit LED7 = P0^6; sbit LED8 = P0^7; // 定义蜂鸣器连接的端口 sbit BEEP = P1^0; // 定义按键连接的端口 sbit K1 = P2^0; sbit K2 = P2^1; sbit K3 = P2^2; sbit K4 = P2^3; // 延时函数 void delay_ms(unsigned int ms) { unsigned int i, j; for (i = 0; i < ms; i++) { for (j = 0; j < 110; j++); // 简单的延时循环 } } // 初始化函数 void init() { // 初始化 LED 为熄灭状态 LED1 = 0; LED2 = 0; LED3 = 0; LED4 = 0; LED5 = 0; LED6 = 0; LED7 = 0; LED8 = 0; // 初始化蜂鸣器为关闭状态 BEEP = 0; } // 蜂鸣器间隔响函数 void beep_interval() { BEEP = 1; // 蜂鸣器响 delay_ms(500); // 延时 500 毫秒 BEEP = 0; // 蜂鸣器停 delay_ms(500); // 延时 500 毫秒 } // 左移流水灯函数 void led_left_shift() { unsigned char temp = 0x01; // 初始值为 0000 0001 while (1) { P0 = temp; // 输出到 LED 端口 delay_ms(500); // 延时 500 毫秒 temp = temp << 1; // 左移一位 if (temp == 0x00) // 如果移到最左边 { temp = 0x01; // 重新从最右边开始 } } } // 右移流水灯函数 void led_right_shift() { unsigned char temp = 0x80; // 初始值为 1000 0000 while (1) { P0 = temp; // 输出到 LED 端口 delay_ms(500); // 延时 500 毫秒 temp = temp >> 1; // 右移一位 if (temp == 0x00) // 如果移到最右边 { temp = 0x80; // 重新从最左边开始 } } } // 主函数 void main() { init(); // 调用初始化函数 while (1) { // 检测 K1 按键按下 if (K1 == 0) // 如果 K1 按下 { delay_ms(10); // 消抖延时 if (K1 == 0) // 再次确认按下 { while (K1 == 0); // 等待按键抬起 // 执行蜂鸣器间隔响 beep_interval(); } } // 检测 K2 按键按下 if (K2 == 0) // 如果 K2 按下 { delay_ms(10); // 消抖延时 if (K2 == 0) // 再次确认按下 { while (K2 == 0); // 等待按键抬起 // 执行左移流水灯 led_left_shift(); } } // 检测 K3 按键按下 if (K3 == 0) // 如果 K3 按下 { delay_ms(10); // 消抖延时 if (K3 == 0) // 再次确认按下 { while (K3 == 0); // 等待按键抬起 // 执行右移流水灯 led_right_shift(); } } // 检测 K4 按键按下 if (K4 == 0) // 如果 K4 按下 { delay_ms(10); // 消抖延时 if (K4 == 0) // 再次确认按下 { while (K4 == 0); // 等待按键抬起 // 关闭所有 LED 和蜂鸣器 LED1 = 0; LED2 = 0; LED3 = 0; LED4 = 0; LED5 = 0; LED6 = 0; LED7 = 0; LED8 = 0; BEEP = 0; } } } } ``` 上述代码是基于 51 单片机编写的,您需要根据实际的硬件连接情况进行相应的修改。在实际应用中,还需要考虑更多的因素,如按键防抖的优化、异常情况的处理等。 ######[AI写代码神器 | 1342点数解答 | 2024-10-24 16:46:48]
- Keil编译报错:找不到core_cm3.h文件的原因及解决办法(字节豆包 | 666点数解答 | 2025-11-12 18:26:21)153
- Keil MDK编译报错“无法打开 core_cm3.h”,解决办法及注意事项全揭秘!(字节豆包 | 560点数解答 | 2025-11-12 18:31:47)79
- 求解最优二叉查找树:计算平均搜索结点访问数的动态规划方案(讯飞星火 | 743点数解答 | 2024-05-30 18:04:31)304
- C语言实现:从含搜索概率的关键字序列构建最优二叉查找树并计算平均访问结点数(讯飞星火 | 666点数解答 | 2024-05-30 18:04:53)234
- 动态规划解最优二叉查找树问题:求平均搜索结点访问数(结果3.65) (GPT | 1243点数解答 | 2024-06-04 11:00:54)176
- 巧用动态规划:求解最优二叉查找树平均搜索结点数(GPT | 1027点数解答 | 2024-06-07 16:14:36)301
- 最优二叉查找树:输入概率求平均搜索结点数的动态规划解法及代码实现(GPT | 584点数解答 | 2024-06-07 16:14:48)306
- Python实现:计算最优二叉查找树平均搜索结点数(百度文心 | 780点数解答 | 2024-06-07 16:16:21)271
- Python 实现最优二叉查找树:计算平均搜索结点访问数(讯飞星火 | 526点数解答 | 2024-06-09 02:46:12)257
- 动态规划求解最优二叉查找树:计算平均搜索结点访问数(GPT | 1311点数解答 | 2024-06-09 14:30:32)298
- Python实现从给定关键字序列构造最优二叉查找树并计算平均搜索结点数(GPT | 857点数解答 | 2024-06-09 14:30:52)281
- Python实现:根据关键字与虚拟键概率构建最优二叉查找树并输出平均搜索结点数(讯飞星火 | 450点数解答 | 2024-06-09 16:12:27)204