Skip to content

Latest commit

 

History

History
62 lines (47 loc) · 3.22 KB

08_force.md

File metadata and controls

62 lines (47 loc) · 3.22 KB

Force Sensor

- detect if the sensor has been touched
- measure how much force has been applied to the sensor
- measure how far the sensor has been depressed
- detect if the force applied to the sensor exceeds a threshold
:class: important
To explore all Pybricks' features check the **[Pybricks documentaion](https://docs.pybricks.com/en/stable/index.html)**. This can also be seen in the right-hand panel of the Pybricks IDE.

The force sensor is like a more complicated button. Not only can it detect if it has been pressed, it can also measure how hard it has been pressed, or, in other words, the force applied to it. The measuring element is the black 'button' on the front of the sensor.

Force Sensor

To initialise the force sensor you must call the ForceSensor() class and nominate it's port. For example, with the robot you would use:

force_sensor = ForceSensor(Port.A)

Force Sensor Functions

Pybrick provides four functions to interact with the force sensor:

Force Sensor Example

Check how to use each of these functions by using the following code.

  1. Create a new file called force_sensor.py
  2. Type the code below into the file
  3. Predict what you think will happen.
  4. Run your code
:linenos:
- **lines 3 - 7** → imports all the Pybricks command for use with your robot
- **line 10** → initialises the hub
- **line 11** → initialises the force sensor
- **line 14** → creates an infinite loop
- **line 15** → takes the force reading, rounds it to one decimal place and then stores it in `force_reading`
- **line 16** → takes the distance reading, rounds it to one decimal place and then stores it in `distance_reading`
- **line 17** → checks if the sensor is experiencing more than 3N of force and stores result in `is_pressed`
- **line 18** → checks if the sensor has been touched and stores the result in `is_touched`
- **lines 20 - 25** → prints the values that have been stored
    - this is actually one print statement split over multiple line to make it easier to read
:class: caution
- what happens if you change the `pressed` threshold to `11`?
- what happens if you change the `pressed` threshold to `0`?