IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 【FPGA】FPGA lcd彩条的实现 -> 正文阅读

[嵌入式]【FPGA】FPGA lcd彩条的实现

一、LCD

LCD ( Liquid Crystal Display 的简称)液晶显示器。LCD 的构造是在两片平行的玻璃基板当中放置液晶盒,下基板玻璃上设置TFT(薄膜晶体管),上基板玻璃上设置彩色滤光片,通过TFT上的信号与电压改变来控制液晶分子的转动方向,从而达到控制每个像素点偏振光出射与否而达到显示目的。LCD已经替代CRT成为主流,价格也已经下降了很多,并已充分普及。

二、看TM043NDH02-40–LCD手册

1.描述

用的LCD的型号是TM043NDH02-40
在这里插入图片描述

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9BoiKjRK-1645452299062)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221185301169.png)]

2.信号接口

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0TxkvNSz-1645452299063)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221185716552.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-RbZSynX9-1645452299064)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221185726725.png)]

信号位宽说明
R8红基色
G8绿基色
B8蓝基色
DCLK串行时钟
DISP显示信号
HSYNC行同步信号
VSYNC场同步信号
DE数据有效

3.LCD模块图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tdwv68c7-1645452299064)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221204519672.png)]

4.LCD时序

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-d7G0Hf4m-1645452299064)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221190121838.png)]

同步脉冲a:sync

显示后沿b:back porch

显示时序段c:display

显示前沿d:font porch

5.LCD原理图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FSvYuuqS-1645452299064)(C:\Users\Jin\AppData\Roaming\Typora\typora-user-images\image-20220221204329954.png)]

三、代码部分

1.lcd_driver.v

module lcd_driver( 
    input				clk		,
    input				rst_n	,
    input   [23:0]      rgb_data,
    output  [7:0]       lcd_r   ,
    output  [7:0]       lcd_g   ,
    output  [7:0]       lcd_b   ,
    output              lcd_vsync,
    output              lcd_hsync,
    output              lcd_dclk,
    output              lcd_disp,
    output              lcd_de  ,
    output  [10:0]      pixel_x ,
    output  [9:0]       pixel_y 
);								 

// 场
parameter   V_SYNC      = 2     ,  
            V_BKPORCH   = 33    ,
            V_DISPLAY   = 480   ,
            V_FTPORCH   = 10    ,
            V_ALL       = V_SYNC + V_BKPORCH + V_DISPLAY + V_FTPORCH;
// 行
parameter   H_SYNC      = 96    ,
            H_BKPORCH   = 48    ,
            H_DISPLAY   = 640   ,
            H_FTPORCH   = 16    ,
            H_ALL       = H_SYNC + H_BKPORCH + H_DISPLAY + H_FTPORCH;  

// 场帧长计数器
reg     [10:0]      cnt_v;
wire                add_cnt_v;
wire                end_cnt_v;

// 行帧长计数器
reg     [10:0]      cnt_h;
wire                add_cnt_h;
wire                end_cnt_h;

// 行帧长计数器  
always @(posedge clk or negedge rst_n)begin 
   if(!rst_n)begin
        cnt_h <= 0;
    end 
    else if(add_cnt_h)begin 
            if(end_cnt_h)begin 
                cnt_h <= 0;
            end
            else begin 
                cnt_h <= cnt_h + 1;
            end 
    end
   else  begin
       cnt_h <= cnt_h;
    end
end 

assign add_cnt_h = 1'b1;
assign end_cnt_h = add_cnt_h && cnt_h == H_ALL - 1;   

// 场帧长计数器
always @(posedge clk or negedge rst_n)begin 
   if(!rst_n)begin
        cnt_v <= 0;
    end 
    else if(add_cnt_v)begin 
            if(end_cnt_v)begin 
                cnt_v <= 0;
            end
            else begin 
                cnt_v <= cnt_v + 1;
            end 
    end
   else  begin
       cnt_v <= cnt_v;
    end
end 

assign add_cnt_v = end_cnt_h;
assign end_cnt_v = add_cnt_v && cnt_v == V_ALL - 1;

// 场同步信号
assign lcd_vsync = (cnt_v <= V_SYNC - 1)?1'b0:1'b1;

// 行同步信号
assign lcd_hsync = (cnt_h <= H_SYNC - 1)?1'b0:1'b1;

