女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁(yè) > 技術(shù)學(xué)院 > FPGA之旅
[導(dǎo)讀]這是FPGA之旅設(shè)計(jì)的第九例啦!??!本例將介紹如何使用FPGA驅(qū)動(dòng)OLED屏幕,并在接下來(lái)的幾例中,配合其它模塊,進(jìn)行一些有趣的綜合實(shí)驗(yàn)。由于使用的OLED屏是IIC接口的,對(duì)IIC接口不是很清楚的,可以參考第五例的設(shè)計(jì),同時(shí)使用第五例寫好的IIC模塊,驅(qū)動(dòng)OLED屏。Let's do it!

一. 簡(jiǎn)介

這是FPGA之旅設(shè)計(jì)的第九例啦?。?!本例將介紹如何使用FPGA驅(qū)動(dòng)OLED屏幕,并在接下來(lái)的幾例中,配合其它模塊,進(jìn)行一些有趣的綜合實(shí)驗(yàn)。由于使用的OLED屏是IIC接口的,對(duì)IIC接口不是很清楚的,可以參考第五例的設(shè)計(jì),同時(shí)使用第五例寫好的IIC模塊,驅(qū)動(dòng)OLED屏。Let's do it!

二. 0.96寸OLED屏介紹

這里就只介紹最常用的0.96寸屏,其它的一樣。OLED共支持8080并口、SPI和IIC三種接口,同樣也只介紹IIC接口的用法。0.96寸OLED屏幕的分辨率為128×64,內(nèi)部有一塊GRAM用來(lái)存儲(chǔ)顯示的數(shù)據(jù)。

1

OLED的存儲(chǔ)區(qū)域


這塊存儲(chǔ)區(qū)域分為8個(gè)page,每個(gè)page下面共有128bit,如下圖所示

這就難免會(huì)有些疑問(wèn)了,128×8,不應(yīng)該是128×64嘛?8個(gè)page,為什么是64行呢?數(shù)據(jù)寫入的呢?

每一個(gè)page包括8行,所以說(shuō)8個(gè)page共有64行。IIC每次發(fā)送數(shù)據(jù)的時(shí)候,是發(fā)送一個(gè)byte的,也就是8bit,這8bit數(shù)據(jù)會(huì)存儲(chǔ)到某一列的八行中,例如圖中SEG0區(qū)域,是第一列的頭八行。這樣GRAM的存儲(chǔ)區(qū)域就弄懂了。


2

OLED的數(shù)據(jù)存儲(chǔ)模式

當(dāng)我們向OLED的GRAM發(fā)送顯示數(shù)據(jù)的過(guò)程中,OLED內(nèi)部共有三種處理模式。

模式一: 當(dāng)我們指定了一個(gè)page和某一列的時(shí)候,每寫一個(gè)數(shù)據(jù),列會(huì)自動(dòng)加一,當(dāng)寫到page的最后一列的時(shí)候,列數(shù),會(huì)自動(dòng)跳轉(zhuǎn)到第零列,需要手動(dòng)的切換page。


模式二與模式一不同的時(shí)候,當(dāng)寫達(dá)到page的最后一列的時(shí)候,列數(shù)跳轉(zhuǎn)到第零列的同時(shí),page數(shù)也會(huì)加一。


模式三: 與前兩個(gè)模式不同,模式三,是一列一列的寫,每寫完一個(gè)數(shù)據(jù),page數(shù)加一,當(dāng)加到最后一個(gè)page的時(shí)候,列數(shù)加一,page跳轉(zhuǎn)到第一個(gè)page。


在實(shí)際的使用中,具體使用那一種模式,可以根據(jù)自己的子模軟件或者項(xiàng)目來(lái),怎么方便怎么來(lái)!

