how to connect the adjacent lower edges of each bounding box
    조회 수: 3 (최근 30일)
  
       이전 댓글 표시
    
I have drawn a bounding box of rectangle shape on each character and save the all 4 point of all bounding box 
Now I want to connect the lower edges of bounding box with each other
How to do it??
sample code for making bounding box and saving all 4 points of bounding box 
I = imread('textlineImage.png');
I=im2bw(I);
I=imcomplement(I);
st=regionprops(I,'BoundingBox','Area');
allBB = zeros(length(st), 4);
for k = 1 : length(st)
    thisBB = st(k).BoundingBox;
    rectangle('Position',  [thisBB(1),thisBB(2),thisBB(3),thisBB(4)],...
    'EdgeColor', 'r', 'LineWidth', 1)
    allBB(k, :) = thisBB;
points are save in varibale  allBB
Image is

댓글 수: 8
답변 (1개)
  Image Analyst
      
      
 2019년 8월 17일
        
      편집: Image Analyst
      
      
 2019년 8월 17일
  
      Use kmeans on the y values to identify boxes in one of the 5 lines that your image has.
[classIndexes, classCentroid] = kmeans(y, 5);
After that, you know which line each y is in then sort by x, then use spline.  Something like (untested)
y = allBB(2:4:end);
[classIndexes, classCentroid] = kmeans(y, 5);
newXSamplePoints = 1 : size(yourImage, 2)
for k = 1 : 5
    thisClass = classIndexes(k);
    thesex = sort(x(thisClass), 'ascend');
    % Fit the x to splines at every column in the image.
    newY = spline(x, y, newXSamplePoints);
end
hold on;
plot(newXSamplePoints, newY, 'm-', 'LineWidth', 2)
참고 항목
카테고리
				Help Center 및 File Exchange에서 Read, Write, and Modify Image에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



