Ein Roboter mit bürstenlosem Antrieb, differenzial und NRF24L01 Funk. Großflächig gebaut um ein großes Solarpanel aufzunehmen. https://gitlab.informatik.hs-fulda.de/fdai5253/roboter
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

174 lines
4.3 KiB

  1. /*
  2. * modularer Mini Roboter mit diversen Sensoren
  3. *
  4. *
  5. */
  6. //Funk
  7. #include <SPI.h>
  8. #include <nRF24L01.h>
  9. #include <RF24.h>
  10. #define CE A0
  11. #define CSN 3
  12. RF24 radio(A0, 3); // CE, CSN
  13. byte commands[32]; //byte 0 = command
  14. long timer;
  15. void inline clearCommands() {
  16. for(uint8_t i=0; i<32; i++) {
  17. commands[i] = 0xFF;
  18. }
  19. }
  20. const byte address[6] = "00001";
  21. //Kommandos
  22. #define nothing 9 //reset/nichts tun
  23. #define speedA 1 // set speed A + speed
  24. #define dirA 2 // set direction A + dir
  25. #define speedB 3 // set speed B + speed
  26. #define dirB 4 // set direction B + dir
  27. #define goDrive 5 //go + time to go
  28. #define stopDrive 6 //stop
  29. #define getTemp 7 //get temperature
  30. #define timeToDrive 8 //Zeitdauer des fahrens
  31. #define distance 10 //Abstand zu Objekten
  32. //Motortreiber
  33. //#include <MX1508.h>
  34. #include <L298N.h>
  35. #define BEEP 14
  36. #define PWM_PINA 10
  37. #define PINA 8
  38. #define PWM_PINB 9
  39. #define PINB 7
  40. #define NUMPWM 1
  41. #define RESOLUTION 255
  42. //MX1508 motorA(PWM_PINA,PINA, FAST_DECAY, NUMPWM);
  43. //MX1508 motorB(PWM_PINB,PINB, FAST_DECAY, NUMPWM);
  44. L298N drive;
  45. volatile int pwmA = 0;
  46. volatile int pwmB = 0;
  47. bool forwardA = true;
  48. bool forwardB = true;
  49. volatile bool driveOn = false;
  50. int temperatur = 0;
  51. volatile long driveTimeout = 0;
  52. volatile long driveTimeDiff = 0;
  53. void setup() {
  54. Serial.begin(115200);
  55. // motorA.setPWM16(2,RESOLUTION);
  56. // motorB.setPWM16(2,RESOLUTION);
  57. radio.begin();
  58. radio.openReadingPipe(0, address);
  59. radio.setPALevel(RF24_PA_MAX);
  60. radio.startListening();
  61. clearCommands();
  62. //Temperatur- und Abstandsmessung
  63. tempDistSetup();
  64. setEchoPins(0, 0); //Setze die pins für den Abstandsensor aus denen gelesenw erden soll das erster ist der Trigger-, das zweite der Echopin
  65. timer = millis();
  66. }
  67. void loop() {
  68. if (radio.available()) {
  69. radio.read(&commands, sizeof(commands));
  70. commandInterpretation();
  71. }
  72. //Serial.println(driveOn);
  73. if(((millis() - driveTimeDiff) > driveTimeout)) {
  74. pwmA = 0;
  75. pwmB = 0;
  76. }
  77. drive.setPWM_A(pwmA);
  78. drive.setPWM_B(pwmB);
  79. //Temperatur- und Abstandsmessung
  80. temperature = dallas(4, 0);
  81. if(millis() - timer >= 100){
  82. measureDistance();
  83. timer = millis();
  84. }
  85. distance = calculateDistance();
  86. }
  87. void commandInterpretation() {
  88. for(uint8_t i = 0; i < 28; i += 3) {
  89. switch(commands[i]) {
  90. case nothing : {
  91. pwmA = 0;
  92. pwmB = 0;
  93. forwardA = true;
  94. forwardB = true;
  95. driveOn = false;
  96. break;
  97. }
  98. case speedA : {
  99. int temp1;
  100. temp1 = (0xFF00 & (commands[i+1] << 8));
  101. temp1 |= (0x00FF & commands[i+2]);
  102. pwmA = temp1;
  103. break;
  104. }
  105. case dirA : {
  106. bool temp2 = commands[i+2];
  107. break;
  108. }
  109. case speedB : {
  110. int temp3;
  111. temp3 = (0xFF00 & (commands[i+1] << 8));
  112. temp3 |= (0x00FF & commands[i+2]);
  113. pwmB = temp3;
  114. break;
  115. }
  116. case dirB : {
  117. bool temp4;
  118. temp4 = commands[i+2];
  119. break;
  120. }
  121. case goDrive : {
  122. driveOn = true;
  123. break;
  124. }
  125. case stopDrive : {
  126. driveOn = false;
  127. break;
  128. }
  129. case getTemp : {
  130. temperatur = (0xFF00 & (commands[i+1] << 8));
  131. temperatur |= (0x00FF & commands[i+2]);
  132. break;
  133. }
  134. case timeToDrive : {
  135. uint16_t driveTime = 0;
  136. driveTime = (0xFF00 & (commands[i+1] << 8));
  137. driveTime |= (0x00FF & commands[i+2]);
  138. driveTimeout = (long)driveTime;
  139. driveTimeDiff = millis();
  140. Serial.println(driveTimeout);
  141. break;
  142. }
  143. default : { /* pwmA = 0;
  144. pwmB = 0;
  145. forwardA = true;
  146. forwardB = true;
  147. driveOn = false; */
  148. break;
  149. }
  150. }
  151. }
  152. clearCommands();
  153. }