0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

采用FPGA技术控制VGA接口在显示器上的图形显示

电子设计 来源:郭婷 作者:电子设计 2019-05-20 08:04 次阅读

显示器因为其输出信息量大,输出形式多样等特点已经成为现在大多数设计的常用输出设备。在 FPGA 的设计中可以使用很少的资源,就产生 VGA 各种控制信号。这个示例在 RHicSP2200B FPGA 开发板/学习板上使用 VGA 接口在显示器上显示了文字以及简单的图形,可以作为VGA 显示设计的参考。

显示器术语

像素与分辨率

显示器的显示方式有两种 : A/N(Alphabet/Number:字符/数字)显示方式 和 APA(All Point Addressable:全点寻址) 显示方式,即文本显示方式和图形显示方 式。A/N 方式已淘汰不用,目前微机都采用 APA 图形方式。

显示器上输出的一切信息,包括数值、 文字、表格、图象、动画等等,都是由光点(即像素)构成的。组成屏幕显示画面的最小单位是像素,像素之间的最小距离为点距(Pitch)。点距越小像素密度越大,画面越 清晰。显示器的点距有 0.31mm、0.28mm、0.24mm、0.22mm 等多种。

分辨率指整屏显示的像素的多少,是衡量显示器的一个常用指标。这同屏幕尺寸及点距密切相关,可用屏幕实际显示的尺寸与 点距相除来近似求得。点距为 0.28mm 的 15 英寸显示器,分辨率最高为 1024×768。

显示器尺寸

显示器屏幕尺寸以对角线来度量,常用的显示器有 14、15、17、19、21 英寸等。 显示器水平方向长度与垂直方向高度之比 一般为 4:3。

扫描频率

显示器采用光栅扫描方式,即轰击荧光屏的电子束在 CRT 屏幕上从左到右(受水 平同步信号 HSYNC 控制)、从上到下(受 垂直同步信号 VSYNC 控制)做有规律的移动。光栅扫描又分逐行扫描和隔行扫描。电子束采用光栅扫描方式,从屏幕左上角一点 开始,向右逐点进行扫描,形成一条水平线;到达最右端后,又回到下一条水平线的左 端,重复上面的过程;当电子束完成右下角一点的扫描后,形成一帧。此后,电子束又回到左上方起点,开始下一帧的扫描。这种 方法也就是常说的逐行扫描显示。

而隔行扫描指电子束在扫描时每隔一 行扫一线,完成一屏后再返回来扫描剩下的 线,这与电视机的原理一样。隔行扫描的显示器比逐行扫描闪烁得更厉害,也会让使用者的眼睛更疲劳。目前微机所用显示器几乎都是逐行扫描。

完成一行扫描所需时间称为水平扫描时间,其倒数称为行频率;完成一帧(整屏) 扫描所需的时间称为垂直扫描时间,其倒数为垂直扫描频率,又称刷新频率,即刷新一屏的频率。常见的有 60Hz、75Hz 等,标准 VGA 显示的场频60Hz,行频为31.5kHz。

显示带宽

带宽则指显示器可以处理的频率范围。如果 60Hz 刷新频率的 VGA 方式,其带宽达 640×480×60=18.4MHz;70Hz 刷新频率1024×768 分辨率的 SVGA 方式,其带宽达1024×768×70=55.1MHz。

早期的显示器频率固定。现在流行的多 屏显示器采用自动跟踪技术,使显示器的扫描频率自动与显示卡的输出同步,达到较宽的适用范围。

显示卡术语

一个像素点可有多种颜色,由表示该像素的二进位数(又称像素的位宽)决定。像 素位宽为 8bit,则每个像素有 28=256 种颜 色;位宽为16bit 则有 216=65536 种颜色, 位宽为 24bit 则有 224 即一千七百多万种颜色。显示卡内的D/A(数/模)转换电路将每 个像素的位宽(二进位整数)转换成对应亮度的 R、G、B(红、绿、蓝)模拟信号,控制屏幕上相应的三色荧光点发光,产生所要求的颜色。

