一幅JPG图像,编写Matlab程序,将其切割成9幅小图(3×3).
2个回答
展开全部
% 图像切片代码
% my_imslice(filename); 缺省方式,输出 3×3 切片;
% my_imslice(filename,rc,cc); 输出 rc×cc 切片;
function [rgb,mn] = my_imslice(filename,rc,cc)
p = imread(filename);
if nargin == 1, rc = 3; cc = 3; end; % rc,cc 缺省值
% 图片补齐及计算每片大小
[m,n,h] = size(p);
rp = rc*(fix(m/rc)+1*(mod(m,rc)==1)); % 补齐后行像素
frow = fix(rp/rc); % 片行像素
cp = cc*(fix(n/cc)+1*(mod(n,cc)==1)); % 补齐后列像素
fcol = fix(cp/cc); % 片列像素
mn = [frow fcol];
pp = p;
pp(rp,cp,:) = 0; % 原始数据补齐
% 数据分片、显示
rgb = cell(rc,cc);
for r = 1:rc
for c = 1:cc
rrr = ((r-1)*frow+1):r*frow;
ccc = ((c-1)*fcol+1):c*fcol;
rgb{r,c} = pp(rrr,ccc,:);
subplot(rc,cc,(r-1)*cc+c);
imshow(rgb{r,c});
tt = [num2str(r) num2str(c)];
title(tt);
end;
end;
% 切片保存为文件
txt = '是否将切片保存为文件?';
ttl = '切片保存提醒';
str1 = '保存';
str2 = '放弃';
def = str1;
button = questdlg(txt,ttl,str1,str2,def);
saved = strcmp(str1,button);
if ~saved, disp('放弃切片文件保存。'); return; end;
ps = find(filename=='.');
nm = filename(1:ps-1); % 文件名称
ext = filename(ps+1:end); % 文件扩展名
txt = ['保存为 ' num2str(rc*cc) ' 个切片文件: '];
disp(txt);
for r = 1:rc
for c = 1:cc
tt = [num2str(r) num2str(c)];
fnm = [nm '_' tt '.' ext];
imwrite(rgb{r,c},fnm); % 保存片文件
disp(fnm);
end;
end;
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询