我正在尝试将方法从c ++转换为java。这是方法:
void rgb2cmyk(cv::Mat& src, std::vector<cv::Mat>& cmyk)
{
CV_Assert(src.type() == CV_8UC3);
cmyk.clear();
for (int i = 0; i < 4; ++i)
cmyk.push_back(cv::Mat(src.size(), CV_32F));
for (int i = 0; i < src.rows; ++i)
{
for (int j = 0; j < src.cols; ++j)
{
cv::Vec3b p = src.at<cv::Vec3b>(i,j);
float r = p[2] / 255.;
float g = p[1] / 255.;
float b = p[0] / 255.;
float k = (1 - std::max(std::max(r,g),b));
cmyk[0].at<float>(i,j) = (1 - r - k) / (1 - k);
cmyk[1].at<float>(i,j) = (1 - g - k) / (1 - k);
cmyk[2].at<float>(i,j) = (1 - b - k) / (1 - k);
cmyk[3].at<float>(i,j) = k;
}
}
}
问题在于OpenCv的方法。这是一些细节:
CV_Assert
方法。不知道任何替代
为此。cmyk.push_back
已替换为cmyk[i].pushback
Mat
替换cv::Vec3b
,它显示没有错误std::max
已替换为Math.max
cmyk[0].at<float>(i,j)
任何人都有建议或更好的方法将此方法更改为java。
提前感谢您的帮助......
修改
我做了什么
public void rgb2xmyk(Mat src,Mat[] cmyk)
{
//CV_Assert(src.type() == CV_8UC3);
//cmyk.clear();
for (int i = 0; i < 4; ++i)
cmyk[i].push_back(new Mat(src.size(), CvType.CV_32F));
for (int i = 0; i < src.rows; ++i)
{
for (int j = 0; j < src.cols; ++j)
{
double[] p = src.get(i,j);
float r = (float) (p[2] / 255.);
float g = (float) (p[1] / 255.);
float b = (float) (p[0] / 255.);
float k = (1 - Math.max(Math.max(r,g),b));
cmyk[0].at<float>(i,j) = (1 - r - k) / (1 - k);
cmyk[1].at<float>(i,j) = (1 - g - k) / (1 - k);
cmyk[2].at<float>(i,j) = (1 - b - k) / (1 - k);
cmyk[3].at<float>(i,j) = k;
}
}
}
答案 0 :(得分:7)
您必须确保Mat的cmyk数组的大小= 4。 在for循环中,我建议你使用setTo:
for (int i = 0; i < 4; ++i)
cmyk[i].setTo(new Mat(src.size(), CvType.CV_32F));
在嵌套的for循环中,你填充你的cmyk,我会使用put方法
cmyk[0].put(i,j,new Float[] {(1 - r - k) / (1 - k)});
cmyk[1].put(i,j,new Float[] {(1 - g - k) / (1 - k)});
cmyk[2].put(i,j,new Float[] {(1 - b - k) / (1 - k)});
cmyk[3].put(i,j,new Float[] {k});
...希望这会有所帮助
答案 1 :(得分:7)
你可能会在这一行找到:
cmyk[0].at<float>(i,j) = (1 - r - k) / (1 - k);
结果在被转换为float之前被处理为int,因为你有整数开始每个块。尝试:
cmyk[0].at<float>(i,j) = (1.0f - r - k) / (1.0f - k);
我认为你已经对如何通过(通过.put)访问该数组中的元素有一个合理的答案。