00. 目录
01. 概述
QModbusDevice类是Modbus类QModbusServer和QModbusClient的基类。
Header: #include
qmake: QT += serialbusSince: Qt 5.8
Inherits: QObject
Inherited By: QModbusClient and QModbusServer
02. 开发环境
Windows系统:Windows10
Qt版本:Qt5.15或者Qt6
03. 公有类型
enum ConnectionParameter { SerialPortNameParameter, SerialParityParameter, SerialBaudRateParameter, SerialDataBitsParameter, SerialStopBitsParameter, …, UserParameter }
enum Error { NoError, ReadError, WriteError, ConnectionError, ConfigurationError, …, UnknownError }
enum State { UnconnectedState, ConnectingState, ConnectedState, ClosingState }
枚举QModbusDevice :: ConnectionParameter
该枚举描述了可以为Modbus设备连接设置的可能值。
通用值(和关联的类型)为:
常量 | 值 | 描述 |
---|---|---|
QModbusDevice::SerialPortNameParameter |
0 |
此参数保存用于设备通信的串行端口,例如COM1。 QString |
QModbusDevice::SerialParityParameter |
1 |
该参数保持奇偶校验模式。 QSerialPort::Parity |
QModbusDevice::SerialBaudRateParameter |
2 |
此参数保存通信的数据波特率。 QSerialPort::BaudRate |
QModbusDevice::SerialDataBitsParameter |
3 |
此参数将数据位保存在一个帧中。 QSerialPort::DataBits |
QModbusDevice::SerialStopBitsParameter |
4 |
此参数保存一帧中停止位的数量。 QSerialPort::StopBits |
QModbusDevice::NetworkPortParameter |
5 |
此参数保存网络端口。 int |
QModbusDevice::NetworkAddressParameter |
6 |
此参数保存用于网络通信的主机地址。 QString |
enum QModbusDevice::Error类型
该枚举描述了所有可能的错误情况。
常量 | 值 | 描述 |
---|---|---|
QModbusDevice::NoError |
0 |
没有发生错误。 |
QModbusDevice::ReadError |
1 |
读取操作期间发生错误。 |
QModbusDevice::WriteError |
2 |
写操作期间发生错误。 |
QModbusDevice::ConnectionError |
3 |
尝试打开后端时发生错误。 |
QModbusDevice::ConfigurationError |
4 |
尝试设置配置参数时发生错误。 |
QModbusDevice::TimeoutError |
5 |
I / O期间发生超时。在给定的时间范围内,I / O操作未完成。 |
QModbusDevice::ProtocolError |
6 |
发生Modbus特定协议错误。 |
QModbusDevice::ReplyAbortedError |
7 |
由于设备断开连接,回复被中止。 |
QModbusDevice::UnknownError |
8 |
出现未知错误。 |
enum QModbusDevice::State
该枚举描述了所有可能的设备状态。
常量 | 值 | 描述 |
---|---|---|
QModbusDevice::UnconnectedState |
0 |
设备已断开连接。 |
QModbusDevice::ConnectingState |
1 |
设备正在连接。 |
QModbusDevice::ConnectedState |
2 |
设备已连接到Modbus网络。 |
QModbusDevice::ClosingState |
3 |
设备正在关闭。 |
04. 成员方法
QModbusDevice::QModbusDevice(QObject *parent = nullptr)
用指定的parent构造一个Modbus设备。
[signal] void QModbusDevice::errorOccurred(QModbusDevice::Error error)
当错误发生,该信号被发送
[signal] void QModbusDevice::stateChanged(QModbusDevice::State state)
每次设备状态更改时都会发出此信号。新状态由state表示。
[virtual] QModbusDevice::~QModbusDevice()
析构函数
[pure virtual protected] void QModbusDevice::close()
该函数负责关闭Modbus连接。实现必须确保实例的状态()设置为QModbusDevice :: UnconnectedState。
bool QModbusDevice::connectDevice()
将设备连接到Modbus网络。返回true是否成功启动连接过程;否则返回false。否则false。最终连接成功确认要求状态()更改为QModbusDevice :: ConnectedState。
QVariant QModbusDevice::connectionParameter(int parameter) const
返回与给定连接参数关联的值。返回的值可以为空。
默认情况下,QModbusDevice使用一些通用值初始化。串行端口设置为偶校验,波特率为每秒19200位,八个数据位和一个停止位。主机地址的网络设置设置为本地主机,端口设置为502。
注意:为了使串行连接成功,需要将SerialPortNameParameter设置为有效的通信端口。可以从QSerialPortInfo获得有关有效串行端口的信息。
注意:如果已经连接了设备,则在重新连接设备后会考虑设置。
QIODevice *QModbusDevice::device() const
返回用于ModBus通信或设备尚未完全初始化时返回nullptr
void QModbusDevice::disconnectDevice()
断开设备连接。
QModbusDevice::Error QModbusDevice::error() const
返回设备的错误状态。
QString QModbusDevice::errorString() const
返回设备错误的描述性错误文本。
[pure virtual protected] bool QModbusDevice::open()
该函数由connectDevice()调用。子类必须提供true在成功进行Modbus连接或连接初始化后返回的实现;否则返回false。
实现必须确保成功时将实例的状态()设置为QModbusDevice :: ConnectingState或QModbusDevice :: ConnectedState;否则QModbusDevice :: UnconnectedState。通常,当连接过程异步向后报告时使用QModbusDevice :: ConnectingState,而在同步连接行为的情况下使用QModbusDevice :: ConnectedState。
void QModbusDevice::setConnectionParameter(int parameter, const QVariant &value)
将parameter的值设置为value。如果参数已经存在,则先前的值将被覆盖。活动或正在运行的连接不受此类参数更改的影响。
[protected] void QModbusDevice::setError(const QString &errorText, QModbusDevice::Error error)
设置设备的错误状态。发生错误时,ModBus设备实现必须使用此功能来设置错误类型和描述性errorText。
[protected] void QModbusDevice::setState(QModbusDevice::State newState)
将设备的状态设置为newState。Modbus设备实现必须使用此功能来更新设备状态。
QModbusDevice::State QModbusDevice::state() const
返回设备的当前状态。
05. 预留
06. 附录
6.1 Qt教程汇总
网址:https://dengjin.blog.csdn.net/article/details/115174639
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容