了解了上面兩個(gè)部分后,基本就可以編寫驅(qū)動(dòng)程序啦,不要問(wèn)為什么,(#^.^#),初始化OLED就是配置一些列命令的過(guò)程,而這些寄存器和配置的值一般都是copy現(xiàn)成的。然后了解一下關(guān)鍵的一兩個(gè)命令就可以啦。想要深入的了解OLED的功能的話,可以閱讀對(duì)應(yīng)的芯片手冊(cè)哦!在后面的例程中也會(huì)介紹部分功能強(qiáng)大的命令。


三. OLED關(guān)鍵命令介紹

  • 0xAE/0xAF: 對(duì)應(yīng)著開(kāi)啟OLED顯示和關(guān)閉OLED顯示

  • 0x20-0x22: 對(duì)應(yīng)著上面的三種OLED數(shù)據(jù)存儲(chǔ)模式,默認(rèn)為0x22,模式一

  • 0x00-0x0F: 設(shè)置列地址的低四位,默認(rèn)為0x00

  • 0x10-0x1F: 設(shè)置列地址的高四位,默認(rèn)為0x10

  • 0xB0-0xB7: 設(shè)置page,第四位表示page

暫時(shí)差不多只需要了解上面的這些寄存器。


四. IIC驅(qū)動(dòng)OLED數(shù)據(jù)格式

驅(qū)動(dòng)OLED分為寫數(shù)據(jù)和寫命令(讀暫時(shí)不考慮)。寫命令就是配置的過(guò)程,寫數(shù)據(jù)就是寫入GRAM中進(jìn)行顯示的過(guò)程。

IIC數(shù)據(jù)格式  :OLED地址 + 命令 / 數(shù)據(jù) +  值。

OLED地址,就是IIC協(xié)議中的從機(jī)地址,我這里是0x78。

命令/數(shù)據(jù)中0x00表示接下來(lái)的值代表命令,0x40表示接下的值表示數(shù)據(jù),存入GRMA。

,具體的命令或者數(shù)據(jù)

也就是說(shuō)每一次IIC需要傳輸24bit,3個(gè)字節(jié)的數(shù)據(jù),和第五例的IIC模塊完美對(duì)應(yīng),那事情就好辦啦!


五. OLED初始化

直接copy某例程提供的配置參數(shù),共需要配置26個(gè)命令,第一個(gè)是上面介紹的0xAE命令,關(guān)閉OLED顯示。最后一個(gè)也是介紹的0xAF命令,開(kāi)啟OLED顯示,沒(méi)有配置模式,直接使用的默認(rèn)的模式一,配置完成后,可以看到OLED屏被點(diǎn)亮,內(nèi)容是雜亂的

always@(*)begin case(Init_index) 'd0:    Init_data_reg <= {8'h78,8'h00,8'hAE}; //OLED地址 + 命令  +  值。** 'd1:    Init_data_reg <= {8'h78,8'h00,8'h00}; 'd2:    Init_data_reg <= {8'h78,8'h00,8'h10}; 'd3:    Init_data_reg <= {8'h78,8'h00,8'h40}; 'd4:    Init_data_reg <= {8'h78,8'h00,8'hB0}; 'd5:    Init_data_reg <= {8'h78,8'h00,8'h81}; 'd6:    Init_data_reg <= {8'h78,8'h00,8'hFF}; 'd7:    Init_data_reg <= {8'h78,8'h00,8'hA1}; 'd8:    Init_data_reg <= {8'h78,8'h00,8'hA6}; 'd9:    Init_data_reg <= {8'h78,8'h00,8'hA8}; 'd10:    Init_data_reg <= {8'h78,8'h00,8'h3F}; 'd11:    Init_data_reg <= {8'h78,8'h00,8'hC8}; 'd12:    Init_data_reg <= {8'h78,8'h00,8'hD3}; 'd13:    Init_data_reg <= {8'h78,8'h00,8'h00}; 'd14:    Init_data_reg <= {8'h78,8'h00,8'hD5}; 'd15:    Init_data_reg <= {8'h78,8'h00,8'h80}; 'd16:    Init_data_reg <= {8'h78,8'h00,8'hD8}; 'd17:    Init_data_reg <= {8'h78,8'h00,8'h05}; 'd18:    Init_data_reg <= {8'h78,8'h00,8'hD9}; 'd19:    Init_data_reg <= {8'h78,8'h00,8'hF1}; 'd20:    Init_data_reg <= {8'h78,8'h00,8'hDA}; 'd21:    Init_data_reg <= {8'h78,8'h00,8'h12}; 'd22:    Init_data_reg <= {8'h78,8'h00,8'hDB}; 'd23:    Init_data_reg <= {8'h78,8'h00,8'h30}; 'd24:    Init_data_reg <= {8'h78,8'h00,8'h8D}; 'd25:    Init_data_reg <= {8'h78,8'h00,8'h14}; 'd26:    Init_data_reg <= {8'h78,8'h00,8'hAF}; default: Init_data_reg <= {8'h78,8'h00,8'hAE}; endcaseend


