終于寫計(jì)算器了,其實(shí)計(jì)算器老早就寫好了的,只是那會(huì)一直在忙考試還有實(shí)驗(yàn)室項(xiàng)目,所以沒能空出時(shí)間來寫博客?,F(xiàn)在寒假在家,終于可以靜心的學(xué)點(diǎn)東西了。
下面就先寫點(diǎn)自己寫這個(gè)程序的過程。其實(shí)這是個(gè)
單片機(jī)課的期末課題,但是沒有幾個(gè)能寫的好的。計(jì)算器其實(shí)要考慮周全也是很復(fù)雜的,。但我們只要求做
簡(jiǎn)易計(jì)算器,所以我的計(jì)算器只有整數(shù)加減乘除,帶負(fù)數(shù)功能。經(jīng)過檢驗(yàn),實(shí)用性還是可以的。這個(gè)程序的整體思路很簡(jiǎn)單,主要是一些細(xì)節(jié)的處理。思路是,先
矩陣鍵盤掃描,監(jiān)測(cè)運(yùn)算符號(hào)按下,存儲(chǔ)兩個(gè)運(yùn)算數(shù),計(jì)算結(jié)果,整個(gè)過程的實(shí)時(shí)顯示。先是矩陣鍵盤掃描,我以前一直用的郭天祥教的方法,這種方法很好理解,但是缺點(diǎn)是代碼太長(zhǎng)了,于是我上網(wǎng)去找一種簡(jiǎn)單的矩陣鍵盤掃描。(相比于埋頭苦想,有時(shí)候去網(wǎng)上找方法也是不錯(cuò)的)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ù)組成員就可以達(dá)到實(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}}這個(gè)就是計(jì)算函數(shù)了,里面的a+=(Input[x]-0)*pow(10,n-x-1);b+=(Input[x]-0)*pow(10,l-x-1);這是用來計(jì)算輸入數(shù)值的,這個(gè)應(yīng)該可以理解最后是主函數(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);}簡(jiǎn)易計(jì)算器的51程序就此結(jié)束了
關(guān)鍵詞:
51單片機(jī)12864簡(jiǎn)易計(jì)算