Crates.io | pelcodrs |
lib.rs | pelcodrs |
version | 0.2.1 |
source | src |
created_at | 2019-09-07 08:22:50.346159 |
updated_at | 2019-10-27 11:56:20.831142 |
description | A library for handling the Pelco D protocol. |
homepage | |
repository | https://github.com/fparat/pelcodrs |
max_upload_size | |
id | 162943 |
size | 43,759 |
pelcodrs
is a Rust library for communications using the Pelco D protocol.
The Pelco D protocol is widely used for controlling PTZ cameras, especially in the CCTV industry.
Add this in your application Cargo.toml
:
[dependencies]
pelcodrs = "0.2.0"
Create message objects to send to the device:
use pelcodrs::*;
let msg = MessageBuilder::new(10)
.camera_on()
.focus_far()
.down()
.tilt(Speed::Range(0.5))
.finalize()?;
assert_eq!(&[0xFF, 0x0A, 0x88, 0x90, 0x00, 0x20, 0x42], msg.as_ref());
A port object can be used with any Read + Write
object for communicating with
the target device. For example, a SerialPort
object from the crate
serialport can be used as port:
use serialport;
use pelcodrs::*;
let dev = PelcoDPort::new(serialport::open("/dev/ttyS0"));
dev.send_message(Message::flip_180(10)?)?;
Licensed under either of
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.
This library is not affiliated or associated in any way with Pelco.
All product and company names are trademarks or registered trademarks of their respective holders. Use of them does not imply any affiliation with or endorsement by them.
License: MIT OR Apache-2.0