六. 向GRAM中寫入數(shù)據(jù)

初始化后,就可以顯示內(nèi)容啦,僅僅只需要配置page和起始列三個(gè)命令,然后寫入數(shù)據(jù)即可,配置頁(yè)和列地址,只有在模式一有效,也就是上電默認(rèn)的模式。

這樣就可以顯示數(shù)據(jù)啦,親測(cè)可用哦!

'd0:show_data_reg <= {8'h78,8'h00,8'hb0 + show_pag}; //配置頁(yè)'d1:show_data_reg <= {8'h78,8'h00,8'h00 +start_x[3:0]}; //配置列的低四位'd2:show_data_reg <= {8'h78,8'h00,8'h10 + start_x[6:4]}; //配置列的高四位,128列只需要配置高三位即可。'd3:show_data_reg <= {8'h78,8'h40, data}; //向配置的地址中,寫入顯示的數(shù)據(jù)

其實(shí)驅(qū)動(dòng)OLED也沒(méi)有那么復(fù)雜嘛。


七. 上板驗(yàn)證

先來(lái)編寫個(gè)簡(jiǎn)單的模塊,用來(lái)初始化OLED。下載程序后,我的OLED是亮起來(lái)了,你的呢!

//OLED頂層模塊module OLED_Top( input      sys_clk, input      rst_n, //OLED IIC output    OLED_SCL, inout      OLED_SDA);localparam  OLED_INIT = 'd0;      //初始化localparam  OLED_IDLE = 'd1; //空閑reg[4:0]  state , next_state;wire      init_finish;wire[23:0]  Init_data;wire       init_req;wire      IICWriteDone;assign init_req = (state == OLED_INIT) ? 1'b1 : 1'b0;always@(posedge sys_clk or negedge rst_n)begin if(rst_n == 1'b0) state <= OLED_INIT; else state <= next_state;endalways@(*)begin case(state) OLED_INIT: if(init_finish == 1'b1) next_state <= OLED_IDLE; else next_state <= OLED_INIT; OLED_IDLE: next_state <= OLED_IDLE; default: next_state <= OLED_INIT; endcaseendOLED_Init OLED_Init(  .sys_clk        (sys_clk), .rst_n        (rst_n),  .init_req      (init_req), //初始化請(qǐng)求 .write_done      (IICWriteDone), //一組初始化數(shù)據(jù)完成信號(hào)  .init_finish    (init_finish), //初始化完成輸出  .Init_data      (Init_data)//初始化的數(shù)據(jù));IIC_Driver IIC_DriverHP_OLED( .sys_clk        (sys_clk), /*系統(tǒng)時(shí)鐘*/ .rst_n        (rst_n), /*系統(tǒng)復(fù)位*/  .IICSCL        (OLED_SCL), /*IIC 時(shí)鐘輸出*/ .IICSDA        (OLED_SDA), /*IIC 數(shù)據(jù)線*/   .IICSlave      ({Init_data[15:8],Init_data[23:16]}), /*從機(jī) 8bit的寄存器地址 + 8bit的從機(jī)地址*/  .IICWriteReq    (init_req), /*IIC寫寄存器請(qǐng)求*/ .IICWriteDone    (IICWriteDone), /*IIC寫寄存器完成*/ .IICWriteData    (Init_data[7:0]), /*IIC發(fā)送數(shù)據(jù)  8bit的數(shù)據(jù)*/  .IICReadReq      (1'b0), /*IIC讀寄存器請(qǐng)求*/ .IICReadDone      (), /*IIC讀寄存器完成*/ .IICReadData        () /*IIC讀取數(shù)據(jù)*/);endmodule

FPGA驅(qū)動(dòng)OLED就結(jié)束啦!


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

在數(shù)字化浪潮席卷全球的今天,F(xiàn)PGA技術(shù)正成為驅(qū)動(dòng)創(chuàng)新的核心引擎。2025年8月21日,深圳將迎來(lái)一場(chǎng)聚焦FPGA技術(shù)與產(chǎn)業(yè)應(yīng)用的盛會(huì)——2025安路科技FPGA技術(shù)沙龍。本次沙龍以“定制未來(lái) 共建生態(tài)”為主題,匯聚行業(yè)...

關(guān)鍵字: FPGA 核心板 開(kāi)發(fā)板

