605b209620bb001711b8bf632416c20d 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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. @Override
  23. public void move(double x) {
  24. pilot.travel(x);
  25. x += Math.cos(Math.toRadians(theta)) * x;
  26. y += Math.sin(Math.toRadians(theta)) * x;
  27. // double dx = Math.sin(Math.toRadians(pose.getHeading())) * x;
  28. // double dy = Math.cos(Math.toRadians(pose.getHeading())) * x;
  29. // pose.translate((float) dx, (float) -dy);
  30. }
  31. @Override
  32. public void rotate(double x) { // espera um valor positivo ou negativo entre 0 e 360
  33. pilot.rotate(x);
  34. if ((theta + x) > 360){
  35. int add = (theta + x) % 360;
  36. theta += add;
  37. }
  38. else if ((theta + x) < 0){
  39. theta = 360 + (theta + x);
  40. }
  41. else
  42. theta += x;
  43. }
  44. @Override
  45. public ArrayList<DataPose> scann(int ini, int end, int interval) {
  46. ArrayList<DataPose> result = new ArrayList<DataPose>();
  47. Pose p = new Pose((float) x, (float) y, (float) theta);
  48. int val = 0;
  49. int i=0;
  50. double ang = 0;
  51. Motor.C.setSpeed(200);
  52. Motor.C.rotate(450); // gira sonar para a posicao 0 grau
  53. Motor.C.rotate(-(5*ini)); // gira ate a posicao inicial passada no parametro ini
  54. Motor.C.setSpeed(80);
  55. for (int j=0; j <= (5*end); j+=(5*interval)){
  56. DataPose data = new DataPose();
  57. Motor.C.rotate(-(5*interval));
  58. val = sonar.getDistance();
  59. //ang = (j/(5*end)) * 180.0;
  60. ang = ini + interval;
  61. data.setDistance(val);
  62. data.setSensorAngle(ang);
  63. data.setPose(p);
  64. result.add(data);
  65. }
  66. Motor.C.setSpeed(200);
  67. Motor.C.rotate(460);
  68. return result;
  69. }
  70. @Override
  71. public String toString() {
  72. return "LCP Robot";
  73. }
  74. @Override
  75. public void moveForward() {
  76. // TODO Auto-generated method stub
  77. }
  78. @Override
  79. public void moveLeft() {
  80. // TODO Auto-generated method stub
  81. }
  82. @Override
  83. public void moveRight() {
  84. // TODO Auto-generated method stub
  85. }
  86. @Override
  87. public void moveBackward() {
  88. // TODO Auto-generated method stub
  89. }
  90. @Override
  91. public void stop() {
  92. // TODO Auto-generated method stub
  93. }
  94. @Override
  95. public void scann(RobotReturn r) {
  96. // TODO Auto-generated method stub
  97. }
  98. @Override
  99. public void stopScann() {
  100. // TODO Auto-generated method stub
  101. }
  102. @Override
  103. public boolean connect() {
  104. return true;
  105. }
  106. @Override
  107. public void disconnect() {
  108. }
  109. @Override
  110. public void setPose(float x, float y, float a) {
  111. // TODO Auto-generated method stub
  112. }
  113. }