初始界面
data:image/s3,"s3://crabby-images/38610/386103f338ec83e13baf0e2cfacc19c7fe21748a" alt="数字图像处理GUI大作业——matlab_第1张图片"
导入图像
data:image/s3,"s3://crabby-images/c3689/c368934eab510d5475bc414c2c007964e94182c3" alt="数字图像处理GUI大作业——matlab_第2张图片"
[fn,pn,~]=uigetfile('*.jpg','请选择要处理的图片');
I=imread([pn fn]);
imshow(I)
title('原图像');
handles.image = I;
guidata(hObject,handles)
图像旋转
data:image/s3,"s3://crabby-images/6d2fa/6d2fadd269531d070b260ce0cdef0c31618b3abc" alt="数字图像处理GUI大作业——matlab_第3张图片"
J = imrotate(I,-45,'crop');%旋转图形
镜像图片
data:image/s3,"s3://crabby-images/6a842/6a842b33076ae4f25dd98fcecddb3457b04e575d" alt="数字图像处理GUI大作业——matlab_第4张图片"
J = flipdim(I,2);%原图像的垂直镜像
边缘提取
data:image/s3,"s3://crabby-images/01015/0101550fd97f5d9bbb8b1c90c267edce4748c68b" alt="数字图像处理GUI大作业——matlab_第5张图片"
BW1 = edge(I,'Roberts');%Roberts算子
BW2 = edge(I,'Prewitt');%Prewitt算子
BW3 = edge(I,'Sobel');%Sobel算子
[M,N] = size(I);%拉普拉斯算子
BW4 = zeros(size(I));
for x = 2:M-1
for y = 2:N-1
BW4(x,y) = I(x+1,y) + I(x-1,y) + I(x,y+1) + I(x,y-1) - 4*I(x,y);
end;
end
对比度增强
data:image/s3,"s3://crabby-images/a7c21/a7c21d4da69a39ab73bc068532ffc3316daaec1f" alt="数字图像处理GUI大作业——matlab_第6张图片"
X = 0.7;
image = im2double(image1);
image2 = (image .^ X);%进行幂律变换
灰度线性反转
data:image/s3,"s3://crabby-images/74060/740600d5eca93bb9ef3741cee589144b70f2ad4e" alt="数字图像处理GUI大作业——matlab_第7张图片"
img=-img+255; %图像反转线性变换
二值图像
data:image/s3,"s3://crabby-images/e70d7/e70d7e4ac0a04c4deda260a3e019a2a291b42c1d" alt="数字图像处理GUI大作业——matlab_第8张图片"
gdata = rgb2gray(I);
j=imbinarize(gdata);
图像腐蚀
data:image/s3,"s3://crabby-images/7a6ab/7a6ab354509c295312084cc1483cf5a0834d6bf6" alt="数字图像处理GUI大作业——matlab_第9张图片"
j=imbinarize(gdata);
se=eye(5);
bw=bwmorph(j,'erode');
索引图像
data:image/s3,"s3://crabby-images/14ca2/14ca2f84ccd725365d1e5d59186e04e8ea759c38" alt="数字图像处理GUI大作业——matlab_第10张图片"
y=grayslice(gdata,16);
图像裁剪
data:image/s3,"s3://crabby-images/650c9/650c9deb36dd2d20e5ddd5cd2468f5d9caf758d3" alt="数字图像处理GUI大作业——matlab_第11张图片"
waitforbuttonpress;
clf;
I = handles.image;
I2=imcrop(I);
close
添加椒盐噪声
data:image/s3,"s3://crabby-images/fa862/fa8626db37cdaf8bb40975bc3166a499f9a68f1e" alt="数字图像处理GUI大作业——matlab_第12张图片"
J = imnoise(I,'salt & pepper',number);
添加高斯噪声
data:image/s3,"s3://crabby-images/8ff54/8ff54408636e7b56d85fb00604086b51368e1ba5" alt="数字图像处理GUI大作业——matlab_第13张图片"
J = imnoise(I,'gaussian',number);%添加高斯噪声
频率滤波
data:image/s3,"s3://crabby-images/13666/136663e79165835e9a7f4c9de71f2067cc878fbe" alt="数字图像处理GUI大作业——matlab_第14张图片"
f = double(I2);
g = fft2(f);
g = fftshift(g);
[N1,N2] = size(g);
n = 2;
d0 = 50;
n1 = fix(N1/2);
n2 = fix(N2/2);
for i = 1:N1
for j = 1:N2
d = sqrt((i - n1)^2 + (j - n2)^2);
% Buttetworth低通滤波
h = 1/(1 + (d/d0)^(2*n));
result1(i,j) = h*g(i,j);
% 理想低通滤波
if d>30
result2(i,j) = 0;
else
result2(i,j) = g(i,j);
end
end
end
result1 = ifftshift(result1);
result2 = ifftshift(result2);
X2 = ifft2(result1);
X3 = uint8(real(X2));
X4 = ifft2(result2);
X5 = uint8(real(X4));
空间滤波
data:image/s3,"s3://crabby-images/140d2/140d225685b6615a7a39fe5a4ac7fe79fc9af403" alt="数字图像处理GUI大作业——matlab_第15张图片"