在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何使用FPGA實現字符顯示

電子設計 ? 來源:電子設計 ? 作者:電子設計 ? 2022-02-09 10:29 ? 次閱讀

作者:ALINX

* 本原創教程由芯驛電子科技(上海)有限公司(ALINX)創作,版權歸本公司所有,如需轉載,需授權并注明出處。

適用于板卡型號:

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

實驗Vivado工程為“hdmi_char”。

在HDMI輸出實驗中講解了HDMI顯示原理和顯示方式,本實驗介紹如何使用FPGA實現字符顯示,通過這個實驗更加深入的了解HDMI的顯示方式。

1. 實驗原理

實驗通過字符轉換工具將字符轉換為16進制coe文件存放到單端口的ROM IP 核中,再從ROM 中把轉換后的數據讀取出來顯示到HDMI上。

2.程序設計

字符顯示例程是在HDMI顯示的基礎上增加了一個osd_display的模塊,“osd_display”模塊是用來讀取存儲在Rom ip核里轉換后的字符信息,并在指定區域顯示。程序框圖如下圖所示:

pIYBAGAJbwiABA5_AACDMYqn5qM256.png

2.1 在“timing_gen_xy”模塊是根據HDMI時序標準定義了“x_cnt”和“y_cnt”兩個計數器并由這兩個計數器產生了HDMI顯示的“x”坐標和“y”坐標。程序中用“vs_edge”和“de_falling”分別表示場同步開始信號和數據有效結束信號。其原理如下圖所示:

o4YBAGAJb4WAPkl1AAA_z3eNx_A049.png

timing_gen_xy模塊端口

2.2 下面介紹如何存儲文字信息的ROMIP,首先需要生成能夠被XILINX FPGA識別的.coe文件。

首先在工程文件夾下找到“FPGA字模提取”工具。

pIYBAGAJb82AGcrLAAACb-XdSDs808.png

雙擊.exe文件打開工具

在提取工具的“字符輸入”框中輸入需要顯示的字符,字體和字符高度可以自定義選擇。設置完成后點擊“轉換”按鈕,在界面左下角可以看到轉換后的字符點陣大小,點陣的寬和高在程序中是需要用到

點陣的寬和高這里位144x32,需要跟osd_display程序中定義的一致:

pIYBAGAJcJGALjJZAAACd2FyqGw689.png

點擊“保存”按鈕,將文件保存到本例程源文件目錄下,需要注意的是在保存類型下應該選擇Xilinx(*.coe),點擊“保存”按鈕。

找到生成的.coe文件打開后可以看到如下:

o4YBAGAJcQ6AAHDyAAARYbJQeyc512.png

調用單端口Rom IP核的過程在前面ROM的使用中已經介紹過,設置為Single Port ROM

在PortA Options欄中設置如下:

按如下圖添加osd.coe文件(找到前面生成的coe文件),完成后點擊“OK”按鈕:

2.3 osd_display模塊包含timing_gen_xy 模塊和osd_rom模塊。osd_rom里存儲的字符數據,如果數據為1,OSD的區域顯示ROM中的前景紅色(顯示ALINX芯驛),如果數據是0,OSD的區域顯示數據為背景色(彩條)。

o4YBAGAJchGAOBWMAAAUSFeMZK4808.png

設置區域有效信號,也就是字符顯示在此區域中,起始坐標設置成(9,9),區域大小可以根據字符生成工具設置的區域設置。

pIYBAGAJck-AHimWAAAaMQ9ftS8526.png

在ROM的讀地址部分可能很多人不理解,為什么是[15:3],也就是八個時鐘周期才讀出一個數據,這是因為字符的一個點只表示1bit,而ROM的存儲數據寬度是8位,因此需要八個周期取出一個數據,并比較每個bit位的值,將字符一個點轉換成圖像上的一個像素。

pIYBAGAJco-Aa47nAAAMJLGS_rE191.png

pIYBAGAJcs2AYy0WAAA3dOkFW5Y690.png

osd_display模塊端口

3.實驗現象

