quartus Ⅱ 12.1 使用教程(7) vga显示测试

2024-03-18 07:38

本文主要是介绍quartus Ⅱ 12.1 使用教程(7) vga显示测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

开发板使用的是EP4CE15F23C8,软件使用的是quartus 12.1 ,工程主要使用vga显示方格

行计数

//hsync计数
always@(posedge clk_148M or negedge i_rst_n)beginif(i_rst_n	==	1'b0)hsync_cnt	<=	12'd0;else	if(hsync_cnt == H_TOTAL -12'd1)hsync_cnt	<=	12'd0;elsehsync_cnt	<=	hsync_cnt	+	1'b1;
end

场计数

//VSYNC计数
always@(posedge clk_148M or negedge	i_rst_n)beginif(i_rst_n	==	1'b0)vsync_cnt	<=	12'd0;else	if(hsync_cnt == H_TOTAL -12'd1)if(vsync_cnt == V_TOTAL - 12'd1)vsync_cnt	<=	12'd0;elsevsync_cnt	<=	vsync_cnt	+	1'b1;
end

产生行信号

//hsync
assign vga_hs = ((hsync_cnt >= 12'd0)&&(hsync_cnt < H_SYNC))? 1'b0:1'b1;

产生场信号

//vsync
assign vga_vs = ((vsync_cnt >= 12'd0)&&(vsync_cnt < V_SYNC))? 1'b0:1'b1;

行场信号有效区域

//hsync和vsync显示有效区域
assign	hsync_en = ((hsync_cnt >= (H_SYNC + H_BACK))&&(hsync_cnt < (H_SYNC + H_BACK + H_ACTIVE)));
assign	vsync_en = ((vsync_cnt	>= (V_SYNC + V_BACK))&&(vsync_cnt < (V_SYNC + V_BACK + V_ACTIVE)));

输出显示

assign	vga_r	=	(hsync_en && vsync_en)? grid_data_1[15:11]: 5'd0;
assign	vga_g	=	(hsync_en && vsync_en)? grid_data_1[10:5]: 6'd0;
assign	vga_b	=	(hsync_en && vsync_en)? grid_data_1[4:0]: 5'd0;

下面的程序是显示一个1080p的一个方格的vga程序

module vga_test(i_clk,i_rst_n,vga_hs,vga_vs,vga_r,vga_g,vga_b);input				i_clk;
input				i_rst_n;
output			vga_hs;
output			vga_vs;
output	[4:0]	vga_r;
output	[5:0]	vga_g;
output	[4:0]	vga_b;parameter H_SYNC = 12'd44;
parameter H_BACK = 12'd148;
parameter H_ACTIVE = 12'd1920;
parameter H_FRONT = 12'd88;
parameter H_TOTAL = H_SYNC + H_BACK + H_ACTIVE + H_FRONT;parameter V_SYNC = 12'd5;
parameter V_BACK = 12'd36;
parameter V_ACTIVE = 12'd1080;
parameter V_FRONT = 12'd4;
parameter V_TOTAL = V_SYNC + V_BACK + V_ACTIVE + V_FRONT;reg	[11:0]	hsync_cnt;
reg	[11:0]	vsync_cnt;
wire				hsync_en;
wire				vsync_en;
wire				clk_148M;
reg	[15:0] 	grid_data_1;
reg	[4:0]		vga_r_reg;
reg	[5:0]		vga_g_reg;
reg	[4:0]		vga_b_reg;pll	pll_inst (.inclk0 ( i_clk ),//input	50M.c0 ( clk_148M )	//output	148M);//HSYNC计数
always@(posedge clk_148M or negedge i_rst_n)beginif(i_rst_n	==	1'b0)hsync_cnt	<=	12'd0;else	if(hsync_cnt == H_TOTAL -12'd1)hsync_cnt	<=	12'd0;elsehsync_cnt	<=	hsync_cnt	+	1'b1;
end//hsync
assign vga_hs = ((hsync_cnt >= 12'd0)&&(hsync_cnt < H_SYNC))? 1'b0:1'b1;//VSYNC计数
always@(posedge clk_148M or negedge	i_rst_n)beginif(i_rst_n	==	1'b0)vsync_cnt	<=	12'd0;else if(hsync_cnt == H_TOTAL -12'd1)if(vsync_cnt == V_TOTAL - 12'd1)vsync_cnt	<=	12'd0;elsevsync_cnt	<=	vsync_cnt	+	1'b1;
end//vsync
assign vga_vs = ((vsync_cnt >= 12'd0)&&(vsync_cnt < V_SYNC))? 1'b0:1'b1;//hsync和vsync显示有效区域
assign	hsync_en	=	((hsync_cnt >= (H_SYNC + H_BACK))&&(hsync_cnt < (H_SYNC + H_BACK + H_ACTIVE)));
assign	vsync_en	=	((vsync_cnt	>=	(V_SYNC + V_BACK))&&(vsync_cnt < (V_SYNC + V_BACK + V_ACTIVE)));//方格always@(posedge clk_148M or negedge i_rst_n)beginif(i_rst_n	==	1'b0)grid_data_1<= 16'h0000;else if ((hsync_cnt[4]==1'b1) ^ (vsync_cnt[4]==1'b1))     //产生小格子图像grid_data_1<= 16'h0000;elsegrid_data_1<= 16'hffff;  endassign	vga_r	=	(hsync_en && vsync_en)? grid_data_1[15:11]: 5'd0;
assign	vga_g	=	(hsync_en && vsync_en)? grid_data_1[10:5]: 6'd0;
assign	vga_b	=	(hsync_en && vsync_en)? grid_data_1[4:0]: 5'd0;endmodule

显示效果如下图

这篇关于quartus Ⅱ 12.1 使用教程(7) vga显示测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/821647

相关文章

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

Python验证码识别方式(使用pytesseract库)

《Python验证码识别方式(使用pytesseract库)》:本文主要介绍Python验证码识别方式(使用pytesseract库),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1、安装Tesseract-OCR2、在python中使用3、本地图片识别4、结合playwrigh

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

SpringCloud中的@FeignClient注解使用详解

《SpringCloud中的@FeignClient注解使用详解》在SpringCloud中使用Feign进行服务间的调用时,通常会使用@FeignClient注解来标记Feign客户端接口,这篇文章... 在Spring Cloud中使用Feign进行服务间的调用时,通常会使用@FeignClient注解

Java Spring 中的监听器Listener详解与实战教程

《JavaSpring中的监听器Listener详解与实战教程》Spring提供了多种监听器机制,可以用于监听应用生命周期、会话生命周期和请求处理过程中的事件,:本文主要介绍JavaSprin... 目录一、监听器的作用1.1 应用生命周期管理1.2 会话管理1.3 请求处理监控二、创建监听器2.1 Ser