版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 多功能電子數(shù)字鐘設計 </p><p> 數(shù)字鐘在日常生活中最常見,應用也最廣泛。本文主要就是設計一款數(shù)字鐘,以89C52單片機為核心,配備液晶顯示模塊、時鐘芯片、等功能模塊。數(shù)字鐘采用24小時制方式顯示時間,定時信息以及年月日顯示等功能。文章的核心主要從硬件設計和軟件編程兩個大的方面。硬件電路設計主要包括中央處理單元電路、時鐘電路、人機接口電路、信號處理電路、執(zhí)行電路等幾部分組成。軟件
2、用C語言來實現(xiàn),主要包括主程序、鍵盤掃描子程序、時間設置子程序等軟件模塊。關鍵詞 單片機 液晶顯示器模塊 數(shù)字鐘 </p><p> 一 硬件電路設計及描述;</p><p> 1、MCS-51單片機</p><p> 單片機是
3、在一塊硅片上集成了各種部件的微型計算機。這些部件包括中央處理器CPU、數(shù)據(jù)存儲器RAM、程序存儲器ROM、定時器/計數(shù)器和多種I/O接口電路。</p><p> 8051單片機的結構特點有以下幾點:8位CPU;片內(nèi)振蕩器及時鐘電路; 32根I/O線;外部存儲器ROM和RAM;尋址范圍各64KB;兩個16位的定時器/計數(shù)器; 5個中斷源,2個中斷優(yōu)先級;全雙工串行口。</p><p>&l
4、t;b> 定時器/計數(shù)器</b></p><p> 8051內(nèi)部有兩個16位可編程定時器/計數(shù)器,記為T0和T1。16位是指他們都是由16個觸發(fā)器構成,故最大計數(shù)模值為2-1??删幊淌侵杆麄兊墓ぷ鞣绞接芍噶顏碓O定,或者當計數(shù)器來用,或者當定時起來用,并且計數(shù)(定時)的范圍也可以由指令來設置。這種控制功能是通過定時器方式控制寄存器TMOD來完成的。在定時工作時,時鐘由單片機內(nèi)部提供,即系統(tǒng)時鐘
5、經(jīng)過12分頻后作為定時器的時鐘。技術工作時,時鐘脈沖由TO和T1輸入。</p><p><b> 中斷系統(tǒng)</b></p><p> 8051的中斷系統(tǒng)允許接受五個獨立的中斷源,即兩個外部中斷申請,兩個定時器/計數(shù)器中斷以及一個串行口中斷。</p><p> 外部中斷申請通過INTO和INT1(即P3.2和P3.3)輸入,輸入方式可以使電
6、平觸發(fā)(低電平有效),也可以使邊沿觸發(fā)(下降沿有效)。</p><p> 2、8051的芯片引腳</p><p><b> 如圖1-2所示</b></p><p><b> VCC:供電電壓。</b></p><p><b> GND:接地。</b></p>
7、<p> P0口:P0口為一個8位漏極開路雙向I/O口,每腳可吸收8TTL門電流。當P1口的管腳第一次寫1時,被定義為高阻輸入。P0能夠用于外部程序數(shù)據(jù)存儲器,它可以被定義為數(shù)據(jù)/地址的第八位。在FIASH編程時,P0 口作為原碼輸入口,當FIASH進行校驗時,P0輸出原碼,此時P0外部必須被拉高。</p><p> P1口:P1口是一個內(nèi)部提供上拉電阻的8位雙向I/O口,P1口緩沖器能接收輸出
8、4TTL門電流。P1口管腳寫入1后,被內(nèi)部上拉為高,可用作輸入,P1口被外部下拉為低電平時,將輸出電流,這是由于內(nèi)部上拉的緣故。在FLASH編程和校驗時,P1口作為第八位地址接收。</p><p> P2口:P2口為一個內(nèi)部上拉電阻的8位雙向I/O口,P2口緩沖器可接收,輸出4個TTL門電流,當P2口被寫“1”時,其管腳被內(nèi)部上拉電阻拉高,且作為輸入。并因此作為輸入時,P2口的管腳被外部拉低,將輸出電流。這是由
9、于內(nèi)部上拉的緣故。P2口當用于外部程序存儲器或16位地址外部數(shù)據(jù)存儲器進行存取時,P2口輸出地址的高八位。在給出地址“1”時,它利用內(nèi)部上拉優(yōu)勢,當對外部八位地址數(shù)據(jù)存儲器進行讀寫時,P2口輸出其特殊功能寄存器的內(nèi)容。P2口在FLASH編程和校驗時接收高八位地址信號和控制信號。</p><p> P3口:P3口管腳是8個帶內(nèi)部上拉電阻的雙向I/O口,可接收輸出4個TTL門電流。當P3口寫入“1”后,它們被內(nèi)部上
10、拉為高電平,并用作輸入。作為輸入,由于外部下拉為低電平,P3口將輸出電流(ILL)這是由于上拉的緣故。</p><p> P3口也可作為AT89C51的一些特殊功能口,如下表所示:</p><p> P3.0 RXD(串行輸入口);P3.1 TXD(串行輸出口);P3.2 /INT0(外部中斷0);</p><p> P3.3 /INT1(外部中斷1);P3.
11、4 T0(記時器0外部輸入);P3.5 T1(記時器1外部輸入);P3.6 /WR(外部數(shù)據(jù)存儲器寫選通);P3.7 /RD(外部數(shù)據(jù)存儲器讀選通)</p><p> P3口同時為閃爍編程和編程校驗接收一些控制信號。</p><p> RST:復位輸入。當振蕩器復位器件時,要保持RST腳兩個機器周期的高電平時間。</p><p> ALE/PROG:當訪問外部
12、存儲器時,地址鎖存允許的輸出電平用于鎖存地址的地位字節(jié)。在FLASH編程期間,此引腳用于輸入編程脈沖。在平時,ALE端以不變的頻率周期輸出正脈沖信號,此頻率為振蕩器頻率的1/6。因此它可用作對外部輸出的脈沖或用于定時目的。然而要注意的是:每當用作外部數(shù)據(jù)存儲器時,將跳過一個ALE脈沖。如想禁止ALE的輸出可在SFR8EH地址上置0。此時, ALE只有在執(zhí)行MOVX,MOVC指令是ALE才起作用。另外,該引腳被略微拉高。如果微處理器在外部
13、執(zhí)行狀態(tài)ALE禁止,置位無效。</p><p> /PSEN:外部程序存儲器的選通信號。在由外部程序存儲器取指期間,每個機器周期兩次/PSEN有效。但在訪問外部數(shù)據(jù)存儲器時,這兩次有效的/PSEN信號將不出現(xiàn)。</p><p> /EA/VPP:當/EA保持低電平時,則在此期間外部程序存儲器(0000H-FFFFH),不管是否有內(nèi)部程序存儲器。注意加密方式1時,/EA將內(nèi)部鎖定為RES
14、ET;當/EA端保持高電平時,此間內(nèi)部程序存儲器。在FLASH編程期間,此引腳也用于施加12V編程電源(VPP)。</p><p> XTAL1:反向振蕩放大器的輸入及內(nèi)部時鐘工作電路的輸入。</p><p> XTAL2:來自反向振蕩器的輸出。</p><p><b> ? </b></p><p> 二 設計
15、基本原理簡介</p><p> 數(shù)字鐘的設計首先要保證其走時盡可能準確,其次再根據(jù)人們?nèi)粘5氖褂昧晳T來設定其附加功能。在設計中利用單片機定時計數(shù)器來完成走時并用兩組輸出口控制數(shù)碼管來顯示;通過編程向某一輸出口輸出方波實現(xiàn)報時及鬧鈴;利用輸入端口外接各種開關來完成對走時及顯示的控制(如預置時間等)。</p><p><b> 1復位電路</b></p>
16、<p> MCS-51單片機的復位是由外部的復位電路來實現(xiàn)的。復位引腳RST通過一個斯密特觸發(fā)器與復位電路相連,斯密特觸發(fā)器用來抑制噪聲,在每個機器周期的S5P2,斯密特觸發(fā)器的輸出電平由復位電路采樣一次,然后才能得到內(nèi)部復位操作所需要的信號。</p><p> 上電復位:上電復位電路是—種簡單的復位電路,只要在RST復位引腳接一個電容到VCC,接一個電阻到地就可以了。上電復位是指在給系統(tǒng)上電時,
17、復位電路通過電容加到RST復位引腳一個短暫的高電平信號,這個復位信號隨著VCC對電容的充電過程而回落,所以RST引腳復位的高電平維持時間取決于電容的充電時間。為了保證系統(tǒng)安全可靠的復位,RST引腳的高電平信號必須維持足夠長的時間。</p><p><b> 2時鐘電路</b></p><p> 時鐘是單片機的心臟,單片機各功能部件的運行都是以時鐘頻率為基準,有條不
18、紊的一拍一拍地工作。因此,時鐘頻率直接影響單片機的速度,時鐘電路的質(zhì)量也直接影響單片機系統(tǒng)的穩(wěn)定性。常用的時鐘電路有兩種方式:一種是內(nèi)部時鐘方式,另一種為外部時鐘方式。本文用的是內(nèi)部時鐘方式。</p><p><b> 電路圖如下:</b></p><p> MCS-51單片機內(nèi)部有一個用于構成振蕩器的高增益反相放大器,該高增益反向放大器的輸入端為芯片引腳XTAL
19、1,輸出端為引腳XTAL2。這兩個引腳跨接石英晶體振蕩器和微調(diào)電容,就構成一個穩(wěn)定的自激振蕩器。 按鍵電路按鍵的開關狀態(tài)通過一定的電路轉換為高、低電平狀態(tài)。按鍵閉合過程在相應的I/O端口形成一個負脈沖。閉合和釋放過程都要經(jīng)過一定的過程才能達到穩(wěn)定,這一過程是處于高、低電平之間的一種不穩(wěn)定狀態(tài),稱為抖動。抖動持續(xù)時間的常長短與開關的機械特性有關,一般在5-10ms之間。為了避免CPU多次處理按鍵的一次閉合,應采用措施消除抖動。本文采用的是
20、獨立式按鍵,直接用I/O口線構成單個按鍵電路,每個按鍵占用一條I/O口線,每個按鍵的工作狀態(tài)不會產(chǎn)生互相影響。電路圖如下:</p><p><b> 4.3 按鍵電路</b></p><p> 按鍵的開關狀態(tài)通過一定的電路轉換為高、低電平狀態(tài)。按鍵閉合過程在相應的I/O端口形成一個負脈沖。閉合和釋放過程都要經(jīng)過一定的過程才能達到穩(wěn)定,這一過程是處于高、低電平之間的
21、一種不穩(wěn)定狀態(tài),稱為抖動。抖動持續(xù)時間的常長短與開關的機械特性有關,一般在5-10ms之間。為了避免CPU多次處理按鍵的一次閉合,應采用措施消除抖動。本文采用的是獨立式按鍵,直接用I/O口線構成單個按鍵電路,每個按鍵占用一條I/O口線,每個按鍵的工作狀態(tài)不會產(chǎn)生互相影響。</p><p><b> 電路圖如下:</b></p><p> P1.0口表示功能移位鍵,
22、按鍵選擇要調(diào)整的年、月、日、小時、分、秒。 </p><p> P1.1口表示數(shù)字“+“鍵,按一下則對應的數(shù)字加1。</p><p> P1.2口表示數(shù)字“-”鍵,按一下則對應的數(shù)字減1。</p><p> P1.3口表示退去選項,時間已經(jīng)調(diào)整好</p><p><b> 總電路原理圖</b></p>
23、<p><b> 電路的軟件設計 </b></p><p><b> 1軟件程序內(nèi)容</b></p><p> 本設計的軟件程序包括主程序、中斷子程序、打鈴子程序、時鐘顯示子程序、查詢時間表切換程序和延時子程序等等。另外由于電路中有四個按鍵,還另外設計了防抖動程序來防止干擾。</p><p> 系統(tǒng)軟
24、件設計流程圖這次的數(shù)字電子鐘設計用到很多子程序,它們的流程圖如下所示。主程序是先開始,然后啟動定時器,定時器啟動后在進行按鍵檢測,檢測完后,就可以顯示時間。</p><p> 圖5-1 主程序流程圖</p><p> 按鍵處理是先檢測秒按鍵是否按下,秒按鍵如果按下,秒就加1;如果沒有按下,就檢測分按鍵是否按下,分按鍵如果按下,分就加1;如果沒有按下,就檢測時按鍵是否按下,時按鍵如果按下
25、,時就加1;如果沒有按下,就把時間顯示出來。</p><p> 圖5-2 按鍵處理流程圖</p><p> 定時器中斷時是先檢測1秒是否到,1秒如果到,秒單元就加1;如果沒到,就檢測1分鐘是否到,1分鐘如果到,分單元就加1;如果沒到,就檢測1小時是否到,1小時如果到,時單元就加1,如果沒到,就顯示時間。</p><p> 圖5-3 定時器中斷流程</p&
26、gt;<p> 時間顯示是先秒個位計算顯示,然后是秒十位計算顯示,再是分個位計算顯示,再然后是分十位顯示,再就是時個位計算顯示,最后是時十位顯示。</p><p> 5.3 定時程序設計</p><p> 單片機的定時功能也是通過計數(shù)器的計數(shù)來實現(xiàn)的,此時的計數(shù)脈沖來自單片機的內(nèi)部,即每個機器周期產(chǎn)生一個計數(shù)脈沖,也就是每經(jīng)過1個機器周期的時間,計數(shù)器加1。如果MCS-
27、52采用的12MHz晶體,則計數(shù)頻率為1MHz,即每過1us的時間計數(shù)器加1。這樣可以根據(jù)計數(shù)值計算出定時時間,也可以根據(jù)定時時間的要求計算出計數(shù)器的初值。MCS-51單片機的定時器/計數(shù)器具有4種工作方式,其控制字均在相應的特殊功能寄存器中,通過對特殊功能寄存器的編程,可以方便的選擇定時器/計數(shù)器兩種工作模式和4種工作方式。</p><p> 定時器/計數(shù)器工作在方式0時,為13位的計數(shù)器,由TLX(X=0、
28、1)的低5位和THX的高8位所構成。TLX低5位溢出則向THX進位,THX計數(shù)溢出則置位TCON中的溢出標志位TFX.</p><p> 當定時器/計數(shù)器工作于方式1,為16位的計數(shù)器。本設計師單片機多功能定時器,所以MCS-51內(nèi)部的定時器/計數(shù)器被選定為定時器工作模式,計數(shù)輸入信號是內(nèi)部時鐘脈沖,每個機器周期產(chǎn)生一個脈沖使計數(shù)器增1。</p><p> 5.3.1實時時鐘實現(xiàn)的基本
29、方法</p><p> 時鐘的最小計時單位是秒,但使用定時器的方式1,最大的定時時間也只能達到131ms。我們可把定時器的定時時間定為50ms。這樣,計數(shù)溢出20次即可得到時鐘的最小計時單位:秒。而計數(shù)20次可以用軟件實現(xiàn)。</p><p> 秒計時是采用中斷方式進行溢出次數(shù)的累積,計滿20次,即得到秒計時。從秒到分,從分到時是通過軟件累加并進行比較的方法來實現(xiàn)的。要求每滿1秒,則“秒
30、”單元中的內(nèi)容加1;“秒”單元滿60,則“分”單元中的內(nèi)容加1;“分”單元滿60,則“時”單元中的內(nèi)容加1;“時”單元滿24,則將時、分、秒的內(nèi)容全部清零。</p><p> 5.3.2 實時時鐘程序設計步驟 </p><p> (1)選擇工作方式,計算初值; </p><p> ?。?)采用中斷方式進行溢出次數(shù)累計;</p><p>
31、 (3)從秒——分——時的計時是通過累加和數(shù)值比較實現(xiàn)的;</p><p> (4)時鐘顯示緩沖區(qū):時鐘時間在方位數(shù)碼管上進行顯示,為此在內(nèi)部RAM中要設置顯示緩沖區(qū),共6個地址單元。顯示緩沖區(qū)從左到右依次存放時、分、秒數(shù)值;</p><p> ?。?)主程序:主要進行定時器/計數(shù)器的初始化編程,然后反復調(diào)用顯示</p><p> 子程序的方法等待中斷的到來。&
32、lt;/p><p> ?。?)中斷服務程序:進行計時操作</p><p> (7)加1子程序:用于完成對時、分、秒的加操作,中斷服務程序在秒、</p><p> 分、時加1時共有三種條調(diào)用加1子程序,包括三項內(nèi)容:合字、加1并進行十進制調(diào)整、分字。</p><p><b> 5.4程序說明</b></p>
33、<p> 在整個系統(tǒng)中,在單片機的30H、31H和32H中存儲當前時間的小時、分鐘和秒。由于要用數(shù)碼管顯示當前的時間,必須用到分字和合字,因此在33H、34H、35H、36H、37H和38H中存儲當前時間的時十位、時個位、分十位、分個位、秒十位和秒個位,方便顯示。</p><p> 本設計有由四個輕觸按鍵組成的小鍵盤,這些按鍵可以任意改變當前的狀態(tài)。按功能移位鍵一次,表示當前要校對小時的十位;按第
34、二次,表示當前校對的是小時的個位;按第三次,則表示校對的是分鐘的十位;第四次,表示的校對的是分鐘的個位。按下數(shù)字“+” 鍵和數(shù)字“-”鍵可在當前校對的數(shù)字上相應加上1或者減去1。</p><p> 本設計采用查表方式,在程序里預先存儲兩個表格,即日常作息時間表和考試時間表,可以通過手動按鍵來選擇所要執(zhí)行的時間表。并且用紅、綠發(fā)光二極管來區(qū)別當前所執(zhí)行的時間表。系統(tǒng)開機后,按功能移位鍵就可以調(diào)整當前的時間,整個系
35、統(tǒng)操作簡單,功能明確。</p><p> 顯示數(shù)據(jù)時,先把要顯示的數(shù)據(jù)送到數(shù)據(jù)緩沖區(qū)SBUF中,再從SBUF中顯示。串行口緩沖寄存器SBUF器是可直接尋址的專用寄存器。在物理上,它對應著兩個寄存器,一個發(fā)送寄存器,一個接收寄存器。CPU寫SBUF,就是修改發(fā)送寄存器;讀SBUF,就是讀接收寄存器。接收器是雙緩沖的,以避免在接收下一幀數(shù)據(jù)之前,CPU未能及時響應接收器的中斷,沒有把上一幀數(shù)據(jù)讀走,而產(chǎn)生兩幀數(shù)據(jù)重
36、疊的問題。對于發(fā)送器,為了保持最大的傳輸速率,一般不需要雙緩沖,因為發(fā)送時CPU是主動的,不會產(chǎn)生寫重疊的問題。</p><p><b> 總程序</b></p><p> ORG 0000H ;程序入口地址LJMP STARTORG 000BH ;定時器0中斷入口地址LJMP TIMER_0K1 BIT P1.0 ;定義調(diào)時按鍵K2 BIT P1.1
37、;定義調(diào)分按鍵START: MOV TMOD,#01H ;定時器0,工作模式1MOV TH0,#03CHMOV TL0,#0B0H ;賦初值,定時50msSETB EA ;開中斷總開關SETB TR0 ;開啟定時器0SETB ET0 ;定時器0中斷允許位MOV R6,#0 ;用于控制走時的基準時鐘源,計中斷次數(shù)MOV R5,#0 ;R5用于控制掃描按鍵的時間間隔MOV 20H,#0 ;秒個位寄存器清零MOV 21H
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 單片機課程設計--數(shù)字鐘電子鐘
- 單片機課程設計--多功能數(shù)字電子鐘
- 單片機課程設計— 多功能數(shù)字電子鐘
- 江蘇大學單片機課程設計-多功能數(shù)字鐘的設計
- 單片機數(shù)字鐘課程設計
- 單片機數(shù)字鐘課程設計
- 課程設計---多功能電子數(shù)字鐘
- 單片機數(shù)字時鐘課程設計--單片機多功能電子鐘設計
- 單片機課程設計--智能電子數(shù)字鐘設計
- 課程設計--多功能電子數(shù)字鐘
- 單片機課程設計報告---多功能電子鐘
- 單片機課程設計數(shù)字鐘報告
- 單片機課程設計---數(shù)字鐘設計
- 多功能數(shù)字鐘課程設計報告
- 多功能數(shù)字鐘課程設計報告
- 多功能數(shù)字鐘課程設計報告
- 單片機課程設計--- 簡易數(shù)字鐘
- 單片機課程設計數(shù)字鐘
- 單片機課程設計報告-數(shù)字鐘的設計
- 基于單片機的多功能數(shù)字鐘設計[開題報告]
評論
0/150
提交評論