Type conversions among famous Rust computer vision libraries. It supports the following crates:
Run cargo add cv-convert
to add this crate to your project. In the
default setting, up-to-date dependency versions are used.
If you desire to enable specified dependency versions. Add
default-features = false
and select crate versions as Cargo
features. For example, the feature nalgebra_0-30
enables nalgebra
0.30.x.
toml
[dependencies.cv-convert]
version = 'x.y.z' # Please look up the recent version on crates.io
default-features = false
features = [
'image_0-24',
'opencv_0-70',
'tch_0-8',
'nalgebra_0-31',
'ndarray_0-15',
]
The full
feature was available before 0.20 but was removed since
0.21 to avoid bloating and surprising dependency update.
The minimum supported rustc
is 1.51. You may use older versions of
the crate (>=0.6) in order to use rustc
versions that do not support
const-generics.
opencv_0-76
opencv_0-75
opencv_0-74
opencv_0-73
opencv_0-72
opencv_0-71
opencv_0-70
opencv_0-69
opencv_0-68
opencv_0-67
opencv_0-66
opencv_0-65
opencv_0-64
opencv_0-63
image_0-24
image_0-23
imageproc_0-23
ndarray_0-15
nalgebra_0-32
nalgebra_0-31
nalgebra_0-30
nalgebra_0-29
nalgebra_0-28
nalgebra_0-27
nalgebra_0-26
tch_0-10
The crate provides FromCv
, TryFromCv
, IntoCv
, TryIntoCv
traits, which are similar to standard library's From
and Into
.
```rust use cv_convert::{FromCv, IntoCv, TryFromCv, TryIntoCv}; use nalgebra as na; use opencv as cv;
// FromCv
let cvpoint = cv::core::Point2d::new(1.0, 3.0);
let napoints = na::Point2::
// IntoCv
let cvpoint = cv::core::Point2d::new(1.0, 3.0);
let napoints: na::Point2
// TryFromCv let namat = na::DMatrix::fromvec(2, 3, vec![1.0, 2.0, 3.0, 4.0, 5.0, 6.0]); let cvmat = cv::core::Mat::tryfromcv(&namat)?;
// TryIntoCv let namat = na::DMatrix::fromvec(2, 3, vec![1.0, 2.0, 3.0, 4.0, 5.0, 6.0]); let cvmat: cv::core::Mat = namat.tryintocv()?; ```
To add the new version of nalgebra 0.32 for cv-convert for example,
open cv-convert-generate/packages.toml
in the source repository. Add
a new version to the list like this.
toml
[package.nalgebra]
versions = ["0.26", "0.27", "0.28", "0.29", "0.30", "0.31", "0.32"]
use_default_features = true
features = []
Run make generate
at the top-level directory. It modifies Rust
source files automatically. One extra step is to copy the snipplet in
cv-convert/generated/Cargo.toml.snipplet
and paste it to
cv-convert/Cargo.toml
.
To add a new type conversion, take image::DynamicImage
and
opencv::Mat
for example. Proceed to cv-convert/src
and implement
the code in with_opencv_image.rs
because it is a conversion among
opencv and image crates.
Choose FromCv
or TryFromCv
trait and add the trait implementation
on image::DynamicImage
and opencv::Mat
types. The choice of
FromCv
or TryFromCv
depends on whether the conversion is fallible
or not.
```rust impl FromCv<&image::DynamicImage> for opencv::Mat { /* omit / } impl FromCv<&opencv::Mat> for image::DynamicImage { / omit */ }
// or
impl TryFromCv<&image::DynamicImage> for opencv::Mat { /* omit / } impl TryFromCv<&opencv::Mat> for image::DynamicImage { / omit */ }
mod tests { // Write a test } ```
MIT license. See LICENSE file.