當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]近來,看到好幾個(gè)要求用 51 單片機(jī)和數(shù)碼管來設(shè)計(jì)計(jì)算器的題目51 單片機(jī),本質(zhì)上是微控制器,以邏輯運(yùn)算見長。用它來設(shè)計(jì)計(jì)算器 ?不知道誰想出來的這樣的題目,思路明顯就是跑偏了,呵呵特別是后一個(gè)的題目


近來,看到好幾個(gè)要求用 51 單片機(jī)和數(shù)碼管來設(shè)計(jì)計(jì)算器的題目


51 單片機(jī),本質(zhì)上是微控制器,以邏輯運(yùn)算見長。

用它來設(shè)計(jì)計(jì)算器 ?

不知道誰想出來的這樣的題目,思路明顯就是跑偏了,呵呵


特別是后一個(gè)的題目,不僅要求能加減乘除,竟然還要求選用數(shù)碼管來顯示。

如果是選用 LCD1602 液晶屏來顯示,勉強(qiáng)還算對路。

數(shù)碼管,只能顯示出來減號,讓它顯示加號、乘號、除號,都是不可能的。


一些網(wǎng)友為這個(gè)題目提供了答案,可是沒有一個(gè)像樣的,呵呵

提問者也明顯不滿意,又反復(fù)提問了好幾次。


前一個(gè)設(shè)計(jì)計(jì)算器的題目,提問者提供了部分程序和電路,要求如下:


老師要求只要3個(gè)數(shù)碼管,完成10以內(nèi)加減。

第一個(gè)數(shù)碼管表示第1個(gè)數(shù)字,

第二個(gè)數(shù)碼管表示符號(+或-,用A-F任意表示),

第三個(gè)數(shù)碼管表示第2個(gè)數(shù)字。

按下等號(等號也用A-F任意表示)三個(gè)數(shù)碼管熄燈,第一個(gè)數(shù)碼管顯示答案。


因?yàn)樘釂栒呓o出的資料較多,要求也非常簡明,故此做而論道針對這個(gè)題目,給出了一個(gè)答案。

(另外一個(gè)題目,就不回答了。)


做而論道設(shè)計(jì)的計(jì)算器電路,和提問者給定的,稍有不同。


仿真運(yùn)行后的畫面如下:


這是在輸入了 1+8 時(shí)的截圖,其中的+,數(shù)碼管顯示不出來,只好用【-1】冒充了一下。



做而論道的設(shè)計(jì),有幾個(gè)特點(diǎn):


1.具有光標(biāo)顯示功能。


在等待用戶按鍵時(shí),光標(biāo)會在指定的位置上閃動(dòng)。

當(dāng)輸入一個(gè)數(shù)字后,光標(biāo)自動(dòng)向右移動(dòng)一位,繼續(xù)閃爍。


2.選用了計(jì)算器的標(biāo)準(zhǔn)鍵盤。


由于自定義的 4×4 鍵盤不好看,而且電路復(fù)雜,不如用 PROTEUS 帶來的標(biāo)準(zhǔn)鍵盤。

只是這樣弄,鍵盤的編碼表就要重新編寫了,這也是一般人難以勝任的工作。


3.具有無效鍵排除功能。


在不同的位置只能輸入特定的按鍵,比如在輸入數(shù)字時(shí),只能輸入0~9,按下其它的按鍵,

本系統(tǒng)不予理會。

同樣,在需要輸入等號=時(shí),按下數(shù)字鍵,本系統(tǒng)也不予理會。


4.可以顯示大于兩位數(shù)的結(jié)果。


題目僅僅要求顯示一位數(shù)字的結(jié)果。而本系統(tǒng)最大可以顯示 18,即 9 + 9 的結(jié)果。


5.可以顯示負(fù)數(shù)。


題目對此沒有要求。本系統(tǒng)則可以顯示負(fù)號和絕對值,比如,輸入 4 - 9 =,

本系統(tǒng)就能顯示出來:-5。


6.可以循環(huán)工作。


題目對此也沒有要求。本系統(tǒng)則在顯示結(jié)果之后,再按下 ON/C,即可清除顯示屏,重新開始工作。


還有一些有特色的地方,就不多說了,請大家自己發(fā)掘。


