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

简介: 笔记

一. 简介


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


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


二. QT上位机


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


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


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

20.png



三. 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信号线*/
);


(二). 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


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

21.jpeg



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


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

公众号:FPGA之旅

目录
相关文章
|
7月前
|
数据格式 异构计算
|
算法 芯片 异构计算
通过FPGA实现基于RS232串口的指令发送并控制显示器中目标位置
通过FPGA实现基于RS232串口的指令发送并控制显示器中目标位置
|
异构计算
FPGA项目四:串口通信(下)
FPGA项目四:串口通信
132 2
FPGA项目四:串口通信(下)
|
异构计算 Python
|
程序员 异构计算
FPGA项目四:串口通信(中)
FPGA项目四:串口通信
301 0
FPGA项目四:串口通信(中)
|
芯片 异构计算
FPGA项目四:串口通信(上)
FPGA项目四:串口通信
389 0
FPGA项目四:串口通信(上)

热门文章

最新文章

下一篇
DataWorks