CANバスマネージャー

CANバスフレームの送受信を行います。

この例では、CANバスフレームを送受信します。受信フレームは、タイプに従って順序付けられます。CANバスの接続パラメーターを調整するための接続ダイアログが用意されています。

この例で使用されているQt Serial Busの主なクラスです:

QCanBusDeviceの作成

CAN通信を行うには、QCanBusDevice のインスタンスが必要です。

ConnectDialog 、必要なパラメーターをすべて指定できます。その後、提供されたプラグイン名とインターフェース名を使用してデバイスが作成されます:

    QString errorString;
    m_canDevice.reset(QCanBus::instance()->createDevice(p.pluginName, p.deviceInterfaceName,
                                                        &errorString));
    connect(m_canDevice.get(), &QCanBusDevice::errorOccurred,
            this, &MainWindow::processErrors);
    connect(m_canDevice.get(), &QCanBusDevice::framesReceived,
            this, &MainWindow::processReceivedFrames);
    connect(m_canDevice.get(), &QCanBusDevice::framesWritten,
            this, &MainWindow::processFramesWritten);

確立された接続により、受信フレームの処理、送信フレームの制御、エラー処理が可能になります。

デバイスが作成されたら、QCanBusDevice::connectDevice() を使用して通信を開始します。

受信フレームの処理

QCanBusDevice は、新しいフレームが利用可能になると () シグナルを発信します。 がある間は、 () メソッドを使用して、単一の を読み取ることができます。フレームを受信すると、 、 、 などの個々のパラメータを抽出することができます:framesReceived available frames readFrame QCanBusFrame frameId timeStamp payload

    while (m_canDevice->framesAvailable()) {
        m_numberFramesReceived++;
        const QCanBusFrame frame = m_canDevice->readFrame();

        QString data;
        if (frame.frameType() == QCanBusFrame::ErrorFrame)
            data = m_canDevice->interpretErrorFrame(frame);
        else
            data = QString::fromLatin1(frame.payload().toHex(' ').toUpper());

        const QString time = QString::fromLatin1("%1.%2  ")
                .arg(frame.timeStamp().seconds(), 10, 10, ' '_L1)
                .arg(frame.timeStamp().microSeconds() / 100, 4, 10, '0'_L1);

        const QString flags = frameFlags(frame);

        const QString id = QString::number(frame.frameId(), 16).toUpper();
        const QString dlc = QString::number(frame.payload().size());

        m_model->appendFrame(QStringList({QString::number(m_numberFramesReceived),
                                          time, flags, id, dlc, data}));
    }

フレームの送信

カスタムデータをCANバスで送信するには、ユーザーは少なくともframeIdpayload を提供する必要があります。オプションで、その他のQCanBusFrame パラメータを設定することもできます:

    const uint frameId = m_ui->frameIdEdit->text().toUInt(nullptr, 16);
    QString data = m_ui->payloadEdit->text();
    m_ui->payloadEdit->setText(formatHexData(data));
    const QByteArray payload = QByteArray::fromHex(data.remove(u' ').toLatin1());

    QCanBusFrame frame = QCanBusFrame(frameId, payload);
    frame.setExtendedFrameFormat(m_ui->extendedFormatBox->isChecked());
    frame.setFlexibleDataRateFormat(m_ui->flexibleDataRateBox->isChecked());
    frame.setBitrateSwitch(m_ui->bitrateSwitchBox->isChecked());

    if (m_ui->errorFrame->isChecked())
        frame.setFrameType(QCanBusFrame::ErrorFrame);
    else if (m_ui->remoteFrame->isChecked())
        frame.setFrameType(QCanBusFrame::RemoteRequestFrame);

フレームが準備されると、QCanBusDevice::writeFrame() メソッドを使用して送信できます:

    m_canDevice->writeFrame(frame);

例の実行

Qt Creator からサンプルを実行するには、Welcome モードを開き、Examples からサンプルを選択します。詳しくは、Building and Running an Example を参照してください。

サンプルプロジェクト @ code.qt.io

©2024 The Qt Company Ltd. 本書に含まれるドキュメントの著作権は、それぞれの所有者に帰属します。 ここで提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。