Проблема в написании кода

aysen
Offline
Зарегистрирован: 07.06.2014

Здравствуйте дорогие форумчане! Я делаю машинку управляемую через телефон (android). 

Arduino Leonardo + Motor Shield 2A + Wireless Proto Shield + Bluetooth Bee. 

Проблема в том, что когда загружаю код Motor Shield не отвечает на приложение.

Сигнал с Bluetooth Bee есть, а на Motor Shield не идет.

В качестве примера брал http://cxem.net/uprav/uprav46.php

С Андроид приложение идет L, R, H, F, r , w

 

 

скетч:

#include "EEPROM.h"
int E1 = 5;
int M1 = 4;
int E2 = 6;                   
int M2 = 7;
int HORN = 13;      // доп. канал 1 подключен к 13 пину
//#define autoOFF 2500  // кол-во миллисекунд через которое робот останавливается при потери связи
#define cmdL 'L'      // команда UART для левого двигателя
#define cmdR 'R'      // команда UART для правого двигателя
#define cmdH 'H'      // команда UART для доп. канала 1 (к примеру сигнал Horn)
#define cmdF 'F'      // команда UART для работы с EEPROM памятью МК для хранения настроек
#define cmdr 'r'      // команда UART для работы с EEPROM памятью МК для хранения настроек (чтение)
#define cmdw 'w'      // команда UART для работы с EEPROM памятью МК для хранения настроек (запись)
char incomingByte;    // входящие данные
char L_Data[4];      // строковый массив для данных левого мотора L
byte L_index = 0;    // индекс массива
char R_Data[4];      // строковый массив для данных правого мотора R
byte R_index = 0;    // индекс массива
char H_Data[1];      // строковый массив для доп. канала
byte H_index = 0;    // индекс массива H
char F_Data[8];      // строковый массив данных для работы с EEPROM
byte F_index = 0;    // индекс массива F
char command;        // команда: передача координат R, L или конец строки
unsigned long currentTime, lastTimeCommand, autoOFF;
void setup() {
  Serial.begin(9600);      // инициализация порта
  pinMode(HORN, OUTPUT);    // дополнительный канал
  pinMode(E1, OUTPUT);      // выход для задания направления вращения двигателя
  pinMode(E2, OUTPUT);      // выход для задания направления вращения двигателя
  /*EEPROM.write(0,255);
  EEPROM.write(1,255);
  EEPROM.write(2,255);
  EEPROM.write(3,255);*/
  timer_init();            // инициализируем программный таймер
}
void timer_init() {
  uint8_t sw_autoOFF = EEPROM.read(0);  // считываем с EEPROM параметр "включена ли ф-ия остановки машинки при потере связи"
  if(sw_autoOFF == '1'){                // если таймер останова включен
    char var_Data[3];
    var_Data[0] = EEPROM.read(1);
    var_Data[1] = EEPROM.read(2);
    var_Data[2] = EEPROM.read(3);
    autoOFF = atoi(var_Data)*100;        // переменная автовыкл. для хранения кол-ва мс
  }
  else if(sw_autoOFF == '0'){     
    autoOFF = 999999;
  }
  else if(sw_autoOFF == 255){
    autoOFF = 2500;                      // если в EEPROM ничего не записано, то по умолчанию 2.5 сек
  }
  currentTime = millis();                // считываем время, прошедшее с момента запуска программы
}

