《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 其他 > 教學:FPGA中如何顯示16*16大小的字符

教學:FPGA中如何顯示16*16大小的字符

2022-09-28
來源:FPGA之旅

  一。 簡介

  這是FPGA之旅設計的第十三例啦,本例是一個綜合性的例程,基于OLED屏幕顯示,和DHT11溫濕度采集,將DHT11采集到的溫濕度顯示到OLED屏幕上。

  在開始本例之前,先補充一下,在上例中,代碼中有個位置有錯誤,就是DHT11是先發(fā)送濕度然后發(fā)送溫度,代碼中給弄反了,已修改。

  顯示效果如下

  二。 字體的顯示

  字體的制作,以及如何將生成的字符數據添加到FPGA中,在上一例已經說明了,以及如何顯示16*8的大小的字符,也就是不需要換行字符。本例中著重介紹如何顯示16*16大小的字符,即在寫入字符的過程中,需要有換行的操作,即切換page。本例的漢字大小為16*16,英文和數字為8*16大小的,即兩種字體大小,這也是在顯示過程中需要注意的點。

  1

  字符數據輸出

  這部分,還是和上例中一樣,不同的是額外添加了一個font_row參數,因為本例中使用的字符都是需要換行的,所以需要添加這個參數。

  always@(*)begin  case(showfont_index)  'd0:  showfont_data_reg <= {8'h78,8'h00,8'hB0 + show_y + font_row};  'd1:  showfont_data_reg <= {8'h78,8'h00,8'h00 + show_x[3:0]};  'd2:  showfont_data_reg <= {8'h78,8'h00,8'h10 + show_x[7:4]};  default:  showfont_data_reg <= {8'h78,8'h40,fontdata}; //fontdata  endcaseend

  如何使用這個參數進行換行呢?

  我們知道8*16大小的字符,一共用16個數據,每行占八個數據。所以這里需要先發(fā)送八個數據后,然后進行換行,將font_row參數加一,以及將showfont_index置0即可。在取字符的時候,需要注意,我們是根據showfont_index的值來取的,而換行后,這個參數置0了,這個時候,需要將font_row也用上,也就是還要加上8*font_row,這樣就可以接著上次的位置繼續(xù)取字符數據了。

  當font_size字符大小為0,即8*16時,showfont_index為10的時候,就需要進行換行了,3個設置顯示地址數據 加 8個正好是10(11)。

  always@(posedge sys_clk or negedge rst_n)begin  if(rst_n == 1'b0)    font_row <= 1'b0;    else if(onefont_finish == 1'b1)  //一個字符顯示完    font_row <= 1'b0;  else if(font_size == 'd0 && showfont_index == 'd10 && write_done == 1'b1)    font_row <= 1'b1;  else if(font_size == 'd1 && showfont_index == 'd18 && write_done == 1'b1)    font_row <= 1'b1;  else    font_row <= font_row;endalways@(posedge sys_clk or negedge rst_n)begin  if(rst_n == 1'b0)    showfont_index <= 'd0;  else if(onefont_finish == 1'b1)    showfont_index <= 'd0;  else if(font_size == 'd0 && showfont_index == 'd10 && write_done == 1'b1)    showfont_index <= 'd0;  else if(font_size == 'd1 && showfont_index == 'd18 && write_done == 1'b1)    showfont_index <= 'd0;  else if(write_done == 1'b1 && ShowFont_req == 1'b1)    showfont_index <= showfont_index + 1'b1;  else    showfont_index <= showfont_index;end

  取數據

  data <= data0[index + 'd8 * font_row];

  2

  多個字符顯示

  這里只需要看這兩行代碼。每次一個字符顯示完成后,font_index就加一,當顯示完14個字符的時候,將ShowFont_finish拉高即可。比較容易。

  assign onefont_finish = ((showfont_index == (‘d10 + 'd8 * font_size)) && (font_row == 1'b1) && write_done == 1'b1) ? 1'b1 : 1'b0;assign ShowFont_finish = (onefont_finish == 1'b1 && font_index == 'd14) ? 1'b1 : 1'b0;

  三。 整體介紹

  本例中,OLED顯示一共分為如下5個狀態(tài)。在初始化完成后,屏幕顯示的是雜亂無章的數據,所以在初始化完成后,要進行一次刷新,將OLED中的數據全部寫0。然后進行顯示固定不變的支符,例如像溫度濕度這樣的字符。然后進入空閑態(tài),直到DHT11采集到數據后,就進入到數據顯示狀態(tài),數據顯示完成后,又回到空閑態(tài)。這是整個的一個流程。

  localparam  OLED_INIT      =  'd0;      //初始化localparam  OLED_Refresh   =  'd1;      //刷新,將oled全部寫0localparam  OLED_ShowFont  =  'd2;        //顯示字符localparam  OLED_IDLE      =  'd3;       //空閑localparam  OLED_ShowData  =  'd4;        //顯示數據

  總框圖如下,可以看到在top模塊,除了一些模塊,還有一些其他的內容,這部分是專門針對DHT11的。測試過程中,發(fā)現每次采集數據的時間間隔不能太小,否則數據一直不變,查看手冊后,得知兩次采集的數據間隔不能小于1s,否則會有問題。

07.JPG



更多信息可以來這里獲取==>>電子技術應用-AET<<

mmexport1621241704608.jpg



 


本站內容除特別聲明的原創(chuàng)文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創(chuàng)文章及圖片等內容無法一一聯(lián)系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 男女国产一级毛片| 里番肉本子同人全彩h| 男女交性高清全过程无遮挡| 国产在线jyzzjyzz免费麻豆| 伊人性伊人情综合网| 在线观看免费av网站| yellow日本动漫高清小说| 护士在办公室里被躁视频| 亚洲欧美日韩中文字幕网址| 视频aavvmm国产野外| 国产青榴视频在线观看网站 | 久久久久久久久人体| 尤物网在线视频| 九九视频九九热| 欧美日本一本线在线观看| 亚洲视频免费在线观看| 色天天综合色天天碰| 国产在线精品一区二区| 韩国成人在线视频| 天堂mv在线看中文字幕| 一级黄色免费大片| 日韩精品欧美高清区| 亚洲色av性色在线观无码| 精品亚洲成a人无码成a在线观看 | 尤物yw午夜国产精品视频| 中文国产成人精品久久不卡| 无码国产精品一区二区免费模式 | 好吊色青青青国产综合在线观看| 久久精品人人做人人爽| 特级毛片a级毛片在线播放www | 一本久久a久久精品vr综合| 最新亚洲人成无码网www电影 | 1000部啪啪未满十八勿入免费| 在线a免费观看| JIZZ成熟丰满| 最近免费中文字幕大全视频 | 九九这里只有精品视频| 李老汉别揉我奶了嗯啊h| 亚洲免费视频在线观看| 欧美婷婷六月丁香综合色| 免费在线看黄网站|