2023c245cbb90017124d9f37712eb7c1 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package robots;
  2. import java.util.ArrayList;
  3. import lejos.robotics.mapping.LineMap;
  4. import lejos.robotics.navigation.Pose;
  5. public class VirtualRobot implements Robot {
  6. private Pose pose;
  7. private Simulate simthread;
  8. private RobotReturn rr;
  9. private LineMap map;
  10. private class Simulate extends Thread {
  11. public boolean run = true;
  12. public void run() {
  13. int ang = 0;
  14. int add = -5;
  15. while (run) {
  16. DataPose data = new DataPose();
  17. Pose tmppose = new Pose(pose.getX(), pose.getY(), (float) (pose.getHeading() + ang));
  18. float dist = map.range(tmppose);
  19. if (dist == -1) dist = 255;
  20. data.setDistance((int)dist);
  21. data.setPose(pose);
  22. data.setSensorAngle(ang);
  23. rr.robotData(data);
  24. ang += add;
  25. if (ang == -180 || ang == 0)
  26. add *= -1;
  27. try {
  28. Thread.sleep(200);
  29. } catch (InterruptedException e) {
  30. }
  31. }
  32. }
  33. }
  34. public VirtualRobot(LineMap map) {
  35. simthread = new Simulate();
  36. pose = new Pose();
  37. pose.setHeading(90);
  38. this.map = map;
  39. }
  40. @Override
  41. public void moveForward() {
  42. double dx = Math.sin(Math.toRadians(pose.getHeading())) * 5;
  43. double dy = Math.cos(Math.toRadians(pose.getHeading())) * 5;
  44. pose.translate((float) dx, (float) -dy);
  45. }
  46. @Override
  47. public void moveLeft() {
  48. pose.rotateUpdate(45);
  49. }
  50. @Override
  51. public void moveRight() {
  52. pose.rotateUpdate(-45);
  53. }
  54. @Override
  55. public void moveBackward() {
  56. double dx = Math.sin(Math.toRadians(pose.getHeading())) * 5;
  57. double dy = Math.cos(Math.toRadians(pose.getHeading())) * 5;
  58. pose.translate((float) -dx, (float) dy);
  59. }
  60. @Override
  61. public boolean connect(RobotReturn r) {
  62. return true;
  63. }
  64. @Override
  65. public void stop() {
  66. }
  67. @Override
  68. public void move(double x) {
  69. // TODO Auto-generated method stub
  70. }
  71. @Override
  72. public void rotate(double x) {
  73. // TODO Auto-generated method stub
  74. }
  75. @Override
  76. public ArrayList<DataPose> scann(int ini, int end, int interval) {
  77. // TODO Auto-generated method stub
  78. return null;
  79. }
  80. @Override
  81. public void scann(RobotReturn r) {
  82. rr = r;
  83. simthread.start();
  84. }
  85. @Override
  86. public void stopScann() {
  87. // TODO Auto-generated method stub
  88. }
  89. @Override
  90. public void disconnect() {
  91. simthread.run = false;
  92. try {
  93. simthread.join();
  94. } catch (InterruptedException e) {
  95. // TODO Auto-generated catch block
  96. e.printStackTrace();
  97. }
  98. }
  99. @Override
  100. public void setPose(float x, float y, float a) {
  101. pose.setHeading(a);
  102. pose.setLocation(x, y);
  103. }
  104. }