void loop() {
  if (Serial.available() > 0) {          // если пришли UART данные
    incomingByte = Serial.read();        // считываем байт
    if(incomingByte == cmdL) {          // если пришли данные для мотора L
      command = cmdL;                    // текущая команда
      memset(L_Data,0,sizeof(L_Data));  // очистка массива
      L_index = 0;                      // сброс индекса массива
    }
    else if(incomingByte == cmdR) {      // если пришли данные для мотора R
      command = cmdR;
      memset(R_Data,0,sizeof(R_Data));
      R_index = 0;
    }
    else if(incomingByte == cmdH) {      // если пришли данные для доп. канала 1
      command = cmdH;
      memset(H_Data,0,sizeof(H_Data));
      H_index = 0;
    } 
    else if(incomingByte == cmdF) {      // если пришли данные для работы с памятью
      command = cmdF;
      memset(F_Data,0,sizeof(F_Data));
      F_index = 0;
    }
    else if(incomingByte == '\r') command = 'e';  // конец строки
    else if(incomingByte == '\t') command = 't';  // конец строки для команд работы с памятью
 
    if(command == cmdL && incomingByte != cmdL){
      L_Data[L_index] = incomingByte;              // сохраняем каждый принятый байт в массив
      L_index++;                                  // увеличиваем текущий индекс массива
    }
    else if(command == cmdR && incomingByte != cmdR){
      R_Data[R_index] = incomingByte;
      R_index++;
    }
    else if(command == cmdH && incomingByte != cmdH){
      H_Data[H_index] = incomingByte;
      H_index++;
    } 
    else if(command == cmdF && incomingByte != cmdF){
      F_Data[F_index] = incomingByte;
      F_index++;
    } 
    else if(command == 'e'){                      // если приняли конец строки
      Control4WD(atoi(L_Data),atoi(R_Data),atoi(H_Data));
      delay(10);
    }
    else if(command == 't'){                      // если приняли конец строки для работы с памятью
      Flash_Op(F_Data[0],F_Data[1],F_Data[2],F_Data[3],F_Data[4]);
    }
    lastTimeCommand = millis();                    // считываем текущее время, прошедшее с момента запуска программы
  }
  if(millis() >= (lastTimeCommand + autoOFF)){    // сравниваем текущий таймер с переменной lastTimeCommand + autoOFF
    Control4WD(0,0,0);                            // останавливаем машинку
  }
}
void Control4WD(int mLeft, int mRight, uint8_t Horn){
  bool directionL, directionR;      // направление вращение для L298N
  byte valueL, valueR;              // значение ШИМ M1, M2 (0-255)

  if(mLeft > 0){
    valueL = mLeft;
    directionL = 0;
  }
  else if(mLeft < 0){
    valueL = 255 - abs(mLeft);
    directionL = 1;
  }
  else {
    directionL = 0;
    valueL = 0;
  }

  if(mRight > 0){
    valueR = mRight;
    directionR = 0;
  }
  else if(mRight < 0){
    valueR = 255 - abs(mRight);
    directionR = 1;
  }
  else {
    directionR = 0;
    valueR = 0;
  }
 
  analogWrite(M1, valueL);            // задаем скорость вращения для L
  analogWrite(M2, valueR);            // задаем скорость вращения для R
  digitalWrite(E1, directionL);      // задаем направление вращения для L
  digitalWrite(E2, directionR);      // задаем направление вращения для R

  digitalWrite(HORN, Horn);          // дополнительный канал
}
void Flash_Op(char FCMD, uint8_t z1, uint8_t z2, uint8_t z3, uint8_t z4){
  if(FCMD == cmdr){          // если команда чтения EEPROM данных
    Serial.print("FData:");      // посылаем данные с EEPROM
    Serial.write(EEPROM.read(0));    // считываем значение ячейки памяти с 0 адресом и выводим в UART
    Serial.write(EEPROM.read(1));
    Serial.write(EEPROM.read(2));
    Serial.write(EEPROM.read(3));
    Serial.print("\r\n");        // маркер конца передачи EEPROM данных
  }
  else if(FCMD == cmdw){          // если команда записи EEPROM данных
    EEPROM.write(0,z1);              // запись z1 в ячейку памяти с адресом 0
    EEPROM.write(1,z2);
    EEPROM.write(2,z3);
    EEPROM.write(3,z4);
    timer_init();            // переинициализируем таймер
    Serial.print("FWOK\r\n");        // посылаем сообщение, что данные успешно записаны
  }
}

 

art100
Offline
Зарегистрирован: 09.03.2014

тут теоретически просто

а на самой деле масса несовместимостей

1. Android должен быть не менее 150$ а как правило 250$ с USB способным быть как USB-host

2. терминалом под root вы как минимум должны видеть обмен с внешинми USB-clients например arduino serial.Begin(115200) что-нибудь в этом духе

3. Application на Android должне иметь пару Sketch на Arduino

и только после этого можно хоть что-то отлаживать

а практика показывает в наших деревнях Москва даже 1-ый пункт не реализуем

 

есть удачные решения на 7" планшетах за ~150$ но это как правило исключения без возможности повторения

интеренет завален примерами а ничанешь копать вранье недосказанность сокрытие ключевых надо

 

как минимум должна быть теоретически заявленно слово OTG которое еще допиливать и допиливать

у меня вообще большие сомнения

у кого-нибудь с коробки хоть клавиатурка по usb запускалась

начинаешь реально спрашивать

все вроде знают

а работачую пару никто показать не может

специалисты хреновы