| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectlejos.navigation.SimpleNavigator
public class SimpleNavigator
The SimpleNavigator class can keep track of the robot position and the direction angle it faces; It uses a _pilot object to control NXT robot movements.
 The position and direction angle values are updated automatically when the movement command returns after the movement is complete and and after stop() command is issued.
 However, some commands optionally return immediately, to permit sensor monitoring in the main thread.  It is then the programmers responsibility to 
 call updatePosition() when the robot motion is completed.  All angles are in degrees, distances in the units used to specify robot dimensions.
 It must use a Pilot that can turn in place, for example using 2 wheel differential steering.
 The assumed initial position of the robot is at (0,0) and initial angle 0 i.e. pointing in the +X direction.
| Constructor Summary | |
|---|---|
| SimpleNavigator(float wheelDiameter,
                float trackWidth,
                Motor leftMotor,
                Motor rightMotor)Allocates a SimpleNavigator object and initializes it with a TachoPilot The x and y values and the direction angle are all initialized to 0, so if the first move is forward() the robot will run along the x axis. | |
| SimpleNavigator(float wheelDiameter,
                float trackWidth,
                Motor leftMotor,
                Motor rightMotor,
                boolean reverse)Allocates a SimpleNavigator object and initializes it with a TachoPilot The x and y values and the direction angle are all initialized to 0, so if the first move is forward() the robot will run along the x axis. | |
| SimpleNavigator(Pilot pilot)Allocates a SimpleNavigator with the Pilot that you supply The x and y coordinate values and the direction angle are all initialized to 0, so if the first move is forward() the robot will run along the x axis. | |
| Method Summary | |
|---|---|
|  float | angleTo(float x,
        float y)returns the direction angle (degrees) to point with coordinates (x,y) | 
|  void | backward()Moves the NXT robot backward until stop() is called. | 
|  float | distanceTo(float x,
           float y)distance from robot to the point with coordinates (x,y) . | 
|  void | forward()Moves the NXT robot forward until stop() is called. | 
|  float | getAngle()Returns the current angle the NXT robot is facing, relative to the +X axis direction; the +Y direction is 90 degrees. | 
|  Pilot | getPilot() | 
|  float | getX()Returns the current x coordinate of the NXT. | 
|  float | getY()Returns the current y coordinate of the NXT. | 
|  void | goTo(float x,
     float y)Rotates the NXT robot towards the target point (x,y) and moves the required distance. | 
|  void | goTo(float x,
     float y,
     boolean immediateReturn)Rotates the NXT robot towards the target point (x,y) and moves the required distance. | 
|  boolean | isMoving()returns true iff the robot is moving under power | 
|  void | rotate(float angle)Rotates the NXT robot a specific number of degrees in a direction (+ or -). | 
|  void | rotate(float angle,
       boolean immediateReturn)Rotates the NXT robot a specific number of degrees in a direction (+ or -). | 
|  void | rotateLeft()Rotates the NXT to the left (increasing angle) until stop() is called; | 
|  void | rotateRight()Rotates the NXT to the right (decreasing angle) until stop() is called; | 
|  void | rotateTo(float angle)Rotates the NXT robot to point in a specific direction. | 
|  void | rotateTo(float angle,
         boolean immediateReturn)Rotates the NXT robot to point in a specific direction. | 
|  void | setMoveSpeed(float speed)Set the movement speed of the robot, wheel diameter units/seconds. | 
|  void | setPosition(float x,
            float y,
            float directionAngle)sets robot location (x,y) and direction angle | 
|  void | setSpeed(int speed)Set the speed of the motors, in degrees/second. | 
|  void | setTurnSpeed(float speed)Set the rotation speed of the robot in degree/seconds when robot is turning in place. | 
|  void | stop()Halts the NXT robot and calculates new x, y and angle coordinates. | 
|  void | travel(float distance)Moves the NXT robot a specific distance. | 
|  void | travel(float distance,
       boolean immediateReturn)Moves the NXT robot a specific distance. | 
|  void | turn(float radius)Moves the NXT robot in a circular path with a specified radius. | 
|  void | turn(float radius,
     int angle)Moves the NXT robot in a circular arc through the specificd angle; The center of the turning circle is on the right side of the robot iff parameter radius is negative. | 
|  void | turn(float radius,
     int angle,
     boolean immediateReturn)Moves the NXT robot in a circular arc through a specific angle; The center of the turning circle is on the right side of the robot if parameter radius is negative. | 
