基于51單片機(jī)的俄羅斯方塊設(shè)計(jì)論文,基于,51,單片機(jī),俄羅斯方塊,設(shè)計(jì),論文
*******************學(xué)院
畢業(yè)設(shè)計(jì)(論文)
題 目:基于單片機(jī)的俄羅斯方塊游戲系統(tǒng)的設(shè)計(jì)
學(xué)習(xí)中心:
專 業(yè): 通信工程
年 級(jí):
姓 名:
學(xué) 號(hào):
指導(dǎo)教師:
年 月 日
********************學(xué)院畢業(yè)設(shè)計(jì)(論文)
摘 要
俄羅斯方塊是一款風(fēng)靡全球的電視游戲機(jī)和掌上游戲機(jī)游戲,它由俄羅斯人阿列克謝·帕基特諾夫發(fā)明,故得此名。俄羅斯方塊的基本規(guī)則是移動(dòng)、旋轉(zhuǎn)和擺放游戲自動(dòng)輸出的各種方塊,使之排列成完整的一行或多行并且消除得分。由于上手簡(jiǎn)單、老少皆宜,從而家喻戶曉,風(fēng)靡世界。
這次設(shè)計(jì)將使用52單片機(jī)和HD61202液晶顯示控制驅(qū)動(dòng)器和JM12864J液晶顯示器組合,來實(shí)現(xiàn)比較簡(jiǎn)單的俄羅斯方塊設(shè)計(jì)。
此次設(shè)計(jì)初期是在keil和proteus聯(lián)合仿真中進(jìn)行,編程語言為51匯編,后期是進(jìn)行實(shí)物焊接。
論文描述了俄羅斯方塊的主要功能函數(shù)的實(shí)現(xiàn)。
關(guān)鍵詞:俄羅斯方塊,算法,仿真
Abstract
Tetris is a popular television game machine and game machine game, which Alexei Pajitnov invented by Russians, it was this name. Tetris are the basic rules of movement, rotation and display the game automatically output of the box, which are arranged into a complete one or more rows and eliminate scores. Due to use simple, ages, thus make known to every family, swept the world.
Based on single chip computer of the curriculum design of opportunity, I will use the 51 single-chip microcomputer and HD61202 LCD control driver and JM12864J liquid crystal display combination, to carry out a more simple Russian square design.
This design is in early keil and proteus joint simulation, programming language for 51 assembly, later is welding material.
The paper describes the main functions of the Russian box function of the realization of.
Keywords: Russian square, Algorithm, Simulation
2
***************************學(xué)院畢業(yè)設(shè)計(jì)(論文)
目 錄
摘 要 1
Abstract 2
目 錄 1
引 言 3
1整體設(shè)計(jì)方案 4
1.1 系統(tǒng)的核心部分單片機(jī) 4
1.2 液晶顯示模塊 8
2 系統(tǒng)程序的設(shè)計(jì) 16
2.1 俄羅斯方塊驅(qū)動(dòng)流程圖 16
2.2 俄羅斯方塊所有繪圖工作流程圖 17
2.3 俄羅斯方塊中按下鍵的流程圖 18
2.4 俄羅斯方塊所有繪圖工作流程圖 19
3系統(tǒng)仿真 20
3.1 Proteus軟件介紹 20
3.2 Keil軟件介紹 20
3.3俄羅斯方塊系統(tǒng)PROTUES仿真 21
結(jié) 論 24
參 考 文 獻(xiàn) 25
附 錄A 電路原理圖 26
附 錄B 主要程序 28
附 錄C 英文資料和中文翻譯 45
結(jié) 束 語 1
*********************************學(xué)院畢業(yè)設(shè)計(jì)(論文)
引 言
游戲是人們活動(dòng)中一項(xiàng)非常重要的內(nèi)容,有人認(rèn)為如果哪一天人類對(duì)所有的游戲都失去興趣,恐怕世界的末日就要到了。電腦對(duì)游戲的貢獻(xiàn)有目共睹,現(xiàn)在摸過電腦的人很少有沒玩過電腦游戲的,喜歡游戲的人也很少有不玩電腦的。
俄羅斯方塊是一款風(fēng)靡全球的電視游戲機(jī)和掌上游戲機(jī)游戲,它曾經(jīng)造成的轟動(dòng)與造成的經(jīng)濟(jì)價(jià)值可以說是游戲史上的一件大事。這款游戲最初是由蘇聯(lián)的游戲制作人Alex Pajitnov制作的,它看似簡(jiǎn)單但卻變化無窮,令人上癮。相信大多數(shù)用戶都還記得為它癡迷得茶不思飯不想的那個(gè)俄羅斯方塊時(shí)代。究其歷史,俄羅斯方塊最早還是出現(xiàn)在PC機(jī)上,而我國(guó)的用戶都是通過紅白機(jī)了解、喜歡上它的?,F(xiàn)在聯(lián)眾又將重新掀起這股讓人沉迷的俄羅斯方塊風(fēng)潮。對(duì)一般用戶來說,它的規(guī)則簡(jiǎn)單,容易上手,且游戲過程變化無窮,而在"聯(lián)眾俄羅斯方塊"中,更有一些聯(lián)眾網(wǎng)絡(luò)游戲所獨(dú)有的魅力――有單機(jī)作戰(zhàn)與兩人在線對(duì)戰(zhàn)兩種模式,用戶可任選一種進(jìn)行游戲。網(wǎng)絡(luò)模式還增加了積分制,使用戶既能感受到游戲中的樂趣,也給用戶提供了一個(gè)展現(xiàn)自己高超技藝的場(chǎng)所。
俄羅斯方塊游戲可以說是隨計(jì)算機(jī)的發(fā)展而發(fā)展,并不斷推陳出新演變出各種類似游戲, 深受廣大玩家喜愛。這個(gè)游戲有的簡(jiǎn)單, 有的復(fù)雜, 但其根本原理是一樣的都是對(duì)運(yùn)動(dòng)的方塊進(jìn)行組合, 來訓(xùn)練玩家的反應(yīng)能力。本文利用單片機(jī)進(jìn)行俄羅斯方塊設(shè)計(jì),采用51匯編語言進(jìn)行編程,基于匯編語言的原因是在編寫程序的過程中,對(duì)于程序的執(zhí)行會(huì)有一個(gè)比較直觀的表現(xiàn)。
1 系統(tǒng)的核心部分單片機(jī)
1.1 單片機(jī)的選擇
單片機(jī)微型計(jì)算機(jī)是微型計(jì)算機(jī)的一個(gè)重要分支,也是頗具生命力的機(jī)種。單片機(jī)微型計(jì)算機(jī)簡(jiǎn)稱單片機(jī),特別適用于控制領(lǐng)域,故又稱為微控制器。
通常,單片機(jī)由單塊集成電路芯片構(gòu)成,內(nèi)部包含有計(jì)算機(jī)的基本功能部件:中央處理器、存儲(chǔ)器和I/O接口電路等。因此,單片機(jī)只需要和適當(dāng)?shù)能浖巴獠吭O(shè)備相結(jié)合,便可成為一個(gè)單片機(jī)控制系統(tǒng)。
20世紀(jì)末,電子技術(shù)獲得了飛速的發(fā)展,在其推動(dòng)下,現(xiàn)代電子產(chǎn)品幾乎滲透了社會(huì)的各個(gè)領(lǐng)域,有力地推動(dòng)了社會(huì)生產(chǎn)力的發(fā)展和社會(huì)信息化程度的提高,同時(shí)也使現(xiàn)代電子產(chǎn)品性能進(jìn)一步提高,產(chǎn)品更新?lián)Q代的節(jié)奏也越來越快。 時(shí)間對(duì)人們來說總是那么寶貴,工作的忙碌性和繁雜性容易使人忘記當(dāng)前的時(shí)間。忘記了要做的事情,當(dāng)事情不是很重要的時(shí)候,這種遺忘無傷大雅。但是,一旦重要事情,一時(shí)的耽誤可能釀成大禍。
目前,單片機(jī)正朝著高性能和多品種方向發(fā)展趨勢(shì)將是進(jìn)一步向著CMOS化、低功耗、小體積、大容量、高性能、低價(jià)格和外圍電路內(nèi)裝化等幾個(gè)方面發(fā)展。下面是單片機(jī)的主要發(fā)展趨勢(shì)。單片機(jī)應(yīng)用的重要意義還在于,它從根本上改變了傳統(tǒng)的控制系統(tǒng)設(shè)計(jì)思想和設(shè)計(jì)方法。從前必須由模擬電路或數(shù)字電路實(shí)現(xiàn)的大部分功能,現(xiàn)在已能用單片機(jī)通過軟件方法來實(shí)現(xiàn)了。這種軟件代替硬件的控制技術(shù)也稱為微控制技術(shù),是傳統(tǒng)控制技術(shù)的一次革命。
單片機(jī)經(jīng)過3代的發(fā)展,正朝著多功能、高性能、低電壓、低功耗、低價(jià)格、大存儲(chǔ)容量、強(qiáng)I/O功能及較好的結(jié)構(gòu)兼容性方向發(fā)展。其發(fā)展趨勢(shì)不外乎以下幾個(gè)方面:
(1)多功能
單片機(jī)中盡可能地把所需要的存儲(chǔ)器和I/O口都集成在一塊芯片上,使得單片機(jī)可以實(shí)現(xiàn)更多的功能。比如A/D、PWM、PCA(可編程計(jì)數(shù)器陣列)、WDT(監(jiān)視定時(shí)器---看家狗)、高速I/O口及計(jì)數(shù)器的捕獲/比較邏輯等。
有的單片機(jī)針對(duì)某一個(gè)應(yīng)用領(lǐng)域,集成了相關(guān)的控制設(shè)備,以減少應(yīng)用系統(tǒng)的芯片數(shù)量。例如,有的芯片以51內(nèi)核為核心,集成了USB控制器、SMART CARD接口、MP3解碼器、CAN或者I*I*C總線控制器等,LED、LCD或VFD顯示驅(qū)動(dòng)器也開始集成在8位單片機(jī)中。
(2)高效率和高性能
為了提高執(zhí)行速度和執(zhí)行效率,單片機(jī)開始使用RISC、流水線和DSP的設(shè)計(jì)技術(shù),使單片機(jī)的性能有了明顯的提高,表現(xiàn)為:?jiǎn)纹瑱C(jī)的時(shí)鐘頻率得到提高;同樣頻率的單片機(jī)運(yùn)行效率也有了很大的提升;由于集成度的提高,單片機(jī)的尋址能力、片內(nèi)ROM(FLASH)和RAM的容量都突破了以往的數(shù)量和限制。
由于系統(tǒng)資源和系統(tǒng)復(fù)雜程度的增加,開始使用高級(jí)語言(如C語言)來開發(fā)單片機(jī)的程序。使用高級(jí)語言可以降低開發(fā)難度,縮短開發(fā)周期,增強(qiáng)軟件的可讀性和可移植性,便于改進(jìn)和擴(kuò)充功能。
(3)低電壓和低功耗
單片機(jī)的嵌入式應(yīng)用決定了低電壓和低功耗的特性十分重要。由于CMOS等工藝的大量采用,很多單片機(jī)可以在更低的電壓下工作(1.2V或0.9V),功耗已經(jīng)降低到uA級(jí)。這些特性使得單片機(jī)系統(tǒng)可以在更小電源的支持下工作更長(zhǎng)的時(shí)間。
(4)低價(jià)格
單片機(jī)應(yīng)用面廣,使用數(shù)量大,帶來的直接好處就是成本的降低。目前世界各大公司為了提高競(jìng)爭(zhēng)力,在提高單片機(jī)性能的同時(shí),十分注意降低其產(chǎn)品的價(jià)格。
在此,我們采用型號(hào)為AT89S52的單片機(jī)。因?yàn)椋?AT89S52是一種低功耗、高性能CMOS8位微控制器,具有8K在系統(tǒng)可編程Flash存儲(chǔ)器。使用Atmel公司高密度非易失性存儲(chǔ)器技術(shù)制造,與工業(yè)80C51產(chǎn)品指令和引腳完全兼容。片上Flash允許程序存儲(chǔ)器在系統(tǒng)可編程,亦適于常規(guī)編程器。在單芯片上,擁有靈巧的8位CPU和在系統(tǒng)可編程Flash,使得AT89S52為眾多嵌入式控制應(yīng)用系統(tǒng)提供高靈活、超有效的解決方案。
與MCS-51單片機(jī)產(chǎn)品兼容 、8K字節(jié)在系統(tǒng)可編程Flash存儲(chǔ)器、1000次擦寫周期、全靜態(tài)操作:0Hz~33MH、三級(jí)加密程序存儲(chǔ)器 、32個(gè)可編程I/O口線 、三個(gè)16位定時(shí)器/計(jì)數(shù)器八個(gè)中斷源 、全雙工UART串行通道、低功耗空閑和掉電模式 、掉電后中斷可喚醒 、看門狗定時(shí)器 、雙數(shù)據(jù)指針 、掉電標(biāo)識(shí)符 。
AT89S52具有以下標(biāo)準(zhǔn)功能:8K字節(jié)Flash,256字節(jié)RAM,32位I/O口線,看門狗定時(shí)器,2個(gè)數(shù)據(jù)指針,三個(gè)16位定時(shí)器/計(jì)數(shù)器,一個(gè)6向量2級(jí)中斷結(jié)構(gòu),全雙工串行口,片內(nèi)晶振及時(shí)鐘電路。另外,AT89S52可降至0Hz 靜態(tài)邏輯操作,支持2種軟件可選擇節(jié)電模式??臻e模式下,CPU停止工作,允許RAM、定時(shí)器/計(jì)數(shù)器、串口、中斷繼續(xù)工作。掉電保護(hù)方式下,RAM內(nèi)容被保存,振蕩器被凍結(jié),單片機(jī)一切工作停止,直到下一個(gè)中斷或硬件復(fù)位為止。
AT89S52單片機(jī)有PDIP、PLCC、TQFP三種封裝方式,在此我選用DPIP也就是雙列直插封裝的單片機(jī)此種封裝有如下特點(diǎn):
1) 適合PCB的穿孔安裝;
2) 易于對(duì)PCB布線;
3) 操作方便;
1.2 AT89S52引腳功能描述
AT89S52單片機(jī)的管腳說明如圖2.1所示:
圖2.1 DIP封裝 AT89S52單片機(jī)引腳結(jié)構(gòu)圖
(1) VCC:電源。
(2) GND:接地端 。
(3) P0口(P0.0~P0.7):P0口是一個(gè)8位漏極開路的雙向I/O口。作為輸出口,每位能驅(qū)動(dòng)8個(gè)TTL邏輯電平。對(duì)P0端口寫“1”時(shí),引腳用作高阻抗輸入。當(dāng)訪問外部程序和數(shù)據(jù)存儲(chǔ)器時(shí),P0口也被作為低8位地址/數(shù)據(jù)復(fù)用。在這種模式下,P0具有內(nèi)部上拉電阻。在Flash編程時(shí),P0口也用來接收指令字節(jié);在程序校驗(yàn)時(shí),輸出指令字節(jié)。程序校驗(yàn)時(shí),需要外部上拉電阻。
(4)P1口(P1.0~P1.7):P1口是一個(gè)具有內(nèi)部上拉電阻的8位雙向I/O口,P1輸出緩沖器能驅(qū)動(dòng)4個(gè)TTL邏輯電平。對(duì)P1端口寫“1”時(shí),內(nèi)部上拉電阻把端口拉高,此時(shí)可以作為輸入口使用。作為輸入使用時(shí),被外部拉低的引腳由于內(nèi)部電阻的原因,將輸出電流(IIL)。此外,P1.0和 P1.2分別作定時(shí)器/計(jì)數(shù)器2的外部計(jì)數(shù)輸入(P1.0/T2)和時(shí)器/計(jì)數(shù)器2的觸發(fā)輸入(P1.1/T2EX),具體如表2-1所示:
在 Flash編程和校驗(yàn)時(shí),P1口接收低8位地址字節(jié)。
表2-1 P1口第二功能
引腳號(hào)
第二功能
P1.0
T2(定時(shí)器/計(jì)數(shù)器 T2 的外部計(jì)數(shù)輸入),時(shí)鐘輸出
P1.1
T2EX(定時(shí)器/計(jì)數(shù)器 T2 的捕捉/重載觸發(fā)信號(hào)和方向控制)
P1.5
MOSI(在系統(tǒng)編程用)
P1.6
MISO(在系統(tǒng)編程用)
P1.7
SCK(在系統(tǒng)編程用)
(5)P2口(P2.0~P2.7):P2口是一個(gè)具有內(nèi)部上拉電阻的8位雙向I/O口,P2輸出緩沖器能驅(qū)動(dòng)4個(gè)TTL邏輯電平。對(duì)P2端口寫“1”時(shí),內(nèi)部上拉電阻把端口拉高,此時(shí)可以作為輸入口使用。作為輸入使用時(shí),被外部拉低的引腳由于內(nèi)部電阻的原因,將輸出電流(IIL)。在訪問外部程序存儲(chǔ)器或用16位地址讀取外部數(shù)據(jù)存儲(chǔ)器(例如執(zhí)行MOVX @DPTR)時(shí),P2口送出高八位地址。在這種應(yīng)用中,P2口使用很強(qiáng)的內(nèi)部上拉發(fā)送1。在使用8位地址(如 MOVX @RI)訪問外部數(shù)據(jù)存儲(chǔ)器時(shí),P2口輸出P2 鎖存器的內(nèi)容。在flash編程和校驗(yàn)時(shí),P2口也接收高8位地址字節(jié)和一些控制信號(hào)。
(6)P3口(P3.0~P3.7):P3 口是一個(gè)具有內(nèi)部上拉電阻的8位雙向I/O口,P2輸出緩沖器能驅(qū)動(dòng)4個(gè)TTL邏輯電平。對(duì)P3端口寫“1”時(shí),內(nèi)部上拉電阻把端口拉高,此時(shí)可以作為輸入口使用。作為輸入使用時(shí),被外部拉低的引腳由于內(nèi)部電阻的原因,將輸出電流(IIL)。P3口亦作為 AT89S52第二功能使用,如表2-2所示:
表2-2 P3口第二功能
引腳號(hào)
第二功能
P3.0
RXD(串行輸入)
P3.1
TXD(串行輸出)
P3.2
I(外部中斷 0)
P3.3
I(外部中斷 0)
P3.4
T0(定時(shí)器 0 外部輸入)
P3.5
T1(定時(shí)器 1 外部輸入)
P3.6
(外部數(shù)據(jù)存儲(chǔ)器寫選通)
P3.7
(外部數(shù)據(jù)存儲(chǔ)器寫選通)
在 flash 編程和校驗(yàn)時(shí),P3 口也接收一些控制信號(hào)。RST:復(fù)位輸入。晶振工作時(shí),RST腳持續(xù)2個(gè)機(jī)器周期高電平將使單片機(jī)復(fù)位??撮T狗計(jì)時(shí)完成后,RST腳輸出96個(gè)晶振周期的高電平。特殊寄存器 AUXR(地址8EH)上的DISRTO位可以使此功能無效。DISRTO默認(rèn)狀態(tài)下,復(fù)位高電平有效。
ALE/:地址鎖存控制信號(hào)(ALE)是訪問外部程序存儲(chǔ)器時(shí),鎖存低8位地址的輸出脈沖。在flash編程時(shí),此引腳(PROG)也用作編程輸入脈沖。在一般情況下,ALE以晶振六分之一的固定頻率輸出脈沖,可用來作為外部定時(shí)器或時(shí)鐘使用。然而,特別強(qiáng)調(diào),在每次訪問外部數(shù)據(jù)存儲(chǔ)器時(shí),ALE 脈沖將會(huì)跳過。如果需要,通過將地址為8EH的SFR的第0位置“1”,ALE操作將無效。這一位置“1”,ALE 僅在執(zhí)行MOVX或MOVC指令時(shí)有效。否則,ALE將被微弱拉高。這個(gè)ALE使能標(biāo)志位(地址為8EH的SFR的第0位)的設(shè)置對(duì)微控制器處于外部執(zhí)行模式下無效。
:外部程序存儲(chǔ)器選通信號(hào)(PSEN)是外部程序存儲(chǔ)器選通信號(hào)。當(dāng) AT89S52從外部程序存儲(chǔ)器執(zhí)行外部代碼時(shí),PSEN在每個(gè)機(jī)器周期被激活兩次,而在訪問外部數(shù)據(jù)存儲(chǔ)器時(shí),PSEN將不被激活。
A/VPP:訪問外部程序存儲(chǔ)器控制信號(hào)。為使能從0000H到FFFFH的外部程序存儲(chǔ)器讀取指令,EA 必須接 GND。為了執(zhí)行內(nèi)部程序指令,EA應(yīng)該接VCC。在flash編程期間,EA也接收12伏VPP電壓。
XTAL1:振蕩器反相放大器和內(nèi)部時(shí)鐘發(fā)生電路的輸入端。
XTAL2:振蕩器反相放大器的輸出端。
1.3 晶振特性
AT89S52單片機(jī)有一個(gè)用于構(gòu)成內(nèi)部振蕩器的反相放大器,XTAL1和XTAL2分別是放大器的輸入、輸出端。石英晶體和陶瓷諧振器都可以用來一起構(gòu)成自激振蕩器。從外部時(shí)鐘源驅(qū)動(dòng)器件的話,XTAL2可以不接,而從XTAL1接入,如圖2-2所示。由于外部時(shí)鐘信號(hào)經(jīng)過二分頻觸發(fā)后作為外部時(shí)鐘電路輸入的,所以對(duì)外部時(shí)鐘信號(hào)的占空比沒有其它要求,最長(zhǎng)低電平持續(xù)時(shí)間和最少高電平持續(xù)時(shí)間等還是要符合要求的。如圖 2.2 所示:
圖2.2內(nèi)部振蕩電路連接圖
2 液晶顯示模塊
顯示器部分是由HD61202液晶顯示控制驅(qū)動(dòng)器和JM12864J液晶顯示器組成的,下面對(duì)其分別進(jìn)行介紹。
2.1 液晶顯示控制驅(qū)動(dòng)器HD61202的特點(diǎn)
HD61202液晶顯示控制驅(qū)動(dòng)器是一種帶有驅(qū)動(dòng)輸出的圖形液晶顯示控制器,它可直接與8位微處理器相連,它可與HD61203配合對(duì)液晶屏進(jìn)行行、列驅(qū)動(dòng)。HD61202是一種帶有列驅(qū)動(dòng)輸出的液晶顯示控制器,它可與行驅(qū)動(dòng)器HD61203配合使用,組成液晶顯示驅(qū)動(dòng)控制系統(tǒng)。
(1)內(nèi)藏64×64=4096位顯示RAM,RAM中每位數(shù)據(jù)對(duì)應(yīng)LCD屏上一個(gè)點(diǎn)的亮、暗狀態(tài);
(2)HD61202是列驅(qū)動(dòng)器,具有64路列驅(qū)動(dòng)輸出;
(3)HD61202讀、寫操作時(shí)序與68系列微處理器相符,因此它可直接與68系列微處理器接口相連;
(4)HD61202的占空比為1/32~1/64。
2.2 液晶顯示控制驅(qū)動(dòng)器HD61202的引腳功能
引腳CS1,CS2,CS3 為芯片的片選端;引腳 E 為讀寫使能信號(hào),它是在下降沿時(shí)數(shù)據(jù)被鎖存入HD61202的;在E 高電平期間,數(shù)據(jù)被讀出;R/W 為讀寫選擇信號(hào),當(dāng)它為一時(shí)為讀選通,為零時(shí)為寫選通;DB0-DB7為數(shù)據(jù)總線RST 為復(fù)位信號(hào)復(fù)位信號(hào)有效時(shí),關(guān)閉液晶顯示,使顯示起始行為0,RST可跟MCU相連,由MCU控制;也可直接接VDD,使之不起作用。HD61202的引腳功能如下表2-3所示:
表2-3 HD61202的引腳功能
引腳符號(hào)
狀態(tài)
引腳名稱
功能
CS1,CS2,CS3
輸入
芯片片選端
CS1和CS2低電平選通,CS3高電平選通。
E
輸入
讀寫使能信號(hào)
在E下降沿,數(shù)據(jù)被鎖存(寫)入HD61202;在E高電平期間,數(shù)據(jù)被讀出
R/W
輸入
讀寫選擇信號(hào)
R/W=1為讀選通,R/W=0為寫選通
RS
輸入
數(shù)據(jù)、指令選擇信號(hào)
RS=1為數(shù)據(jù)操作
RS=0為寫指令或讀狀態(tài)
DB0-DB7
三態(tài)
數(shù)據(jù)總線
RST
輸入
復(fù)位信號(hào)
復(fù)位信號(hào)有效時(shí),關(guān)閉液晶顯示,使顯示起始行為0,RST可跟MCU相連,由MCU控制;也可直接接VDD,使之不起作用。
2.3 液晶顯示控制驅(qū)動(dòng)器HD61202的指令系統(tǒng)
HD61202的指令系統(tǒng)比較簡(jiǎn)單,總共只有七種?,F(xiàn)分別介紹如下:
1. 顯示開/關(guān)指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
0 0
0 0 1 1 1 1 1 1/0
當(dāng)DBO=1時(shí),LCD顯示RAM中的內(nèi)容;DBO=0時(shí),關(guān)閉顯示。
2. 顯示起始行(ROW)設(shè)置指令
該指令設(shè)置了對(duì)應(yīng)液晶屏最上一行的顯示RAM的行號(hào),有規(guī)律的改變顯示起始行,可以使LCD實(shí)現(xiàn)顯示滾屏的效果。
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
0 0
1 1 顯示起始行(0-63)
3. 頁(PAGE)置指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
0 0
1
0
1
1
1
頁號(hào)(0-7)
顯示RAM共64行,分8頁,每頁8行。
4. 列地址(Y Address)設(shè)置指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
0 0
0 1 顯示列地址(0-63)
設(shè)置了頁地址和列地址,就唯一確定了顯示RAM中的一個(gè)單元,這樣MCU就可以用讀、寫指令讀出該單元中的內(nèi)容或向該單元寫進(jìn)一個(gè)字節(jié)數(shù)據(jù)。
5. 讀狀態(tài)指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
1 0
BUSY 0 ON/OFF REST 0 0 0 0
該指令用來查詢HD61202的狀態(tài),各參量含義如下:
BUSY: 1-內(nèi)部在工作 0-正常狀態(tài)
ON/OFF:1-顯示關(guān)閉 0-顯示打開
REST: 1-復(fù)位狀態(tài) 0-正常狀態(tài)
在BUSY和REST狀態(tài)時(shí),除讀狀態(tài)指令外,其它指令均不對(duì)HD61202產(chǎn)生作用。在對(duì)HD61202操作之前要查詢BUSY狀態(tài),以確定是否可以對(duì)HD61202進(jìn)行操作。
6. 寫數(shù)據(jù)指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
0 1
寫 數(shù) 據(jù)
讀、寫數(shù)據(jù)指令每執(zhí)行完一次讀、寫操作,列地址就自動(dòng)增一,必須注意的是,進(jìn)行讀操作之前,必須有一次空讀操作,緊接著再讀才會(huì)讀出所要讀的單元中的數(shù)據(jù)。
7. 讀數(shù)據(jù)指令
R/W RS
DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
1 1
讀 顯 示 數(shù) 據(jù)
2.4 HD61202的軟件設(shè)計(jì)
液晶控制器HD61202 一共有七條指令,從作用上可分為兩類,顯示狀態(tài)設(shè)置指令和數(shù)據(jù)讀/寫操作指令。詳見指令系統(tǒng)可查看圖形液晶顯示器產(chǎn)品有關(guān)手冊(cè)。顯示起始行設(shè)置中L5~L0 為顯示起始行的地址,取值在0-3FH(1-64 行)范圍內(nèi)。頁面地址設(shè)置中P2-P0 為選擇的頁面地址,取值范圍為0-7H,代表1-8 頁。列地址設(shè)置中C5-C0 為Y地址計(jì)數(shù)器的內(nèi)容,取值在0-3FH(1-64 行)范圍內(nèi)。
顯示器上128 點(diǎn)×64 點(diǎn),每8點(diǎn)為一字節(jié)數(shù)據(jù),都對(duì)應(yīng)著顯示數(shù)據(jù)RAM(在HD61202 芯片內(nèi)),一點(diǎn)對(duì)應(yīng)一個(gè)bit,計(jì)算機(jī)寫入或讀出顯示存儲(chǔ)器的數(shù)據(jù)代表顯示屏上某一點(diǎn)列上的垂直8 點(diǎn)行的數(shù)據(jù)。D0 代表最上一行的點(diǎn)數(shù)據(jù),D1為第二行的點(diǎn)數(shù)據(jù),……D7為第八行的點(diǎn)數(shù)據(jù)。該bit=1 時(shí)該點(diǎn)則顯示黑點(diǎn)出來,該bit=0 時(shí)該點(diǎn)則消失。另外LCD 指令中有-條display ON/OFF 指令,display ON 時(shí)顯示RAM 數(shù)據(jù)對(duì)應(yīng)顯示的畫面;display OFF 則畫面消失,RAM 中顯示數(shù)據(jù)仍存在。
點(diǎn)陣字模文件的建立:
由于MGLS12864 液晶顯示器沒有內(nèi)部字符發(fā)生器,所以在屏幕上顯示的任何字符、漢字等須自己建立點(diǎn)陣字模庫,然后均按圖形方式進(jìn)行顯示。由于HD61202 顯示存儲(chǔ)器的特性,不能將計(jì)算機(jī)內(nèi)的漢字庫和其它字模庫提出直接使用,需要將其旋轉(zhuǎn)90 度后再寫入。點(diǎn)陣字模庫建立包括以下幾個(gè)方面:
(1)建立8×16 點(diǎn)陣常用字符、數(shù)字、符號(hào)字模庫。
可選用計(jì)算機(jī)BIOS 中ASCII 的8×16 字模庫,所有字符按照ASCII 值從小到大升序排列。
asm{MOV ax,1130h /*AH=11h—功能調(diào)用。裝入字庫至軟字庫 */
mov bh,6 /*AL=30h 取點(diǎn)陣信息 */
int 10h /*BH=6 取ROM8X16 點(diǎn)陣指針(VGA) */
mov ax,es /*出口:ES:BP 指向字庫指針 */
mov ascii_es,ax
mov ax,bp
mov ascii_bp,ax };
ascii_offset=ascii_bp+16*asciicode;
for(j=0;j<16;j++) buf[j]=peekb(ascii_es,ascii_offset+j); /*讀16 字節(jié)點(diǎn)陣數(shù)據(jù)*/
for(m=0;m<16;m++) /*點(diǎn)陣數(shù)據(jù)轉(zhuǎn)換成LCD 格式數(shù)據(jù)*/
{ if(m<8) { beginbyte= 7; shiftn="7";}
else { beginbyte="15"; shiftn="15";}
for(j=0;j<8;j++)
ascii8x16[m]=(ascii8x16[m]+ (buf[beginbyte-j]>>(shiftn-m))&0x01)<<1;
}
也可選用UCDOS 的ASC16 文件做字模庫。ASC16 文件的字符為8×16 點(diǎn)陣。所有字符按照ASCII值從小到大升序排列。計(jì)算字符首地址的公式:字符首地址=字符的ASCII 碼值×16加字模庫首地址。
(2)建立所用到的16×16 點(diǎn)陣字模庫。漢字字符可選用UCDOS 的HZK16 文件做字模庫。HZK16 文件的字符為16×16 點(diǎn)陣。所有字符按照區(qū)位碼從小到大升序排列。計(jì)算漢字字符首地址的公式如下:漢字首地址=((區(qū)碼-1)×94+位碼-1)×32。作者用C 語言編寫的讀取UCDOS 點(diǎn)陣字庫字模程序,完成字模讀取。
數(shù)據(jù)重新排列,并按MCS-51 匯編程序的要求寫成相應(yīng)格式的文本文件。
p=((quma-1)*94+weima-1)*32;
cclibfile="fopen"("HZK16","rb");
fseek(cclibfile,(long)p,SEEK_SET);
fread(buf,sizeof(unsigned char),32,cclibfile); /*讀32 字節(jié)點(diǎn)陣數(shù)據(jù)*/
for(m=0;m<32;m++){ /*點(diǎn)陣數(shù)據(jù)轉(zhuǎn)換成LCD 格式數(shù)據(jù)*/
if(m<8) { beginbyte="14"; shiftn="7";}
else if( m>= 8 && m<16 ) { beginbyte="15"; shiftn="15";}
else if( m>=16 && m<24 ) { beginbyte="30"; shiftn="23";}
else { beginbyte="31"; shiftn="31";}
for(j=0;j<8;j++)
hzk16x16[m]=(hzk16x16[m]+ (buf[beginbyte-2*j] >>(shiftn-m))&0x01)<<1;
}
(3)常用圖形(如產(chǎn)品商標(biāo)等)的點(diǎn)陣圖形的建立。對(duì)已有的圖形可采用掃描儀進(jìn)行掃描,然后用圖形處理軟件進(jìn)行處理,再將BMP 格式文件轉(zhuǎn)換成MCS-51的匯編文件的格式。
以上所有的字模數(shù)據(jù)都存放在單片機(jī)W78E58 的程序存儲(chǔ)器中,如用到的漢字、圖形較多,可選用較大容量的程序存儲(chǔ)器。
通用子程序:通用子程序分左半屏、右半屏寫指令代碼子程序和寫顯示數(shù)據(jù)子程序。液晶顯示驅(qū)動(dòng)器HD16202 內(nèi)部有個(gè)忙標(biāo)志寄存器,當(dāng)BF=1 時(shí),表示內(nèi)部操作正在運(yùn)行,不能接受外部數(shù)據(jù)或指令。下面子程序中設(shè)指令代碼寄存器為COMM,數(shù)據(jù)寄存器為DATA。
(COMM EQU 20H /*指令寄存器*/ DATA EQU 21H /*數(shù)據(jù)寄存器*/)
1)左半屏寫指令子程序
WR_CMD1: MOV DPTR,#CRADR1 ;/*讀狀態(tài)字口地址*/
WAIT1: MOVX A,@DPTR ;/* 讀狀態(tài)字 */
JB ACC.7,WAIT1 ;/*判忙標(biāo)志BF,如BF=1 忙,等待*/
MOV DPTR,#CWADR1 ;/*寫指令字口地址*/
MOV A,COMM ;/*取指令代碼*/
MOVX @DPTR,A ;/*寫指令代碼*/
RET
2)左半屏寫數(shù)據(jù)子程序
WR_DATA1:MOV DPTR,#CRADR1 ;/*讀狀態(tài)字口地址*/
WAIT11: MOVX A,@DPTR ;/* 讀狀態(tài)字 */
JB ACC.7,WAIT11 ;/*判忙標(biāo)志BF,如BF=1 忙,等待*/
MOV DPTR,#DWADR1 ;/*寫數(shù)據(jù)字口地址*/
MOV A,DATA ;/*取數(shù)據(jù)/
MOVX @DPTR,A ;/*寫數(shù)據(jù)*/
RET
3)右半屏寫指令子程序WR_CMD2 和右半屏寫數(shù)據(jù)子程序WR_DATA2 的編制同左半屏子程序相同,只是對(duì)應(yīng)口地址不同。
2.5 JM12864J的電路結(jié)構(gòu)特點(diǎn)
JM12864J是使用HD61202及其兼容控制驅(qū)動(dòng)器作為列驅(qū)動(dòng)器,同時(shí)使用HD61203作為行驅(qū)動(dòng)器的液晶模塊。由于HD6120不與MPU發(fā)生聯(lián)系,只要提供電源就能產(chǎn)生行驅(qū)動(dòng)信號(hào)和各種同步信號(hào),比較簡(jiǎn)單,因此這里就不作介紹了。下面主要介紹一下JM12864J的邏輯電路圖。
JM12864J共有兩片HD61202及其兼容控制驅(qū)動(dòng)器和一片HD61203,如圖2.3所示:
圖2.3 JM12864J的邏輯電路圖
在JM12864J中,兩片HD61202的ADC均接高電平,RST也接高電平,這樣在使用JM12864J時(shí)就不必再考慮這兩個(gè)引腳的作用。跟HD61202(1)的相連;跟HD61202(2)的CS1相連,因此、選通組合信號(hào)為,=01選通(1),,=10選通(2)。對(duì)于JM12864J,只要供給VDD、VSS和V0即可,HD61202和HD61203所需的電源將由模塊內(nèi)部電路在VDD和V0、VSS的作用下產(chǎn)生。
2.6 JM12864J的應(yīng)用
以下內(nèi)容為以單片機(jī)89S52為例機(jī)的接口電路,控制電路為直接訪問方式的接口電路。電路原理圖如圖2.4所示:
圖2.4 AT89S52 與液晶的接口電路
根據(jù)以上電路原理圖中液晶的各引腳與單片機(jī)的接法,可得本設(shè)計(jì)的液晶模塊電路如圖2.5所示:
由圖2.5可以看出:VSS接地;數(shù)字電源VDD接+5V;數(shù)據(jù)、指令選擇信號(hào)RS接單片機(jī)P3.2口;讀寫選擇信號(hào)R/W接單片機(jī)P3.1口;DB0~DB7分別接單片機(jī)的P2.0~P2.7口;芯片1、芯片2的片選分別接單片機(jī)的P3.4、P3.3口;復(fù)位端RST、背光正電源LEDA接+5V;液晶驅(qū)動(dòng)電壓VEE、背光負(fù)電源LEDK接地。
圖2.5液晶模塊電路
2.7 鍵盤電路
鍵盤電路本設(shè)計(jì)共采用按鍵3個(gè),分別與單片機(jī)的 P1.0、P3.5、P3.6、P3.7口相連,分別對(duì)應(yīng)旋轉(zhuǎn)、左移、下、右移。
3 系統(tǒng)程序的設(shè)計(jì)
行滿
表格滿
消除行并把上面的行數(shù)據(jù)下移并置清行為true、當(dāng)前圖改變?yōu)閒alse
清所有數(shù)據(jù)
繪圖(清屏)
N
Y
N
提示圖形變量給當(dāng)前圖形
隨機(jī)生成一個(gè)圖形交給提示圖形變量
游戲結(jié)束
繪圖
結(jié)束
Y
Y
繪圖一次
Y
圖形到底了嗎
根據(jù)變化繪圖(繪提示圖和當(dāng)前圖形)
隨機(jī)生成一個(gè)圖形
交給提示圖形變量
開始
隨機(jī)生成一個(gè)圖形
交給當(dāng)前圖形變量
圖形下降一行
N
3.1 俄羅斯方塊驅(qū)動(dòng)流程圖
圖3.1俄羅斯方塊驅(qū)動(dòng)圖流程圖
3.2 俄羅斯方塊所有繪圖工作流程圖
開始
輸出分?jǐn)?shù)
清除剛才位置的圖形
N
當(dāng)前圖形改變
Y
繪當(dāng)前圖的現(xiàn)在位置
提示圖形改變真?
N
Y
繪提示圖
消行動(dòng)作為真?
N
從消行的那一行的第一列開始
Y
為空數(shù)據(jù)
N
Y
繪白色;相當(dāng)于清除色彩
表格中對(duì)應(yīng)的色彩
行+1到移動(dòng)數(shù)據(jù)最后一行
N
Y
結(jié)束
圖3.2 俄羅斯方塊所有繪圖工作流程圖
3.3 俄羅斯方塊中按下鍵的流程圖
按下鍵
記下下降圖形時(shí)的位置()
直接把圖形下降到底
行滿
N
N
消除行并把上面的行數(shù)據(jù)下移并置清行為true、當(dāng)前圖改變?yōu)閒alse
Y
Y
表格滿
繪圖(清屏)
清所有數(shù)據(jù)
游戲結(jié)束
提示圖形變量給當(dāng)前圖形
繪圖
隨機(jī)生成一個(gè)圖形交給提示圖形變量
結(jié)束
圖3.3 俄羅斯方塊按下鍵的流程圖
第 54 頁 共 52 頁
***********************學(xué)院畢業(yè)設(shè)計(jì)(論文)
4 系統(tǒng)仿真
4.1 Proteus軟件介紹
Proteus軟件是來自英國(guó)Labcenter electronics公司的EDA工具軟件。 Proteus軟件有十多年的歷史,在全球廣泛使用,除了其具有和其它EDA工具一樣的原理布圖、PCB自動(dòng)或人工布線及電路仿真的功能外,其革命性的功能是,他的電路仿真是互動(dòng)的,針對(duì)微處理器的應(yīng)用,還可以直接在基于原理圖的虛擬原型上編程,并實(shí)現(xiàn)軟件源碼級(jí)的實(shí)時(shí)調(diào)試,如有顯示及輸出,還能看到運(yùn)行后輸入輸出的效果,配合系統(tǒng)配置的虛擬儀器如示波器、邏輯分析儀等,不需要?jiǎng)e的,Proteus建立了完備的電子設(shè)計(jì)開發(fā)環(huán)境!
Proteus組合了高級(jí)原理布圖、混合模式SPICE仿真,PCB設(shè)計(jì)以及自動(dòng)布線來實(shí)現(xiàn)一個(gè)完整的電子設(shè)計(jì)系統(tǒng)。此系統(tǒng)受益于15年來的持續(xù)開發(fā),被《電子世界》在其對(duì)PCB設(shè)計(jì)系統(tǒng)的比較文章中評(píng)為最好產(chǎn)品—“The Route to PCB CAD”。Proteus 產(chǎn)品系列也包含了革命性的VSM技術(shù),用戶可以對(duì)基于微控制器的設(shè)計(jì)連同所有的周圍電子器件一起仿真。用戶甚至可以實(shí)時(shí)采用諸如LED/LCD、鍵盤、RS232終端等動(dòng)態(tài)外設(shè)模型來對(duì)設(shè)計(jì)進(jìn)行交互仿真。
其功能模塊:—個(gè)易用而又功能強(qiáng)大的ISIS原理布圖工具;Proteus混合模型SPICE仿真; ARES PCB設(shè)計(jì)。Proteus 仿真器的一個(gè)擴(kuò)展Proteus VSM:便于包括所有相關(guān)的器件的基于微處理器設(shè)計(jì)的協(xié)同仿真。此外,還可以結(jié)合微控制器軟件使用動(dòng)態(tài)的鍵盤,開關(guān),按鈕,LEDs甚至LCD顯示CPU模型。
(1)支持許多通用的微控制器,如PIC,AVR,HC11以及8051;
(2)交互的裝置模型包括:LED和LCD顯示,RS232終端,通用鍵盤;
(3)強(qiáng)大的調(diào)試工具,包括寄存器和存儲(chǔ)器,斷點(diǎn)和單步模式;
(4)IAR C-SPY 和Keil uVision3等開發(fā)工具的源層調(diào)試;
(5)應(yīng)用特殊模型的DLL界面-提供有關(guān)元件庫的全部文件。
4.2 Keil軟件介紹
Keil C51 μVision2集成開發(fā)環(huán)境是Keil Software,Inc/Keil Elektronik GmbH開發(fā)的基于80C51內(nèi)核的微處理器軟件開發(fā)平臺(tái),內(nèi)嵌多種符合當(dāng)前工業(yè)標(biāo)準(zhǔn)的開發(fā)工具,可以完成從工程建立到管理、編譯、鏈接、目標(biāo)代碼的生成、軟件仿真、硬件仿真等完整的開發(fā)流程尤其是C編譯工具在產(chǎn)生代碼的準(zhǔn)確性和效率方面達(dá)到了較高的水平,而且可以附加靈活的控制選項(xiàng),在開發(fā)大型項(xiàng)目時(shí)非常理想。Keil C51集成開發(fā)環(huán)境的主要功能有以下幾點(diǎn):
(1)μVision2 for Windows:是一個(gè)集成開發(fā)環(huán)境,它將項(xiàng)目管理、源代碼編輯和程序調(diào)試等組合在一個(gè)功能強(qiáng)大的環(huán)境中;
(2)C51國(guó)際際準(zhǔn)化C交叉編譯器:從C源代碼產(chǎn)生可重定位的目標(biāo)模塊;
(3)A51宏匯編器:從80C51匯編源代碼產(chǎn)生可重定位的目標(biāo)模塊;
(4)BL51鏈接器/定位器:組合由C51和A51產(chǎn)生的可重定位的目標(biāo)模塊,生成絕對(duì)目標(biāo)模塊;
(5)LIB51庫管理器:從目標(biāo)模塊生成連接器可以使用的庫文件;
(6)OH51目標(biāo)文件至HEX格式的轉(zhuǎn)換器,從絕對(duì)目標(biāo)模塊生成Intel Hex文件;
(7)RTX-51實(shí)時(shí)操作系統(tǒng):簡(jiǎn)化了復(fù)雜的實(shí)時(shí)應(yīng)用軟件項(xiàng)目的設(shè)計(jì)。
這個(gè)工具套件是為專業(yè)軟件開發(fā)人員設(shè)計(jì)的,但任何層次的編程人員都可以使用,并獲得80C51單片機(jī)的絕大部分應(yīng)用。Keil Software提供了一流的80C51系列開發(fā)工具軟件,下面描述每個(gè)套件及其內(nèi)容:
1)PK51專業(yè)開發(fā)套件:PK51專業(yè)開發(fā)套件提供了所有工具,適合專業(yè)開發(fā)人員建立和調(diào)試80C51系列微控制器的復(fù)雜嵌入式應(yīng)用程序。專業(yè)開發(fā)套件可針對(duì)80C51及其所有派生系列進(jìn)行配置使用;
2)DK51開發(fā)套件:DK51開發(fā)套件是PK51的精簡(jiǎn)版,它不包括RTX51 Tiny實(shí)時(shí)操作系統(tǒng)。開發(fā)套件可針對(duì)80C51及其所以派生系列進(jìn)行配置使用;
3)編譯器套件:如果開發(fā)者只需要一個(gè)C編譯器而不需要調(diào)試系統(tǒng),則CA51編譯器套件就是最好的選擇。CA51編譯器套件只包含μVision2 IDE集成開發(fā)環(huán)境,CA51不提供μVision2調(diào)試器的功能。這個(gè)套件包括了要建立嵌入式應(yīng)用的所有工具軟件,可針對(duì)80C51及其所有派生系列進(jìn)行配置使用;
表4-1 開發(fā)套件和工具對(duì)照表
Components
PK51
DK51
CA51
A51
FR51
uVision2 Project Management&Editor
√
√
√
√
A51 Assembler
√
√
√
√
C51 Compiler
√
√
√
BL51 Liker/locator
√
√
√
√
LIB51 Library Magaer
√
√
√
√
uVision2 Debugger/Simulator
√
√
RTX51 Tiny
√
RTX51 Full
√
4)A51匯編器套件:A51匯編器套件包括一個(gè)匯編器和創(chuàng)建嵌入式應(yīng)用所需要的所有工具。它可針對(duì)80C51及其所有派生系列進(jìn)行配置使用;
5)RTX51實(shí)時(shí)操作系統(tǒng)(FR51):RTX51實(shí)時(shí)操作系統(tǒng)是80C51系列微控制器的一個(gè)實(shí)時(shí)內(nèi)核。RTX51 Full提供RTX51 Tiny的所以功能和一些擴(kuò)展功能,并且包括CAN通信協(xié)議接口子程序;
6)比較表:表4-1列出了每個(gè)套件的功能,表的頂上一欄為工具套件名稱,表的左邊一列為軟件組成部分,使用這個(gè)對(duì)照表可以選擇符合需要的套件。
4.3俄羅斯方塊系統(tǒng)PROTUES仿真
用Proteus軟件,根據(jù)俄羅斯方塊電路原理圖,畫出仿真圖。
電路圖畫完后使用Proteus與Keil聯(lián)調(diào),這里使用的軟件是Keil μVision3.8與Proteus7.4。
(1)打開PROTEUS的安裝目錄,進(jìn)入help目錄,打開ARM.HLP幫助文檔,點(diǎn)擊聯(lián)接:Remote Debugger Drivers/Download and Install remote debugger driver for Keil uVision3, 下載VDMAGDI.EXE, 運(yùn)行安裝到KEIL安裝目錄VDM51.dll文檔會(huì)自動(dòng)安裝到KEIL\C51\BIN目錄。
(2)打開KEIL中打開要聯(lián)調(diào)的項(xiàng)目,在project workspace的“target1”上點(diǎn)右鍵/options for target'target1'。
在打開的對(duì)話框中點(diǎn)擊到Debug選項(xiàng)卡,在右上角上先中USE選項(xiàng), 并在下拉菜單中選中proteus VSM Simulator,在旁邊的Settings點(diǎn)一下,如果是proteus在同一臺(tái)電腦,host:127.0.0.1, port:8000, 點(diǎn)確定/OK保存。
(3)打開proteus并打開要仿真的圖紙,點(diǎn)擊Debug菜單/選中Use Remote Debug Monitor。
(4)完成,如果程序和電路圖沒問題,在KEIL中build all并且仿真運(yùn)行后,可以在proteus看到實(shí)時(shí)效果了如圖4.1所示:
圖4.1 Protues仿真
結(jié) 論
通過3個(gè)月地全心投入和辛苦努力,終于完成了基于單片機(jī)的俄羅斯方塊游戲的設(shè)計(jì),設(shè)計(jì)的過程就是綜合運(yùn)用所學(xué)知識(shí)和學(xué)習(xí)新知識(shí)的過程。由于經(jīng)驗(yàn)不足,難免出現(xiàn)一些小的失誤,但無論怎樣,本次畢業(yè)設(shè)計(jì)對(duì)于我來說都是一次難得的鍛煉機(jī)會(huì),使我積累了許多寶貴的經(jīng)驗(yàn)。
本文對(duì)單片機(jī)制作的俄羅斯方塊游戲的運(yùn)行原理進(jìn)行了分析,全面、詳細(xì)地闡述了俄羅斯方塊游戲的設(shè)計(jì)過程。本游戲機(jī)已經(jīng)達(dá)到了掌上娛樂的要求,但在設(shè)計(jì)上還留有進(jìn)一步改善的余地,如可以美化游戲界面、加入背景和動(dòng)作音樂、力回饋系統(tǒng)等。
畢業(yè)設(shè)計(jì)的整個(gè)開發(fā)過程是曲折的,首先在硬件設(shè)計(jì)上,由于開始對(duì)LCD液晶屏不熟悉,加之其程序量較多,所以,在設(shè)計(jì)的過程中,不免有些困難,通過我多方面的查找資料,并不斷的向老師和同學(xué)請(qǐng)教,結(jié)合網(wǎng)絡(luò)資源,最終找出比較完善的方案,在理論上能夠?qū)崿F(xiàn)功能要求。經(jīng)過幾個(gè)月的前期學(xué)習(xí),我積累了很多的關(guān)于液晶顯示方面和C語言設(shè)計(jì)方面的資料,并對(duì)電路的整合有了一個(gè)基本的概念,最后設(shè)計(jì)出總的電路圖,經(jīng)過不斷的測(cè)試與修改,最終完善了硬件電路的設(shè)計(jì)。
對(duì)于軟件設(shè)計(jì),因?yàn)橐郧暗木幊探?jīng)驗(yàn)不夠,再加上對(duì)AT89S52這一芯片的了解不是很徹底,因此,在這方面花費(fèi)了很多的精力和時(shí)間。當(dāng)然這個(gè)過程不乏有同學(xué)的幫助,我要非常感謝實(shí)驗(yàn)室同學(xué)的幫助在我的軟件調(diào)試過程中給了我至關(guān)重要的幫助,并給了我很多非常好的建議。
當(dāng)然由于我在理論和實(shí)踐方面存在一定的不足,所以在設(shè)計(jì)思路和實(shí)現(xiàn)功能上難免有不足和沒有想到的地方,還請(qǐng)各位老師給予指正。
參 考 文 獻(xiàn)
[1]高凌琴,陳青華.俄羅斯方塊游戲關(guān)鍵技術(shù)探討[J]. 信息技術(shù)與信息化.2008.
[2]譚浩強(qiáng). C程序設(shè)計(jì).[M] 北京:清華大學(xué)出版社,2003.
[3]張齊.杜群貴.單片機(jī)應(yīng)用系統(tǒng)設(shè)計(jì)技術(shù)——基于C語言編程[M].北京:電子工業(yè)出版社,2004.
[4]劉洪波.AT89C2051單片機(jī)及I/O口的擴(kuò)展方法[J].山東電子,1997,1:16-18
[5]胡漢才.單片機(jī)原理及其接口技術(shù)[M].清華大學(xué)出版社,2000
[6]王彥朝. 二維數(shù)組在俄羅斯方塊游戲編程中的應(yīng)用[J].信息與電腦(理論版),2010-04:46-47
[7]王曉威,唐叔進(jìn),邢瑞.基于單片機(jī)和液晶顯示器的游戲開發(fā)[J].電子世界,2005,7:30-31
[8]徐金增.單片機(jī)編程仿真實(shí)驗(yàn)系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)[D].山東師范大學(xué),2009,4
[9] George Lee,Karina Ng,Edmond Kwang.Design of ring oscillator based voltage controlled oscillator. Project Final Report[R]. 2005
[10] Yeager Brent.How to troubleshoot your electronic scale[J].Powder and Bulk Engineering,1995
附 錄A 電路原理圖
附 錄B 主要程序
#include
#define uchar unsigned char
#define uint unsigned int
#define DOWNTIME 30
#define MAXHANG 20
#define MAXLIE 16
#define MAXPIX 3
#define PUSHON 50
#define LCD P2
#define EN P3_0
#define RW P3_1
#define RS P3_2
#define CS1 P3_3
#define CS2 P3_4
#define KEYLEFT P3_5
#define KEYDOWN P3_6
#define KEYRIGH P3_7
#define KEYROTATION P1_0
uchar gkey=0xff,keystate=0,t0ms1=0,t0ms=0,downtimegap=0;
uchar miao=0,fen=0;
uchar downok;
bit keyflag,timeupdate,fashionupdate;
uchar idata cubeMap[MAXHANG][2];
typedef struct{
uchar code * box;
uchar cube : 4;
uchar state : 4;
char row;
char column;
} block;
block this;
uint score=0;
uchar speed=1;
uchar code bittable[8]={1,2,4,8,0x10,0x20,0x40,0x80};
uchar code cube[]=
{
/* ■
■■■
*/
0,4,0xe,0, 0,2,6,2, 0,7,2,0, 4,6,4,0,
/*■
■■■
*/
0,8,0xe,0, 0,4,4,0xc, 0,0,0xe,2, 0,6,4,4,
/*■■■
■
*/
0,0xe,8,0, 0,4,4,6, 0,1,7,0, 6,2,2,0,
/*■■
■■
*/
0,0xc,6,0, 0,2,6,4, 0,6,3,0, 2,6,4,0,
/* ■■
■■
*/
0,6,0xc,0, 0,4,6,2, 0,3,6,0, 4,6,2,0,
/*■■■■
*/
0,0xf,0,0, 4,4,4,4, 0,0,0xf,0, 2,2,2,2,
/*■■
■■
*/
0,6,6,0, 0,6,6,0, 0,6,6,0, 0,6,6,0
};
uchar code asii[]=
{
0x3E,0x51,0x49,0x45,0x3E, // -0-
0x00,0x42,0x7F,0x40,0x00, // -1-
0x62,0x51,0x49,0x49,0x46, // -2-
0x21,0x41,0x49,0x4D,0x33, // -3-
0x18,0x14,0x12,0