c++ - 使用AVRstudi基于ATMega8的计算器

标签 c++ c calculator avr

关于计算器:

基本上这个计算器是用公式计算铜线和铝线在环境温度下的电阻 R2= R1*(1+alpha(T-25))

这里 R2 将是输出,R1 将是用户使用 4x4 矩阵键盘输入的值(其中包括 12.5 等十进制值),T 是温度传感器 LM35 记录的温度(以摄氏度为单位)。 铜的 alpha = 0.0039 铝的 alpha = 0.0042

它应该如何工作:

基本上,温度将由计算器记录,计算器将给出输入 T。用户将使用键盘输入 25 摄氏度时的电阻值。 现在是 0-9 和“.”键用于输入值。 此后,当用户在键盘上按“+”时,它应该执行铜的公式并在 LCD 上显示结果,同样,当用户按“-”时,它应该执行铝的公式。让我们暂时保留“*”、“/”和“=”按钮。

到目前为止的进展:

使用我在附件中发送给您的代码,我能够正确地在屏幕上获取温度,我能够看到 R1 的值(即 25 摄氏度时的电阻值)现在我不知道如何使用这些值来获取输出。

请帮我解决这个问题。 :)

谢谢和问候, 莫希特·戈亚尔

#define F_CPU 1000000UL
#include <avr/io.h>
#include <stdio.h>
#include <stdlib.h>
#include <util/delay.h>
#include "lcd.h"
#include "lcd.c"
#include <math.h>
#define KB_PORT_OUT PORTB
#define KB_PORT_IN PINB
void port_init(void)
{

DDRB  = 0x0f;       //Key-board port, higer nibble - input, lower nibble -     output
 PORTB = 0xff;  
}
 void init_devices(void)
{
port_init();

 MCUCR = 0x00;
 TIMSK = 0x00; //timer interrupt sources
 } 

void InitADC()
{
ADMUX=(1<<REFS0);
ADCSRA=(1<<ADEN)|(1<<ADPS1)|(1<<ADPS0);

}
uint16_t ReadADC (uint8_t ch)
{
ch=ch&0b00000111;
ADMUX|=ch;
ADCSRA|=(1<<ADSC);
while (! (ADCSRA & (1<<ADIF)));
ADCSRA|=(1<<ADIF);
return (ADC);
}
void Wait ()
{
uint8_t i;
for (i=0;i<1;i++)
_delay_loop_2(0);
}
void main()   
{

char Temp[3];
uint16_t adc_result,mV;
int t;
lcd_init (LCD_DISP_ON);
lcd_clrscr();
InitADC();
lcd_gotoxy(0,0);
lcd_puts("R1=");
lcd_gotoxy(9,0);
lcd_puts(",T=");
lcd_gotoxy(15,0);
lcd_puts("C");
lcd_gotoxy(0,1);
lcd_puts("R2=");
while(1)
{
adc_result=ReadADC(0);
mV=(int)(1000.0*5.0*(((float)adc_result)/1023.0));
t=(int)(mV/10);
sprintf(Temp,"%d",t);
lcd_gotoxy(12,0);
lcd_puts(Temp);
Wait();
unsigned char Res, upperNibble, myCharPointer, keyCode, keyPressed, j;
int a=0, b=0, c=0, d=0, display=0;
 init_devices();


 lcd_gotoxy(3,0);
 while(1)
 {
    upperNibble = 0xff;

    for(j=0; j<4; j++)
    {
     _delay_ms(1);
     KB_PORT_OUT = ~(0x01 << j);
     _delay_ms(1);                        //delay for port o/p settling
     upperNibble = KB_PORT_IN | 0x0f;

     if (upperNibble != 0xff)
     {
       _delay_ms(20);                //key debouncing delay
       upperNibble = KB_PORT_IN | 0x0f;
       if(upperNibble == 0xff) goto OUT;

       keyCode = (upperNibble & 0xf0) | (0x0f & ~(0x01 << j));

       while (upperNibble != 0xff)
         upperNibble = KB_PORT_IN | 0x0f;

       _delay_ms(20);                  //key debouncing delay

       switch (keyCode)            //generating key characetr to display on LCD
       {
        case (0xee): keyPressed = "1"; 
        a=1;
        b=b*10+1;
                     break;
        case (0xed): keyPressed = "4";
        a=4;
        b=b*10+4;
                     break;
        case (0xeb): keyPressed = "7"; 
        a=7;
        b=b*10+7;
                     break;
        case (0xe7): keyPressed = "."; 

                     break;
        case (0xde): keyPressed = "2"; 
        a=2;
        b=b*10+2;
                     break;
        case (0xdd): keyPressed = "5"; 
        a=5;
        b=b*10+5;
                     break;
        case (0xdb): keyPressed = "8"; 
        a=8;
        b=b*10+8;
                     break;
        case (0xd7): keyPressed = "0"; 
        a=0;
        b=b*10+0;
                     break;
        case (0xbe): keyPressed = "3"; 
        a=3;
        b=b*10+3;
                     break;
        case (0xbd): keyPressed = "6"; 
        a=6;
        b=b*10+6;
                     break;
        case (0xbb): keyPressed = "9"; 
        a=9;
        b=b*10+9;
                     break;
        case (0xb7): keyPressed = "="; 
                     break;
        case (0x7e): keyPressed = "A"; 
                     break;
        case (0x7d): keyPressed = "B"; 
                     break;
        case (0x7b): keyPressed = "C"; 
                     break;
        case (0x77): keyPressed = "D"; 
                     break;
        default    : keyPressed = "X";
        }//end of switch

        lcd_puts(keyPressed);

 lcd_gotoxy(3,1);
 lcd_puts(keyPressed);










       OUT:;
      }//end of if
    }//end of for
}//end of while(1)  

return 0; 
 } 

}

最佳答案

读取输入的一种方法是读取字符数组中的字符(在 switch case block 中使用 strcat 函数将按键附加到字符数组)。然后检查格式是否正确。然后将字符数组中的数字转换为 float 并在计算中使用它,如 question link 中所述。

将按键附加到字符串的方法:

char s[25]="";
strcat(s,"1")

我注意到一个错误
更改

keypressed="1"

keypressed='1'

在所有此类情况下。 “1”是常量字符数组。 “1”是字符

或者更改按键字符数组的类型并使用 strcpy 为其分配任何字符串。

strcpy(keypressed,"1")

关于c++ - 使用AVRstudi基于ATMega8的计算器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18490942/

相关文章:

python - 使用默认参数提升 python make_constructor

c - 从用户那里获取内存地址

c - scanf 不超过缓冲区溢出

c - C语言的时间计算器

带堆栈的 C 计算器程序

c++ - 如何声明指向二维数组的指针数组

c++ - 通过将文本文件发送到标准输入来自动测试 Visual Studio 中的 C++ 控制台应用程序?

c++ - 解析 C++ 中的命令行参数?

c - fseek、fread 和返回二进制文件中的指针 (C) 函数无法正常工作

Java GUI 计算器文本字段