随着 PC 机的不断更新换代,显示控制卡(即显示适配器)的标准也不断发展。从最初的 MDA(单色显示适配器)→CGA(彩色图形显示适配器)→EGA(增强型图形适配器)→VGA(视频图形阵列适配器)。VGA 一改以前显示卡采用的数字视频信号输出,而用模拟视频信号输出,VGA 卡内的 D/A 转换器数字信号转换为控制 R、G、B 三 原色的模拟信号,使像素色彩变化非常平滑,更适合人的视觉感受。

性能高于VGA 并与之兼容的显示适配 卡有 TVGA 和 SVGA。随着 Windows 的普及和对快速度、多色彩、高分辨率的需要, 一些厂家在 SVGA 芯片中增加更多的硬件 来支持 Windows 的加速,这类显示适配器一般被称作 AVGA(Accelerated VGA:加速VGA)。目前大多数微机上的显示卡都属于 AVGA 类型。

显示卡主要由图形处理芯片、视频存储器及 BIOS 芯片等组成。一般 AVGA 类型显示卡的控制器由单块 AVGA 芯片充当,其中包含的图形加速控制器对提升图形功能至关重要。

显示卡的性能主要取决于卡上使用的图形芯片。早期的图形芯片没有帧缓冲器,有关帧的操作都要由 CPU去处理,降低了显示速度。现在多数显示卡上都设置具有图形处理功能的加速芯片,可处理像 Windows类型的图形任务而减少 CPU 参与。更高级的显示卡上有协处理器,可大大减免 CPU 的处理和参与。

利用视频存储器 VRAM 储存显示数据,可减少甚至免去访问系统主存,加快显示速度。 640×480-16色VGA显示一屏需640×480×Log216/8=154KB 显示存储器,1024×768 真彩显示一屏则需1024×768×24÷8≈2.3MB。 显示卡插在系统板的扩展槽内,通过电缆连接到机箱背面的15 针D 型插座连接器上。某些高档的主板内置了显示卡的功能。 CRT 显示器背面有一个与显示器连接好的视频电缆,电缆的末端是 15针插入式连接器,使用时将它直接插入主机机箱背面的 15孔D 型插座上即可。

VGA 时序设计

在 VGA 中,水平同步脉冲在光栅扫描 线需要回到水平开始位置也就是屏幕的左边的时候插入,垂直同步脉冲在光栅扫描线需要回到垂直开始位置也就是屏幕的上方的时候插入。复合同步脉冲是水平同步脉冲与垂直同步信号的组合。RGB 为像素数据,在没有图像投射到屏幕时插入消隐信号,当消隐有效时,RGB 信号无效。

水平时序

在水平时序中,包括以下几个时序参数:水平同步脉冲宽度;水平同步脉冲结束到水平门的开始之间的宽度;一个视频行可视区域的宽度;一个完整的视频行的宽度,从水平同步脉冲的开始到下一个水平同步脉冲的开始。

垂直时序

在垂直时序与水平时序类似,包括以下几个不同的时序参数:垂直同步脉冲宽度; 垂直同步结束到垂直门的开始之间的宽度; 一个视频帧可是区域的宽度;一个完整视频帧的宽度,从垂直同步脉冲到下一个垂直同步脉冲的开始。

组合视频帧时序

视频帧由 vlen 个视频行组成,每一行由 hlen 个像素,水平门与垂直门的“与”函数 即为可是区域,图像的其他区域为消隐区。 目前存在很多种不同VGA 模式,以下就常见的各种模式种参数进行说明,给出 VGA 模式中各种时序参数可以参考。

表 1 水平时序

采用FPGA技术控制VGA接口在显示器上的图形显示

说明:有效时间包括 6 列过扫描边界列,有些时序表将这几列加在后沿和前沿中

表 2 垂直时序

采用FPGA技术控制VGA接口在显示器上的图形显示

说明:有效时间包括 4 行过扫描边界行,有些时序表中将这几行加在后沿和前沿中。

*当有效时间增加时,它超过了 vsync 信号的上升沿,因此前沿为-1

在实际设计中如何通过不同的系统频率确定适当的显示模式 ? 例如在 RhicSP2200 开发板中FPGA 的系统时钟频率为 50MHz。这个时钟频率可以用来设计 显示 800X600 模式,为了显示器显示效果好,采用场频(刷新频率)75Hz,那么帧长可以确定为 666,而行总长设计为 1000 像素。

