当前位置: 首页 > news >正文

stm32利用CubeMX按键控制数码管加减数

首先画电路图:

接下来配置CubeMX:

设置好后生成MDK工程文件:

用keil打开工程:

添加部分代码:

/* USER CODE BEGIN Includes */
uint16_t duan[]={0xC0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90};
uint16_t num=0;/* USER CODE END Includes */

void display(void);  //声明显示函数

编写while循环中的代码:

while (1){display();if(HAL_GPIO_ReadPin(key1_GPIO_Port,key1_Pin)== 0){num++;if(num > 99){num=99;}while(HAL_GPIO_ReadPin(key1_GPIO_Port,key1_Pin)== 0);}if(HAL_GPIO_ReadPin(key2_GPIO_Port,key2_Pin)== 0){num--;if(num < 0){num=0;}while(HAL_GPIO_ReadPin(key2_GPIO_Port,key2_Pin)== 0);}/* USER CODE END WHILE *//* USER CODE BEGIN 3 */}/* USER CODE END 3 */
}

编写显示函数:

/* USER CODE BEGIN 4 */
void display(void)
{//HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState)  // 单个位端口置位函数GPIOA->ODR=0xFFFF;                                         // GPIOA的16位都设置成1 数码管关闭显示HAL_GPIO_WritePin(shi_GPIO_Port,shi_Pin,GPIO_PIN_SET);     // 数码管十位置1HAL_GPIO_WritePin(ge_GPIO_Port,ge_Pin,GPIO_PIN_RESET);     // 数码管个位置0GPIOA->ODR = duan[num/10];                                 // 数码管十位显示num的十位HAL_Delay(2);                                               // 延时2毫秒GPIOA->ODR=0xFFFF;                                         // GPIOA的16位都设置成1 数码管关闭显示HAL_GPIO_WritePin(shi_GPIO_Port,shi_Pin,GPIO_PIN_RESET);   // 数码管十位置0HAL_GPIO_WritePin(ge_GPIO_Port,ge_Pin,GPIO_PIN_SET);       // 数码管个位置1GPIOA->ODR = duan[num%10];                                 // 数码管个位显示num的个位HAL_Delay(2);                                              // 延时2毫秒
}/* USER CODE END 4 */

最后编译成hex文件导入proteus中就可以仿真啦!

上面的按键加,下面的按键减。

http://www.lryc.cn/news/304798.html

相关文章:

  • 前端页面生成条形码,借助layui打印标签
  • 第1~8章 综合复习
  • 转运机器人,AGV底盘小车:打造高效、精准的汽车电子生产线
  • Spring Boot 的参数校验方案
  • 第N3周:Pytorch文本分类入门
  • 宝塔面板安装了mysql5.7和phpMyadmin,但是访问phpMyadmin时提示502 Bad Gateway
  • K8S—Pod详解
  • 深度学习中数据的转换
  • 如何系统地自学 Python?
  • 【软考】传输层协议之UDP
  • 微服务-微服务链路追踪组件Skywalking实战
  • Stream、Collections、Collectors用法
  • Jetson Xavier NX 与笔记本网线连接 ,网络共享,ssh连接到vscode
  • 利用netty手写rpc框架
  • js+views 压缩上传的图片
  • 【安卓基础5】中级控件
  • Arthas—【学习篇】
  • css pointer-events 多层鼠标点击事件
  • k8s中基于alpine的pod无法解析域名问题
  • 缩小ppt文件大小的办法
  • vue3中使用 tui-image-editor进行图片处理,并上传
  • 18.贪心算法
  • [AI]部署安装有道QanyThing
  • NLP_BERT与GPT争锋
  • 放一个还看得过去的后台模板设置模块css样式框架
  • 关于信号强度单位dB和dBm区别
  • 华清远见作业第四十二天——Qt(第四天)
  • vue2和vue3区别 浅析
  • GIT使用和简介
  • HTTPS(超文本传输安全协议)被恶意请求该如何处理。