• FPGA之旅设计99例之第十例-----串口上位机模拟OLED屏


    一. 简介

    这是FPGA之旅设计的第十例啦,在上一例中,已经成功驱动了OLED屏幕,本例将结和上一例,以及第四例多bytes串口通信做一个有趣的例程。

    简单来说,就是利用Qt编写上位机,通过串口与FPGA进行通信,然后FPGA将接收到的数据,通过IIC接口发送给OLED,就这么一个流程。


    二. QT上位机

    大家可能对QT部分不感兴趣,也不熟悉,这里就只对上位机的功能进行说明,实现过程就不叙述了,想了解的可以点个赞,人多的话,就专门介绍一下

    上位机目前一共只实现了两个功能,一个是添加文字,另外一个是添加圆。添加过后,会在OLED预览区域中进行显示。等编辑好之后,就可以点击执行,这时候,上位机会解析这部分的数据,然后通过串口发送给FPGA,接下来的就是FPGA里面的处理了。

    上位机可以更加完善。例如字体的大小可调,字体可选,圆的线宽可调,像其他图形矩形,椭圆,线等等,都是可以的。也可以扩展功能,如添加图片等等。上位机的介绍就到这里。

    在这里插入图片描述


    三. FPGA部分实现

    (一). 串口部分

    在第四例,多byte串口接收模块中,默认为每次接收到三个byte就使能一次。刚好这里发送给OLED的数据也是三个byte,就对应上了,不需要修改任何程序,直接在top模块里面例化即可。

    UART_MulRX  UART_MulRXHP(
        .sys_clk				(sys_clk),        /*系统时钟 50M*/
        .rst_n				(rst_n),              /*复位信号*/
    
        .uart_rxs_done  	(uart_rxs_done),   /*串口接收完成*/
        .odats				(uart_rxs_data),           /*接收数据*/
    
        .uartrx  			(UART_RX)       /*uart rx信号线*/
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    (二). OLED部分

    在上一例中,程序对OLED进行初始化之后,就进入了空闲态,在空闲态的时候,是没有任何处理的。但在本例中,需要对串口接收到的数据进行处理,通过IIC发送给OLED,这部分也很简单,代码如下。

    module OLED_SelData(
    	
    	input				sys_clk,
    	input				rst_n,
    	input				init_req,
        input[23:0]		    init_data,
    
    	input				uart_req,
        input[23:0]		    uart_data,
    	
    	output			    IICWriteReq,
        output[23:0]	    IICWriteData
    );
    
    reg       IICWriteReqReg;
    reg[23:0] IICWriteDataReg; 
    
    assign IICWriteReq  = init_req | uart_req;
    assign IICWriteData = (init_req == 1'b1) ? init_data : uart_data;
    
    endmodule 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21

    这个例程,就是将前面的串口多byte串口通信和这个结和起来了,设计难点在上位机的编写,对上位机感兴趣的可以多了解一下,不感兴趣的可以参考一下,例如说,将IIC模块上包一个串口模块,就可以将IIC接口变为串口了,就可以通过串口来配置OLED了。效果如下

    在这里插入图片描述

    对上位机感兴趣的可以点个赞,后面出相关文章。

    关注微信公众号回复 FPGA之旅设计99例之第十例 获取全部文件

  • 相关阅读:
    如何进行网站测试
    Flutter快学快用开篇词 通往大前端的一把关键钥匙 Flutter
    可视化 | python可视化相关库梳理(自用)| pandas | Matplotlib | Seaborn | Pyecharts | Plotly
    菜鸟先飞之初识Hive、安装教程及常见问题
    Docker 从构建开始导出一个镜像
    【操作系统】十分钟了解关于TCP/IP网络的基础知识(二)ARP、路由器、DHCP、DNS以及TCP/IP
    Golang网络编程:即时通讯系统Instance Messaging System
    [ C++ ] STL _ Vector使用及其模拟实现
    Python常见报错及解决方案,建议收藏
    MyBatis-Plus
  • 原文地址:https://blog.csdn.net/weixin_44678052/article/details/126677675