2017-04-22 109 views
0

我一直在嘗試超過一個星期通過串行端口從樹莓派(QT C++)到Arduino(Arduino IDE C++)進行通信,但我保持失敗。Raspberry pi(QT C++)和Arduino(Arduino IDE)之間的通信

我在谷歌上做了一些搜索,看了一個例子......但仍然沒有成功。好,所以基本的事情是我需要不斷地將Raspberry pi的串口發送命令與Arduino進行通信。我儘量保持代碼儘可能簡單。

最初,我從樹莓派(QT C++)發送「J」字符到Arduino(Arduino IDE C++)並等待J,使LED在Arduino上閃爍。但它不工作..即使我沒有得到任何接口&通信&發送數據樹莓pi(QT C++)到Arduino(Arduino IDE C++)的示例。我不知道究竟是什麼問題。請幫助我解決問題。

在顯示器,9600波特率

我重視程序是什麼我已經在兩側嘗試。

的main.cpp

#include <iostream> 
#include <QIODevice> 

#include <QtSerialPort/QSerialPort> 
#include <QtSerialPort/QSerialPortInfo> 
#include <QString> 

using namespace std; 

int main(int argc, char *argv[]) 
{ 
    QApplication a(argc, argv); 
    Dialog w; 
    w.show(); 

    QSerialPort serialPort; 
    serialPort.setBaudRate(QSerialPort::Baud9600); 

    QSerialPortInfo info("ttyUSB0"); 
     qDebug() << "Name  : "  << info.portName(); 
     qDebug() << "Description : "  << info.description(); 
     qDebug() << "Busy:"    << info.isBusy(); 

     QSerialPort serial; 
     serial.setPortName("ttyUSB0"); 

     serial.open(QIODevice::ReadWrite); 
     serial.setBaudRate(QSerialPort::Baud9600); 
     serial.setDataBits(QSerialPort::Data8); 
     serial.setParity(QSerialPort::NoParity); 
     serial.setStopBits(QSerialPort::OneStop); 
     serial.setFlowControl(QSerialPort::NoFlowControl); 

     serial.open(QSerialPort::ReadWrite); 
     cout<<"Readable :"<<serial.isReadable()<<endl; 
     cout<<"Writable :"<<serial.isWritable()<<endl<<endl; 

     if (serial.isOpen() && serial.isWritable()) 
     { 
      qDebug() << "Is open : " << serial.isOpen() << endl; 
      qDebug() << "Is writable : " << serial.isWritable() << endl; 

      qDebug() << "Ready..." << endl; 
      serial.write("J"); 

      QByteArray ba("J\n"); 

      serial.write(ba); 
      { 
       QByteArray ba("J"); 
       serial.write(ba); 
       serial.flush(); 
       qDebug() << "data has been send" << endl; 
       serial.close(); 
      } 
      if (serial.bytesToWrite() > 0) 
      { 
       serial.flush(); 
       if(serial.waitForBytesWritten(1000)) 
       { 
        qDebug() << "data has been send" << endl; 
       } 
      } 
      if(serial.flush()) 
       { 
        qDebug() << "ok" << endl; 
       } 
       qDebug() <<"value sent "<< endl; 
       serial.close(); 
     } 
     else 
     { 
      qDebug() << "An error occured" << endl; 
     } 
    return a.exec(); 
} 

Arduino的代碼:

int led = 13, avlb = 0; 

void setup() 
{ 
Serial.begin(9600); 
pinMode(led, OUTPUT); 
Serial.println("started"); 
} 

void loop() 
{ 

if (Serial.available() > 0) 
{ 
    Serial.println("available"); 
    Serial.println(Serial.available()); 
    delay(2000); 
    digitalWrite(led, HIGH); 
    delay(5000);   

    if(Serial.read() == 'J') 
{ 
    Serial.println("read"); 
    Serial.println(Serial.read()); 
    delay(2000); 
    digitalWrite(led, LOW); 
    delay(1000); 
} 
} 

else 
{ 
    Serial.println("not available"); 
    delay(1000); 
} 
} 

輸出顯示:

樹莓Qt創建者IDE O/P:

Name  : "ttyUSB0" 
Description : "FT232R USB UART" 
Busy: false 

Readable :1 
Writable :1 

Is open : true 

Is writable : true 

Ready... 

data has been send 

bool QSerialPort::flush(): device not open 
value sent 

Arduino的Ide的輸出顯示:

started 

not available 
not available 
not available 
not available 
not available 
not available 
not available 
not available 
not available 

回答

0

回答你的問題是,在下面的代碼:

QByteArray ba("J"); 
serial.write(ba); 
serial.flush(); 
qDebug() << "data has been send" << endl; 
serial.close(); 

你讓serial.flush()後,立即關閉端口。有必要等到數據真正發送完畢。例如,使用bool QSerialPort :: waitForBytesWritten (int msecs)