連接好開發板和顯示器,連接方式參考《HDMI輸出實驗》教程,需要注意,開發板的各個連接器不要帶電熱插拔,下載好實驗程序,可以看到顯示器顯示以彩條為背景的字符。開發板作為HDMI輸出設備,只能通過HDMI顯示設備來顯示,不要試圖通過筆記本電腦的HDMI接口來顯示,因為筆記本也是輸出設備。

默認字符顯示的位置在坐標為(9,9),另外用戶可以修改下面的pos_y和pos_x的判斷條件將字符顯示在顯示屏的任意位置:

o4YBAGAJc0qAbiR9AAAKp6OGA3E495.png

審核編輯:何安

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1643

    文章

    21983

    瀏覽量

    614852
  • HDMI
    +關注

    關注

    33

    文章

    1823

    瀏覽量

    154735
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    基于易靈思國產FPGA Ti60F225 實現6目同步1080P實時成像系統

    基于FPGA實現單目的采集,并沒有什么難的。 但基于FPGA實現多目的同步采集→存儲→顯示,就不是那么好做了。
    的頭像 發表于 03-04 12:00 ?1187次閱讀
    基于易靈思國產<b class='flag-5'>FPGA</b> Ti60F225 <b class='flag-5'>實現</b>6目同步1080P實時成像系統

    字符串在編程中的應用實例

    常以字符串的形式出現。例如,在命令行程序中,用戶輸入的命令和參數都是字符串。 輸出信息 :程序也經常需要向用戶顯示信息,這些信息同樣可以以字符串的形式呈現。例如,打印歡迎消息、錯誤提示
    的頭像 發表于 01-07 15:33 ?643次閱讀

    字符串與字符數組的區別

    在編程語言中,字符串和字符數組是兩種基本的數據結構,它們都用于存儲和處理文本數據。盡管它們在功能上有一定的重疊,但在內部表示、操作方式和使用場景上存在顯著差異。 1. 內部表示 字符字符
    的頭像 發表于 01-07 15:29 ?1033次閱讀

    字符串反轉的實現方式

    在編程中,字符串反轉是一個基礎而重要的操作,它涉及到將一個字符串中的字符順序顛倒過來。這個操作在多種編程語言中都有不同的實現方式,本文將探討幾種常見的
    的頭像 發表于 01-07 15:27 ?744次閱讀

    字符串處理方法 字符串轉數字的實現

    在編程中,將字符串轉換為數字是一個常見的需求。不同的編程語言有不同的方法來實現這一功能。以下是一些常見編程語言中的字符串轉數字的實現方法: Python 在Python中,可以使用內置
    的頭像 發表于 01-07 15:26 ?799次閱讀

    基于FPGA實現圖像直方圖設計

    簡單,單采用FPGA實現直方圖的統計就稍顯麻煩。若使用Xilinx和Altera的FPGA芯片,可以使用HLS來進行圖像的加速處理。但這暫時不是我的重點。 用C語言實現直方圖統計:u
    的頭像 發表于 12-24 10:24 ?695次閱讀
    基于<b class='flag-5'>FPGA</b><b class='flag-5'>實現</b>圖像直方圖設計

    FPGA驅動AD芯片之實現與芯片通信

    概述:?利用FPGA實現AD芯片的時序,進一步實現與AD芯片數據的交互,主要熟悉FPGA對時序圖的實現,掌握時序圖轉換Verilog硬件描述
    的頭像 發表于 12-17 15:27 ?984次閱讀
    <b class='flag-5'>FPGA</b>驅動AD芯片之<b class='flag-5'>實現</b>與芯片通信

    基于FPGA實現數碼管顯示

    本文介紹數碼管顯示譯碼基本工作原理及Verilog HDL驅動代碼編寫,進一步熟練掌握FPGA入門基礎知識。
    的頭像 發表于 10-24 14:44 ?1700次閱讀
    基于<b class='flag-5'>FPGA</b><b class='flag-5'>實現</b>數碼管<b class='flag-5'>顯示</b>

    基于FPGA的LCD1602液晶顯示模塊驅動設計

    本文通過以LCD1602液晶顯示模塊為基礎,介紹FPGA驅動LCD1602原理,詳細介紹硬件原理圖設計及FPGA驅動LCD1602軟件設計,通過萬年歷功能綜合實現時鐘功能、LCD160
    的頭像 發表于 10-24 14:42 ?3900次閱讀
    基于<b class='flag-5'>FPGA</b>的LCD1602液晶<b class='flag-5'>顯示</b>模塊驅動設計

    Labview 字符串 不常用功能:快捷才當將字符串設置為反斜杠(\'\\\')代碼顯示,用于儀器通信

    右鍵單擊字符串常量、顯示控件或輸入控件,從快捷菜單中選擇 **\'\'代碼顯示** ,則LabVIEW將反斜杠()后緊接的字符視作不可顯示
    發表于 09-06 14:01

    labview字符串如何轉換為16進制字符

    在LabVIEW中,將字符串轉換為16進制字符串是一個常見的需求,尤其是在處理數據通信和硬件接口時。LabVIEW提供了多種方法來實現這一轉換,包括使用內置函數、編寫VI(Virtual
    的頭像 發表于 09-04 15:54 ?4847次閱讀

    labview中如何實現字符串換行

    1. 字符串換行的基本概念 在LabVIEW中,字符串換行通常指的是在字符串中插入換行符,使得字符串在顯示或輸出時能夠自動換行。這在創建用戶
    的頭像 發表于 09-04 15:47 ?3598次閱讀

    labview中如何實現字符串選擇輸出

    在LabVIEW中實現字符串選擇輸出是一項常見的任務,它涉及到字符串處理、條件判斷和用戶界面設計等多個方面。由于LabVIEW是一種圖形化編程語言,其編程方式與傳統的文本編程語言有所不同,因此
    的頭像 發表于 09-04 15:44 ?2080次閱讀

    labview字符串的四種表示各有什么特點

    字符串控件(String Control) 字符串控件是LabVIEW中用于顯示和編輯字符串的圖形界面元素。它允許用戶在前面板(Front Panel)上輸入
    的頭像 發表于 09-04 15:40 ?1285次閱讀

    基于FPGA的圖像采集與顯示系統設計

    源和固有的并行處理能力,在數字信號處理、硬件加速、汽車電子等領域得到了廣泛應用。在圖像采集與顯示系統中,FPGA能夠實現高速、并行的數據處理,顯著提高系統的實時性和性能。本文設計了一個基于FP
    的頭像 發表于 07-17 10:58 ?2725次閱讀
    主站蜘蛛池模板: 天天碰天天干 | 国产精品第一页在线观看 | 三级精品在线观看 | 色婷婷色 | 上色天天综合网 | 国产aaaaaaa毛片 | 六月丁香啪啪六月激情 | 手机福利视频 | 男女性接交无遮挡免费看视频 | 欧美黑人性xxx猛交 欧美黑人性受xxxx精品 | 午夜视频福利 | 亚洲免费网站在线观看 | 午夜免费视频福利集合100 | 国模私拍一区二区三区 | 免费男女视频 | 淫操| 久久免费观看国产精品 | 婷婷久久综合九色综合九七 | 97av免费视频 | 在线免费亚洲 | 国产精品久线观看视频 | 人人看人人做 | 日本黄色录像 | 鲁丝一区二区三区 | 欧美在线精品一区二区三区 | 国产乱码精品一区二区三区四川人 | 多男一女一级淫片免费播放口 | 国产精品欧美久久久久天天影视 | 久久精品隔壁老王影院 | h视频日本 | 色老头在线官方网站 | 色综合成人 | 国产精品高清一区二区三区 | 无遮挡很爽很污很黄很色的网站 | 欧美1314www伊人久久香网 | 免费理论片在线观看播放 | 黑人黑粗硬视频 | 日本美女搞黄 | 性欧美videofree丝袜 | 一级特级女人18毛片免费视频 | 国产精品欧美激情在线播放 |