zhangyl112
2017-11-26 15:57opencv下笛卡尔坐标图片转化为极坐标图片无法显示彩色图片
uchar interpolate_bilinear(cv::Mat& mat_src, double ri, int rf, int rc, double ti, int tf, int tc)
{
double inter_value = 0.0;
if (rf == rc && tc == tf)
{
inter_value = mat_src.ptr<uchar>(rc)[tc];
}
else if (rf == rc)
{
inter_value = (ti - tf) * mat_src.ptr<uchar>(rf)[tc] + (tc - ti) * mat_src.ptr<uchar>(rf)[tf];
}
else if (tf == tc)
{
inter_value = (ri - rf) * mat_src.ptr<uchar>(rc)[tf] + (rc - ri) * mat_src.ptr<uchar>(rf)[tf];
}
else
{
double inter_r1 = (ti - tf) * mat_src.ptr<uchar>(rf)[tc] + (tc - ti) * mat_src.ptr<uchar>(rf)[tf];
double inter_r2 = (ti - tf) * mat_src.ptr<uchar>(rc)[tc] + (tc - ti) * mat_src.ptr<uchar>(rc)[tf];
inter_value = (ri - rf) * inter_r2 + (rc - ri) * inter_r1;
}
return (uchar)inter_value;
}
bool cartesian_to_polar(cv::Mat& mat_c, cv::Mat& mat_p, int img_d)
{
int color_num = mat_c.channels();
cout << "color_num=" << color_num << endl;
mat_p = cv::Mat::zeros(img_d, img_d, CV_8UC1);
//mat_p = cv::Mat::zeros(img_d, img_d, CV_8UC3);
//mat_p = cv::Mat::zeros(img_d, img_d, color_num);
int line_len = mat_c.rows;
int line_num = mat_c.cols;
double delta_r = (2.0*line_len) / (img_d - 1); //半径因子
double delta_t = 2.0 * PI / line_num; //角度因子
double center_x = (img_d - 1) / 2.0;
double center_y = (img_d - 1) / 2.0;
for (int i = 0; i < img_d; i++)
{
for (int j = 0; j < img_d; j++)
{
double rx = j - center_x; //图像坐标转世界坐标
double ry = center_y - i; //图像坐标转世界坐标
double r = std::sqrt(rx*rx + ry*ry);
if (r <= (img_d - 1) / 2.0)
{
double ri = r * delta_r;
int rf = (int)std::floor(ri);
int rc = (int)std::ceil(ri);
if (rf < 0)
{
rf = 0;
}
if (rc >(line_len - 1))
{
rc = line_len - 1;
}
double t = std::atan2(ry, rx);
if (t < 0)
{
t = t + 2.0 * PI;
}
double ti = t / delta_t;
int tf = (int)std::floor(ti);
int tc = (int)std::ceil(ti);
if (tf < 0)
{
tf = 0;
}
if (tc >(line_num - 1))
{
tc = line_num - 1;
}
mat_p.ptr<uchar>(i)[j] = interpolate_bilinear(mat_c, ri, rf, rc, ti, tf, tc);
/*
mat_p.ptr<Vec3b>(i, j)[0] = interpolate_bilinear(mat_c, ri, rf, rc, ti, tf, tc);
mat_p.ptr<Vec3b>(i, j)[1] = interpolate_bilinear(mat_c, ri, rf, rc, ti, tf, tc);
mat_p.ptr<Vec3b>(i, j)[2] = interpolate_bilinear(mat_c, ri, rf, rc, ti, tf, tc);
*/
}
}
}
return true;
}
- 点赞
- 回答
- 收藏
- 复制链接分享
1条回答
为你推荐
- opencv批量处理图片出现的一个警告
- c语言
- c++
- 自动驾驶
- 机器学习
- 2个回答
- opencv读入图片后把图像整体除2,再显示图像,为什么变白了
- 深度学习
- 人工智能
- 机器学习
- 数据挖掘
- 2个回答
- Opencv,imshow打开图片,鼠标放在图片上能自己显示像素值
- opencv
- 图片
- 4个回答
- BYTE*图片如何转化成Mat类型,供opencv读取
- base64
- opencv
- 图片
- 1个回答
- opencv如何读取指定序号的图片
- opencv
- 图片
- c++
- 1个回答
换一换