根据以上所述,我们可以设计如Examples1类似HDL代码,使用这段代码在Valid 有效期间对RGB 中 Blue 两位赋值1,得到一个蓝色屏幕显示边界如图1 所示。

色彩原理

RGB 色彩模式是工业界的一种颜色标准,是通过对红(R)、绿(G)、蓝(B)三个颜色 通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB 即是代表红、 绿、蓝三个通道的颜色,通过三种基本颜色亮度值从 0“255 不同产生出其他各种颜色,这种模式叫加色模式。为什么叫加色模式呢,举个例子,通常使用的电视屏幕和电脑 屏幕上的显示就是这样的模式,在没有图象时,屏幕是黑的,若R,G,B 三色亮度都为255 时混合叠加打在屏幕上时则显示成白色。就是加起来是白色的意思,叫加色模式。这个标准几乎包括了人类视力所能感知的所有颜色,是目前运用最广的颜色系统之 一。

而与我们电脑相关的地方,就是目前的显示器大都是采用了 RGB 颜色标准,这就是为什么它对我们来说这么重要了。

在显示器上,是通过电子枪打在屏幕的红、绿、蓝三色发光极上来产生色彩的,目前的电脑一般都能显示 32 位颜色,约有一百万种以上的颜色。如果说它所显示的颜色 还不能完全吻合自然界中的某种色彩的话,那已经几乎是我们肉眼所不能分辩出来的了。

而 RhicSP2200 开发板系统中每一个色 彩都是使 用 2bit 来 表示的,因 此可见 RhicSP2200 系统可以出现64 种不同的颜 色。其他色彩的使用请在实际工作中更多的加以体会。

显示

通过以上的讲述,已经可以在计算机显示器上显示一个有颜色的区域了,在这个小节中我们再举一个简单的例子,在显示器中显示两个镶嵌的正方形,字符等显示与其类似,可以参考瑞芯科技其他设计示例。 例如我们可以在 xpos 与 ypos 的某一区间给 RGB 信号赋不同的值将得到如图2 所示的显示效果。

例子 1:使用 50MHz 时钟频率产生的 VGA 同步脉冲以及视频有效信号

module sync_gen_50m(

rst_n,// synthesis attribute clock_buffer of rst_n is ibufg;

clk,

hsync,

vsync,

valid,

x_cnt,

y_cnt

);

input rst_n ;

input clk ;

output hsync ;

output vsync ;

output valid ;

output [9:0] x_cnt ;

output [9:0] y_cnt ;

reg hsync ;

reg vsync ;

reg valid ;

reg [9:0] x_cnt ;

reg [9:0] y_cnt ;

always @ ( posedge clkornegedge rst_n )

if ( !rst_n )

x_cnt <= 10‘d0;

else if ( x_cnt == 10’d1000 )

x_cnt <= 10‘d0;

else

x_cnt <= x_cnt + 1’b1;

always @ ( posedge clkornegedge rst_n )

if ( !rst_n )

y_cnt <= 10‘d0;

else if ( y_cnt == 10’d665 )

y_cnt <= 10‘d0;

else if ( x_cnt == 10’d1000 )

y_cnt <= y_cnt + 1‘b1;

always @ ( posedge clkornegedge rst_n )

if ( !rst_n )

begin

hsync <= 1’b0;

vsync <= 1‘b0;

end

else

begin

hsync <= x_cnt <= 10’d50;

vsync <= y_cnt <= 10‘d6;

end

always @ ( posedge clkornegedge rst_n )

if ( !rst_n )

valid <= 1’b0;

else

valid <= ( ( x_cnt > 10‘d180 ) && ( x_cnt < 10’d980) &&

( y_cnt > 10‘d35) && ( y_cnt < 10’d635) );

endmodule

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1630

    文章

    21783

    浏览量

    605023
  • 显示器
    +关注

    关注

    21

    文章

    5002

    浏览量

    140251
  • 频率
    +关注

    关注

    4

    文章

    1532

    浏览量

    59316
