stm32f103c8t6 实现计算器

时间: 2023-10-16 14:02:48 浏览: 87
首先,STM32F103C8T6是一种32位的ARM Cortex-M3微控制器,具有优秀的性能和丰富的外设。要实现一个计算器,我们可以利用STM32F103C8T6的高性能和丰富的外设来设计和实现。 首先,我们需要设计一个合适的用户界面,可以使用LCD显示屏或者OLED显示屏来显示数字和计算结果。然后,我们可以利用STM32F103C8T6的GPIO引脚连接键盘矩阵,用于用户输入数字和运算符。通过矩阵扫描和按键映射,我们可以获取用户的输入。 接下来,我们可以使用STM32F103C8T6的定时器和中断功能来实现计算器的按键响应和计算逻辑。我们可以为每个数字和运算符分配一个特定的中断处理函数,当用户按下相应的按键时,会触发对应的中断处理函数。在中断处理函数中,我们可以对用户输入进行处理,并根据用户的操作进行相应的计算。 在计算逻辑方面,我们可以使用C语言编写对数字和运算符的处理函数,例如实现加减乘除等运算。我们可以使用变量和数组来保存用户的输入和计算结果,并在LCD显示屏上实时显示。 最后,我们需要编写主循环程序,在循环中不断检测是否有按键按下,并根据按键的种类调用相应的中断函数进行处理。同时,我们还可以添加一些额外的功能,如清除输入、取反、小数点等。 总的来说,通过充分利用STM32F103C8T6的性能和外设,我们可以实现一个功能完善的计算器,具有良好的用户界面和计算逻辑。
相关问题

stm32f103c8t6实现简易计算器

以下是基于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); } } } } ```

stm32f103c8t6简易计算器

基于STM32F103C8T6的简易计算器可以实现基本的多位加减乘除功能,输入来自4*4键盘,输出在LCD12864上显示。以下是一个简单的实现步骤: 1. 首先需要定义键盘的行列式矩阵,以便读取键盘输入。 2. 然后需要定义LCD12864的引脚连接方式,以便在屏幕上显示结果。 3. 接下来需要编写读取键盘输入的代码,并将输入的数字和运算符存储在一个数组中。 4. 然后需要编写计算代码,根据输入的运算符进行相应的计算,并将结果存储在一个变量中。 5. 最后需要将计算结果在LCD12864上显示出来。 以下是一个简单的代码示例: ```c #include "stm32f10x.h" #include "lcd12864.h" #include "key.h" int main(void) { u8 key; u8 input[10]; u8 index = 0; u8 op = '+'; u32 result = 0; LCD_Init(); // 初始化LCD12864 KEY_Init(); // 初始化键盘 while (1) { key = KEY_Scan(); // 读取键盘输入 if (key != 0xff) // 如果有输入 { if (key >= '0' && key <= '9') // 如果是数字 { input[index++] = key; // 存储数字 } else if (key == '+' || key == '-' || key == '*' || key == '/') // 如果是运算符 { input[index] = '\0'; // 数字数组结束符 result = calculate(result, atoi(input), op); // 计算结果 op = key; // 存储运算符 index = 0; // 数字数组下标清零 } else if (key == '=') // 如果是等号 { input[index] = '\0'; // 数字数组结束符 result = calculate(result, atoi(input), op); // 计算结果 LCD_ShowNum(0, 0, result, 5, 16); // 在LCD上显示结果 op = '+'; // 运算符清零 index = 0; // 数字数组下标清零 result = 0; // 结果清零 } } } } u32 calculate(u32 a, u32 b, u8 op) { switch (op) { case '+': return a + b; case '-': return a - b; case '*': return a * b; case '/': return a / b; default: return 0; } } ```

相关推荐

最新推荐

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

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

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
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。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

实现实时监控告警系统:Kafka与Grafana整合

![实现实时监控告警系统:Kafka与Grafana整合](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9tbWJpei5xcGljLmNuL21tYml6X2pwZy9BVldpY3ladXVDbEZpY1pLWmw2bUVaWXFUcEdLT1VDdkxRSmQxZXB5R1lxaWNlUjA2c0hFek5Qc3FyRktudFF1VDMxQVl3QTRXV2lhSWFRMEFRc0I1cW1ZOGcvNjQw?x-oss-process=image/format,png) # 1.1 Kafka集群架构 Kafka集群由多个称为代理的服务器组成,这