48 lines
1.1 KiB
C++
48 lines
1.1 KiB
C++
// This file is part of OpenCV project.
|
|
// It is subject to the license terms in the LICENSE file found in the top-level directory
|
|
// of this distribution and at http://opencv.org/license.html.
|
|
//
|
|
// Copyright (C) 2018 Intel Corporation
|
|
|
|
|
|
#ifndef OPENCV_GAPI_GAPI_OWN_SCALAR_HPP
|
|
#define OPENCV_GAPI_GAPI_OWN_SCALAR_HPP
|
|
|
|
#include <opencv2/gapi/own/exports.hpp>
|
|
|
|
namespace cv
|
|
{
|
|
namespace gapi
|
|
{
|
|
namespace own
|
|
{
|
|
|
|
class GAPI_EXPORTS Scalar
|
|
{
|
|
public:
|
|
Scalar() = default;
|
|
explicit Scalar(double v0) { val[0] = v0; };
|
|
Scalar(double v0, double v1, double v2 = 0, double v3 = 0)
|
|
: val{v0, v1, v2, v3}
|
|
{
|
|
}
|
|
|
|
const double& operator[](int i) const { return val[i]; }
|
|
double& operator[](int i) { return val[i]; }
|
|
|
|
static Scalar all(double v0) { return Scalar(v0, v0, v0, v0); }
|
|
|
|
double val[4] = {0};
|
|
};
|
|
|
|
inline bool operator==(const Scalar& lhs, const Scalar& rhs)
|
|
{
|
|
return std::equal(std::begin(lhs.val), std::end(lhs.val), std::begin(rhs.val));
|
|
}
|
|
|
|
} // namespace own
|
|
} // namespace gapi
|
|
} // namespace cv
|
|
|
|
#endif // OPENCV_GAPI_GAPI_OWN_SCALAR_HPP
|