Matlab 图像转极坐标系

Posted hyhy904

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Matlab 图像转极坐标系相关的知识,希望对你有一定的参考价值。

实心圆环

imgVP1=flip(imgVP1,1);  % 水平翻转

polarVP1=polarVolinPlot(imgVP1); % 调用函数
空心圆环

[m,n,~]=size(imgVP2);

% 填充空心部分

for i=m:m+300

    for j=1:n

        imgVP2(i,j,:)=[255,255,255];

    end

end

imgVP2=flip(imgVP2,1);

polarVP2=polarVolinPlot(imgVP2);
 

function [polarImg] = polarImg(img0)
% polarImg
Rimg0=double(img0(:,:,1));
Gimg0=double(img0(:,:,2));
Bimg0=double(img0(:,:,3));
[m,n]=size(Rimg0);
%原图坐标
[t,r]=meshgrid(linspace(-pi,pi,n),1:m);
M=2*m;N=2*n;
[NA,MA]=meshgrid((1:N)-n-0.5,(1:M)-m-0.5);
T=atan2(NA,MA);
R=sqrt(MA.^2+NA.^2);%变换坐标
Rpolar=interp2(t,r,Rimg0,T,R,‘linear‘,0);
Gpolar=interp2(t,r,Gimg0,T,R,‘linear‘,0);
Bpolar=interp2(t,r,Bimg0,T,R,‘linear‘,0);
polarImg=uint8(cat(3,Rpolar,Gpolar,Bpolar));
polarImg=imrotate(polarImg, -90);
% 图片裁剪
if M<N
polarImg = imcrop(polarImg,[0,(N-M)/2,M,M]);
else
polarImg = imcrop(polarImg,[0,(M-N)/2,N,N]);
end
end
--------------------- 

以上是关于Matlab 图像转极坐标系的主要内容,如果未能解决你的问题,请参考以下文章

Matlab 图像转极坐标系

MATLAB:polarplot❤️在极坐标系下绘制线条

在Origin中绘制极坐标云图的方法

matlab图像坐标轴如何望下移动

matlab在图像上如何根据纵坐标找到对应的横坐标,并且将坐标标注在图像上?

极坐标系 隐函数 数值求解 并 绘制 函数图像