收藏 人收藏

    评论

    相关推荐

    基于FPGA实现VGA的彩色图片显示

    VGA进行控制,实现任一彩色图像的显示。通过采用FPGA设计VGA
    发表于 03-24 11:54 4388次阅读
    基于<b class='flag-5'>FPGA</b>实现<b class='flag-5'>VGA</b>的彩色图片<b class='flag-5'>显示</b>

    液晶显示器-VGA 视频接口显示规范

    液晶显示器-VGA 视频接口显示规范 本部分规定了液晶显示器接收设备中视频VGA信号
    发表于 11-21 16:00

    液晶显示器VGA视频接口显示规范

    液晶显示器VGA视频接口显示规范 本部分规定了液晶显示器接收设备中视频VGA信号外部
    发表于 03-03 16:34 83次下载

    基于Actel FPGAVGA显示控制方案

    VGA 是视频图形阵列(Video Graphics Array)的简称,是IBM 于1987 年提出的一个使用模拟信号的图形显示标准。最初的VGA
    发表于 11-15 17:40 79次下载

    VGA图形控制器FPGA实现

    经过硬件平台的验证,基于FPGAVGA 图形显示器已达到设计要求,可实现彩条、汉字、小图像和大图像的显示,并可实现
    发表于 06-08 09:55 2166次阅读
    <b class='flag-5'>VGA</b><b class='flag-5'>图形控制器</b>的<b class='flag-5'>FPGA</b>实现

    基于FPGAVGA图形控制器设计

    VGA(视频图形阵列)作为一种标准的显示接口得到广泛的应用。利用FPGA 芯片和EDA 设计方法,可以因地制宜,根据用户的特定需要,设计出针
    发表于 09-23 16:31 4318次阅读
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>VGA</b><b class='flag-5'>图形控制器</b>设计

    基于FPGAVGA接口显示技术

    可以不使用VGA 显示卡和计算机的情况下,实现VGA 图像的显示控制
    发表于 02-23 15:18 106次下载

    基于FPGAVGA接口实现和字符显示

    基于FPGAVGA接口实现和字符显示论文
    发表于 10-29 17:18 8次下载

    VGA显示与基于FPGAVGA彩色图片显示设计

    FPGAVGA 进行控制,实现 任一彩色图像的显示。通过采用 FPGA 设计
    发表于 11-30 14:57 63次下载
    <b class='flag-5'>VGA</b><b class='flag-5'>显示</b>与基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>VGA</b>彩色图片<b class='flag-5'>显示</b>设计

    vga图像显示_fpga控制vga显示图片

    本文为大家分享fpga控制vga显示图片的方法。
    发表于 01-15 15:56 7964次阅读

    FPGA基础设计之VGA显示方法(文字、图形、波形)

    VGA是一种学习FPGA最常见的基础实验。虽然现在的显示屏大多已经采用DVI和HDMI方案,但其实VGA
    的头像 发表于 06-26 07:03 1.7w次阅读

    显示器接口针脚定义及接法,VGA Pin Definition

    显示器接口针脚定义及接法,VGA Pin Definition 关键字:VGA针脚定义
    的头像 发表于 09-20 19:45 5822次阅读

    采用FPGAVGA图形控制器的Verilog设计方法

    VGA(视频图形阵列)作为一种标准的显示接口得到广泛的应用。依据VGA显示原理,介绍了利用
    的头像 发表于 06-29 10:05 5176次阅读
    <b class='flag-5'>采用</b><b class='flag-5'>FPGA</b>对<b class='flag-5'>VGA</b><b class='flag-5'>图形控制器</b>的Verilog设计方法

    实现一维与二维信号显示VGA接口时序和系统设计

    随着电子技术的发展,VGA(视频图形阵列)接口出现在很多嵌入式平台上,用于图像信息的实时显示等。
    发表于 04-06 08:22 2143次阅读
    实现一维与二维信号<b class='flag-5'>显示</b>的<b class='flag-5'>VGA</b>的<b class='flag-5'>接口</b>时序和系统设计

    使用FPGA芯片和EDA设计VGA显示器控制电路的论文说明

    VGA( 视频图形阵列)作为一种标准的显示接口得到广泛的应用。利用FPGA芯片和EDA 设计方法,可以因地制宜,根据用户的特定需要,设计出针
    发表于 09-01 16:02 20次下载
    使用<b class='flag-5'>FPGA</b>芯片和EDA设计<b class='flag-5'>VGA</b><b class='flag-5'>显示器</b><b class='flag-5'>控制</b>电路的论文说明