实验任务
本章的实验任务是使用领航者开发板上的HDMI接口在显示器上显示一个不停移动的方块,要求方块移动到边界处时能够改变移动方向。显示分辨率为1280*720,刷新速率为60hz。
系统框图
时钟生成IP核(clk_wiz_0)生成1280*720分辨率所需的像素时钟74.25MHz、以及TMDS编码驱动IP核所需的像素时钟的5倍频率即74.25 * 5 =371.25MHz。RGB驱动模块(rgb_driver)负责产生RGB时序,并输出来自RGB显示模块(rgb_display)的RGB数据。RGB数据被送入TMDS编码驱动IP核(rgb2dvi_0)并最后输出到HDMI接口。
在“HDMI彩条显示实验”中,我们利用RGB驱动模块输出的像素点的横坐标,在RGB显示模块中完成了彩条图案的绘制。而在本次实验中,为了完成方块的显示,需要同时使用像素点的横坐标和纵坐标来绘制方块所在的矩形区域,另外还需要知道矩形区域左上角的顶点坐标。由于RGB显示的图像在行场同步信号的同步下不停的刷新,因此只要连续改变方块左上角顶点的坐标,并在新的坐标点处重新绘制方块,即可实现方块移动的效果。
各模块端口及信号连接如图所示
RGB显示模块代码实现
modulergb_display(
input pixel_clk,//像素时钟
input sys_rst_n,//复位信号
input [10:0] pixel_xpos,
input [10:0] pixel_ypos,
output reg [23:0] pixel_data//像素点数据
);
//parameter define
parameter H_DISP=11'd1280;//分辨率--行
parameter V_DISP=11'd720;//分辨率--列13
localparam SIDE_W=11'd40;//屏幕边框宽度
localparam &nb