stm32f103c8t6实现简易计算器

时间: 2023-11-14 21:08:00 浏览: 48
以下是基于STM32F103C8T6的简易计算器的实现方法: 1. 首先需要连接5110屏幕和4*4键盘到STM32F103C8T6开发板上。 2. 然后需要编写程序,实现基本的多位加减乘除功能。可以使用C语言编写程序,并使用Keil或者其他编译器进行编译。 3. 在程序中需要定义键盘输入的方式,并将输入的数字和运算符存储在变量中。 4. 然后需要编写算法,根据输入的数字和运算符进行计算,并将结果显示在5110屏幕上。 5. 最后需要测试程序,确保计算器能够正确地进行加减乘除运算。 以下是一个基于STM32F103C8T6的简易计算器的代码示例: ```c #include "stm32f10x.h" #include "stdio.h" #include "stdlib.h" #include "string.h" #define ROW1 GPIO_Pin_0 #define ROW2 GPIO_Pin_1 #define ROW3 GPIO_Pin_2 #define ROW4 GPIO_Pin_3 #define COL1 GPIO_Pin_4 #define COL2 GPIO_Pin_5 #define COL3 GPIO_Pin_6 #define COL4 GPIO_Pin_7 void delay_ms(uint16_t nms) { uint32_t i; for(i=0;i<nms*1000;i++); } void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOB, ENABLE); GPIO_InitStructure.GPIO_Pin = ROW1|ROW2|ROW3|ROW4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = COL1|COL2|COL3|COL4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOB, &GPIO_InitStructure); } void LCD5110_GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4|GPIO_Pin_5; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOA, &GPIO_InitStructure); } void LCD5110_WriteByte(uint8_t data,uint8_t command) { uint8_t i; GPIO_ResetBits(GPIOA,GPIO_Pin_0); if(command==0) GPIO_SetBits(GPIOA,GPIO_Pin_1); else GPIO_ResetBits(GPIOA,GPIO_Pin_1); for(i=0;i<8;i++) { if(data&0x80) GPIO_SetBits(GPIOA,GPIO_Pin_5); else GPIO_ResetBits(GPIOA,GPIO_Pin_5); GPIO_SetBits(GPIOA,GPIO_Pin_2); GPIO_ResetBits(GPIOA,GPIO_Pin_2); data<<=1; } } void LCD5110_Init(void) { GPIO_SetBits(GPIOA,GPIO_Pin_0); delay_ms(10); GPIO_ResetBits(GPIOA,GPIO_Pin_0); delay_ms(10); GPIO_SetBits(GPIOA,GPIO_Pin_0); LCD5110_WriteByte(0x21,1); LCD5110_WriteByte(0xc8,1); LCD5110_WriteByte(0x06,1); LCD5110_WriteByte(0x13,1); LCD5110_WriteByte(0x20,1); LCD5110_WriteByte(0x0c,1); } void LCD5110_Clear(void) { uint16_t i; for(i=0;i<504;i++) LCD5110_WriteByte(0,0); } void LCD5110_Set_XY(uint8_t X,uint8_t Y) { LCD5110_WriteByte(0x40|Y,1); LCD5110_WriteByte(0x80|X,1); } void LCD5110_Write_Char(uint8_t c) { uint8_t line; uint8_t ch = 0; uint16_t i; for(i=0;i<5;i++) { ch = FontLookup[c-32][i]; LCD5110_WriteByte(ch,0); } } void LCD5110_Write_String(uint8_t X,uint8_t Y,char *s) { LCD5110_Set_XY(X,Y); while(*s) { LCD5110_Write_Char(*s++); } } void LCD5110_Write_Num(uint8_t X,uint8_t Y,uint32_t num) { char str[10]; sprintf(str,"%d",num); LCD5110_Write_String(X,Y,str); } uint8_t KeyScan(void) { uint8_t keyvalue = 0xff; GPIO_ResetBits(GPIOA,ROW1); if(GPIO_ReadInputDataBit(GPIOB,COL1)==0) keyvalue = 1; if(GPIO_ReadInputDataBit(GPIOB,COL2)==0) keyvalue = 2; if(GPIO_ReadInputDataBit(GPIOB,COL3)==0) keyvalue = 3; if(GPIO_ReadInputDataBit(GPIOB,COL4)==0) keyvalue = 10; GPIO_SetBits(GPIOA,ROW1); GPIO_ResetBits(GPIOA,ROW2); if(GPIO_ReadInputDataBit(GPIOB,COL1)==0) keyvalue = 4; if(GPIO_ReadInputDataBit(GPIOB,COL2)==0) keyvalue = 5; if(GPIO_ReadInputDataBit(GPIOB,COL3)==0) keyvalue = 6; if(GPIO_ReadInputDataBit(GPIOB,COL4)==0) keyvalue = 11; GPIO_SetBits(GPIOA,ROW2); GPIO_ResetBits(GPIOA,ROW3); if(GPIO_ReadInputDataBit(GPIOB,COL1)==0) keyvalue = 7; if(GPIO_ReadInputDataBit(GPIOB,COL2)==0) keyvalue = 8; if(GPIO_ReadInputDataBit(GPIOB,COL3)==0) keyvalue = 9; if(GPIO_ReadInputDataBit(GPIOB,COL4)==0) keyvalue = 12; GPIO_SetBits(GPIOA,ROW3); GPIO_ResetBits(GPIOA,ROW4); if(GPIO_ReadInputDataBit(GPIOB,COL1)==0) keyvalue = 14; if(GPIO_ReadInputDataBit(GPIOB,COL2)==0) keyvalue = 0; if(GPIO_ReadInputDataBit(GPIOB,COL3)==0) keyvalue = 15; if(GPIO_ReadInputDataBit(GPIOB,COL4)==0) keyvalue = 13; GPIO_SetBits(GPIOA,ROW4); return keyvalue; } int main(void) { uint8_t keyvalue = 0xff; uint8_t num1 = 0,num2 = 0; uint8_t op = 0; uint32_t result = 0; char str[10]; GPIO_Configuration(); LCD5110_GPIO_Configuration(); LCD5110_Init(); LCD5110_Clear(); while(1) { keyvalue = KeyScan(); if(keyvalue!=0xff) { if(keyvalue>=0&&keyvalue<=9) { if(op==0) { num1 = num1*10+keyvalue; sprintf(str,"%d",num1); LCD5110_Write_String(0,0,str); } else { num2 = num2*10+keyvalue; sprintf(str,"%d",num2); LCD5110_Write_String(0,1,str); } } else if(keyvalue>=10&&keyvalue<=13) { op = keyvalue; LCD5110_Write_Char(op+47); } else if(keyvalue==14) { num1 = 0; num2 = 0; op = 0; result = 0; LCD5110_Clear(); } else if(keyvalue==15) { switch(op) { case 10: result = num1+num2; break; case 11: result = num1-num2; break; case 12: result = num1*num2; break; case 13: result = num1/num2; break; default: break; } sprintf(str,"%d",result); LCD5110_Write_String(0,2,str); } } } } ```

