d062701a20bb001711b8bf632416c20d 3.4 KB

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