當前位置:首頁 > 單片機 > 單片機
[導讀]摘要:設計采用高性能單片機C8051F020為控制芯片,監(jiān)控示波器面板上40個按鍵、3個編碼開關及4個電位器的狀態(tài)。分別介紹了鍵盤、編碼開關和電位器的工作原理,以及其與單片機連接的硬件電路及軟件編程的實現(xiàn)。按鍵部


摘要:設計采用高性能單片機C8051F020為控制芯片,監(jiān)控示波器面板上40個按鍵、3個編碼開關及4個電位器的狀態(tài)。分別介紹了鍵盤、編碼開關和電位器的工作原理,以及其與單片機連接的硬件電路及軟件編程的實現(xiàn)。按鍵部分采用一鍵多義的鍵盤程序設計方法,給出了鍵碼匹配子程序流程圖。
關鍵詞:鍵盤;編碼開關;模數(shù)轉(zhuǎn)換;監(jiān)控程序

    監(jiān)控程序負責系統(tǒng)中全部硬件和軟件資源的分配、調(diào)度工作,它提供用戶接口,使用戶獲得友好的工作環(huán)境,是系統(tǒng)設計中一個重要組成部分。

1 C8051F020單片機概述
    C8051F020單片機是高度集成的片上系統(tǒng)。在芯片內(nèi)集成了2個多通道ADC子系統(tǒng)(每個子系統(tǒng)包括1個可編程增益放大器和1個模擬多路選擇器)、2 個電壓輸出DAC、2個電壓比較器、電壓基準、SMBus/I2C總線接口、UART、SPI總線接口、5個通用的16位定時器、1個具有5個捕捉/比較模塊的可編程計數(shù)器/定時器陣列(PCA)、內(nèi)部振蕩器、8個8位通用數(shù)字I/0端口和64 KBFlash程序存儲器,以及8051兼容的高速微控制器內(nèi)核。

2 一鍵多義鍵盤工作原理
    一臺完善的智能儀表功能往往很多,設定的量程、參數(shù)也很多。如果還是用一鍵一個功能,勢必要有一個很大的鍵盤,面板相應擴大,不美觀,而且成本增加。因此在這類儀表中,鍵盤設計成一鍵多義,一個鍵有多種功能。
    在一鍵多義的情況下,一個命令不是由一次按鍵組成,而是由一個按鍵序列組成。也就是說,對一個按鍵含義的解釋,不僅取決于本次按鍵,還取決于以前按了些什么鍵。因此,對于一鍵多義的監(jiān)控程序,首先要判斷一個按鍵序列(而不是一次按鍵)是否已構(gòu)成一個合法命令。若已構(gòu)成合法命令,則執(zhí)行命令,否則等待新按鍵輸入。一鍵多義鍵盤管理程序,主要解決鍵盤按鍵序列的識別和如何根據(jù)鍵盤的按鍵序列去找相應的操作程序這兩個問題。
    上述問題可用“一圖三表”的方法來解決。即,建立一張鍵圖,依靠分析程序狀態(tài)表,分析程序入口表和動作例行子程序表來完成。其中分析程序狀態(tài)表總共分為4欄,分別為現(xiàn)狀態(tài)PSTi、鍵碼、下一狀態(tài)、動作例行子程序編號。

3 編碼開關工作原理
    編碼開關有3個引腳和5個引腳的,其中2個引腳是按下功能,另外3個引腳控制編碼開關的左旋和右旋功能,與引腳1、2相連的是兩個長短不一的金屬靜片,與引腳3相連的是一周有12或24個齒的金屬動片。當脈沖電位器旋轉(zhuǎn)時可出現(xiàn)4種狀態(tài):引腳3與引腳1相連,引腳3與引腳2及引腳1全相連,引腳3與引腳2 相連,引腳3與引腳2及引腳1全斷開。
    在實際使用中,一般將引腳3接地作為數(shù)據(jù)輸入端。而引腳1、2作為數(shù)據(jù)輸出端與單片機I/0口相連。本設計中用到3個編碼開關,其中一個將引腳1與單片機的P4.0相連,引腳2與單片機的P4.1相連。當脈沖電位器左旋或右旋時,P4.0和P4.1就會周期性地產(chǎn)生圖1所示的波形。如果是12點的脈沖電位器旋轉(zhuǎn)一圈就會產(chǎn)生12組這樣的波形,24點的脈沖電位器就會產(chǎn)生24組這樣的波形。一組波形(或一個周期)包含了4個工作狀態(tài)。因此只要檢測出P4.O 和P4.1的波形,就能識別脈沖電位器是否旋轉(zhuǎn),是左旋還是右旋。