// lcd_de显示有效
assign lcd_de = (((cnt_v >= V_SYNC + V_BKPORCH - 1) && (cnt_v <= V_SYNC + V_BKPORCH + V_DISPLAY - 1)) && ((cnt_h >= H_SYNC + H_BKPORCH - 1) && (cnt_h <= H_SYNC + H_BKPORCH + H_DISPLAY - 1)))?1'b1:1'b0;

// lcd rgb565
assign lcd_r = (lcd_de)?rgb_data[7:0]:0;
assign lcd_g = (lcd_de)?rgb_data[15:8]:0;
assign lcd_b = (lcd_de)?rgb_data[23:16]:0;

// 显示纵坐标
assign pixel_y = (lcd_de)?(cnt_v - (V_SYNC + V_BKPORCH)):0;

// 显示横坐标
assign pixel_x = (lcd_de)?(cnt_h - (H_SYNC + H_BKPORCH)):0;

// 串行时钟
assign lcd_dclk = clk;

// 正常显示置高电平
assign lcd_disp = 1'b1;

endmodule

2.lcd_show.v

module lcd_show(
    input               clk,
    input               rst_n,
    input   [10:0]      pixel_x,
    input   [9:0]       pixel_y, 
    output  [23:0]      rgb_data    
);      

// LCD的分辨率
parameter   H_DISPLAY = 480,
            V_DISPLAY = 272;

parameter   RED     = 24'b11111111_00000000_00000000,
            GREEN   = 24'b00000000_11111111_00000000,
            BLUE    = 24'b00000000_00000000_11111111,
            BLACK   = 24'b00000000_00000000_00000000;

// rgb数据寄存
reg     [23:0]      rgb_data_r;

always @(posedge clk or negedge rst_n)begin 
    if(!rst_n)begin
        rgb_data_r <= BLACK;
    end 
    else if((pixel_x >= 0) && (pixel_x < H_DISPLAY/3))begin 
        rgb_data_r <= RED;
    end 
    else if((pixel_x >= H_DISPLAY/3) && (pixel_x < H_DISPLAY/3*2))begin 
        rgb_data_r <= GREEN;
    end 
    else begin
        rgb_data_r <= BLUE;
    end
end

assign rgb_data = rgb_data_r;

endmodule

3.top.v

module top(
    input				clk		,
    input				rst_n	,
    output  [7:0]       lcd_r   ,
    output  [7:0]       lcd_g   ,
    output  [7:0]       lcd_b   ,
    output              lcd_vsync,
    output              lcd_hsync,
    output              lcd_dclk,
    output              lcd_disp,
    output              lcd_de      
);

wire                clk_25m;
wire    [10:0]      pixel_x;
wire    [9:0]       pixel_y;
wire    [23:0]      rgb_data;            


pll	pll_inst (
	.areset ( ~rst_n ),
	.inclk0 ( clk ),
	.c0     ( clk_25m ),
	.locked ( locked_sig )
	);


lcd_driver u_lcd_driver( 
    /* input				*/.clk		(clk_25m ),
    /* input				*/.rst_n    (rst_n   ),
    /* input   [23:0]       */.rgb_data (rgb_data),
    /* output  [7:0]        */.lcd_r    (lcd_r   ),
    /* output  [7:0]        */.lcd_g    (lcd_g   ),
    /* output  [7:0]        */.lcd_b    (lcd_b   ),
    /* output               */.lcd_vsync(lcd_vsync),
    /* output               */.lcd_hsync(lcd_hsync),
    /* output               */.lcd_dclk (lcd_dclk),
    /* output               */.lcd_disp (lcd_disp),
    /* output               */.lcd_de   (lcd_de  ),
    /* output  [10:0]       */.pixel_x  (pixel_x ),
    /* output  [9:0]        */.pixel_y  (pixel_y )

);


lcd_show u_lcd_show(
    /* input                */.clk       (clk     ),
    /* input                */.rst_n     (rst_n   ),
    /* input   [10:0]       */.pixel_x   (pixel_x ),
    /* input   [9:0]        */.pixel_y   (pixel_y ), 
    /* output  [23:0]       */.rgb_data  (rgb_data)    
);
endmodule

四、仿真验证

这个就直接上板了

五、上板验证

在这里插入图片描述

六、总结

这个只是简单的看看那个手册的时序,然后写的驱动,其实lcd和vga一样的,只是lcd比vga多了几个信号,lcd是rgb888,vga是rgb565,数据转换一下,这个项目是为了摄像头而准备的,所有的学的到时候来个综合的。

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2022-02-26 11:46:32  更:2022-02-26 11:50:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 18:22:46-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码