Обработка пропуская друг друга

Я пытаюсь сгруппировать сегменты вывода XBee в переменную, которая соединяет их. Я использую обработку для кодирования и компиляции. У меня проблема в том, что вывод (println) пропускает каждый второй байт (возможно, это неправильный термин). Так что вывод XBee для i = 4, хотя 11 должен выглядеть так:

0,19,162,0,64,121,230,206 (это адрес XBee, преобразованный из шестнадцатеричного числа).

Но печать показывает это:

19,0,121,206,125,1,0,3 (который начинает попадать в другие сегменты выпуска).

Позже я попробовал другой маршрут, используя массив. Он по-прежнему пропускает все остальные записи, и я обнаружил, что это связано с моей проверкой для i == 126. Есть ли альтернативный способ выполнения проверки, подобной этой?

Замените этот раздел розыгрыша на следующий. Проще следовать. Это был тест с такими же результатами...

void draw() {
    if (myPort.available() > 21) {
        int[] XBeeAddr = new int[22];
        for (int i=0; i<22; i++) {
            XBeeAddr[i] = myPort.read();
            if (myPort.read == 126) {
                i=0;
            }
        println(XBeeAddr[0] + "," + XBeeAddr[1] + "," + XBeeAddr[2]);
    }
}

Оригинальный код

import processing.serial.*;
import de.bezier.data.sql.*; // For SQLite database

SQLite db; // For SQLite database
Serial myPort;

void setup() {
    println(Serial.list());
    myPort = new Serial(this, Serial.list()[0],9600);

    // For SQLite database...
    size( 100, 100 );
    db = new SQLite( this, "test.db" );  // Open database file
    if ( db.connect() ) {
        String[] tableNames = db.getTableNames();
        db.query( "SELECT * FROM %s", tableNames[0] );
        while (db.next()) {
            TableOne t = new TableOne();
            db.setFromRow( t );
            println( t );
        }
    }
}

// For SQLite database
class TableOne {
    public String fieldOne;
    public int fieldTwo;
    public String toString () {
        return String.format("fieldOne: %s fieldTwo: %d", fieldOne, fieldTwo);
    }
}

void draw() {
    if (myPort.available() > 21) {
        int XBeeAddr1 = 0;
        int XBeeAddr2 = 0;
        int XBeeAddr3 = 0;
        int XBeeAddr4 = 0;
        int XBeeAddr5 = 0;
        int XBeeAddr6 = 0;
        int XBeeAddr7 = 0;
        int XBeeAddr8 = 0;

        for (int i=0; i<22; i++) {
            int inByte = myPort.read();
            if (inByte == 126) {
                i=0; // This resets the counter if XBee data was incomplete on the last run.
            }
            if (i == 4) {
                XBeeAddr1 = myPort.read();
            }
            if (i == 5) {
                XBeeAddr2 = myPort.read();
            }
            if (i == 6) {
                XBeeAddr3 = myPort.read();
            }
            if (i == 7) {
                XBeeAddr4 = myPort.read();
            }
            if (i == 8) {
                XBeeAddr5 = myPort.read();
            }
            if (i == 9) {
                XBeeAddr6 = myPort.read();
            }
            if (i == 10) {
                XBeeAddr7 = myPort.read();
            }
            if (i == 11) {
                XBeeAddr8 = myPort.read();
            }

            String XBeeAddrAll = XBeeAddr1 + "," + 
                                 XBeeAddr2 + "," + 
                                 XBeeAddr3 + "," + 
                                 XBeeAddr4 + "," + 
                                 XBeeAddr5 + "," + 
                                 XBeeAddr6 + "," + 
                                 XBeeAddr7 + "," + 
                                 XBeeAddr8;
            println(XBeeAddrAll);
        }
    }
}

1 ответ

Это было исправлено путем изменения myPort.read == 126 в if XBeeAddr[0] != 126, break, Затем я сделал if XBeeAddr[0] == 126 println,

Другие вопросы по тегам