全部程序如下:


//一位數(shù)的加減計(jì)算器


#include


//------------------------------------

char led_mod[] = {

? ? 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,

? ? 0x7f,0x6f,0x77,0x7c,0x58,0x5e,0x79,0x71,0x46,0x40};

//------------------------------------

char key_buf[] = {

? ? 0xd7,0xeb,0xdb,0xbb,?0xed,0xdd,0xbd,0xee,?

? ? 0xde,0xbe,0xe7,0xb7,?0x77,0x7b,0x7d,0x7e};

//------------------------------------

void delay(char i)

{

? ? unsigned ?char ?j, k;

? ? for(j = i; j > 0; j--) ?for(k = 125; k > 0; k--);

}

//------------------------------------

char getKey(void)

{

? ? char key_scan[] = {0xef, 0xdf, 0xbf, 0x7f};

? ? char i, j;

? ? for(i = 0; i < 4; i++){

? ? ? P2 = key_scan[i];

? ? ? if((P2 & 0x0f) != 0x0f)?

? ? ? ? for(j = 0; j < 16; j++)

? ? ? ? ? if(key_buf[j] == P2)

? ? ? ? ? ? return j; ? ? ?

? ? }

? ? return -1;

}

//------------------------------------

//以上,基本上都是提問者給出的資料

//------------------------------------

char FlashKey(char p, char d)

{

? ? unsigned ?char ?i, k;

? ? while(1) {

? ? ? for(i = 100; i > 0; i--) ?{

? ? ? ? delay(10);

? ? ? ? k = getKey();

? ? ? ? if (k < 16) ?return k; ?

? ? ? }

? ? ? if (p == 0) ?P0 = d;

? ? ? if (p == 1) ?P1 = d;

? ? ? if (p == 3) ?P3 = d;

? ? ? for(i = 100; i > 0; i--) ?{

? ? ? ? delay(10);

? ? ? ? k = getKey();

? ? ? ? if (k < 16) ?return k; ?

? ? ? }

? ? ? if (p == 0) ?P0 = 255;

? ? ? if (p == 1) ?P1 = 255;

? ? ? if (p == 3) ?P3 = 255;

? ? }

}

//------------------------------------

void main(void)

{

? ? char ?key, aa, ff, bb, cc;

? ? while(1) {

//-------------------------------

? ? ? key = FlashKey(0, 0xf7);

? ? ? while (key > 9) ?key = FlashKey(0, 0xf7);

? ? ? P0 = ~led_mod[key]; aa = key; //0~9

? ? ? while (getKey() != -1); ? ?//等待釋放

//-------------------------------

? ? ? key = FlashKey(1, 0xf7);

? ? ? while ((key != 12) && (key != 13)) ?key = FlashKey(1, 0xf7);

? ? ? P1 = ~led_mod[key + 4]; ff = key; //加減運(yùn)算

? ? ? while (getKey() != -1); ? ?//等待釋放

//-------------------------------

? ? ? key = FlashKey(3, 0xf7);

? ? ? while (key > 9) ?key = FlashKey(3, 0xf7);

? ? ? P3 = ~led_mod[key]; bb = key; //0~9

? ? ? while (getKey() != -1); ? ?//等待釋放

//-------------------------------

? ? ? while (getKey() != 11); ? ?//等號

? ? ? if(ff == 12) ?cc = aa + bb; ? ? //進(jìn)行計(jì)算

? ? ? if(ff == 13) ?cc = aa - bb;

? ? ? P0 = 255; ?P1 = 255; ?P3 = 255; //清屏

? ? ? if ? (cc < 0) {P1 = 0xbf; ?P3 = ~led_mod[-cc];}

? ? ? else if (cc > 9) {P1 = ~led_mod[cc / 10]; P3 = ~led_mod[cc % 10];}

? ? ? else ?P3 = ~led_mod[cc];

? ? ? while (getKey() != -1); ? ?//等待釋放

//-------------------------------

? ? ? while (getKey() != 10); ? ?//ON/C

? ? ? P0 = 255; ?P1 = 255; ?P3 = 255; //清屏

? ? ? while (getKey() != -1); ? ?//等待釋放

//-------------------------------

? ? }

}

//------------------------------------


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