All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opencv.core.Scalar Maven / Gradle / Ivy

There is a newer version: 2.0.5
Show newest version
package org.opencv.core;

/**
 * 

Template class for a 4-element vector derived from Vec.

* *

template class CV_EXPORTS Scalar_ : public Vec<_Tp, 4>

* *

// C++ code:

* * *

public:

* *

//! various constructors

* *

Scalar_();

* *

Scalar_(_Tp v0, _Tp v1, _Tp v2=0, _Tp v3=0);

* *

Scalar_(const CvScalar& s);

* *

Scalar_(_Tp v0);

* *

//! returns a scalar with all elements set to v0

* *

static Scalar_<_Tp> all(_Tp v0);

* *

//! conversion to the old-style CvScalar

* *

operator CvScalar() const;

* *

//! conversion to another data type

* *

template operator Scalar_() const;

* *

//! per-element product

* *

Scalar_<_Tp> mul(const Scalar_<_Tp>& t, double scale=1) const;

* *

// returns (v0, -v1, -v2, -v3)

* *

Scalar_<_Tp> conj() const;

* *

// returns true iff v1 == v2 == v3 == 0

* *

bool isReal() const;

* *

};

* *

typedef Scalar_ Scalar;

* *

Being derived from Vec<_Tp, 4>, Scalar_ and * Scalar can be used just as typical 4-element vectors. In * addition, they can be converted to/from CvScalar. The type * Scalar is widely used in OpenCV to pass pixel values. *

* * @see org.opencv.core.Scalar_ */ public class Scalar { public double val[]; public Scalar(double v0, double v1, double v2, double v3) { val = new double[] { v0, v1, v2, v3 }; } public Scalar(double v0, double v1, double v2) { val = new double[] { v0, v1, v2, 0 }; } public Scalar(double v0, double v1) { val = new double[] { v0, v1, 0, 0 }; } public Scalar(double v0) { val = new double[] { v0, 0, 0, 0 }; } public Scalar(double[] vals) { if (vals != null && vals.length == 4) val = vals.clone(); else { val = new double[4]; set(vals); } } public void set(double[] vals) { if (vals != null) { val[0] = vals.length > 0 ? vals[0] : 0; val[1] = vals.length > 1 ? vals[1] : 0; val[2] = vals.length > 2 ? vals[2] : 0; val[3] = vals.length > 3 ? vals[3] : 0; } else val[0] = val[1] = val[2] = val[3] = 0; } public static Scalar all(double v) { return new Scalar(v, v, v, v); } public Scalar clone() { return new Scalar(val); } public Scalar mul(Scalar it, double scale) { return new Scalar(val[0] * it.val[0] * scale, val[1] * it.val[1] * scale, val[2] * it.val[2] * scale, val[3] * it.val[3] * scale); } public Scalar mul(Scalar it) { return mul(it, 1); } public Scalar conj() { return new Scalar(val[0], -val[1], -val[2], -val[3]); } public boolean isReal() { return val[1] == 0 && val[2] == 0 && val[3] == 0; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + java.util.Arrays.hashCode(val); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (!(obj instanceof Scalar)) return false; Scalar it = (Scalar) obj; if (!java.util.Arrays.equals(val, it.val)) return false; return true; } @Override public String toString() { return "[" + val[0] + ", " + val[1] + ", " + val[2] + ", " + val[3] + "]"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy