求一个通过matlab的图像坐标变换代码,公式如下图所示:
其中 x,y为原来图像的坐标,x',y’为变换后的图像坐标,参数m已知。
要将得到的变换后的图像保存下来。
------解决方案--------------------
假设你的原参数m是1*8的vector,图像是2d图片
% 分割分子分母的参数矩阵
matx = m(1:3);
maty = m(4:6);
matd = [m(7:8),1];
% 读取原图
oldimg = imread('test.jpg');
% 新图
newimg = [];
% 坐标变换
for x = 1:size(oriImg,2)
for y = 1:size(oriImg,1)
tempvec = [x,y,1]'; % 临时变量
newx = floor((matx*tempvec)/(matd*tempvec)); % 新x坐标并取整
newy = floor((maty*tempvec)/(matd*tempvec)); % 新y坐标并取整
newx = max(1,newx); % 保证x下标从1开始
newy = max(1,newy); % 保证y下标从1开始
newimg(newy,newx) = oldimg(y,x); % 设置新图像(y',x')的值为原图(y,x)的值,注意顺序
end
end
% 转换为unsigned int8图像,像素值[0,255]
newimg = uint8(newimg);
% 保存新图片
imsave('newimg.jpg','jpg');