
Page 60
These commands set the mode and direction of the outputs in one fell swoop, but you should still set the power level explicitly with a call to
SetPower()
.
For timed actions, the following command will come in handy:
OnFor(const outputs, expression time)
This command turns on the specified outputs for the given time, measured in hundredths of a second. Then the given outputs are turned off (in brake mode, not in float mode).
The following example runs outputs A and C forward, waits one second, then reverses outputs A and C. After another second, the outputs are turned off.
task main() {
SetPower(OUT_A + OUT_C, OUT_HALF);
Fwd(OUT_A + OUT_C);
OnFor(OUT_A + OUT_C, 100);
Rev(OUT_A + OUT_C);
OnFor(OUT_A + OUT_C, 100);
}
The
On()
,
Off()
,
Float()
,
Fwd()
,
Rev()
, and
Toggle()
commands are really shorthand for these lower-level output commands:
SetOutput(const outputs, const mode)
This command sets the mode for the given outputs. The outputs are specified in the same way as in the
Fwd()
and
Rev()
commands. The value of
mode
should be one of the constants
OUT_ON
,
OUT_OFF
, and
OUT_FLOAT
.
SetDirection(const outputs, const direction)
This command determines the direction of the supplied outputs. The
direction
parameter should be
OUT_FWD
,
OUT_REV
, or
OUT_TOGGLE
.
OUT_TOGGLE
is a special value that sets the
direction of the output to the opposite of its current value.
In general, I recommend you don't call
SetDirection()
with the
OUT_TOGGLE
value. If you explicitly set the directions of your outputs, your program will be clearer. Furthermore, in
programs with more than one task, your program is more likely to behave as you expect.
Input Commands
Before you can read a value from one of the RCX's inputs, you need to tell the RCX what type of sensor is attached to the input. NQC provides a command that does just this:
Page 61
SetSensor(expression sensor, const configuration)
This command tells the RCX how to configure the given input. Valid values for
sensor
are
SENSOR_1
,
SENSOR_2
, and
SENSOR_3
, which represent the three inputs of the RCX. The sensor
configurations are detailed in Table 4-1. See Appendix A,
Finding Parts and Programming Environments,
which lists the sensors that are available for the RCX.
Summary of Contents for MINDSTORMS Robots
Page 22: ...Page 18 The back tread wheels are anchored to the shafts with the 16t gears ...
Page 23: ...Page 19 Page 20 Next start building support for the drive motors ...
Page 26: ...Page 23 The touch sensors are attached only by the shaft that runs through them ...
Page 41: ...Page 41 ...
Page 43: ...Next build the support for the light sensor ...
Page 80: ...Page 85 Make sure the bump on the long pin is up against the 4u beam ...
Page 82: ......
Page 84: ...Page 89 ...
Page 85: ...Step 14 is similar to Step 11 take a deep breath and go slowly ...
Page 87: ...Page 91 ...
Page 88: ...Page 92 Make sure that the two sides are at the same angle They should mirror each other ...
Page 89: ...Page 93 Page 94 ...
Page 90: ...Structural Support Page 95 ...
Page 91: ...Idler Wheel Page 96 ...
Page 92: ...Page 97 Drive Motor ...
Page 93: ...While you re putting the motor in hold on to the worm gear so it doesn t slip off Page 98 ...
Page 94: ...Grabber Arm Motor ...
Page 95: ...Page 99 ...
Page 96: ...Page 100 RCX Attach the RCX on both sides as shown Page 101 ...
Page 158: ......
Page 159: ...Page 175 The 16t gears are nestled inside the tread wheels ...
Page 160: ...Page 176 ...
Page 161: ...Page 177 Attach the motors to output A and output C as shown Page 178 ...