www.pudn.com > Ms_segmenter.rar > Merge_regions.m


function [New_inner_pts, New_boundary, New_shifts] = ... 
	Merge_regions (Region1, Region2); 
 
Min_x = min(Region1.Shifts(1, 1), Region2.Shifts(1, 1)); 
Max_x = max(Region1.Shifts(1, 2), Region2.Shifts(1, 2)); 
Min_y = min(Region1.Shifts(2, 1), Region2.Shifts(2, 1)); 
Max_y = max(Region1.Shifts(2, 2), Region2.Shifts(2, 2)); 
 
Image1 = zeros(Max_x-Min_x+1, Max_y-Min_y+1); 
Image1(sub2ind(size(Image1), Region1.Boundary(1, :)-Min_x+1, ... 
	Region1.Boundary(2, :)-Min_y+1)) = 1; 
To_start_fill = [Region1.Inner_pts(2, :)-Min_y+1; ... 
	Region1.Inner_pts(1, :)-Min_x+1]; 
Image1 = bwfill(Image1, To_start_fill(1, :), To_start_fill(2, :)); 
 
Image2 = zeros(Max_x-Min_x+1, Max_y-Min_y+1); 
Image2(sub2ind(size(Image2), Region2.Boundary(1, :)-Min_x+1, ... 
	Region2.Boundary(2, :)-Min_y+1)) = 1; 
To_start_fill = [Region2.Inner_pts(2, :)-Min_y+1; ... 
	Region2.Inner_pts(1, :)-Min_x+1]; 
Image2 = bwfill(Image2, To_start_fill(1, :), To_start_fill(2, :)); 
 
Image1 = or(Image1, Image2); 
 
New_boundary = Extract_region_reg(Image1, 1); 
New_boundary = New_boundary + [Min_x-1; Min_y-1]*ones(1, size(New_boundary, 2)); 
New_inner_pts = [Region1.Inner_pts, Region2.Inner_pts]; 
New_shifts = [Min_x, Max_x; Min_y, Max_y];