終于寫計算器了,其實計算器老早就寫好了的,只是那會一直在忙考試還有實驗室項目,所以沒能空出時間來寫博客?,F(xiàn)在寒假在家,終于可以靜心的學點東西了。 下面就先寫點自己寫這個程序的過程。其實這是個單片機課的期末課題,但是沒有幾個能寫的好的。計算器其實要考慮周全也是很復雜的,。但我們只要求做簡易計算器,所以我的計算器只有整數(shù)加減乘除,帶負數(shù)功能。經(jīng)過檢驗,實用性還是可以的。
這個程序的整體思路很簡單,主要是一些細節(jié)的處理。
思路是,先矩陣鍵盤掃描,監(jiān)測運算符號按下,存儲兩個運算數(shù),計算結(jié)果,整個過程的實時顯示。
先是矩陣鍵盤掃描,我以前一直用的郭天祥教的方法,這種方法很好理解,但是缺點是代碼太長了,于是我上網(wǎng)去找一種簡單的矩陣鍵盤掃描。(相比于埋頭苦想,有時候去網(wǎng)上找方法也是不錯的)
void keyscan()
{
uchar h,l;
if(keypress())
{
P3=0X0F;
_nop_();
h=P3;
h&=0X0F;//讀取按鍵所在‘行’
P3=0XF0;
_nop_();
_nop_();
l=P3;
l&=0XF0;//讀取按鍵所在‘列’
key=h+l;//最后相加作為SWITCH CASE的選擇
//這種掃描過程很清楚明了是吧
switch(key)
{
case 0xEE:key=1;Input[i]=1;break;// 1
case 0xDE:key=4;Input[i]=4;break;// 4
case 0xBE:key=7;Input[i]=7;break;// 7
case 0x7E:key=0;Input[i]=0;break; /// 0
case 0xED:key=2;Input[i]=2;break;// 2
case 0xDD:key=5;Input[i]=5;break;// 5
case 0xBD:key=8;Input[i]=8;break; // 8
case 0x7D:key=16;i--;break; // = 16
case 0xEB:key=3;Input[i]=3;break; // 3
case 0xDB:key=6;Input[i]=6;break; // 6
case 0xBB:key=9;Input[i]=9;break; // 9
case 0x7B: clear();break; // c 17
case 0xE7:key=18;Input[i]=+;n=i;break; // + 18
case 0xD7:key=19;Input[i]=-;n=i;break;// - 19
case 0xB7:key=20;Input[i]=*;n=i;break; // * 20
case 0x77:key=21;Input[i]=/;n=i;break; // / 21
default:key=22;
}
i++;
while(keypress());
}
}
我的keyscan()函數(shù)就出來了。。。
把每次按鍵的數(shù)存入數(shù)組,然后一直顯示數(shù)組成員就可以達到實時顯示輸入數(shù)字的效果了。
void jisuan(int n,int l,uchar yusuan)
{
int a=0,b=0,c=0,result;
uchar x;
for(x=0;x
{
a+=(Input[x]-0)*pow(10,n-x-1);
}
for(x=n+1;x
{
b+=(Input[x]-0)*pow(10,l-x-1);
}
// write_num(0,1,a);
// write_num(0,2,b);
switch(yusuan)
{
case +:result=a+b;write_num(0,1,result); break; // + 18
case -:result=a-b;write_num(0,1,result);break;// - 19
case *:result=a*b;write_num(0,1,result);break; // * 20
case /:result=a/b;write_num(0,1,result);break; // / 21
}
}
這個就是計算函數(shù)了,里面的
a+=(Input[x]-0)*pow(10,n-x-1);
b+=(Input[x]-0)*pow(10,l-x-1);
這是用來計算輸入數(shù)值的,這個應該可以理解
最后是主函數(shù):
void main()
{
Lcd_Init();
// write_string(0,3,"check ok");
while(1)
{
keyscan();
write_string(0,0,Input);
if(key==16)
{
l=i;
if(n>0&&n!=i-1)
{
switch(Input[n])
{
case +:jisuan(n,l,+); break; // + 18
case -:jisuan(n,l,-);break;// - 19
case *:jisuan(n,l,*);break; // * 20
case /:jisuan(n,l,/);break; // / 21
}
}
else
{
write_string(0,1,"ERROR");
}
}
delayms(1);
}
while(1);
}
簡易計算器的51程序就此結(jié)束了
評論