MATLAB图像旋转源代码
来源:互联网 发布:sftp指定端口 编辑:程序博客网 时间:2024/06/17 12:06
代码如下:
clear;
clc;
jiaodu=input('请输入角度:'); %要旋转的角度,旋转方向为顺时针
[filename,pathname]=uigetfile({'*jpg;*.bmp;*.jpeg;*.png;'},'load?image');
fpath=fullfile(pathname,filename);
img=imread(fpath);
img=rgb2gray(img);
imshow(img); %这里y为变换后图像的高度,x为变换后图像的宽度
[h w]=size(img);
theta=jiaodu/180*pi;
rot=[cos(theta) -sin(theta) 0;sin(theta) cos(theta) 0;0 0 1];
pix1=[1 1 1]*rot; %变换后图像左上点的坐标
pix2=[1 w 1]*rot; %变换后图像右上点的坐标
pix3=[h 1 1]*rot; %变换后图像左下点的坐标
pix4=[h w 1]*rot; %变换后图像右下点的坐标
height=round(max([abs(pix1(1)-pix4(1))+0.5 abs(pix2(1)-pix3(1))+0.5])); %变换后图像的高度
width=round(max([abs(pix1(2)-pix4(2))+0.5 abs(pix2(2)-pix3(2))+0.5])); %变换后图像的宽度
imgn=zeros(height,width);
delta_y=abs(min([pix1(1) pix2(1) pix3(1) pix4(1)])); %取得y方向的负轴超出的偏移量
delta_x=abs(min([pix1(2) pix2(2) pix3(2) pix4(2)])); %取得x方向的负轴超出的偏移量
for i=1-delta_y:height-delta_y
for j=1-delta_x:width-delta_x
pix=[i j 1]/rot; %用变换后图像的点的坐标去寻找原图像点的坐标,
%否则有些变换后的图像的像素点无法完全填充
float_Y=pix(1)-floor(pix(1));
float_X=pix(2)-floor(pix(2));
if pix(1)>=1 && pix(2)>=1 && pix(1) <= h && pix(2) <= w
pix_up_left=[floor(pix(1)) floor(pix(2))]; %四个相邻的点
pix_up_right=[floor(pix(1)) ceil(pix(2))];
pix_down_left=[ceil(pix(1)) floor(pix(2))];
pix_down_right=[ceil(pix(1)) ceil(pix(2))];
value_up_left=(1-float_X)*(1-float_Y); %计算临近四个点的权重
value_up_right=float_X*(1-float_Y);
value_down_left=(1-float_X)*float_Y;
value_down_right=float_X*float_Y;
imgn(i+delta_y,j+delta_x)=value_up_left*img(pix_up_left(1),pix_up_left(2))+ ...
value_up_right*img(pix_up_right(1),pix_up_right(2))+ ...
value_down_left*img(pix_down_left(1),pix_down_left(2))+ ...
value_down_right*img(pix_down_right(1),pix_down_right(2));
end
end
end
figure,
subplot(121);
imshow(img);
subplot(122);
imshow(uint8(imgn))
结果如下:
- MATLAB图像旋转源代码
- matlab实现图像旋转
- matlab 图像旋转
- 图像旋转(matlab)
- 图像旋转 matlab程序
- 3D matlab 图像旋转
- 基于matlab的图像旋转
- matlab旋转图像任意角度
- Matlab图像几何变换之图像旋转
- [转] MATLAB图像实用源代码
- MATLAB图像处理实用源代码
- 图像旋转系列文章的源代码下载
- matlab实现图像的平移、旋转、缩放
- (实验二) --- 图像旋转变换---matlab实现
- matlab实现图像的平移、旋转、缩放
- matlab中简单的图像旋转算法
- matlab 图像几何变换 平移、旋转、缩放
- 图像旋转的MATLAB和OpenCV源码!
- 动态规划:从新手到专家
- HashMap的工作原理
- Android6.0权限分配终极解决方案
- 2017上海ACM ECL-final 总结
- Windows7操作系统的安装
- MATLAB图像旋转源代码
- 栈(先进后出)
- 关于centOS6.5安装问题
- jquery性能优化
- Codeforces Round #452 (Div. 2) B. Months and Years
- HDOJ 1004 Let the Balloon Rise 让气球升起来
- Ajax文件上传
- ASP.net利用DotNetZip压缩文件,用流输出文件细节
- SSL P2325 最小转弯问题 题目