4 C8051F020單片機ADC0
    C8051F020的ADC0子系統(tǒng)包括:一個9通道的可配置模擬多路開關(AMUX0)、一個可編程增益放大器(PGA0)和一個100 ksps的12位分辨率的逐次逼近寄存器型ADC。ADC中集成了跟蹤保持電路和可編程窗口檢測器。AMUX0、PGA0、數(shù)據(jù)轉(zhuǎn)換方式及窗口檢測器都可用軟件通過特殊功能寄存器來配置。只有當ADC0控制寄存器(ADCOCN)中的ADOEN位被置1時,ADC子系統(tǒng)才被允許工作。當ADOEN位為0 時,ADC子系統(tǒng)處于低功耗關斷方式。
    ADC0端口的每一對均可用編程設置成為單端輸入或差分輸入。差分輸入時的端口配對為(0,1)、(2,3)、(4,5)、(6,7),此設置由通道選擇寄存器AMUXOSL的低4位和通道配置寄存器AMUXOCF的低4位確定。在AMXOCF中,位3~O各對應2個引腳通道。位值=0,表示是獨立的單端輸入(復位值均為單端輸入);位值=1,表示是差分輸入對。
    C8051F系列單片機中ADC的速率都是可編程設置的,但最少要用16個系統(tǒng)時鐘。一般在轉(zhuǎn)換之前還自動加上3個系統(tǒng)時鐘的跟蹤/保持捕獲時間 (>1.5μs)。設置F020內(nèi)ADC速率的方法是通過配置寄存器ADCOCF的位7~3來進行的,其復位值為11111(位 7~3=SYSCLK/CLK(SAR)-1)。
    一般在啟動ADC之前都要處于跟蹤方式,控制寄存器ADCOCN的位6如果為“O”,則一直處于跟蹤方式(此時啟動4種啟動方式都可比跟蹤啟動快3個系統(tǒng)時鐘);如為“1”,則有4種跟蹤啟動方式可選擇,即對ADCOCN中的位3~2賦值:00為向ADBUSY寫1時跟蹤(軟件命令),01為定時器3溢出跟蹤,1O為CNVSTR上升沿跟蹤(外部信號),11為定時器2溢出跟蹤。

5 系統(tǒng)硬件電路設計
    鍵盤部分采用6×6矩陣鍵盤,P7.O~P7.5為行線,P3.0~P3.5為列線。P3.0與P7.O交叉處為一鍵,P7口接10 kΩ的上拉電阻至3.3 V。3個編碼開關的1、2腳直接與單片機的I/0引腳相連,這里選擇P4.O~P4.5,3腳接地,4、5腳用作按鍵使用。僅以接P4.O和P4.1引腳的編碼開關為例,電路圖如圖2所示。模數(shù)轉(zhuǎn)換部分使用內(nèi)部電壓基準,故將VREF引腳與VREF0引腳相連即可。采用電位器調(diào)節(jié)模擬量的輸入,單端輸入,電位器阻值為10 kΩ,基準電壓典型值為2.43 V,電源電壓采用3.3 V供電。為使基準電壓達到最大,需要一個阻值約為3.58 kΩ的電阻與電位器串聯(lián)接到模擬端口,硬件電路如圖3所示,電位器的4、5腳也用作按鍵使用。
        



6 系統(tǒng)軟件設計
6.1 一鍵多義鍵盤程序設計
    在鍵盤分析中,運用一個工作狀態(tài)寄存器保存鍵盤的現(xiàn)狀態(tài),當鍵盤掃描到一個按鍵時,根據(jù)現(xiàn)狀態(tài)的值從分析程序入口表中找到分析程序狀態(tài)表地址,從該地址處進入分析程序狀態(tài)表,找到相匹配的值,把下一狀態(tài)送到現(xiàn)狀態(tài)單元里,取出動作號,根據(jù)動作號計算出動作子程序入口地址,再執(zhí)行相應子程序。圖4為鍵碼匹配子程序的流程圖。


6. 2 編碼開關程序設計
    由圖1可以看出,引腳1和引腳2有同時為高電平的情況,之后如果引腳2比引腳1先到達高電平則表示左旋,如果引腳1比引腳2先到達高電平則表示右旋。編程的時候依據(jù)這個特點來判斷引腳1、引腳2的狀態(tài)即可。以1引腳接P4.0,2引腳接P4.1為例:

6.3 模數(shù)轉(zhuǎn)換軟件設計
    通過設置ADCO控制寄存器ADCOCN位3~2(ADOCM1~O)A/D轉(zhuǎn)換啟動方式選擇位,來啟動A/D轉(zhuǎn)換:位3~2為00時,向ADOBUSY(ADCOCN位4)寫1啟動A/D轉(zhuǎn)換;位3~2為01時,定時器3溢出啟動A/D轉(zhuǎn)換;位3~2為10時,CNVSTR上升沿啟動 A/D轉(zhuǎn)換;位3~2為11時,定時器2溢出啟動A/D轉(zhuǎn)換。本設計采用第一種啟動方式。
    由于單片機的工作量并不大,所以軟件設計時采用查詢的方式。單片機不斷地查詢鍵盤、編碼開關以及電位器的狀態(tài),如果有變化時,單片機將動作信息傳遞給 ARM主MCU,等待主MCU的處理。由于單片機模數(shù)轉(zhuǎn)換的速度非常快,因此在程序中加延時,以便觀察到模數(shù)轉(zhuǎn)換的變化量。另外,硬件設計時沒有考慮濾波,故用軟件實現(xiàn)濾波。一般的濾波的方法有限幅濾波法、中位置濾波法、算術(shù)平均濾波法等,現(xiàn)在提出一種新的濾波方法。由于使用12位A/D,但只要8位就可以達到所要的精度,所以可以采用去掉低4位的方法來實現(xiàn)濾波的目的。由于篇幅有限,下面只給出程序的一部分,以AIN0為例:



結(jié)語
    本文介紹的一鍵多義的按鍵管理程序,對多按鍵的智能儀表可以通用。編碼開關的編程方法簡單易懂。在A/D轉(zhuǎn)換部分,提出的去掉低4位的軟件濾波方法可靠可行,對精度要求不高的場合非常適用。這3部分構(gòu)成了一個完整的監(jiān)控程序,當單片機監(jiān)控到某一部分有變化時,就將其動作信息傳遞給ARM主CPU,主CPU 進行相應的處理。

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

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

關鍵字: 阿維塔 塞力斯 華為

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

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

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

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

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

關鍵字: 亞馬遜 解密 控制平面 BSP

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

關鍵字: 騰訊 編碼器 CPU

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

關鍵字: 華為 12nm EDA 半導體

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

關鍵字: 華為 12nm 手機 衛(wèi)星通信

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

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

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

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

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

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