LambdaSuperRes / KAIR /matlab /zoom_function.m
cooperll
LambdaSuperRes initial commit
2514fb4
raw
history blame
2.18 kB
function [I]=zoom_function(I,upperleft_pixel,box,zoomfactor,zoom_position,nline)
y = upperleft_pixel(1);
x = upperleft_pixel(2);
box1 = box(1);
box2 = box(2); %4
s_color = [0 255 0];
l_color = [255 0 0];
[~, ~, hw] = size( I );
if hw == 1
I=repmat(I,[1,1,3]);
end
Imin = I(x:x+box1-1,y:y+box2-1,:);
I(x-nline:x+box1-1+nline,y-nline:y+box2-1+nline,1) = s_color(1);
I(x-nline:x+box1-1+nline,y-nline:y+box2-1+nline,2) = s_color(2);
I(x-nline:x+box1-1+nline,y-nline:y+box2-1+nline,3) = s_color(3);
I(x:x+box1-1,y:y+box2-1,:) = Imin;
Imax = imresize(Imin,zoomfactor,'nearest');
switch lower(zoom_position)
case {'uper_left','ul'}
I(1:2*nline+zoomfactor*box1,1:2*nline+zoomfactor*box2,1) = l_color(1);
I(1:2*nline+zoomfactor*box1,1:2*nline+zoomfactor*box2,2) = l_color(2);
I(1:2*nline+zoomfactor*box1,1:2*nline+zoomfactor*box2,3) = l_color(3);
I(1+nline:zoomfactor*box1+nline,1+nline:zoomfactor*box2+nline,:) = Imax;
case {'uper_right','ur'}
I(1:2*nline+zoomfactor*box1,end-2*nline-zoomfactor*box2+1:end,1) = l_color(1);
I(1:2*nline+zoomfactor*box1,end-2*nline-zoomfactor*box2+1:end,2) = l_color(2);
I(1:2*nline+zoomfactor*box1,end-2*nline-zoomfactor*box2+1:end,3) = l_color(3);
I(1+nline:zoomfactor*box1+nline,end-nline-zoomfactor*box2+1:end-nline,:) = Imax;
case {'lower_left','ll'}
I(end-2*nline-zoomfactor*box1+1:end,1:2*nline+zoomfactor*box2,1) = l_color(1);
I(end-2*nline-zoomfactor*box1+1:end,1:2*nline+zoomfactor*box2,2) = l_color(2);
I(end-2*nline-zoomfactor*box1+1:end,1:2*nline+zoomfactor*box2,3) = l_color(3);
I(end-nline-zoomfactor*box1+1:end-nline,1+nline:zoomfactor*box2+nline,:) = Imax;
case {'lower_right','lr'}
I(end-2*nline-zoomfactor*box1+1:end,end-2*nline-zoomfactor*box2+1:end,1) = l_color(1);
I(end-2*nline-zoomfactor*box1+1:end,end-2*nline-zoomfactor*box2+1:end,2) = l_color(2);
I(end-2*nline-zoomfactor*box1+1:end,end-2*nline-zoomfactor*box2+1:end,3) = l_color(3);
I(end-nline-zoomfactor*box1+1:end-nline,end-nline-zoomfactor*box2+1:end-nline,:) = Imax;
end