我正在使用MATLAB R2012a,我试图让用户在不使用内置功能的情况下裁剪图像。
这是我的代码:
[x, y] = ginput(2);
m1 = [x(1), y(1)];
m2 = [x(2), y(2)];
m1 = int16(m1);
m2 = int16(m2);
[m, n] = size(manip);
s1 = (m2(1) - m1(1))+1;
s2 = (m2(2) - m2(2))+1;
temp = zeros([s1, s2],('uint8'));
p1 = 0;
p2 = 0;
for c1 = 1:m
if ((c1 <= m1(2)) && (c1 >= m2(2)))
for c2 = 1:n
if ((c2 <= m1(1)) && (c2 >= m2(1)))
temp(p1, p2) = manip(c1, c2);
end
p2 = p2 + 1;
end
end
p1 = p1 + 1;
end
out = temp;
这是我的结果:
我做错了什么想法,我似乎能够看到它。感谢。
答案 0 :(得分:1)
我想你的错误就在这里:s2 = (m2(2) - m2(2))+1;
这不应该是s2 = (m2(2) - m1(2))+1;
吗?
但是你根本不需要那个循环:
Iold = rand(300);
%crop 10 pixels off each side
Inew = Iold(11:end - 10, 11: end - 10);
或者如果您需要相同大小的图像,但是在裁剪位为零的情况下使用零:
Inew = zeros(size(Iold));
Inew(11:end - 10, 11: end - 10) = Iold(11:end - 10, 11: end - 10);
或概括它:
Inew(xmin:xmax, ymin:ymax) = Iold(xmin:xmax, ymin:ymax);