本节我们使用 Qt 来编写一个简单的上位机。
实验介绍:组装 ui 界面,使用 Qt 提供的串口类来实现串口收发功能,需要掌握的相关 Qt 知识有以下几点:
QSerialPort 是 Qt5 中的附加模块,提供了基本的功能,包括配置、I/O 操作、获取和设置 RS-232 引脚的信号,要链接 QtSerialPort 模块,需要在.pro 文件中添加+=serialport。
QSerialPort 封装了丰富的成员变量来对应串口属性,还有很多操作串口的成员函数,常用的成员函数有setPort()或 setPortName(),setBaudRate(),setDataBits(),setStopBits(),setParity()等,可以用这些函数设置要访问的串口设备。本实验使用了 readyRead()信号,当有数据到来时会触发类对象的 readyRead()信号,然后利用它的成员函数 readAll()读取。
类 QSerialPortInfo 可以获取可用的串口信息,如端口名称,系统位置,产品号,描述,制造商等信息。我们把它获取到的端口信息交给 QSerialPort 类对象。
77.1 界面布局
步骤一:将控件拖到 ui 界面上
接收框使用 Plain Text Edit,发送框使用 lineEdit,属性选择组件使用 Combo Box。
data:image/s3,"s3://crabby-images/93ae9/93ae91f577bc5fa88a9e05ee9e5157cf19ed62ac" alt=""
步骤二:属性设置栏布局,以串口号为例,依次水平布局属性选择位。
data:image/s3,"s3://crabby-images/99028/99028d158498d0dec9ab80f6d567cbbb3fbadc57" alt=""
然后全部选中属性选择框,点垂直布局
data:image/s3,"s3://crabby-images/f370e/f370e7852299031b83943ea09a68b64e540eb14d" alt=""
效果如图 :
data:image/s3,"s3://crabby-images/a59c9/a59c92b495793d43944038b978f31e1568ff8f7a" alt=""
步骤三:功能栏布局,在按钮间添加弹簧,点击水平布局。
data:image/s3,"s3://crabby-images/16dbc/16dbc8f4acb5c6353b736ea9d646b0576f28da30" alt=""
选中 Lbel,发送框和功能按钮,点击垂直布局
data:image/s3,"s3://crabby-images/2dc4f/2dc4f5c50e0f67e045669dbccf0208e403a410ae" alt=""
如图 :
data:image/s3,"s3://crabby-images/e58c3/e58c380890a419bb429689622044fd11e48938ec" alt=""
选中属性栏和右侧组件,然后点击水平布局,如图:
data:image/s3,"s3://crabby-images/af854/af8541804f09e2843ed7928cd9505146ffdc1721" alt=""
完成后:
data:image/s3,"s3://crabby-images/76e8b/76e8be100e626e0e662dfbb4ee42ed1496295233" alt=""
再仿照上边的方法将下方的功能部分和接收框垂直布局:
data:image/s3,"s3://crabby-images/2a224/2a2244865f79c355f7577c3df90e504336c50e5e" alt=""
添加完组件后,更改接收框为只读:点击接收框,在 QTextEdit 里标记 readOnly。
在右上角更改 ui 界面对象名,界面组装完成后可以根据需要自行修改,
双击属性选择框添加属性:
data:image/s3,"s3://crabby-images/78651/78651746039975f882b18a2c6eea3f235db3dd47" alt=""
如图:
data:image/s3,"s3://crabby-images/41381/4138143760cd3fa33ae8de30aadd0bb6175e064c" alt=""
data:image/s3,"s3://crabby-images/6684d/6684d542e75ad752df94f0c5d64e626343b570dd" alt=""
哔哩哔哩搜索学习更多内容
|