Crates.io | person-sensor |
lib.rs | person-sensor |
version | 0.3.0 |
source | src |
created_at | 2024-08-16 02:40:05.975782 |
updated_at | 2024-09-02 20:57:37.132492 |
description | An embedded-hal driver for the Useful Things Person Sensor |
homepage | |
repository | https://github.com/riley-williams/person-sensor |
max_upload_size | |
id | 1339882 |
size | 25,440 |
A small driver for the Useful Things Person Sensor.
Original developer guide
This driver has been tested with v1.1 of the sensor, but should also work with v1 and v2. If you're able to validate the other board revisions, please open a pr to update this message :)
The sensor offers two modes: continuous and single shot. It can be converted between the two modes, and the compiler will prevent you from misusing functionality that is only available in a specific mode, or when an interrupt pin is provided.
use person_sensor::PersonSensorBuilder;
let i2c = /* ... */;
let interrupt_pin = /* ... */;
// The driver can be initialized with or without the interrupt pin using the builder
let mut person_sensor = PersonSensorBuilder::new_standby(i2c, true)
.with_interrupt(interrupt_pin) // optional
.build()
.await
.unwrap();
let detections = person_sensor.capture_once().await.unwrap();
// ERROR: an interrupt pin was provided, but person_sensor is in standby mode
// person_sensor.wait_for_person().await.unwrap();
// To use the functionality in continuous mode, convert the sensor like below,
// or use the builder with new_continuous(...)
let mut person_sensor = sensor.into_continuous_mode();
// Now we meet all the requirements to wait for the next detection using the interrupt
_ = person_sensor.wait_for_person().await.unwrap();
// Read the latest detections.
// Note wait_for_person() does not automatically read the detections
let detections = person_sensor.get_detections().await.unwrap();
To run the examples on a pi pico, it should be sufficient to enter bootloader mode and run:
cd examples
cargo run --bin <example_name> --release
Licensed under either of
Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0) MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT) at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.