接着上次的随笔,既然VGA时序已经实现了,那么就显示点东西看看吧。

  想显示个圆,但是无从下手,参考了这篇文章:https://user.qzone.qq.com/1241003385/blog/1543804422

  仔细阅读了这篇文章后才理解所谓显示圆的算法很简单,圆的标准方程是(x - a) ² + (y - b) ² = r ²,只要控制显示范围满足圆的方程就可以了。

  当(x-a)2+(y-b)2<=r2区域是圆内,(x-a)2+(y-b)2>=r2的区域就是圆外。

  这里显示圆的半径是50个像素点,并且以屏幕正中心为原点所以需要满足条件:

  distance = (x-a)*(x-a) + (y-b)*(y-b) = (h_cnt-96-48 -320) *(h_cnt-96-48-320) +(v_cnt-2-33 -240) *(v_cnt-2-33 -240);

  其中96,48为行显示区域以外,320为显示行的中心,2,33为场显示区域以外,320为显示列的正中心。

  如果distance小于r2=(50)2=2500 ,说明在圆内,否则在圆外。

  代码如下:

  

  1. module vga_driver(
  2. clk         ,
  3. rst_n       ,
  4. vga_hys     ,
  5. vga_vys     ,
  6. vga_rgb
  7. );
  8. parameter       DATA_W  = 16;
  9. parameter       LCD_GREEN = 16'b00000_111111_00000;
  10. parameter       LCD_WHITE = 16'b11111_111111_11111;
  11. input         clk      ;
  12. input         rst_n    ;
  13. output        vga_hys    ;
  14. output        vga_vys    ;
  15. output [DATA_W-1:0]  vga_rgb    ;
  16. reg             vga_hys;
  17. reg             vga_vys;
  18. reg     [DATA_W-1:0]vga_rgb;
  19. reg     [9:0]   cnt_hys;
  20. reg     [9:0]   cnt_vys;
  21. reg      [19:0] distance;
  22. reg             green_area;
  23. reg             valid_area;
  24. wire            add_cnt_hys;
  25. wire            end_cnt_hys;
  26. wire            add_cnt_vys;
  27. wire            end_cnt_vys;
  28. wire                 vga_clk;
  29. VGA_PLL U0(
  30. .inclk0 (clk),
  31. .c0     (vga_clk)
  32. );
  33. always @(posedge vga_clk or negedge rst_n)begin
  34. if(!rst_n)begin
  35. cnt_hys <= 0;
  36. end
  37. else if(add_cnt_hys)begin
  38. if(end_cnt_hys)
  39. cnt_hys <= 0;
  40. else
  41. cnt_hys <= cnt_hys + 1;
  42. end
  43. end
  44. assign add_cnt_hys = 1;
  45. assign end_cnt_hys = add_cnt_hys && cnt_hys== 800-1;
  46. always @(posedge vga_clk or negedge rst_n)begin
  47. if(!rst_n)begin
  48. cnt_vys <= 0;
  49. end
  50. else if(add_cnt_vys)begin
  51. if(end_cnt_vys)
  52. cnt_vys <= 0;
  53. else
  54. cnt_vys <= cnt_vys + 1;
  55. end
  56. end
  57. assign add_cnt_vys = end_cnt_hys;
  58. assign end_cnt_vys = add_cnt_vys && cnt_vys==525-1 ;
  59. always  @(posedge vga_clk or negedge rst_n)begin
  60. if(rst_n==1'b0)begin
  61. vga_hys <= 0;
  62. end
  63. else if(add_cnt_hys && cnt_hys == 96-1)begin
  64. vga_hys <= 1;
  65. end
  66. else if(end_cnt_hys)begin
  67. vga_hys <= 0;
  68. end
  69. end
  70. always  @(posedge vga_clk or negedge rst_n)begin
  71. if(rst_n==1'b0)begin
  72. vga_vys <= 0;
  73. end
  74. else if(add_cnt_vys && cnt_vys == 2-1)begin
  75. vga_vys <= 1;
  76. end
  77. else if(end_cnt_vys)begin
  78. vga_vys <= 0;
  79. end
  80. end
  81. always  @(*)begin
  82. distance = ((cnt_hys-96-48-320)*(cnt_hys-96-48-320))+((cnt_vys-2-33-240)*(cnt_vys-2-33-240));
  83. end
  84. always  @(*)begin
  85. green_area = distance < 2500;
  86. end
  87. always  @(*)begin
  88. valid_area = cnt_hys >= (96+48)&&cnt_hys <(96+48+640) && cnt_vys >= (2+33)&&cnt_vys<(2+33+480);
  89. end
  90. always  @(posedge vga_clk or negedge rst_n)begin
  91. if(rst_n==1'b0)begin
  92. vga_rgb <= 16'h0;
  93. end
  94. else if(valid_area)
  95. begin
  96. if(green_area)
  97. begin
  98. vga_rgb <= LCD_GREEN;
  99. end
  100. else begin
  101. vga_rgb <= LCD_WHITE;
  102. end
  103. end
  104. else begin
  105. vga_rgb <= 0;
  106. end
  107. end
  108. endmodule
  109. 显示效果如下图
  110. 中间调试的过程中出现过错误,错误的显示效果是:
  111. 经过排查发现问题出在distance定义的长度上,给distance赋值比自身长度大的数据,导致数据丢失就会产生这样的结果,同样的修改distance的长度反而有意外收获。

VGA显示正圆的更多相关文章

  1. VGA显示

    VGA控制器的编写主要是了解VGA的显示标准和时序,如1024X768@60Hz,确定时钟频率(65MHz=1344X806X60),列像素时间等于时钟周期,扫描从左到右.从上到下(类似于电视扫描PA ...

  2. 基于FPGA的VGA显示设计(一)

    前言 FPGA主要运用于芯片验证.通信.图像处理.显示VGA接口的显示器是最基本的要求了. 原理 首先需要了解 : (1)VGA接口协议:VGA端子_维基百科 .VGA视频传输标准_百度 引脚1 RE ...

  3. [deviceone开发]-do_ImageView实现正圆的示例

    一.简介 我们经常需要用一个正圆形状的图片来设置头像,在do平台这个比较容易,就是通过设置圆角来实现,但是有几个小技巧需要解释一下 主要组件:do_ImageView 二.效果图 三.相关下载 htt ...

  4. 移动端 css实现自适应正圆 ( 宽高随着手机屏幕宽度自适应 )

    序言:应朋友要求随手写了一下移动端 css实现自适应正圆 ( 宽高随着手机屏幕宽度自适应 ) ,以备后用 LESS代码: .adaptive-circle { margin: 50px auto 0; ...

  5. VmodCAM图像采集 VGA显示

    先上图 总体框图 效果图 效果不是很好,因为暂时用的是zedboard自带的VGA,其只能RGB只有3*3*3的彩色度 VmodCAM原理图 VmodCAM的zedboard管脚约束见:http:// ...

  6. vga显示彩条

    vga显示驱动程序可分为扫描行列和行列同步两个部分 //注意:只有在有效区域内给vga赋值才会有颜色变化 assign vga_b = isready ? vga_s[:] :'d0; assign ...

  7. 基于FPGA的VGA显示静态图片

    终于熬到暑假了,记过三四周的突击带考试,终于为我的大二画上了一个完整的句号,接下来终于可以静心去做自己想做的事情了,前一阵子报了一个线上培训班,学学Sobel边缘检测,之前一直在学习图像处理,但是因为 ...

  8. 基于FPGA的Uart接收图像数据至VGA显示

    系统框图 前面我们设计了基于FPGA的静态图片显示,接下来我们来做做基于FPGA的动态图片显示,本实验内容为:由PC端上位机软件通过串口发送一幅图像数据至FPGA,FPGA内部将图像数据存储,最后扫描 ...

  9. 纠错:基于FPGA串口发送彩色图片数据至VGA显示

    今天这篇文章是要修改之前的一个错误,前面我写过一篇基于FPGA的串口发送图片数据至VGA显示的文章,最后是显示成功了,但是显示的效果图,看起来确实灰度图,当时我默认我使用的MATLAB代码将图片数据转 ...

随机推荐

  1. 我的前端组件 ---- 16:9固定宽高比例的div

    目标:遇到一个需求,让图片在页面中,不管宽度如何变化.宽高保持16:9的比例. 实现: 方法一:这也是比较经典的一个方法,利用padding-bottom来实现. <!DOCTYPE html& ...

  2. JSR303定义的校验类型

    空检查 @Null       验证对象是否为null @NotNull    验证对象是否不为null, 无法查检长度为0的字符串 @NotBlank 检查约束字符串是不是Null还有被Trim的长 ...

  3. arduino读取GPIO数据

    一.接线 五向按键模块接线方法,直接盗图,COM接VCC或GND都可以,只不过获得的电平不同 二.初始化 GPIO接口使用前,必须初始化,设定引脚用于输入还是输出 pinMode(D7, INPUT) ...

  4. winform的Textbox设置只读之后使用ForeColor更改颜色

    winform的Textbox设置只读之后设置ForeColor更改颜色无效.这是 TextBox 默认的行为. 解决方法:设置为只读之后,修改控件的BackColor,再设置ForeColor就可以 ...

  5. html大文件上传下载

    一.概述 所谓断点续传,其实只是指下载,也就是要从文件已经下载的地方开始继续下载.在以前版本的HTTP协议是不支持断点的,HTTP/1.1开始就支持了.一般断点下载时才用到Range和Content- ...

  6. phpstorm 设置ftp自动保存服务器 (原)

    打开PHPstorm,依次  tools -  deployment  --  configuration 配置ftp或者sftp地址用户名密码等 端口号 要不就是 21 要不就是 22 , 22不行 ...

  7. json转换时 java.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException

    java.lang.ClassNotFoundException: org.apache.commons.lang.exception.NestableRuntimeException 遇到这种问题是 ...

  8. Java Optional orElse() 和 orElseGet() Optional.flatMap()和Optional.map()区别

    Java Optional 的 orElse() 和 orElseGet() 的区别 1. 接收的参数不同 orElse()方法以一个自定义类型的数据作为参数 public T orElse(T t) ...

  9. pygame基本框架

    代码: import sys #导入sys模块import pygame #导入pygame模块 pygame.init() #pygame初始化size = width,height = 800,8 ...

  10. 编译一个需要用特定key前面的应用程序

    LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) # Build all java files in the java subdirectory L ...