|  void | updatePosition()Updates robot location (x,y) and direction angle. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public SimpleNavigator(Pilot pilot)
pilot - The pilot to use.
public SimpleNavigator(float wheelDiameter,
                       float trackWidth,
                       Motor leftMotor,
                       Motor rightMotor,
                       boolean reverse)
wheelDiameter - The diameter of the wheel, usually printed right on the
 wheel, in centimeters (e.g. 49.6 mm = 4.96 cm = 1.95 in)trackWidth - The distance from the center of the left tire to the center
 of the right tire, in units of your choicerightMotor - The motor used to drive the right wheel e.g. Motor.C.leftMotor - The motor used to drive the left wheel e.g. Motor.A.reverse - If motor.forward() dives the robot backwars, set this parameter true.
public SimpleNavigator(float wheelDiameter,
                       float trackWidth,
                       Motor leftMotor,
                       Motor rightMotor)
wheelDiameter - The diameter of the wheel, usually printed right on the
 wheel, in centimeters (e.g. 49.6 mm = 4.96 cm = 1.95 in)trackWidth - The distance from the center of the left tire to the center
 of the right tire, in units of your choicerightMotor - The motor used to drive the right wheel e.g. Motor.C.leftMotor - The motor used to drive the left wheel e.g. Motor.A| Method Detail | 
|---|
public Pilot getPilot()
public float getX()
getX in interface Navigatorpublic float getY()
getY in interface Navigatorpublic float getAngle()
getAngle in interface Navigator
public void setPosition(float x,
                        float y,
                        float directionAngle)
setPosition in interface Navigatorx - the x coordinate of the roboty - the y coordinate of the robotdirectionAngle - the angle the robot is heading, measured from the x axis.  90 degrees is the +Y directionpublic void setSpeed(int speed)
speed - The motor speed in degrees/seconds.public void setMoveSpeed(float speed)
setMoveSpeed in interface Navigatorspeed - The movement speed in units/seconds.public void setTurnSpeed(float speed)
setTurnSpeed in interface Navigatorspeed - The turning speed in units/seconds.public void forward()
forward in interface NavigatorNavigator.stop()public void backward()
backward in interface NavigatorNavigator.stop().public void stop()
stop in interface NavigatorNavigator.forward().public boolean isMoving()
Navigator
isMoving in interface Navigatorpublic void travel(float distance)
travel in interface Navigatordistance - The positive or negative distance to move the robot, same units as _wheelDiameter
public void travel(float distance,
                   boolean immediateReturn)
travel in interface Navigatordistance - The positive or negative distance to move the robot, same units as _wheelDiameterimmediateReturn - iff true, the method returns immediately, in which case the programmer public void rotateLeft()
rotateLeft in interface Navigatorpublic void rotateRight()
rotateRight in interface Navigatorpublic void rotate(float angle)
rotate in interface Navigatorangle - Angle to rotate in degrees. A positive value rotates left, a negative value right.
public void rotate(float angle,
                   boolean immediateReturn)
rotate in interface Navigatorangle - Angle to rotate in degrees. A positive value rotates left, a negative value right.immediateReturn - iff true, the method returns immediately, in which case the programmer public void rotateTo(float angle)
rotateTo in interface Navigatorangle - The angle to rotate to, in degrees.
public void rotateTo(float angle,
                     boolean immediateReturn)
rotateTo in interface Navigatorangle - The angle to rotate to, in degrees.immediateReturn - iff true,  method returns immediately and the programmer is responsible for calling
 updatePosition() before the robot moves again.
public void goTo(float x,
                 float y)
goTo in interface Navigatorx - The x coordinate to move to.y - The y coordinate to move to.
public void goTo(float x,
                 float y,
                 boolean immediateReturn)
goTo in interface Navigatorx - The x coordinate to move to.y - The y coordinate to move to.immediateReturn - iff true,  method returns immediately and the programmer is responsible for calling
 updatePosition() before the robot moves again.
public float distanceTo(float x,
                        float y)
distanceTo in interface Navigatorx - coordinate of the pointy - coordinate of the point
public float angleTo(float x,
                     float y)
angleTo in interface Navigatorx - coordinate of the pointy - coordinate of the point
public void updatePosition()
updatePosition in interface Navigatorpublic void turn(float radius)
radius - is the radius of the circular path. If positive, the left wheel is on the inside of the turn.  If negative, the left wheel is on the outside.
public void turn(float radius,
                 int angle)
radius - radius of the turning circleangle - The sign of the angle determines the direction of robot motion
public void turn(float radius,
                 int angle,
                 boolean immediateReturn)
radius - of the turning circleangle - The angle to turn.immediateReturn - if true, the method returns immediately, in which case the programmer | 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||