在現(xiàn)代電子系統(tǒng)中,現(xiàn)場(chǎng)可編程門陣列(FPGA)憑借其開(kāi)發(fā)時(shí)間短、成本效益高以及靈活的現(xiàn)場(chǎng)重配置與升級(jí)等諸多優(yōu)點(diǎn),被廣泛應(yīng)用于各種產(chǎn)品領(lǐng)域。從通信設(shè)備到工業(yè)控制,從汽車電子到航空航天,F(xiàn)PGA 的身影無(wú)處不在。為了充分發(fā)揮...

關(guān)鍵字: 可編程門陣列 FPGA 數(shù)字電源

2025年8月4日 – 提供超豐富半導(dǎo)體和電子元器件?的業(yè)界知名新品引入 (NPI) 代理商貿(mào)澤電子 (Mouser Electronics) 即日起開(kāi)售Altera?的Agilex? 3 FPGA C系列開(kāi)發(fā)套件。此開(kāi)...

關(guān)鍵字: FPGA 邊緣計(jì)算 嵌入式應(yīng)用

內(nèi)窺鏡泛指經(jīng)自然腔道或人工孔道進(jìn)入體內(nèi),并對(duì)體內(nèi)器官或結(jié)構(gòu)進(jìn)行直接觀察和對(duì)疾病進(jìn)行診斷的醫(yī)療設(shè)備,一般由光學(xué)鏡頭、冷光源、光導(dǎo)纖維、圖像傳感器以及機(jī)械裝置等構(gòu)成。文章介紹了一款基于兩片圖像傳感器和FPGA組成的微型3D內(nèi)...

關(guān)鍵字: 微創(chuàng) 3D內(nèi)窺鏡 OV6946 FPGA

運(yùn)用單片機(jī)和FPGA芯片作為主控制器件 , 單片機(jī)接收從PC機(jī)上傳過(guò)來(lái)的顯示內(nèi)容和顯示控制命令 , 通過(guò)命令解釋和數(shù)據(jù)轉(zhuǎn)換 , 生成LED顯示屏所需要的數(shù)據(jù)信號(hào)和同步的控制信號(hào)— 數(shù)據(jù)、時(shí)鐘、行同步和面同步 。FPGA芯...

關(guān)鍵字: 單片機(jī) FPGA LED顯示屏

在異構(gòu)計(jì)算系統(tǒng)中,ARM與FPGA的協(xié)同工作已成為高性能計(jì)算的關(guān)鍵架構(gòu)。本文基于FSPI(Fast Serial Peripheral Interface)四線模式,在150MHz時(shí)鐘頻率下實(shí)現(xiàn)10.5MB/s的可靠數(shù)據(jù)...

關(guān)鍵字: ARM FPGA FSPI

在全球FPGA市場(chǎng)被Xilinx(AMD)與Intel壟斷的格局下,國(guó)產(chǎn)FPGA廠商高云半導(dǎo)體通過(guò)構(gòu)建自主IP核生態(tài)與智能時(shí)序約束引擎,走出差異化高端化路徑。本文深入解析高云半導(dǎo)體FPGA工具鏈的兩大核心技術(shù)——全棧IP...

關(guān)鍵字: FPGA 高云半導(dǎo)體

2025年6月12日,由安路科技主辦的2025 FPGA技術(shù)沙龍?jiān)谀暇┱秸匍_(kāi),深圳市米爾電子有限公司(簡(jiǎn)稱:米爾電子)作為國(guó)產(chǎn)FPGA的代表企業(yè)出席此次活動(dòng)。米爾電子發(fā)表演講,并展出米爾基于安路飛龍派的核心板和解決方案...

關(guān)鍵字: FPGA 核心板 開(kāi)發(fā)板

高 I/O、低功耗及先進(jìn)的安全功能,適用于成本敏感型邊緣應(yīng)用

關(guān)鍵字: FPGA I/O 機(jī)器視覺(jué)

本文討論如何為特定應(yīng)用選擇合適的溫度傳感器。我們將介紹不同類型的溫度傳感器及其優(yōu)缺點(diǎn)。最后,我們將探討遠(yuǎn)程和本地檢測(cè)技術(shù)的最新進(jìn)展如何推動(dòng)科技進(jìn)步,從而創(chuàng)造出更多更先進(jìn)的溫度傳感器。

關(guān)鍵字: 溫度傳感器 CPU FPGA
關(guān)閉