[VHDL代碼]LCD1602驅動.docx_第1頁
[VHDL代碼]LCD1602驅動.docx_第2頁
[VHDL代碼]LCD1602驅動.docx_第3頁
[VHDL代碼]LCD1602驅動.docx_第4頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

VHDL代碼LCD1602驅動library IEEE;use IEEE.STD_LOGIC_1164.ALL;use IEEE.STD_LOGIC_ARITH.ALL;use IEEE.STD_LOGIC_UNSIGNED.ALL;entity LCD1602 isPort ( Clk : in std_logic; -狀態(tài)機時鐘信號,同時也是液晶時鐘信號,其周期應該滿足液晶數據的建立時間Sec_low,Sec_high,Min_low,Min_high,Hour_low,Hour_high: in std_logic_vector(3 downto 0);LCD_RS : out std_logic; -寄存器選擇信號LCD_RW : out std_logic; -液晶讀寫信號LCD_EN : out std_logic; -液晶時鐘信號LCD_Data : out std_logic_vector(7 downto 0); -液晶數據信號end LCD1602;architecture Behavioral of LCD1602 istype STATE_TYPE is (START,write_C,write_D,WRITE_BYTE_C,WRITE_BYTE_D,wait_3m1,wait_3m2,wait_5m1,wait_5m2,wait_100m);type MY_ARRAY1 is array(0 to 4) of std_logic_vector(7 downto 0);type MY_ARRAY2 is array(0 to 7) of std_logic_vector(7 downto 0);-長度為14的 8位/字數組constant c_d: MY_ARRAY1:=(x38,x0c,x06,x01,x84);signal d_d: MY_ARRAY2:=(x20,x20,x3A,x20,x20,x3A,x20,x20);signal STATE: STATE_TYPE:=START;signal w_c_flag : integer range 0 to 2:=0;signal w_d_flag : integer range 0 to 2:=0;signal write_c_cnt : integer range 0 to 5:=0;signal write_d_cnt : integer range 0 to 8:=0;signal cnt : integer range 0 to 10000:=0; signal count : integer range 0 to 10000:=0;begin LCD_RW = 0 ; -寫數據d_d(0)=0000&Hour_high+x30;d_d(1)=0000&Hour_low+x30;d_d(3)=0000&Min_high+x30;d_d(4)=0000&Min_low+x30;d_d(6)=0000&Sec_high+x30;d_d(7) LCD_EN=0;w_c_flag=0;w_d_flag=0;write_c_cnt=0;write_d_cnt=0;STATEcase write_c_cnt is when 0 to 4= STATE write_c_cnt=4;STATEif(w_c_flag=0) thenLCD_RS=0;LCD_Data=c_d(write_c_cnt);w_c_flag=1;STATE=wait_3m1;elsif(w_c_flag=1) thenLCD_EN=1; w_c_flag=2;STATE=wait_5m1;elsif(w_c_flag=2) thenLCD_EN=0;w_c_flag=0;write_c_cnt=write_c_cnt+1;STATEcase write_d_cnt is when 0 to 7= STATE write_d_cnt=0;STATEif(w_d_flag=0) thenLCD_RS=1;LCD_Data=d_d(write_d_cnt);w_d_flag=1;STATE=wait_3m2;elsif(w_d_flag=1) thenLCD_EN=1; w_d_flag=2;STATE=wait_5m2;elsif(w_d_flag=2) thenLCD_EN=0;w_d_flag=0;write_d_cnt=write_d_cnt+1;STATEif (cnt=3) then STATE=WRITE_BYTE_C; cnt=0; else cnt=cnt+1; STATE if (cnt=5) then STATE=WRITE_BYTE_C; cnt=0; else cnt=cnt+1; STATE if (cnt=3) then STATE=WRITE_BYTE_D; cnt=0; else cnt=cnt+1; STATE if (cnt=5) then STATE=WRITE_BYTE_D; cnt=0; else cnt=cnt+1; STATE if (cnt=1

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論