cameleon
is a safe, fast, and flexible library for GenICam compatible cameras.
cameleon
is a library for operating on GenICam
compatible cameras.
Our main goal is to provide safe, fast, and flexible library for GenICam
cameras.
Currently, cameleon
supports only USB3 Vision
cameras, but it's planned to support other protocols including GigE Vision
. See Roadmap for more details.
First, you need to install libusb to communicate with U3V
cameras. Then add the following to your Cargo.toml
:
toml
[dependencies]
cameleon = { version = 0.1, features = 'libusb'}
You can enumerate all cameras connected to the host, and start streaming.
```rust use cameleon::u3v;
// Enumerates all cameras connected to the host. let mut cameras = u3v::enumerate_cameras().unwrap();
if cameras.is_empty() { println!("no camera found"); return; }
let mut camera = cameras.pop().unwrap();
// Opens the camera.
camera.open().unwrap();
// Loads GenApi
context. This is necessary for streaming.
camera.load_context().unwrap();
// Start streaming. let payloadrx = camera.startstreaming(10).unwrap();
let mut payloadcount = 0; while payloadcount < 10 { match payloadrx.tryrecv() { Ok(payload) => { println!( "payload received! blockid: {:?}, timestamp: {:?}", payload.id(), payload.timestamp() ); if let Some(imageinfo) = payload.imageinfo() { println!("{:?}\n", imageinfo); let image = payload.image(); // do something with the image. // ... } payload_count += 1;
// Send back payload to streaming loop to reuse the buffer. This is optional.
payload_rx.send_back(payload);
}
Err(_err) => {
continue;
}
}
}
// Closes the camera. camera.close().unwrap(); ```
More examples can be found here.
Cameleon
consists of several crates.
cameleon
]: Provides high-level APIs to control cameras. This is the primary crate.cameleon-genapi
]: Provides parser and interpreter of GenApi
XML.cameleon-device
]: Provides device specific protocol decoder and basic I/O operations for devices, also provides emulators.cameleon-gentl
]: Provides GenTL
interfaces as a C library.cameleon-impl
]: Provides internal APIs for other crates. cameleon-impl
is intended to be used only by cameleon
project.cameleon-impl-macros
]: Provides procedural macros for other crates. cameleon-impl-macros
is intended to be used only by cameleon
project.It's probably due to permission issue for USB devices. You could add permissions by editing udev
rules, a configuration example is found here.
Frame rate can be affected by several reasons.
AcquisitionFrameRate
and ExposureTime
directly affect frame rate. So you need to setup the parameters first to improve frame rate.
Also, if DeviceLinkThroughputLimitMode
is set to On
, you would need to increase the value of DeviceLinkThroughputLimit
.
In this case, it's recommended to allocate the equal throughput limit to the connected cameras, making sure that the total throughput does not exceed the maximum bandwidth of the host controller.
usbfs_memory_mb
is set to low valueIf you use Linux, you may need to increase usbfs_memory_mb
limit.
By default, USB-FS on Linux systems only allows 16 MB of buffer memory for all USB devices. This is quite low for high-resolution image streaming.
We recommend you to set the value to 1000MB. You could set the value as following:
sh
echo 1000 > /sys/module/usbcore/parameters/usbfs_memory_mb
GigE
camerasGenTL
UVC
camerasWe continuously update the minor version every four weeks, until the version reaches 1.0.0
.
Thank you for your interest in contributing to Cameleon
! We are so happy to have you join the development.
To start developing, please refer to CONTRIBUTING.md.
This project is licenced under MPL 2.0.