1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
use num_traits::Zero;

use super::VecN;

/// [docs.opencv.org](https://docs.opencv.org/4.x/d1/da0/classcv_1_1Scalar__.html)
pub type Scalar_<T> = VecN<T, 4>;

impl<T> Scalar_<T> {
	#[inline]
	pub const fn new(v0: T, v1: T, v2: T, v3: T) -> Self {
		Self::from_array([v0, v1, v2, v3])
	}

	/// returns true iff v1 == v2 == v3 == 0
	#[inline]
	pub fn is_real(&self) -> bool
	where
		T: Zero + PartialEq,
	{
		self[1] == T::zero() && self[2] == T::zero() && self[3] == T::zero()
	}
}

impl<T: Zero> From<T> for Scalar_<T> {
	#[inline]
	fn from(v0: T) -> Self {
		Self::from_array([v0, T::zero(), T::zero(), T::zero()])
	}
}

impl From<i32> for Scalar_<f64> {
	#[inline]
	fn from(v0: i32) -> Self {
		Self::from(f64::from(v0))
	}
}

impl<T: Zero> From<(T, T)> for Scalar_<T> {
	#[inline]
	fn from(v: (T, T)) -> Self {
		Self::from_array([v.0, v.1, T::zero(), T::zero()])
	}
}

impl From<(i32, i32)> for Scalar_<f64> {
	#[inline]
	fn from(v: (i32, i32)) -> Self {
		Self::from((f64::from(v.0), f64::from(v.1)))
	}
}

impl<T: Zero> From<(T, T, T)> for Scalar_<T> {
	#[inline]
	fn from(v: (T, T, T)) -> Self {
		Self::from_array([v.0, v.1, v.2, T::zero()])
	}
}

impl From<(i32, i32, i32)> for Scalar_<f64> {
	#[inline]
	fn from(v: (i32, i32, i32)) -> Self {
		Self::from((f64::from(v.0), f64::from(v.1), f64::from(v.2)))
	}
}

impl<T> From<(T, T, T, T)> for Scalar_<T> {
	#[inline]
	fn from(v: (T, T, T, T)) -> Self {
		Self::from_array([v.0, v.1, v.2, v.3])
	}
}

impl From<(i32, i32, i32, i32)> for Scalar_<f64> {
	#[inline]
	fn from(v: (i32, i32, i32, i32)) -> Self {
		Self::from((f64::from(v.0), f64::from(v.1), f64::from(v.2), f64::from(v.3)))
	}
}

impl From<VecN<u8, 3>> for Scalar_<f64> {
	#[inline]
	fn from(v: VecN<u8, 3>) -> Self {
		Self::from((f64::from(v[0]), f64::from(v[1]), f64::from(v[2])))
	}
}