6059681420bb001711b8bf632416c20d 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package robots;
  2. import java.util.ArrayList;
  3. import lejos.robotics.mapping.LineMap;
  4. import lejos.robotics.navigation.Pose;
  5. import lejos.robotics.navigation.DifferentialPilot;
  6. import lejos.nxt.Motor;
  7. import lejos.util.Delay;
  8. import lejos.nxt.SensorPort;
  9. import lejos.nxt.UltrasonicSensor;
  10. public class LCPRobot implements Robot {
  11. //private Pose pose;
  12. //private Simulate simthread;
  13. private RobotReturn rr;
  14. private LineMap map;
  15. static DifferentialPilot pilot;
  16. static UltrasonicSensor sonar;
  17. public LCPRobot () {
  18. pilot = new DifferentialPilot(5.6f, 11.2f, Motor.B, Motor.A);
  19. sonar = new UltrasonicSensor(SensorPort.S1);
  20. pilot.setTravelSpeed(10);
  21. pilot.setRotateSpeed(40);
  22. }
  23. static double theta = 0;
  24. static double x = 0;
  25. static double y = 0;
  26. @Override
  27. public void move(double x) {
  28. pilot.travel(x);
  29. x += Math.cos(Math.toRadians(theta)) * x;
  30. y += Math.sin(Math.toRadians(theta)) * x;
  31. // double dx = Math.sin(Math.toRadians(pose.getHeading())) * x;
  32. // double dy = Math.cos(Math.toRadians(pose.getHeading())) * x;
  33. // pose.translate((float) dx, (float) -dy);
  34. }
  35. @Override
  36. public void rotate(double x) { // espera um valor positivo ou negativo entre 0 e 360
  37. pilot.rotate(x);
  38. if ((theta + x) > 360){
  39. int add = (theta + x) % 360;
  40. theta += add;
  41. }
  42. else if ((theta + x) < 0){
  43. theta = 360 + (theta + x);
  44. }
  45. else
  46. theta += x;
  47. }
  48. @Override
  49. public ArrayList<DataPose> scann(int ini, int end, int interval) {
  50. ArrayList<DataPose> result = new ArrayList<DataPose>();
  51. Pose p = new Pose((float) x, (float) y, (float) theta);
  52. int val = 0;
  53. int i=0;
  54. double ang = 0;
  55. Motor.C.setSpeed(200);
  56. Motor.C.rotate(450); // gira sonar para a posicao 0 grau
  57. Motor.C.rotate(-(5*ini)); // gira ate a posicao inicial passada no parametro ini
  58. Motor.C.setSpeed(80);
  59. for (int j=0; j <= (5*end); j+=(5*interval)){
  60. DataPose data = new DataPose();
  61. Motor.C.rotate(-(5*interval));
  62. val = sonar.getDistance();
  63. //ang = (j/(5*end)) * 180.0;
  64. ang = ini + interval;
  65. data.setDistance(val);
  66. data.setSensorAngle(ang);
  67. data.setPose(p);
  68. result.add(data);
  69. }
  70. Motor.C.setSpeed(200);
  71. Motor.C.rotate(460);
  72. return result;
  73. }
  74. @Override
  75. public String toString() {
  76. return "LCP Robot";
  77. }
  78. @Override
  79. public void moveForward() {
  80. // TODO Auto-generated method stub
  81. }
  82. @Override
  83. public void moveLeft() {
  84. // TODO Auto-generated method stub
  85. }
  86. @Override
  87. public void moveRight() {
  88. // TODO Auto-generated method stub
  89. }
  90. @Override
  91. public void moveBackward() {
  92. // TODO Auto-generated method stub
  93. }
  94. @Override
  95. public void stop() {
  96. // TODO Auto-generated method stub
  97. }
  98. @Override
  99. public void scann(RobotReturn r) {
  100. // TODO Auto-generated method stub
  101. }
  102. @Override
  103. public void stopScann() {
  104. // TODO Auto-generated method stub
  105. }
  106. @Override
  107. public boolean connect() {
  108. return true;
  109. }
  110. @Override
  111. public void disconnect() {
  112. // TODO Auto-generated method stub
  113. }
  114. @Override
  115. public void setPose(float x, float y, float a) {
  116. // TODO Auto-generated method stub
  117. }
  118. }