+ How To Add This Control To Your Project (Click to Expand)
- Load the most recent release of ARC.
- Press the Project tab from the top menu bar in ARC.
- Press Add Control from the button ribbon bar in ARC.
- Choose the Ultrasonic Distance category tab.
- Press the Ultrasonic Distance icon to add the control to your project.
When an HC-SR04 or equivalent Ultrasonic Distance Sensor is connected to an EZB, this skill will display the distance of a detected object/wall in front of the sensor. This skill does not cause a robot to steer or avoid obstacles; it merely displays a distance value. For object avoidance and steering use the Radar skill.
This skill is integrated with scripting and will update when GetPing() is called (with matching port configured) and the PAUSE checkbox is checked. That way you can have this skill on your project but it won't use any communication resources unless it's called from a script with GetPing(). What this means is you can leave the PAUSED checkbox checked, and this skill will be updated when GetPing() is called.
It's worth noting that the distance displayed is not a unit of CM or Inches. The distance value is an arbitrary number that is related to the type of sensor, voltage, detected material, and temperature. If a specific distance unit is required, use a tape measure to identify the distance value.
1. Ultrasonic Distance Value
This is a value between 0-255 that corresponds to the detected distance being sent by the ultrasonic sensor.
2. Bar Display
Displays a visual representation of the detected ultrasonic distance value.
3. Pause Checkbox
This checkbox pauses the capture of the ultrasonic distance value.
1. Title Field
This field contains the title of the skill. You can change it if you'd like. *Note: Changing the title will also change the title in the controlCommand() associated with this skill.
2. Board Index Drop-down
Select the EZB index number that your ultrasonic sensor is connected to.
3. Trigger & Echo Port Drop-downs
Select the digital port that your ultrasonic trigger wire is connected to. Also, select the digital port that your ultrasonic echo wire is connected to. *Note: This port must be the same as the trigger port when using a 3-wire Ultrasonic sensor.
4. Interval Drop-down
This drop-down selects the interval rate in milliseconds that the ultrasonic sensor will be sampled at. The range is 100-60000 milliseconds. The default setting is 250.
5. Variable & Multiplier
A variable will be set with the most recent distance value. This saves your code from having to call GetPing which adds needlessly to the communication channel.
The multiplier value will convert the raw distance value to a unit of measurement. For example, the default value of 1.25 will convert the distance into CM.
6. NMS (Navigation Messaging System)
The distance data can optionally be configured to push detected distances into the NMS (Level #3 Group #1) to be used by navigation robot skills, such as The Navigator. Please read the NMS manual and question marks associated with the options for better detail.
Ultrasonic Distance Sensors come in 2 versions. A 4-wire type with/without an inline voltage regulator and 3 wires with/without a built-in voltage regulator. If an Ultrasonic has a voltage regulator it will need +6V or greater Voltage input, if it doesn't it will need +5V.
3-wire Wiring (with built-in regulator)
- Ground = Black wire to GND
- Power = Red wire to Vin
- Trigger/Echo = white wire to Digital pin
- Ground = Black wire from regulator to GND
- Power = Red wire from regulator to Vin
- Trigger = white wire to Digital pin
- Echo = green wire to a second Digital pin
If you are using an EZ-Robot ultrasonic distance sensor, there may be false positives from the ping sound echoing within the casing. It is easy to fix with a few cotton balls inserted in the case around the sensors. Watch this video for detailed instructions.
You will need an EZB I/O Controller and a Ultrasonic Sensor to use this skill.
Synthiam has a ultrasonic hardware reference design here.