相关推荐

最新推荐

recommend-type

STM32F103C8T6开发板+GY521制作Betaflight飞控板详细图文教程

STM32F103C8T6黑色开发板1个(11.5元) GY-521加速度计模块1个(3.8元) ams1117-3.3电压转换芯片1个(0.38元) 5V有源蜂鸣器1个(0.43元) 5cm*7cm洞洞板1个(0.45元)  肖特基二极管2个 ss8050三极管2个 1k电阻2个,...
recommend-type

【MCU实战经验】基于STM32F103C8T6的hart总线收发器设计

HART总线调试器是基于HART现场工业总线协议研制的可以与现场支持HART总线协议的变送器终端进行通信的一种便携式仪器。使用本设备可以对现场终端的测量范围、阻尼时间、显示模式等参数变量进行现场设定和调校,并能对...
recommend-type

MAX30102心率血氧传感器在STM32F103C8T6上的应用

标准库与HAL库,用IO口模拟IIC void I2C_GPIO_Config(void) //IIC引脚初始化 { #ifdef STDLIB GPIO_InitTypeDef GPIO_InitStructure; RCC_APB2PeriphClockCmd&#40;RCC_APB2Periph_GPIOB , ENABLE&#41;...
recommend-type

启明欣欣stm32f103rct6开发板原理图

启明欣欣stm32f103rct6开发板原理图 哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB取整函数与Web开发的作用:round、fix、floor、ceil在Web开发中的应用

![MATLAB取整函数与Web开发的作用:round、fix、floor、ceil在Web开发中的应用](https://img-blog.csdnimg.cn/2020050917173284.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2thbmdqaWVsZWFybmluZw==,size_16,color_FFFFFF,t_70) # 1. MATLAB取整函数概述** MATLAB取整函数是一组强大的工具,用于对数值进行
recommend-type

我想做python的算法工程师,我应该学什么?学习的顺序是什么?网上有什么推荐的免费课程吗?回答具体精确一点不要太笼统

对于想要成为 Python 算法工程师的人来说,他们应该先从掌握 Python 的基础语法开始,然后学习数据结构和算法,并且要深入了解 Python 中的一些科学计算和数据处理库,比如 NumPy、Pandas 等。 学习的顺序可以是先学习基础语法和编程技巧,然后再学习数据结构和算法相关的知识,最后深入了解数据处理和科学计算相关的库。 对于免费课程的推荐,我建议你可以先去 Coursera、edX、Udacity 等网站上寻找相关课程,这些网站上有很多优质的 Python 编程和算法课程,你可以根据自己的需求和学习进度进行选择。此外,还可以考虑一些在线编程网站,如 HackerRank、L
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依